diff --git a/Source/Core/Core/IPC_HLE/WII_IPC_HLE.cpp b/Source/Core/Core/IPC_HLE/WII_IPC_HLE.cpp index 56bb610431..2738ad2f7a 100644 --- a/Source/Core/Core/IPC_HLE/WII_IPC_HLE.cpp +++ b/Source/Core/Core/IPC_HLE/WII_IPC_HLE.cpp @@ -102,42 +102,54 @@ static void EnqueueEvent(u64 userdata, int cycles_late = 0) Update(); } +static u32 num_devices; + +template +std::shared_ptr AddDevice(const char* deviceName) +{ + auto device = std::make_shared(num_devices, deviceName); + g_DeviceMap[num_devices] = device; + num_devices++; + return device; +} + void Init() { _dbg_assert_msg_(WII_IPC_HLE, g_DeviceMap.empty(), "DeviceMap isn't empty on init"); CWII_IPC_HLE_Device_es::m_ContentFile = ""; - u32 i = 0; + num_devices = 0; + // Build hardware devices - g_DeviceMap[i] = std::make_shared(i, "/dev/usb/oh1/57e/305"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/stm/immediate"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/stm/eventhook"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/fs"); i++; + AddDevice("/dev/usb/oh1/57e/305"); + AddDevice("/dev/stm/immediate"); + AddDevice("/dev/stm/eventhook"); + AddDevice("/dev/fs"); // IOS allows two ES devices at a time for (u32 j=0; j(i, "/dev/es"); i++; + es_handles[j] = AddDevice("/dev/es"); es_inuse[j] = false; } - g_DeviceMap[i] = std::make_shared(i, std::string("/dev/di")); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/kd/request"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/kd/time"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/ncd/manage"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/wd/command"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/ip/top"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/net/ssl"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/usb/kbd"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/sdio/slot0"); i++; - g_DeviceMap[i] = std::make_shared(i, "/dev/sdio/slot1"); i++; + AddDevice("/dev/di"); + AddDevice("/dev/net/kd/request"); + AddDevice("/dev/net/kd/time"); + AddDevice("/dev/net/ncd/manage"); + AddDevice("/dev/net/wd/command"); + AddDevice("/dev/net/ip/top"); + AddDevice("/dev/net/ssl"); + AddDevice("/dev/usb/kbd"); + AddDevice("/dev/sdio/slot0"); + AddDevice("/dev/sdio/slot1"); #if defined(__LIBUSB__) || defined(_WIN32) - g_DeviceMap[i] = std::make_shared(i, "/dev/usb/hid"); i++; + AddDevice("/dev/usb/hid"); #else - g_DeviceMap[i] = std::make_shared(i, "/dev/usb/hid"); i++; + AddDevice("/dev/usb/hid"); #endif - g_DeviceMap[i] = std::make_shared(i, "/dev/usb/oh1"); i++; - g_DeviceMap[i] = std::make_shared(i, "_Unimplemented_Device_"); i++; + AddDevice("/dev/usb/oh1"); + AddDevice("_Unimplemented_Device_"); event_enqueue = CoreTiming::RegisterEvent("IPCEvent", EnqueueEvent); }