From ba565c340347e68c94600073534b9d3499b73dde Mon Sep 17 00:00:00 2001 From: Gliniak Date: Thu, 17 Sep 2020 18:49:04 +0200 Subject: [PATCH] [Kernel/Usbcam] XUsbcamCreate - Provided description to some parameters - Provided description what function more/less should do - Changed return code based on game behaviour --- src/xenia/kernel/xboxkrnl/xboxkrnl_usbcam.cc | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/xenia/kernel/xboxkrnl/xboxkrnl_usbcam.cc b/src/xenia/kernel/xboxkrnl/xboxkrnl_usbcam.cc index 8c02e50c6..40c3f1987 100644 --- a/src/xenia/kernel/xboxkrnl/xboxkrnl_usbcam.cc +++ b/src/xenia/kernel/xboxkrnl/xboxkrnl_usbcam.cc @@ -17,11 +17,17 @@ namespace xe { namespace kernel { namespace xboxkrnl { -dword_result_t XUsbcamCreate(unknown_t unk1, // E - unknown_t unk2, // 0x4B000 +dword_result_t XUsbcamCreate(dword_t buffer, + dword_t buffer_size, // 0x4B000 640x480? lpunknown_t unk3_ptr) { - // 0 = success. - return X_ERROR_DEVICE_NOT_CONNECTED; + // This function should return success. + // It looks like it only allocates space for usbcam support. + // returning error code might cause games to initialize incorrectly. + // "Carcassonne" initalization function checks for result from this + // function. If value is different than 0 instead of loading + // rest of the game it returns from initalization function and tries + // to run game normally which causes crash, due to uninitialized data. + return X_STATUS_SUCCESS; } DECLARE_XBOXKRNL_EXPORT1(XUsbcamCreate, kNone, kStub);