Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Merge pull request #1977 from lioncash/vi-log | bunnei | 2019-01-03 | 1 | -63/+74 |
|\ | | | | | service/vi: Log more information where applicable | ||||
| * | service/vi: Log more information where applicable | Lioncash | 2019-01-03 | 1 | -63/+74 |
| | | | | | | | | | | | | In many cases, we didn't bother to log out any of the popped data members. This logs them out to the console within the logging call to provide more contextual information. | ||||
* | | core/kernel: Remove unnecessary inclusions | Lioncash | 2019-01-01 | 16 | -16/+22 |
|/ | | | | Gets rid of a few unnecessary header dependencies in some source files. | ||||
* | Merge pull request #1966 from lioncash/backtrace | bunnei | 2018-12-31 | 2 | -7/+8 |
|\ | | | | | arm_interface: Minor cleanup | ||||
| * | arm_interface: Make include path relative for arm_interface.h | Lioncash | 2018-12-31 | 1 | -1/+1 |
| | | | | | | | | Makes it consistent with the rest of the includes. | ||||
| * | arm_interface: Make LogBacktrace() a const member function | Lioncash | 2018-12-31 | 2 | -2/+2 |
| | | | | | | | | This function doesn't modify instance state, so it can be made const. | ||||
| * | arm_interface: Mark variables as const where applicable in LogBacktrace() | Lioncash | 2018-12-31 | 1 | -3/+4 |
| | | | | | | | | | | Two of these variables have fixed values, so we can make that immediately obvious from the get-go. | ||||
| * | arm_interface: Remove unnecessary semicolon | Lioncash | 2018-12-31 | 1 | -1/+1 |
| | | | | | | | | | | Namespaces don't require the use of a semicolon. Silences a -Wextra-semi warning. | ||||
* | | kernel/svc: Correct misleading error message within CreateThread() | Lioncash | 2018-12-31 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | This is a bounds check to ensure that the thread priority is within the valid range of 0-64. If it exceeds 64, that doesn't necessarily mean that an actual priority of 64 was expected (it actually means whoever called the function screwed up their math). Instead clarify the message to indicate the allowed range of thread priorities. | ||||
* | | kernel/svc: Sanitize core number and thread priorities in CreateThread() | Lioncash | 2018-12-31 | 1 | -6/+17 |
| | | | | | | | | | | | | Now that we handle the kernel capability descriptors we can correct CreateThread to properly check against the core and priority masks like the actual kernel does. | ||||
* | | kernel/process: Rename GetAllowedProcessorMask() and GetAllowedThreadPriorityMask() | Lioncash | 2018-12-31 | 2 | -11/+11 |
| | | | | | | | | Makes them consistent with their kernel capability counterparts. | ||||
* | | kernel/svc: Simplify thread core ID sanitizing in CreateThread | Lioncash | 2018-12-31 | 1 | -7/+1 |
|/ | | | | | Rather than use a switch here, this can be collapsed into a simple range check, which is a little easier on the eyes. | ||||
* | Merge pull request #1956 from lioncash/process-thread | Sebastian Valle | 2018-12-31 | 5 | -57/+51 |
|\ | | | | | kernel/process: Start the main thread using the specified ideal core | ||||
| * | kernel/process: Start the main thread using the specified ideal core | Lioncash | 2018-12-28 | 1 | -2/+2 |
| | | | | | | | | | | This matches kernel behavior in that processes are started using their specified ideal core, rather than always starting on core 0. | ||||
| * | kernel: Rename 'default' CPU core to 'ideal' core | Lioncash | 2018-12-28 | 4 | -21/+21 |
| | | | | | | | | | | | | This makes the naming more closely match its meaning. It's just a preferred core, not a required default core. This also makes the usages of this term consistent across the thread and process implementations. | ||||
| * | kernel/thread: Move process thread initialization into process.cpp | Lioncash | 2018-12-28 | 3 | -36/+30 |
| | | | | | | | | | | | | | | | | | | | | This function isn't a general purpose function that should be exposed to everything, given it's specific to initializing the main thread for a Process instance. Given that, it's a tad bit more sensible to place this within process.cpp, which keeps it visible only to the code that actually needs it. | ||||
* | | Merge pull request #1847 from ogniK5377/backtrace-break | bunnei | 2018-12-30 | 6 | -1/+41 |
|\ \ | | | | | | | Print backtrace on svcBreak | ||||
| * | | Moved log backtrace to arm_interface.cpp. Added printing of error code to fatal | David Marcec | 2018-12-29 | 4 | -18/+36 |
| | | | |||||
| * | | Moved backtrace to ArmInterface | David Marcec | 2018-12-19 | 8 | -47/+20 |
| | | | |||||
| * | | Moved backtrace to ArmInterface | David Marcec | 2018-12-03 | 6 | -14/+39 |
| | | | | | | | | | | | | Added to both dynarmic and unicorn | ||||
| * | | Print backtrace on svcBreak | David Marcec | 2018-12-03 | 3 | -0/+24 |
| | | | | | | | | | | | | When we get an svcBreak we get a backtrace now | ||||
* | | | service/time: Minor cleanup to GetClockSnapshot() | Lioncash | 2018-12-30 | 1 | -7/+9 |
| | | | | | | | | | | | | Moves some variables closer to their actual usage sites. | ||||
* | | | service/time: Fill in some structures and remove padding where not necessary | Lioncash | 2018-12-30 | 2 | -7/+9 |
| | | | |||||
* | | | Merge pull request #1954 from lioncash/npdm | bunnei | 2018-12-28 | 1 | -3/+7 |
|\ \ \ | | | | | | | | | file_sys/program_metadata: Print out more descriptive address space descriptions | ||||
| * | | | file_sys/program_metadata: Print out more descriptive address space descriptions | Lioncash | 2018-12-28 | 1 | -3/+7 |
| | |/ | |/| | | | | | | | | | | | | | | | | Provides extra information that makes it easier to tell if an executable being run is using a 36-bit address space or a 39-bit address space. While we don't support AArch32 executables yet, this also puts in distinguishing information for the 32-bit address space types as well. | ||||
* / | | kernel/process: Remove most allocation functions from Process' interface | Lioncash | 2018-12-28 | 4 | -49/+35 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In all cases that these functions are needed, the VMManager can just be retrieved and used instead of providing the same functions in Process' interface. This also makes it a little nicer dependency-wise, since it gets rid of cases where the VMManager interface was being used, and then switched over to using the interface for a Process instance. Instead, it makes all accesses uniform and uses the VMManager instance for all necessary tasks. All the basic memory mapping functions did was forward to the Process' VMManager instance anyways. | ||||
* | | Merge pull request #1928 from lioncash/caps | bunnei | 2018-12-27 | 12 | -125/+670 |
|\ \ | | | | | | | kernel: Handle kernel capability descriptors | ||||
| * | | kernel/process: Hook up the process capability parser to the process itself | Lioncash | 2018-12-21 | 7 | -122/+44 |
| | | | | | | | | | | | | | | | While we're at it, we can also toss out the leftover capability parsing from Citra. | ||||
| * | | kernel/process_capability: Handle debug capability flags | Lioncash | 2018-12-21 | 2 | -1/+18 |
| | | | |||||
| * | | kernel/process_capability: Handle handle table capability flags | Lioncash | 2018-12-21 | 2 | -1/+11 |
| | | | | | | | | | | | | | | | This just specifies the handle table size. There's also a section of reserved bits that are checked against. | ||||
| * | | kernel/process_capability: Handle kernel version capability flags | Lioncash | 2018-12-21 | 2 | -1/+18 |
| | | | |||||
| * | | kernel/process_capability: Handle program capability flags | Lioncash | 2018-12-21 | 3 | -2/+29 |
| | | | |||||
| * | | kernel/process_capability: Handle interrupt capability flags | Lioncash | 2018-12-21 | 1 | -1/+21 |
| | | | | | | | | | | | | | | | | | | Similar to the service capability flags, however, we currently don't emulate the GIC, so this currently handles all interrupts as being valid for the time being. | ||||
| * | | kernel/process_capability: Handle syscall capability flags | Lioncash | 2018-12-21 | 2 | -1/+29 |
| | | | |||||
| * | | kernel/process_capability: Handle the priority mask and core mask flags | Lioncash | 2018-12-21 | 2 | -1/+40 |
| | | | | | | | | | | | | | | | | | | Handles the priority mask and core mask flags to allow building up the masks to determine the usable thread priorities and cores for a kernel process instance. | ||||
| * | | kernel/process: Introduce process capability parsing skeleton | Lioncash | 2018-12-21 | 5 | -3/+468 |
| | | | | | | | | | | | | | | | | | | | | | We've had the old kernel capability parser from Citra, however, this is unused code and doesn't actually map to how the kernel on the Switch does it. This introduces the basic functional skeleton for parsing process capabilities. | ||||
* | | | Merge pull request #1929 from bunnei/fix-hid | bunnei | 2018-12-27 | 1 | -44/+163 |
|\ \ \ | | | | | | | | | hid: Fix SetNpadJoyHoldType and improve logging. | ||||
| * | | | hid: Fix SetNpadJoyHoldType and improve logging. | bunnei | 2018-12-21 | 1 | -44/+163 |
| | | | | |||||
* | | | | Merge pull request #1945 from bunnei/fix-hid-horiz | bunnei | 2018-12-27 | 1 | -46/+0 |
|\ \ \ \ | | | | | | | | | | | npad: Remove code to invert input in horizontal mode. | ||||
| * | | | | npad: Remove code to invert input in horizontal mode. | bunnei | 2018-12-26 | 1 | -46/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | - This was incorrect, the game appears to handle this for us. - Fixes horizontal mode with Puyo Puyo Tetris and Super Mario Odyssey. | ||||
* | | | | | Merge pull request #1949 from lioncash/unmap | bunnei | 2018-12-27 | 1 | -0/+1 |
|\ \ \ \ \ | | | | | | | | | | | | | kernel/vm_manager: Reset region attributes when unmapping a VMA | ||||
| * | | | | | kernel/vm_manager: Reset region attributes when unmapping a VMA | Lioncash | 2018-12-27 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Like the other members related to memory regions, the attributes need to be reset back to their defaults as well. | ||||
* | | | | | | am: Implement GetSaveDataSize and ExtendSaveData | Zach Hilman | 2018-12-27 | 5 | -5/+50 |
| | | | | | | | | | | | | | | | | | | These functions come in a pair and are needed by Smash Ultimate, Minecraft, and Skyrim, amongst others. | ||||
* | | | | | | filesystem: Populate save data sizes from control data | Zach Hilman | 2018-12-27 | 2 | -0/+53 |
| | | | | | | |||||
* | | | | | | savedata_factory: Partially implement IVFC save sizes using files | Zach Hilman | 2018-12-27 | 2 | -0/+38 |
| | | | | | | | | | | | | | | | | | | This stores a file in the save directory called '.yuzu_save_size' which stores the two save sizes (normal area and journaled area) sequentially as u64s. | ||||
* | | | | | | loader: Add accessor for game control data | Zach Hilman | 2018-12-27 | 5 | -9/+14 |
| | | | | | | |||||
* | | | | | | control_metadata: Update NACP fields with latest Switchbrew data | Zach Hilman | 2018-12-27 | 2 | -6/+29 |
| | | | | | | |||||
* | | | | | | control_metadata: Use value member instead of unique_ptr to store struct | Zach Hilman | 2018-12-27 | 2 | -10/+13 |
| | | | | | | | | | | | | | | | | | | Serves no actual purpose in this instance besides making NACP's copy assignment deleted, which is not intended behavior. | ||||
* | | | | | | vfs: Add reinterpret_casts to WriteArray and Object | Zach Hilman | 2018-12-27 | 1 | -2/+2 |
|/ / / / / | | | | | | | | | | | Allows these functions to compile when T is not u8. | ||||
* | | | | | Merge pull request #1849 from encounter/svcSetThreadActivity | bunnei | 2018-12-26 | 4 | -6/+72 |
|\ \ \ \ \ | |/ / / / |/| | | | | svc: Implement SetThreadActivity (thread suspension) | ||||
| * | | | | svc: Implement SetThreadActivity (thread suspension) | Luke Street | 2018-12-04 | 4 | -6/+72 |
| | | | | | |||||
* | | | | | Merge pull request #1886 from FearlessTobi/port-4164 | bunnei | 2018-12-23 | 2 | -0/+22 |
|\ \ \ \ \ | | | | | | | | | | | | | Port citra-emu/citra#4164: "citra_qt, video_core: Screenshot functionality" | ||||
| * | | | | | yuzu, video_core: Screenshot functionality | zhupengfei | 2018-12-18 | 2 | -0/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | Allows capturing screenshot at the current internal resolution (native for software renderer), but a setting is available to capture it in other resolutions. The screenshot is saved to a single PNG in the current layout. | ||||
* | | | | | | Merge pull request #1781 from DarkLordZach/applet-profile-select | bunnei | 2018-12-23 | 8 | -0/+197 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | am: Implement HLE profile selector applet | ||||
| * | | | | | | applets: Correct event ResetTypes from OneShot to Sticky | Zach Hilman | 2018-12-03 | 4 | -13/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixes bugs relating to signalling in software keyboard. | ||||
| * | | | | | | qt: Implement GUI dialog frontend for ProfileSelector | Zach Hilman | 2018-12-03 | 1 | -0/+2 |
| | | | | | | | | | | | | | | | | | | | | | Presents profiles in a list, similar to switch. | ||||
| * | | | | | | am: Use ProfileSelect applet | Zach Hilman | 2018-12-03 | 1 | -0/+4 |
| | | | | | | | |||||
| * | | | | | | applets: Implement ProfileSelect applet | Zach Hilman | 2018-12-03 | 2 | -0/+130 |
| | | | | | | | | | | | | | | | | | | | | | Allows the player to select an emulated profile. | ||||
| * | | | | | | core: Add getter/setter for ProfileSelector in System | Zach Hilman | 2018-12-03 | 2 | -0/+16 |
| | | | | | | | |||||
| * | | | | | | frontend: Add frontend applet for ProfileSelect | Zach Hilman | 2018-12-03 | 3 | -0/+48 |
| | | | | | | | | | | | | | | | | | | | | | Responsible for selecting a profile and firing callback upon completion. | ||||
| * | | | | | | software_keyboard: Signal state changed event upon construction | Zach Hilman | 2018-12-03 | 1 | -1/+6 |
| | | | | | | | | | | | | | | | | | | | | | Previously, ILibraryAppletAccessor would signal upon creation of any applet, but this is incorrect. A flag inside of the applet code determines whether or not creation should signal state change and swkbd happens to be one of these applets. | ||||
* | | | | | | | Merge pull request #1921 from ogniK5377/no-unit | bunnei | 2018-12-21 | 3 | -0/+3 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Fixed uninitialized memory due to missing returns in canary | ||||
| * | | | | | | | Fixed uninitialized memory due to missing returns in canary | David Marcec | 2018-12-19 | 3 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Functions which are suppose to crash on non canary builds usually don't return anything which lead to uninitialized memory being used. | ||||
* | | | | | | | | Merge pull request #1925 from lioncash/pid | bunnei | 2018-12-21 | 7 | -28/+59 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | kernel/{process, thread}: Amend behavior related to IDs | ||||
| * | | | | | | | | kernel/svc: Handle thread handles within GetProcessId | Lioncash | 2018-12-19 | 1 | -10/+23 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If a thread handle is passed to svcGetProcessId, the kernel attempts to access the process ID via the thread's instance's owning process. Technically, this function should also be handling the kernel debug objects as well, however we currently don't handle those kernel objects yet, so I've left a note via a comment about it to remind myself when implementing it in the future. | ||||
| * | | | | | | | | kernel/kernel: Use correct initial PID for userland Process instances | Lioncash | 2018-12-19 | 2 | -4/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Starts the process ID counter off at 81, which is what the kernel itself checks against internally when creating processes. It's actually supposed to panic if the PID is less than 81 for a userland process. | ||||
| * | | | | | | | | kernel/svc: Correct output parameter for svcGetThreadId | Lioncash | 2018-12-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The service call uses a 64-bit value, just like svcGetProcessId. This amends the function signature accordingly. | ||||
| * | | | | | | | | kernel/thread: Make thread_id a 64-bit value | Lioncash | 2018-12-19 | 4 | -7/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel uses a 64-bit value for the thread ID, so we shouldn't be using a 32-bit value. | ||||
| * | | | | | | | | kernel/svc: Correct output parameter for svcGetProcessId | Lioncash | 2018-12-19 | 2 | -2/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcGetProcessId's out parameter is a pointer to a 64-bit value, not a 32-bit one. | ||||
| * | | | | | | | | kernel/process: Make process_id a 64-bit value | Lioncash | 2018-12-19 | 3 | -6/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the actual kernel, this is a 64-bit value, so we shouldn't be using a 32-bit type to handle it. | ||||
* | | | | | | | | | Merge pull request #1914 from lioncash/id | bunnei | 2018-12-21 | 1 | -2/+5 |
|\ \ \ \ \ \ \ \ \ | |_|_|_|_|_|/ / / |/| | | | | | | | | service/am: Unstub GetAppletResourceUserId | ||||
| * | | | | | | | | service/am: Unstub GetAppletResourceUserId | Lioncash | 2018-12-18 | 1 | -2/+5 |
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is supposed to return the current process' ID. (0 indicates an invalid ID for both process IDs and ARU IDs). | ||||
* | | | | | | | | Merge pull request #1923 from ogniK5377/nfp-device-list | bunnei | 2018-12-19 | 1 | -2/+2 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | Device handle should not be a random id, instead it's the current npad id | ||||
| * | | | | | | | | Device handle should not be a random id, instead it's the current npad id | David Marcec | 2018-12-19 | 1 | -2/+2 |
| | |/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | Found during hardware testing | ||||
* | | | | | | | | Merge pull request #1915 from lioncash/sm | bunnei | 2018-12-19 | 1 | -4/+5 |
|\ \ \ \ \ \ \ \ | |_|_|_|_|_|/ / |/| | | | | | | | service/sm: Improve debug log for RegisterService | ||||
| * | | | | | | | service/sm: Improve debug log for RegisterService | Lioncash | 2018-12-19 | 1 | -4/+5 |
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now it also indicates the name and max session count. This also gives a name to the unknown bool. This indicates if the created port is supposed to be using light handles or regular handles internally. This is passed to the respective svcCreatePort parameter internally. | ||||
* | | | | | | | Merge pull request #1907 from lioncash/attribute | bunnei | 2018-12-19 | 3 | -14/+279 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | kernel/svc: Implement svcSetMemoryAttribute | ||||
| * | | | | | | svc: Implement svcSetMemoryAttribute | Lioncash | 2018-12-19 | 1 | -5/+46 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | With all the basic backing functionality implemented, we can now unstub svcSetMemoryAttribute. | ||||
| * | | | | | | vm_manager: Add member function for setting memory attributes across an address range | Lioncash | 2018-12-19 | 2 | -0/+41 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This puts the backing functionality for svcSetMemoryAttribute in place, which will be utilized in a following change. | ||||
| * | | | | | | vm_manager: Add member function for checking a memory range adheres to certain attributes, permissions and states | Lioncash | 2018-12-19 | 2 | -0/+100 |
| | | | | | | | |||||
| * | | | | | | vm_manager: Rename meminfo_state to state | Lioncash | 2018-12-16 | 2 | -10/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is shorter and more concise. This also removes the now-innaccurate comment, as it's not returned wholesale to svcQueryMemory anymore. | ||||
| * | | | | | | vm_manager: Add backing functionality for memory attributes | Lioncash | 2018-12-16 | 2 | -1/+85 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Adds the barebones enumeration constants and functions in place to handle memory attributes, while also essentially leaving the attribute itself non-functional. | ||||
* | | | | | | | Merge pull request #1913 from MerryMage/default-fpcr | bunnei | 2018-12-18 | 1 | -0/+3 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | kernel/thread: Set default fpcr | ||||
| * | | | | | | | kernel/thread: Set default fpcr | MerryMage | 2018-12-18 | 1 | -0/+3 |
| | |/ / / / / | |/| | | | | | |||||
* | | | | | | | Merge pull request #1918 from MerryMage/cntfrq | bunnei | 2018-12-18 | 1 | -0/+1 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | arm_dynarmic: Set CNTFRQ value | ||||
| * | | | | | | | arm_dynarmic: Set CNTFRQ value | MerryMage | 2018-12-18 | 1 | -0/+1 |
| |/ / / / / / | |||||
* | | | | | | | Merge pull request #1889 from DarkLordZach/swkbd-state-changed | bunnei | 2018-12-18 | 3 | -6/+4 |
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | | applets: Correct usage of SignalStateChanged event | ||||
| * | | | | | | applets: Correct usage of SignalStateChanged event | Zach Hilman | 2018-12-10 | 3 | -6/+4 |
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | This was causing some games (most notably Pokemon Quest) to softlock due to an event being fired when not supposed to. This also removes a hack wherein we were firing the state changed event when the game retrieves it, which is incorrect. | ||||
* | | | | | | Merge pull request #1905 from bunnei/ignore-empty-gpu-lists | bunnei | 2018-12-15 | 1 | -0/+4 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | nvhost_gpu: Skip empty GPU command lists. | ||||
| * | | | | | | nvhost_gpu: Skip empty GPU command lists. | bunnei | 2018-12-15 | 1 | -0/+4 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1901 from jschmer/ServiceLeak | bunnei | 2018-12-15 | 2 | -10/+12 |
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | | Fix Service object leak on emulation stop | ||||
| * | | | | | | Fix Service object leak on emulation stop | Jens Schmer | 2018-12-13 | 2 | -10/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Services created with the ServiceFramework base class install themselves as HleHandlers with an owning shared_ptr in the ServerPort ServiceFrameworkBase::port member variable, creating a cyclic ownership between ServiceFrameworkBase and the ServerPort, preventing deletion of the service objects. Fix that by removing the ServiceFrameworkBase::port member because that was only used to detect multiple attempts at installing a port. Instead store a flag if the port was already installed to achieve the same functionality. | ||||
* | | | | | | | Merge pull request #1732 from DarkLordZach/yield-types | bunnei | 2018-12-15 | 4 | -9/+165 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | svc: Implement yield types 0 and -1 | ||||
| * | | | | | | svc: Avoid incorrect fast yield condition | Zach Hilman | 2018-12-05 | 1 | -6/+1 |
| | | | | | | | |||||
| * | | | | | | scheduler: Avoid manual Reschedule call | Zach Hilman | 2018-12-04 | 2 | -11/+11 |
| | | | | | | | | | | | | | | | | | | | | | This will automatically occur anyway when PrepareReschedule is called | ||||
| * | | | | | | scheduler: Only work steal higher priority threads from other cores | Zach Hilman | 2018-12-03 | 3 | -35/+24 |
| | | | | | | | |||||
| * | | | | | | svc: Avoid performance-degrading unnecessary reschedule | Zach Hilman | 2018-12-02 | 2 | -8/+6 |
| | | | | | | | |||||
| * | | | | | | scheduler: Add explanations for YieldWith and WithoutLoadBalancing | Zach Hilman | 2018-11-22 | 5 | -77/+139 |
| | | | | | | | |||||
| * | | | | | | svc: Implement yield types 0 and -1 | Zach Hilman | 2018-11-19 | 5 | -2/+114 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1899 from lioncash/state | bunnei | 2018-12-14 | 7 | -84/+188 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | vm_manager/svc: Modify MemoryState enum, and correct error handling for svcQueryMemory | ||||
| * | | | | | | | svc: Enable svcQueryProcessMemory | Lioncash | 2018-12-12 | 2 | -1/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcQueryProcessMemory is trivial to implement, given all the behavior necessary for it is present, it just needs a handler for it. | ||||
| * | | | | | | | svc: Write out the complete MemoryInfo structure in QueryProcessMemory | Lioncash | 2018-12-12 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the previous change, the memory writing was moved into the service function itself, however it still had a problem, in that the entire MemoryInfo structure wasn't being written out, only the first 32 bytes of it were being written out. We still need to write out the trailing two reference count members and zero out the padding bits. Not doing this can result in wrong behavior in userland code in the following scenario: MemoryInfo info; // Put on the stack, not quaranteed to be zeroed out. svcQueryMemory(&info, ...); if (info.device_refcount == ...) // Whoops, uninitialized read. This can also cause the wrong thing to happen if the user code uses std::memcmp to compare the struct, with another one (questionable, but allowed), as the padding bits are not guaranteed to be a deterministic value. Note that the kernel itself also fully zeroes out the structure before writing it out including the padding bits. | ||||
| * | | | | | | | svc: Handle memory writing explicitly within QueryProcessMemory | Lioncash | 2018-12-12 | 2 | -26/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Moves the memory writes directly into QueryProcessMemory instead of letting the wrapper function do it. It would be inaccurate to allow the handler to do it because there's cases where memory shouldn't even be written to. For example, if the given process handle is invalid. HOWEVER, if the memory writing is within the wrapper, then we have no control over if these memory writes occur, meaning in an error case, 68 bytes of memory randomly get trashed with zeroes, 64 of those being written to wherever the memory info address points to, and the remaining 4 being written wherever the page info address points to. One solution in this case would be to just conditionally check within the handler itself, but this is kind of smelly, given the handler shouldn't be performing conditional behavior itself, it's a behavior of the managed function. In other words, if you remove the handler from the equation entirely, does the function still retain its proper behavior? In this case, no. Now, we don't potentially trash memory from this function if an invalid query is performed. | ||||
| * | | | | | | | vm_manager: Correct ordering of last two struct members of MemoryInfo | Lioncash | 2018-12-12 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These should be swapped. | ||||
| * | | | | | | | vm_manager: Amend the returned values for invalid memory queries in QueryMemory() | Lioncash | 2018-12-12 | 2 | -4/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel returns a memory info instance with the base address set to the end of the address space, and the size of said block as 0 - address_space_end, it doesn't set both of said members to zero. | ||||
| * | | | | | | | vm_manager: Migrate memory querying to the VMManager interface | Lioncash | 2018-12-12 | 4 | -18/+33 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of the need to directly access the managed VMAs outside of the memory manager itself just for querying memory. | ||||
| * | | | | | | | vm_manager: Migrate MemoryInfo and PageInfo to vm_manager.h | Lioncash | 2018-12-12 | 3 | -17/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets the two structures out of an unrelated header and places them with the rest of the memory management code. This also corrects the structures. PageInfo appears to only contain a 32-bit flags member, and the extra padding word in MemoryInfo isn't necessary. | ||||
| * | | | | | | | vm_manager: Amend MemoryState enum members | Lioncash | 2018-12-12 | 5 | -28/+111 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Amends the MemoryState enum to use the same values like the actual kernel does. Also provides the necessary operators to operate on them. This will be necessary in the future for implementing svcSetMemoryAttribute, as memory block state is checked before applying the attribute. | ||||
* | | | | | | | | Merge pull request #1900 from lioncash/wrapper | bunnei | 2018-12-14 | 1 | -1/+1 |
|\ \ \ \ \ \ \ \ | |_|_|/ / / / / |/| | | | | | | | svc_wrap: Correct register index for a wrapper specialization | ||||
| * | | | | | | | svc_wrap: Correct register index for a wrapper specialization | Lioncash | 2018-12-12 | 1 | -1/+1 |
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This would result in svcSetMemoryAttribute getting the wrong value for its third parameter. This is currently fine, given the service function is stubbed, however this will be unstubbed in a future change, so this needs to change. | ||||
* | | | | | | | Fix Process object leak on emulation stop | Jens Schmer | 2018-12-12 | 3 | -13/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The Process object kept itself alive indefinitely because its handle_table contains a SharedMemory object which owns a reference to the same Process object, creating a circular ownership scenario. Break that up by storing only a non-owning pointer in the SharedMemory object. | ||||
* | | | | | | | Merge pull request #1891 from DarkLordZach/istorage-getsize | Mat M | 2018-12-12 | 1 | -2/+15 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | fsp_srv: Implement IStorage::GetSize | ||||
| * | | | | | | | fsp_srv: Implement IStorage::GetSize | Zach Hilman | 2018-12-10 | 1 | -2/+15 |
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | Takes no input and returns the size as a u64. Needed by Katamari Damacy Reroll to boot. | ||||
* | | | | | | | patch_manager: Prevent use of a dangling pointer within PatchRomFS | Lioncash | 2018-12-11 | 1 | -4/+3 |
| |/ / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | fmt::format() returns a std::string instance by value, so calling .c_str() on it here is equivalent to doing: auto* ptr = std::string{}.c_str(); The data being pointed to isn't guaranteed to actually be valid anymore after that expression ends. Instead, we can just take the string as is, and provide the necessary formatting parameters. | ||||
* | | | | | | Merge pull request #1846 from lioncash/dir | bunnei | 2018-12-11 | 1 | -2/+2 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | file_sys/directory: Amend path buffer size for directory entries | ||||
| * | | | | | | file_sys/directory: Amend path buffer size for directory entries | Lioncash | 2018-12-03 | 1 | -2/+2 |
| | |_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | The path buffer is actually 0x301 (769) characters in length, with the extra character being intended for the null-terminator. | ||||
* | | | | | | Merge pull request #1819 from DarkLordZach/disable-addons | bunnei | 2018-12-11 | 11 | -14/+102 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | patch_manager: Add support for disabling patches | ||||
| * | | | | | | loader: Add support for reading the name of game's developer | Zach Hilman | 2018-12-03 | 5 | -0/+26 |
| | | | | | | | |||||
| * | | | | | | aoc_u: Obey disabled add-ons list when listing DLC | Zach Hilman | 2018-12-03 | 1 | -0/+12 |
| | | | | | | | |||||
| * | | | | | | patch_manager: Obey disabled add-ons list when patching game | Zach Hilman | 2018-12-03 | 2 | -11/+50 |
| | | | | | | | |||||
| * | | | | | | core: Make GetGameFileFromPath function externally accessible | Zach Hilman | 2018-12-03 | 2 | -3/+9 |
| | | | | | | | |||||
| * | | | | | | settings: Store list of disabled add-ons per title ID | Zach Hilman | 2018-12-03 | 1 | -0/+5 |
| | |_|_|/ / | |/| | | | | |||||
* | | | | | | Merge pull request #1887 from FearlessTobi/port-4476 | bunnei | 2018-12-11 | 1 | -8/+4 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Port citra-emu/citra#4476: "web_service: move telemetry condition from TelemetrySession constructor to destructor" | ||||
| * | | | | | | web_service: move telemetry condition from TelemetrySession constructor to destructor | fearlessTobi | 2018-12-08 | 1 | -8/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixes an issue where Testcases couldn't be sent when Telemetry was disabled, because both things are tied closely together in the backend. | ||||
* | | | | | | | Merge pull request #1883 from lioncash/log-fsp | bunnei | 2018-12-11 | 1 | -1/+10 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | service/fsp_srv: Correct returned value in GetGlobalAccessLogMode() | ||||
| * | | | | | | | service/fsp_srv: Correct returned value in GetGlobalAccessLogMode() | Lioncash | 2018-12-10 | 1 | -1/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Based off RE, the backing code only ever seems to use 0-2 as the range of values 1 being a generic log enable, with 2 indicating logging should go to the SD card. These are used as a set of flags internally. Given we only care about receiving the log in general, we can just always signify that we want logging in general. | ||||
* | | | | | | | | Merge pull request #1885 from lioncash/data_id | bunnei | 2018-12-11 | 1 | -1/+3 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | file_sys/save_data_factory: Update SaveDataSpaceId enum | ||||
| * | | | | | | | | file_sys/save_data_factory: Update SaveDataSpaceId enum | Lioncash | 2018-12-08 | 1 | -1/+3 |
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Amends it with missing values deduced from RE (ProperSystem being from SwitchBrew for naming) (SdCardUser wasn't that difficult to discern given it's used alongside SdCardSystem when creating the save data indexer, based off the usage of the string "saveDataIxrDbSd" nearby). | ||||
* | | | | | | | | Merge pull request #1872 from lioncash/proc-info | Hexagon12 | 2018-12-10 | 1 | -0/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | kernel/process: Set ideal core from metadata | ||||
| * | | | | | | | | kernel/process: Set ideal core from metadata | Lioncash | 2018-12-05 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A very trivial change. If metadata is available, the process should use it to retrieve the desired core for the process to run on. | ||||
* | | | | | | | | | Merge pull request #1880 from DarkLordZach/cache-storage | Hexagon12 | 2018-12-10 | 1 | -1/+7 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | savedata_factory: Add CacheStorage and delete TemporaryStorage on boot | ||||
| * | | | | | | | | | savedata_factory: Add support for CacheStorage | Zach Hilman | 2018-12-07 | 1 | -0/+2 |
| | | | | | | | | | | |||||
| * | | | | | | | | | savedata_factory: Delete TemporaryStorage on startup | Zach Hilman | 2018-12-07 | 1 | -1/+5 |
| | |_|_|_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | Mimics hardware behavior. | ||||
* | | | | | | | | | Merge pull request #1876 from lioncash/vma | bunnei | 2018-12-10 | 5 | -28/+41 |
|\ \ \ \ \ \ \ \ \ | |_|_|_|/ / / / / |/| | | | | | | | | vm_manager: Make vma_map private | ||||
| * | | | | | | | | memory: Convert ASSERT into a DEBUG_ASSERT within GetPointerFromVMA() | Lioncash | 2018-12-06 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given memory should always be expected to be valid during normal execution, this should be a debug assertion, rather than a check in regular builds. | ||||
| * | | | | | | | | vm_manager: Make vma_map private | Lioncash | 2018-12-06 | 5 | -28/+41 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was only ever public so that code could check whether or not a handle was valid or not. Instead of exposing the object directly and allowing external code to potentially mess with the map contents, we just provide a member function that allows checking whether or not a handle is valid. This makes all member variables of the VMManager class private except for the page table. | ||||
* | | | | | | | | | Merge pull request #1864 from lioncash/nrr | bunnei | 2018-12-08 | 1 | -4/+5 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | service/ldr: Amend layouts of NRO and NRR headers | ||||
| * | | | | | | | | | service/ldr: Amend layout of the NRO header | Lioncash | 2018-12-05 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The first word is just a padding byte, it's not an actual entry instruction. Also renames the rest of the entries according to SwitchBrew. | ||||
| * | | | | | | | | | service/ldr: Corrent padding within the NRR header layout | Lioncash | 2018-12-05 | 1 | -1/+2 |
| | |_|/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The padding after the magic signature value should be 12 bytes rather than 28 bytes. The other 16 should be placed after the title ID pattern. | ||||
* | | | | | | | | | Merge pull request #1874 from lioncash/bindings | bunnei | 2018-12-08 | 2 | -19/+8 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | hle/service, hle/sm: Minor cleanup | ||||
| * | | | | | | | | | hle/service: Replace log + UNIMPLEMENTED with UNIMPLEMENTED_MSG | Lioncash | 2018-12-06 | 1 | -2/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Combines the two into one, shortening the amount of code here. | ||||
| * | | | | | | | | | hle/service: Remove unnecessary using declarations | Lioncash | 2018-12-06 | 1 | -5/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Only one usage of the specified objects made use of the lack of namespacing. Given the low usage, we can just remove these. | ||||
| * | | | | | | | | | hle/service, hle/sm: Compress usages of MakeResult() | Lioncash | 2018-12-06 | 2 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These auto-deduce the result based off its arguments, so there's no need to do that work for the compiler, plus, the function return value itself already indicates what we're returning. | ||||
| * | | | | | | | | | hle/service, hle/sm: Use structured bindings where applicable | Lioncash | 2018-12-06 | 2 | -9/+3 |
| | |/ / / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of the need to keep the variables separate from their actual initialization spots. | ||||
* | | | | | | | | | Merge pull request #1873 from lioncash/const | bunnei | 2018-12-08 | 10 | -10/+10 |
|\ \ \ \ \ \ \ \ \ | |_|_|/ / / / / / |/| | | | | | | | | loaders: Make GetFileType() a const qualified member function | ||||
| * | | | | | | | | loaders: Make GetFileType() a const qualified member function | Lioncash | 2018-12-05 | 10 | -10/+10 |
| | |/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | No implementations actually modify instance state (and it would be questionable to do that in the first place given the name), so we can make this a const member function. | ||||
* | | | | | | | | Merge pull request #1875 from DarkLordZach/oss-ngword2 | bunnei | 2018-12-06 | 3 | -1/+41 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | system_archive: Implement open source NgWord2 | ||||
| * | | | | | | | | system_archive: Implement open source NgWord2 | Zach Hilman | 2018-12-06 | 3 | -1/+41 |
| | |_|/ / / / / | |/| | | | | | | |||||
* | | | | | | | | Merge pull request #1861 from lioncash/reset | bunnei | 2018-12-06 | 6 | -11/+101 |
|\ \ \ \ \ \ \ \ | |/ / / / / / / |/| | | | | | | | kernel/svc: Correct behavior of svcResetSignal() | ||||
| * | | | | | | | kernel/svc: Correct behavior of svcResetSignal() | Lioncash | 2018-12-05 | 1 | -4/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While partially correct, this service call allows the retrieved event to be null, as it also uses the same handle to check if it was referring to a Process instance. The previous two changes put the necessary machinery in place to allow for this, so we can simply call those member functions here and be done with it. | ||||
| * | | | | | | | kernel/process: Make Process a WaitObject | Lioncash | 2018-12-05 | 3 | -6/+68 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Process instances can be waited upon for state changes. This is also utilized by svcResetSignal, which will be modified in an upcoming change. This simply puts all of the WaitObject related machinery in place. | ||||
| * | | | | | | | kernel/readable_event: Add member function for enforcing a strict reset contract | Lioncash | 2018-12-05 | 2 | -1/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcResetSignal relies on the event instance to have already been signaled before attempting to reset it. If this isn't the case, then an error code has to be returned. | ||||
* | | | | | | | | Merge pull request #1867 from lioncash/alloc | bunnei | 2018-12-06 | 2 | -4/+3 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | system_archive: Use a regular function pointer instead of std::function for the file-scope system archive array | ||||
| * | | | | | | | | ng_word: Deduplicate use of a constant value | Lioncash | 2018-12-05 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We've already given the constant to the vector itself, so we don't need to re-hardcode it in the array. | ||||
| * | | | | | | | | system_archive: Use a regular function pointer instead of std::function for file-scope system archive array | Lioncash | 2018-12-05 | 1 | -3/+2 |
| | |/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This allows the array to be constexpr. std::function is also allowed to allocate memory, which makes its constructor non-trivial, we definitely don't want to have all of these execute at runtime, taking up time before the application can actually load. | ||||
* | | | | | | | | Merge pull request #1866 from lioncash/cache | bunnei | 2018-12-06 | 1 | -8/+2 |
|\ \ \ \ \ \ \ \ | |_|_|/ / / / / |/| | | | | | | | service/ldr: Deduplicate instruction cache clearing code in LoadNro() | ||||
| * | | | | | | | service/ldr: Deduplicate instruction cache clearing code in LoadNro() | Lioncash | 2018-12-05 | 1 | -8/+2 |
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | We don't need to specify all of the ARM interfaces explicitly. | ||||
* / / / / / / | Call shrink_to_fit after page-table vector resizing to cause crt to actually lower vector capacity. For 36-bit titles saves 800MB of commit. | heapo | 2018-12-05 | 1 | -0/+8 |
|/ / / / / / | |||||
* | | | | | | Merge pull request #1704 from DarkLordZach/oss-sysarchive | bunnei | 2018-12-05 | 8 | -1/+227 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | file_sys: Implement open source system archives | ||||
| * | | | | | file_sys: Implement system archive synthesizer for NgWord (806) | Zach Hilman | 2018-11-23 | 5 | -6/+61 |
| | | | | | | |||||
| * | | | | | fsp_srv: Add support for using open source archive if not found in NAND | Zach Hilman | 2018-11-16 | 1 | -0/+10 |
| | | | | | | |||||
| * | | | | | file_sys: Add framework for synthesizing open source archives | Zach Hilman | 2018-11-16 | 3 | -0/+109 |
| | | | | | | |||||
| * | | | | | vfs_vector: Add VFS backend for std::array | Zach Hilman | 2018-11-16 | 1 | -0/+52 |
| | | | | | | | | | | | | | | | | | | | | | | | | Allows using constexpr/static const data with VFS. | ||||
* | | | | | | Merge pull request #1838 from lioncash/dedup | bunnei | 2018-12-05 | 1 | -27/+26 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | file_sys/registered_cache: Eliminate variable shadowing | ||||
| * | | | | | | file_sys/registered_cache: Eliminate variable shadowing | Lioncash | 2018-12-02 | 1 | -27/+26 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also inverts if statements where applicable to allow unindenting code a little bit. | ||||
* | | | | | | | Merge pull request #1836 from lioncash/unused | bunnei | 2018-12-05 | 1 | -1/+0 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | crypto/key_manager: Remove unused variable in GetTicketblob() | ||||
| * | | | | | | | crypto/key_manager: Remove unused variable in GetTicketblob() | Lioncash | 2018-12-02 | 1 | -1/+0 |
| |/ / / / / / | |||||
* | | | | | | | kernel/svc: Remove unused header inclusion | Lioncash | 2018-12-04 | 1 | -1/+0 |
| | | | | | | | |||||
* | | | | | | | kernel/svc: Implement svcSignalEvent() | Lioncash | 2018-12-04 | 1 | -1/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function simply does a handle table lookup for a writable event instance identified by the given handle value. If a writable event cannot be found for the given handle, then an invalid handle error is returned. If a writable event is found, then it simply signals the event, as one would expect. | ||||
* | | | | | | | kernel/svc: Implement svcCreateEvent() | Lioncash | 2018-12-04 | 2 | -1/+42 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcCreateEvent operates by creating both a readable and writable event and then attempts to add both to the current process' handle table. If adding either of the events to the handle table fails, then the relevant error from the handle table is returned. If adding the readable event after the writable event to the table fails, then the writable event is removed from the handle table and the relevant error from the handle table is returned. Note that since we do not currently test resource limits, we don't check the resource limit table yet. | ||||
* | | | | | | | Merge pull request #1845 from lioncash/nro | bunnei | 2018-12-04 | 5 | -19/+23 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | loader/{nro, nso}: Remove dependency on the System class | ||||
| * | | | | | | | loader/nso: Remove dependency on the System class | Lioncash | 2018-12-03 | 3 | -8/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Similar to the NRO changes, we can also pass the process explicitly as a parameter from Load instead of indirecting through the System class. | ||||
| * | | | | | | | loader/nro: Make the static LoadNro function internally linked | Lioncash | 2018-12-03 | 2 | -7/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This simply acts as a forwarding function for the Load() function, so this doesn't need to be directly exposed. | ||||
| * | | | | | | | loader/nro: Remove dependency on the System class | Lioncash | 2018-12-03 | 2 | -10/+13 |
| | |_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Load() is already given the process instance as a parameter, so instead of coupling the class to the System class, we can just forward that parameter to LoadNro() | ||||
* | | | | | | | Merge pull request #1853 from lioncash/event | bunnei | 2018-12-04 | 5 | -10/+19 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | kernel/object: Amend handle types to distinguish between readable and writable events | ||||
| * | | | | | | | kernel/object: Amend handle types to distinguish between readable and writable events | Lioncash | 2018-12-04 | 5 | -10/+19 |
| | |_|_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Two kernel object should absolutely never have the same handle ID type. This can cause incorrect behavior when it comes to retrieving object types from the handle table. In this case it allows converting a WritableEvent into a ReadableEvent and vice-versa, which is undefined behavior, since the object types are not the same. This also corrects ClearEvent() to check both kernel types like the kernel itself does. | ||||
* | | | | | | | kernel/handle_table: Amend reference to CTR-OS in Create() | Lioncash | 2018-12-04 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Another hold-over from Citra. | ||||
* | | | | | | | kernel/svc: Implement the resource limit svcGetInfo option | Lioncash | 2018-12-04 | 4 | -9/+34 |
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | Allows a process to register the resource limit as part of its handle table. | ||||
* | | | | | | [Kernel::CreateThread] Match format specifiers to LOG_TRACE's arguments | V.Kalyuzhny | 2018-12-04 | 1 | -1/+1 |
| | | | | | | |||||
* | | | | | | Merge pull request #1840 from lioncash/info | bunnei | 2018-12-04 | 1 | -50/+100 |
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories | ||||
| * | | | | | svc: Use the current process' handle table for retrieving the process instance to act upon | Lioncash | 2018-12-02 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel uses the handle table of the current process to retrieve the process that should be used to retrieve certain information. To someone not familiar with the kernel, this might raise the question of "Ok, sounds nice, but doesn't this make it impossible to retrieve information about the current process?". No, it doesn't, because HandleTable instances in the kernel have the notion of a "pseudo-handle", where certain values allow the kernel to lookup objects outside of a given handle table. Currently, there's only a pseudo-handle for the current process (0xFFFF8001) and a pseudo-handle for the current thread (0xFFFF8000), so to retrieve the current process, one would just pass 0xFFFF8001 into svcGetInfo. The lookup itself in the handle table would be something like: template <typename T> T* Lookup(Handle handle) { if (handle == PSEUDO_HANDLE_CURRENT_PROCESS) { return CurrentProcess(); } if (handle == PSUEDO_HANDLE_CURRENT_THREAD) { return CurrentThread(); } return static_cast<T*>(&objects[handle]); } which, as is shown, allows accessing the current process or current thread, even if those two objects aren't actually within the HandleTable instance. | ||||
| * | | | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories | Lioncash | 2018-12-02 | 1 | -50/+99 |
| | |/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | Our implementation of svcGetInfo was slightly incorrect in that we weren't doing proper error checking everywhere. Instead, reorganize it to be similar to how the kernel seems to do it. | ||||
* | | | | | Merge pull request #1835 from lioncash/cache-global | bunnei | 2018-12-03 | 6 | -31/+17 |
|\ \ \ \ \ | | | | | | | | | | | | | filesystem: De-globalize registered_cache_union | ||||
| * | | | | | filesystem: De-globalize registered_cache_union | Lioncash | 2018-12-02 | 6 | -31/+17 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just return a new instance of this when it's requested. This only ever holds pointers to the existing registed caches, so it's not a large object. Plus, this also gets rid of the need to keep around a separate member function just to properly clear out the union. Gets rid of one of five globals in the filesystem code. | ||||
* | | | | | Merge pull request #1803 from DarkLordZach/k-able-event | bunnei | 2018-12-03 | 33 | -236/+397 |
|\ \ \ \ \ | | | | | | | | | | | | | kernel: Divide Event into ReadableEvent and WritableEvent | ||||
| * | | | | | hle_ipc: Refactor SleepClientThread to avoid ReadableEvent | Zach Hilman | 2018-11-29 | 9 | -14/+14 |
| | | | | | | |||||
| * | | | | | kernel/event: Reference ReadableEvent from WritableEvent | Zach Hilman | 2018-11-29 | 30 | -311/+169 |
| | | | | | | |||||
| * | | | | | core: Port all current usages of Event to Readable/WritableEvent | Zach Hilman | 2018-11-29 | 25 | -153/+274 |
| | | | | | | |||||
| * | | | | | hle_ipc: Use event pair for SleepClientThread | Zach Hilman | 2018-11-29 | 2 | -19/+22 |
| | | | | | | |||||
| * | | | | | kernel: Add named event table | Zach Hilman | 2018-11-29 | 2 | -0/+30 |
| | | | | | | | | | | | | | | | | | | | | | | | | Used to store ReadableEvents of all events on the system. | ||||
| * | | | | | kernel: Divide Event into ReadableEvent and WritableEvent | Zach Hilman | 2018-11-29 | 6 | -61/+210 |
| | | | | | | | | | | | | | | | | | | | | | | | | More hardware accurate. On the actual system, there is a differentiation between the signaler and signalee, they form a client/server relationship much like ServerPort and ClientPort. | ||||
| * | | | | | kernel/object: Add descriptions to ResetTypes | Zach Hilman | 2018-11-29 | 1 | -3/+3 |
| | | | | | | |||||
* | | | | | | Merge pull request #1833 from lioncash/clean | bunnei | 2018-12-03 | 5 | -5/+97 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | service/fsp_srv: Implement CleanDirectoryRecursively | ||||
| * | | | | | | file_sys: Override missing mutating functions to be stubbed out for ReadOnlyVfsDirectory by default | Lioncash | 2018-12-01 | 2 | -0/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ensures that read only indeed means read only. | ||||
| * | | | | | | service/fsp_srv: Implement CleanDirectoryRecursively | Lioncash | 2018-12-01 | 5 | -5/+72 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is the same behavior-wise as DeleteDirectoryRecursively, with the only difference being that it doesn't delete the top level directory in the hierarchy, so given: root_dir/ - some_dir/ - File.txt - OtherFile.txt The end result is just: root_dir/ | ||||
* | | | | | | | Merge pull request #1839 from lioncash/init | bunnei | 2018-12-03 | 1 | -2/+2 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | service/audio/audout_u: Amend constructor initialization list order | ||||
| * | | | | | | | service/audio/audout_u: Amend constructor initialization list order | Lioncash | 2018-12-02 | 1 | -2/+2 |
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | Orders the constructor initializer list the same way the members of the class are declared. Prevents -Wreorder warnings | ||||
* | | | | | | | Merge pull request #1841 from ogniK5377/npad-mode-fix | bunnei | 2018-12-03 | 1 | -2/+3 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Fixed crash with SetNpadMode | ||||
| * | | | | | | | Fixed crash with SetNpadMode | David Marcec | 2018-12-02 | 1 | -2/+3 |
| | |_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | fixed crash due to handheld | ||||
* | | | | | | | service/usb: Update function table | Lioncash | 2018-12-02 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Updates the function table for IClientEpSession based off information provided by SwitchBrew. | ||||
* | | | | | | | service/erpt: Update function table | Lioncash | 2018-12-02 | 1 | -5/+7 |
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | Updates the function table according to information provided by SwitchBrew. | ||||
* | | | | | | Merge pull request #1830 from Subv/vi_ub | bunnei | 2018-12-02 | 1 | -0/+2 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior. | ||||
| * | | | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior. | Subv | 2018-11-30 | 1 | -0/+2 |
| | |/ / / | |/| | | | | | | | | | | | | | Assert that it is not empty before using it in the DequeueBuffer wait callback. | ||||
* | | | | | Fix debug build | Lioncash | 2018-12-01 | 1 | -1/+1 |
| |/ / / |/| | | | | | | | | | | | | | | | A non-existent parameter was left in some formatting calls (the logging macro for which only does anything meaningful on debug builds) | ||||
* | | | | service/set: Convert GetLanguageCode over to using PushEnum() | Lioncash | 2018-11-30 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | This code was around prior to the introduction of PushEnum, so convert it over so we don't need to cast here. | ||||
* | | | | service/set: Implement MakeLanguageCode | Lioncash | 2018-11-30 | 2 | -1/+19 |
|/ / / | | | | | | | | | | This function simply converts a given index into a language code. | ||||
* | | | Merge pull request #1801 from ogniK5377/log-before-execute | bunnei | 2018-11-29 | 51 | -390/+860 |
|\ \ \ | | | | | | | | | Changed logging to be "Log before execution", Added more error logging, all services/svc should now log on some level | ||||
| * | | | Added comment on Main memory size for more clarity | David Marcec | 2018-11-27 | 1 | -0/+1 |
| | | | | |||||
| * | | | Made svcSetHeapSize and svcCreateSharedMemory more readable | David Marcec | 2018-11-27 | 1 | -4/+4 |
| | | | | |||||
| * | | | Reworked svcs slightly, improved error messages in AM and fsp_srv | David Marcec | 2018-11-27 | 3 | -20/+30 |
| | | | | |||||
| * | | | Fixed hwopus compile error | David Marcec | 2018-11-26 | 1 | -1/+1 |
| | | | | |||||
| * | | | Improved error messages in AM, HwOpus and NvMap | David Marcec | 2018-11-26 | 3 | -26/+39 |
| | | | | |||||
| * | | | Improved error messages for SVCs | David Marcec | 2018-11-26 | 1 | -76/+170 |
| | | | | |||||
| * | | | Changed logging to be "Log before execution", Added more error logging, all services should now log on some level | David Marcec | 2018-11-26 | 51 | -374/+726 |
| | | | | |||||
* | | | | Merge pull request #1817 from DarkLordZach/npad-idx-fix | bunnei | 2018-11-28 | 1 | -2/+2 |
|\ \ \ \ | | | | | | | | | | | npad: Use NPadIdToIndex to prevent invalid array access | ||||
| * | | | | npad: Use NPadIdToIndex to prevent invalid array access | Zach Hilman | 2018-11-28 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | Merge pull request #1792 from bunnei/dma-pusher | bunnei | 2018-11-28 | 1 | -5/+10 |
|\ \ \ \ \ | | | | | | | | | | | | | gpu: Rewrite GPU command list processing with DmaPusher class. | ||||
| * | | | | | dma_pushbuffer: Optimize to avoid loop and copy on Push. | bunnei | 2018-11-28 | 1 | -8/+6 |
| | | | | | | |||||
| * | | | | | gpu: Rewrite GPU command list processing with DmaPusher class. | bunnei | 2018-11-27 | 1 | -3/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | - More accurate impl., fixes Undertale (among other games). | ||||
* | | | | | | Merge pull request #1814 from lioncash/ptr | bunnei | 2018-11-28 | 2 | -28/+26 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | file_sys/registered_cache: Use regular const references instead of std::shared_ptr for InstallEntry() | ||||
| * | | | | | | file_sys/registered_cache: Remove unused <map> include | Lioncash | 2018-11-27 | 1 | -1/+0 |
| | | | | | | | |||||
| * | | | | | | file_sys/registered_cache: Use regular const references instead of std::shared_ptr for InstallEntry() | Lioncash | 2018-11-27 | 2 | -27/+26 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These parameters don't need to utilize a shared lifecycle directly in the interface. Instead, the caller should provide a regular reference for the function to use. This also allows the type system to flag attempts to pass nullptr and makes it more generic, since it can now be used in contexts where a shared_ptr isn't being used (in other words, we don't constrain the usage of the interface to a particular mode of memory management). | ||||
* | | | | | | | npad: Fix copy/paste error with LED position assignments | Zach Hilman | 2018-11-27 | 1 | -3/+3 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1802 from DarkLordZach/user-data-storage | bunnei | 2018-11-27 | 3 | -17/+19 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | profile_manager: Save and load ProfileData from disk | ||||
| * | | | | | | | profile_manager: Save and load ProfileData from disk | Zach Hilman | 2018-11-26 | 3 | -17/+19 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The ProfileData is a 0x80-sized structure that stores various pieces of miscellaneous data for the account. | ||||
* | | | | | | | | control_metadata: Correct typo in language name (Portugese -> Portuguese) | Lioncash | 2018-11-27 | 1 | -7/+17 |
| |/ / / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While we're at it, organize the array linearly, since clang formats the array elements quite wide length-wise with the addition of the missing 'u'. Technically also fixes patch lookup and icon lookup with Portuguese, though I doubt anyone has actually run into this issue. | ||||
* | | | | | | | Merge pull request #1804 from lioncash/cast | bunnei | 2018-11-27 | 1 | -1/+1 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | gdbstub: Silence value truncation warning within FpuWrite() | ||||
| * | | | | | | gdbstub: Silence value truncation warning within FpuWrite() | Lioncash | 2018-11-27 | 1 | -1/+1 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | Previously this would cause an implicit truncation warning about assigning a u64 value to a u32 value without an explicit cast. | ||||
* | | | | | | svc: Implement svcSetResourceLimitLimitValue() | Lioncash | 2018-11-27 | 1 | -1/+36 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The opposite of the getter functions, this function sets the limit value for a particular ResourceLimit resource category, with the restriction that the new limit value must be equal to or greater than the current resource value. If this is violated, then ERR_INVALID_STATE is returned. e.g. Assume: current[Events] = 10; limit[Events] = 20; a call to this service function lowering the limit value to 10 would be fine, however, attempting to lower it to 9 in this case would cause an invalid state error. | ||||
* | | | | | | svc: Implement svcGetResourceLimitCurrentValue() | Lioncash | 2018-11-27 | 1 | -16/+49 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This kernel service function is essentially the exact same as svcGetResourceLimitLimitValue(), with the only difference being that it retrieves the current value for a given resource category using the provided resource limit handle, rather than retrieving the limiting value of that resource limit instance. Given these are exactly the same and only differ on returned values, we can extract the existing code for svcGetResourceLimitLimitValue() to handle both values. | ||||
* | | | | | | svc: Implement svcGetResourceLimitLimitValue() | Lioncash | 2018-11-27 | 2 | -2/+33 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This kernel service function retrieves the maximum allowable value for a provided resource category for a given resource limit instance. Given we already have the functionality added to the resource limit instance itself, it's sufficient to just hook it up. The error scenarios for this are: 1. If an invalid resource category type is provided, then ERR_INVALID_ENUM is returned. 2. If an invalid handle is provided, then ERR_INVALID_HANDLE is returned (bad thing goes in, bad thing goes out, as one would expect). If neither of the above error cases occur, then the out parameter is provided with the maximum limit value for the given category and success is returned. | ||||
* | | | | | | svc: Implement svcCreateResourceLimit() | Lioncash | 2018-11-27 | 2 | -1/+27 |
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function simply creates a ResourceLimit instance and attempts to create a handle for it within the current process' handle table. If the kernal fails to either create the ResourceLimit instance or create a handle for the ResourceLimit instance, it returns a failure code (OUT_OF_RESOURCE, and HANDLE_TABLE_FULL respectively). Finally, it exits by providing the output parameter with the handle value for the ResourceLimit instance and returning that it was successful. Note: We do not return OUT_OF_RESOURCE because, if yuzu runs out of available memory, then new will currently throw. We *could* allocate the kernel instance with std::nothrow, however this would be inconsistent with how all other kernel objects are currently allocated. | ||||
* | | | | | Merge pull request #1793 from lioncash/ref | bunnei | 2018-11-26 | 2 | -2/+2 |
|\ \ \ \ \ | |_|/ / / |/| | | | | service/sm: Take std::string by const reference in UnregisterService | ||||
| * | | | | service/sm: Take std::string by const reference in UnregisterService | Lioncash | 2018-11-24 | 2 | -2/+2 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids the need to create a copy of the std::string instance (potentially allocating). The only reason RegisterService takes its argument by value is because it's std::moved internally. | ||||
* | | | | svc: Return ERR_INVALID_ENUM_VALUE from svcGetInfo | Luke Street | 2018-11-25 | 1 | -1/+2 |
| | | | | |||||
* | | | | Merge pull request #1791 from bunnei/nvdrv-stub | bunnei | 2018-11-25 | 2 | -2/+18 |
|\ \ \ \ | |/ / / |/| | | | nvdrv: Implement/stub DumpGraphicsMemoryInfo and GetStatus. | ||||
| * | | | nvdrv: Implement/stub DumpGraphicsMemoryInfo and GetStatus. | bunnei | 2018-11-24 | 2 | -2/+18 |
| | | | | | | | | | | | | | | | | - Used by Undertale. | ||||
* | | | | Merge pull request #1641 from DarkLordZach/sm-register-unregister | bunnei | 2018-11-24 | 2 | -2/+55 |
|\ \ \ \ | | | | | | | | | | | sm: Implement RegisterService and UnregisterService | ||||
| * | | | | sm: Implement RegisterService and UnregisterService | Zach Hilman | 2018-11-04 | 2 | -2/+55 |
| | | | | | | | | | | | | | | | These are needed by Edizon to boot. They are used to see if a user is using SX OS, as SX OS registers a custom service called 'tx' and attempting to register a service of the same name lets the application know if it is present. | ||||
* | | | | | Merge pull request #1731 from DarkLordZach/change-dir-crash | bunnei | 2018-11-24 | 2 | -0/+6 |
|\ \ \ \ \ | | | | | | | | | | | | | filesystem: Clear registered union paths on factory creation | ||||
| * | | | | | filesystem: Clear registered union paths on factory creation | Zach Hilman | 2018-11-19 | 2 | -0/+6 |
| | |_|_|/ | |/| | | | |||||
* | | | | | Merge pull request #1692 from Hedges/GDBClean | bunnei | 2018-11-24 | 1 | -37/+86 |
|\ \ \ \ \ | | | | | | | | | | | | | GDBStub Improvements | ||||
| * | | | | | GDBStub improvements: | Hedges | 2018-11-13 | 1 | -37/+86 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Add FPU support - Fix access to TLS Fix clang-format. | ||||
* | | | | | | Merge pull request #1708 from ogniK5377/res-scale | bunnei | 2018-11-24 | 2 | -13/+31 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Report resolution scaling support for vi and am | ||||
| * | | | | | | Removed hard coded values for width and height | David Marcec | 2018-11-19 | 1 | -2/+4 |
| | | | | | | | |||||
| * | | | | | | Report resolution scaling support for vi and am | David Marcec | 2018-11-16 | 2 | -13/+29 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Specifying an internal resolution in yuzu now will report the scaled changes to vi and am. | ||||
* | | | | | | | Merge pull request #1747 from DarkLordZach/exefs-lfs | bunnei | 2018-11-24 | 2 | -2/+48 |
|\ \ \ \ \ \ \ | |_|_|_|_|/ / |/| | | | | | | patch_manager: Add support for applying LayeredFS patches to ExeFS | ||||
| * | | | | | | patch_manager: Show LayeredExeFS patch in add-ons column | Zach Hilman | 2018-11-21 | 1 | -3/+14 |
| | | | | | | | | | | | | | | | | | | | | | The decision was made to name them LayeredExeFS instead of just LayeredFS to differentiate from normal RomFS-based mods. The name may be long/unweildy, but conveys the meaning well. | ||||
| * | | | | | | patch_manager: Apply LayeredExeFS patches | Zach Hilman | 2018-11-20 | 1 | -0/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will scan the <mod>/exefs dir for all files and then layer those on top of the game's exefs and use this as the new exefs. This allows for overriding of the compressed NSOs or adding new files. This does use the same dir as IPS/IPSwitch patch, but since the loader will not look for those they are ignored. | ||||
| * | | | | | | settings: Add option to dump ExeFS of games upon launch | Zach Hilman | 2018-11-20 | 2 | -0/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | When enabled, all exefs(es) will be copied to yuzu/dump/<title_id>/exefs. | ||||
* | | | | | | | Merge pull request #1770 from DarkLordZach/applet-stub | bunnei | 2018-11-23 | 4 | -4/+102 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | applets: Add StubApplet and use it as fallback when AppletId is not implemented | ||||
| * | | | | | | | am: Return StubApplet instead of nullptr when AppletId not found | Zach Hilman | 2018-11-22 | 3 | -11/+11 |
| | | | | | | | | |||||
| * | | | | | | | applets: Add StubApplet | Zach Hilman | 2018-11-22 | 3 | -0/+98 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will log all data it receives, log all calls to its methods and push dummy data into both channels on execution. | ||||
* | | | | | | | | Merge pull request #1777 from lioncash/core-mgr | bunnei | 2018-11-23 | 4 | -97/+225 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | core: Relocate CPU core management to its own class | ||||
| * | | | | | | | | core: Relocate CPU core management to its own class | Lioncash | 2018-11-22 | 4 | -97/+225 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Keeps the CPU-specific behavior from being spread throughout the main System class. This will also act as the home to contain member functions that perform operations on all cores. The reason for this being that the following pattern is sort of prevalent throughout sections of the codebase: If clearing the instruction cache for all 4 cores is necessary: Core::System::GetInstance().ArmInterface(0).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(1).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(2).ClearInstructionCache(); Core::System::GetInstance().ArmInterface(3).ClearInstructionCache(); This is kind of... well, silly to copy around whenever it's needed. especially when it can be reduced down to a single line. This change also puts the basics in place to begin "ungrafting" all of the forwarding member functions from the System class that are used to access CPU state or invoke CPU-specific behavior. As such, this change itself makes no changes to the direct external interface of System. This will be covered by another changeset. | ||||
* | | | | | | | | | Merge pull request #1762 from bunnei/getgputime | bunnei | 2018-11-23 | 2 | -0/+19 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | nvhost_ctrl_gpu: Implement IoctlGetGpuTime. | ||||
| * | | | | | | | | | nvhost_ctrl_gpu: Implement IoctlGetGpuTime. | bunnei | 2018-11-21 | 2 | -0/+19 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Used by Undertale. | ||||
* | | | | | | | | | | debug_pad: Avoid loading input for nonexistent buttons (Home and Screenshot) | Zach Hilman | 2018-11-22 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents memory exceptions when the debug pad is enabled. | ||||
* | | | | | | | | | | Merge pull request #1765 from bunnei/multi-audout | bunnei | 2018-11-22 | 2 | -9/+22 |
|\ \ \ \ \ \ \ \ \ \ | |_|/ / / / / / / / |/| | | | | | | | | | audout_u: Add support for multiple IAudioOut streams. | ||||
| * | | | | | | | | | audout_u: Add support for multiple IAudioOut streams. | bunnei | 2018-11-22 | 2 | -9/+22 |
| |/ / / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Used by Undertale. | ||||
* | | | | | | | | | Merge pull request #1767 from lioncash/handle | bunnei | 2018-11-22 | 2 | -12/+14 |
|\ \ \ \ \ \ \ \ \ | |_|/ / / / / / / |/| | | | | | | | | kernel/handle_table: Minor changes | ||||
| * | | | | | | | | kernel/handle_table: Move private static functions into the cpp file | Lioncash | 2018-11-22 | 2 | -7/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These don't depend on class state, and are effectively implementation details, so they can go into the cpp file . | ||||
| * | | | | | | | | kernel/handle_table: Restrict handle table size to 1024 entries | Lioncash | 2018-11-22 | 1 | -5/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The previous handle table size is a holdover from Citra. The actual handle table construct on Horizon only allows for a maximum of 1024 entries. | ||||
| * | | | | | | | | kernel/handle_table: Default destructor in the cpp file | Lioncash | 2018-11-22 | 2 | -0/+3 |
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We don't need to potentially inline the teardown logic of all of the handle instances. | ||||
* | | | | | | | | Merge pull request #1742 from lioncash/hle-swkbd | bunnei | 2018-11-21 | 5 | -44/+63 |
|\ \ \ \ \ \ \ \ | |/ / / / / / / |/| | | | | | | | am/applets: Minor cleanup | ||||
| * | | | | | | | am/applets: Make the applet data broker part of the applet itself. | Lioncash | 2018-11-20 | 5 | -31/+36 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The accessor should be doing just that, accessing, rather than retaining the lifetime of the data broker as well. | ||||
| * | | | | | | | am/applets: Replace includes with forward declarations where applicable | Lioncash | 2018-11-20 | 2 | -2/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also resolve places where includes should have been provided, but weren't. | ||||
| * | | | | | | | am/applets: Relocate comments above the relevant data member in AppletDataBroker | Lioncash | 2018-11-20 | 1 | -11/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids wonky wrapping and makes it nicer to read. | ||||
* | | | | | | | | am: Correct build failure | Lioncash | 2018-11-21 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The interface for shared memory was changed, but another commit was merged that relied on the (previously public) internals of SharedMemory. This amends that discrepancy. | ||||
* | | | | | | | | Merge pull request #1734 from lioncash/shared | bunnei | 2018-11-21 | 3 | -29/+45 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | kernel/shared_memory: Make data members private, plus minor interface changes | ||||
| * | | | | | | | | kernel/shared_memory: Make Map() and Unmap() take the target process by reference rather than as a pointer | Lioncash | 2018-11-19 | 3 | -12/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Both member functions assume the passed in target process will not be null. Instead of making this assumption implicit, we can change the functions to be references and enforce this at the type-system level. | ||||
| * | | | | | | | | kernel/shared_memory: Add a const qualified member function overload for GetPointer() | Lioncash | 2018-11-19 | 2 | -1/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given this doesn't mutate instance state, we can provide a const-qualified variant as well. | ||||
| * | | | | | | | | kernel/shared_memory: Use 64-bit types for offset and size in CreateForApplet | Lioncash | 2018-11-19 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Keeps the interface consistent with the regular Create() function. | ||||
| * | | | | | | | | kernel/shared_memory: Make GetPointer() take a std::size_t instead of a u32 | Lioncash | 2018-11-19 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes the interface nicer to use in terms of 64-bit code, as it makes it less likely for one to get truncation warnings (and also makes sense in the context of the rest of the interface where 64-bit types are used for sizes and offsets | ||||
| * | | | | | | | | kernel/shared_memory: Make data members private | Lioncash | 2018-11-19 | 1 | -12/+17 |
| | |_|_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than allow unfettered access to the class internals, we hide all members by default and create and API that other code can operate against. | ||||
* | | | | | | | | Merge pull request #1733 from lioncash/ldr | bunnei | 2018-11-21 | 1 | -29/+12 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | ldr: Clean up error codes | ||||
| * | | | | | | | | ldr: Clean up error codes | Lioncash | 2018-11-19 | 1 | -29/+12 |
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The separate enum isn't particularly necessary here, and the values can just be directly put into the ResultCode instances, given the names are also self-documenting here. | ||||
* | | | | | | | | Merge pull request #1746 from lioncash/random | bunnei | 2018-11-21 | 2 | -1/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | kernel/process: Move <random> include to the cpp file | ||||
| * | | | | | | | | kernel/process: Move <random> include to the cpp file | Lioncash | 2018-11-20 | 2 | -1/+1 |
| | |/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | <random> isn't necesary directly within the header and can be placed in the cpp file where its needed. Avoids propagating random generation utilities via a header file. | ||||
* / | | | | | | | file_sys/card_image: Provide named members for the GamecardInfo struct | Lioncash | 2018-11-21 | 1 | -1/+12 |
|/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | Fills out the struct according to information provided by SwitchBrew | ||||
* | | | | | | | Merge pull request #1667 from DarkLordZach/swkbd | bunnei | 2018-11-20 | 12 | -106/+840 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | am: Implement HLE software keyboard applet | ||||
| * | | | | | | | software_keyboard: Fix erroneous extra PushNormalData | Zach Hilman | 2018-11-19 | 1 | -3/+2 |
| | | | | | | | | |||||
| * | | | | | | | software_keyboard: Return correct result code on user cancel operation | Zach Hilman | 2018-11-19 | 3 | -5/+1 |
| | | | | | | | | |||||
| * | | | | | | | applet: Add AppletDataBroker to manage HLE to AM service interaction | Zach Hilman | 2018-11-19 | 5 | -104/+194 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This cleans up most of the callbacks and such in the Applets::Applet interface, while also properly implementing all four data channels. | ||||
| * | | | | | | | software_keyboard: Use correct offset for inital text string | Zach Hilman | 2018-11-19 | 1 | -1/+2 |
| | | | | | | | | |||||
| * | | | | | | | software_keyboard: Check for UTF-8 config flag | Zach Hilman | 2018-11-19 | 2 | -9/+23 |
| | | | | | | | | |||||
| * | | | | | | | software_keyboard: Push all data over all channels on dialog completion | Zach Hilman | 2018-11-18 | 1 | -18/+26 |
| | | | | | | | | |||||
| * | | | | | | | applet: Use std::queue instead of std::vector for storage stack | Zach Hilman | 2018-11-18 | 5 | -18/+44 |
| | | | | | | | | |||||
| * | | | | | | | applet: Add operation completed callback | Zach Hilman | 2018-11-18 | 4 | -6/+12 |
| | | | | | | | | |||||
| * | | | | | | | software_keyboard: Push buffer size to offset 0x4 in output data | Zach Hilman | 2018-11-18 | 4 | -18/+39 |
| | | | | | | | | |||||
| * | | | | | | | software_keyboard: Make GetText asynchronous | Zach Hilman | 2018-11-18 | 5 | -11/+29 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | a | ||||
| * | | | | | | | am: Allow applets to push multiple and different channels of data | Zach Hilman | 2018-11-18 | 6 | -44/+41 |
| | | | | | | | | |||||
| * | | | | | | | am: Implement ILibraryAppletAccessor IsCompleted and GetResult | Zach Hilman | 2018-11-18 | 2 | -4/+9 |
| | | | | | | | | |||||
| * | | | | | | | am: Implement text check software keyboard mode | Zach Hilman | 2018-11-18 | 5 | -14/+103 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows the game to verify and send a message to the frontend. | ||||
| * | | | | | | | am: Deglobalize software keyboard applet | Zach Hilman | 2018-11-18 | 11 | -62/+106 |
| | | | | | | | | |||||
| * | | | | | | | qt/main: Register Qt Software Keyboard frontend with AM | Zach Hilman | 2018-11-18 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows using Qt provider over default. | ||||
| * | | | | | | | am: Construct and use proper applets with ILibraryAppletAccessor | Zach Hilman | 2018-11-18 | 1 | -1/+26 |
| | | | | | | | | | | | | | | | | | | | | | | | | Allows use of software keyboard applet and future applets to be easily added by adding enum ID and a switch case. | ||||
| * | | | | | | | am/applets: Add connector between frontend and AM applet classes | Zach Hilman | 2018-11-18 | 3 | -0/+130 |
| | | | | | | | | | | | | | | | | | | | | | | | | Provides a middleman between the Frontend provider class and the expected AM::Applets::Applet class needed by ILibraryAppletAccessor | ||||
| * | | | | | | | frontend/applets: Add frontend software keyboard provider and default | Zach Hilman | 2018-11-18 | 3 | -0/+63 |
| | | | | | | | | | | | | | | | | | | | | | | | | Default implementation will return "yuzu" for any string. GUI clients (or CLI) can implement the Frontend::SoftwareKeyboardApplet class and register an instance to provide functionality. | ||||
| * | | | | | | | am/applets: Add Applet superclass to describe a generic applet | Zach Hilman | 2018-11-18 | 3 | -0/+77 |
| | | | | | | | | | | | | | | | | | | | | | | | | Adds an Initialize and Execute methods which are used by the ILibraryAppletAccessor to start and control the applet. | ||||
| * | | | | | | | am: Unstub ILibraryAppletAccessor::Start | Zach Hilman | 2018-11-18 | 1 | -5/+17 |
| | | | | | | | | | | | | | | | | | | | | | | | | Now starts the applet provided in constructor. | ||||
| * | | | | | | | am: Implement PopInteractiveOutData and PushInteractiveInData | Zach Hilman | 2018-11-18 | 1 | -14/+24 |
| | | | | | | | | | | | | | | | | | | | | | | | | Used by software keyboard applet for data transfer. | ||||
| * | | | | | | | am: Convert storage stack to vector | Zach Hilman | 2018-11-18 | 1 | -27/+59 |
| | | | | | | | | | | | | | | | | | | | | | | | | std::stack was no longer suitable for non-trivial operations | ||||
| * | | | | | | | am: Move AM::IStorage to header | Zach Hilman | 2018-11-18 | 1 | -0/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | Needs to be accessible by applet files. | ||||
| * | | | | | | | am: Move IStorageAccessor to header and update backing buffer | Zach Hilman | 2018-11-18 | 2 | -64/+62 |
| | | | | | | | | | | | | | | | | | | | | | | | | Writes to an AM::IStorage object through an IStorageAccessor will now be preserved once the accessor is destroyed. | ||||
| * | | | | | | | am: Implement CreateTransferMemoryStorage | Zach Hilman | 2018-11-18 | 2 | -0/+26 |
| | | | | | | | | | | | | | | | | | | | | | | | | Creates an AM::IStorage object with the contents of the transfer memory located at the handle provided. | ||||
| * | | | | | | | svc: Implement svcCreateTransferMemory | Zach Hilman | 2018-11-18 | 1 | -3/+33 |
| | |/ / / / / | |/| | | | | | | | | | | | | Seems to be used and created identically to SharedMemory, so just reuse that. | ||||
* | | | | | | | Merge pull request #1739 from lioncash/lm | bunnei | 2018-11-20 | 1 | -1/+12 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | lm: Implement SetDestination by doing nothing | ||||
| * | | | | | | | lm: Implement SetDestination by doing nothing | Lioncash | 2018-11-20 | 1 | -1/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This service function was likely intended to be a way to redirect where the output of a log went. e.g. Firing a log over a network, dumping over a tunneling session, etc. Given we always want to see the log and not change its output. It's one of the lucky service functions where the easiest implementation is to just do nothing at all and return success. | ||||
* | | | | | | | | kernel/resource_limit: Clean up interface | Lioncash | 2018-11-20 | 6 | -190/+81 |
|/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Cleans out the citra/3DS-specific implementation details that don't apply to the Switch. Sets the stage for implementing ResourceLimit instances properly. While we're at it, remove the erroneous checks within CreateThread() and SetThreadPriority(). While these are indeed checked in some capacity, they are not checked via a ResourceLimit instance. In the process of moving out Citra-specifics, this also replaces the system ResourceLimit instance's values with ones from the Switch. | ||||
* | | | | | | | hid: Use player-defined controller type as PREFERRED_CONTROLLER | Zach Hilman | 2018-11-19 | 6 | -215/+114 |
| | | | | | | | |||||
* | | | | | | | hid/npad: Update NPad to use player controller bindings and type | Zach Hilman | 2018-11-19 | 2 | -55/+108 |
| | | | | | | | |||||
* | | | | | | | hid/touchscreen: Update Touchscreen to use advanced parameters | Zach Hilman | 2018-11-19 | 1 | -6/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Including finger ID, diamater x/y, and angle. Additionally, checks if the touchscreen is enabled. | ||||
* | | | | | | | hid: Add controller bindings for Mouse controller | Zach Hilman | 2018-11-19 | 2 | -4/+30 |
| | | | | | | | |||||
* | | | | | | | hid: Add keyboard bindings for Keyboard controller | Zach Hilman | 2018-11-19 | 2 | -2/+24 |
| | | | | | | | |||||
* | | | | | | | hid: Add controller bindings for DebugPad controller | Zach Hilman | 2018-11-19 | 2 | -21/+43 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Used by developers to test games, not present on retail systems. Some games are known to respond to DebugPad input though, for example Kirby Star Allies. | ||||
* | | | | | | | settings: Add settings for multiple players and controllers | Zach Hilman | 2018-11-19 | 1 | -3/+48 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Uses the PlayerInput struct to represent all of the data that constitutes a player. | ||||
* | | | | | | | settings: Add Native type for keyboard | Zach Hilman | 2018-11-19 | 1 | -0/+210 |
| | | | | | | | |||||
* | | | | | | | settings: Add Native type for mouse buttons | Zach Hilman | 2018-11-19 | 2 | -0/+34 |
| | | | | | | | |||||
* | | | | | | | Added missing start/end touch attributes to touchscreen | David Marcec | 2018-11-19 | 2 | -1/+18 |
| | | | | | | | |||||
* | | | | | | | Added debugpad skeleton | David Marcec | 2018-11-19 | 2 | -2/+55 |
| | | | | | | | |||||
* | | | | | | | Added controller helper funcs | David Marcec | 2018-11-19 | 2 | -0/+35 |
| | | | | | | | |||||
* | | | | | | | Changed polling rate of hid and Right joycon rotation | David Marcec | 2018-11-19 | 1 | -2/+2 |
| | | | | | | | |||||
* | | | | | | | Left joycon rotation button remapping | David Marcec | 2018-11-19 | 2 | -7/+21 |
| | | | | | | | |||||
* | | | | | | | Added automatic npad switch based on supported stylesets | David Marcec | 2018-11-19 | 2 | -4/+124 |
| | | | | | | | |||||
* | | | | | | | Added multi-input support and controller assignment at any port | David Marcec | 2018-11-19 | 2 | -122/+181 |
| |/ / / / / |/| | | | | | |||||
* | | | | | | Merge pull request #1620 from DarkLordZach/ldr-ro | bunnei | 2018-11-19 | 7 | -23/+405 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | ldr_ro: Complete LDR:RO implementation | ||||
| * | | | | | | ldr_ro: Add error check for memory allocation failure | Zach Hilman | 2018-11-18 | 4 | -13/+27 |
| | | | | | | | |||||
| * | | | | | | ldr_ro: Implement UnloadNro (command 1) | Zach Hilman | 2018-11-15 | 1 | -22/+85 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Includes actual unmapping and address error checking. | ||||
| * | | | | | | ldr_ro: Fully Implement LoadNro (command 0) | Zach Hilman | 2018-11-15 | 1 | -11/+110 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Includes NRO and BSS error checking, maximum loaded NRO check, NRR hash check, and proper remapping of BSS data. | ||||
| * | | | | | | ldr_ro: Implement UnloadNrr (command 3) | Zach Hilman | 2018-11-15 | 1 | -2/+84 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Includes initialization check, proper address check, alignment check, and actual unloading of a loaded NRR. | ||||
| * | | | | | | ldr_ro: Fully implement LoadNrr (command 2) | Zach Hilman | 2018-11-15 | 1 | -0/+112 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Includes parameter error checking, hash enforcement, initialization check, and max NRR load check. | ||||
| * | | | | | | process: Make MirrorMemory take state to map new memory as | Zach Hilman | 2018-11-15 | 2 | -3/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Credits to Subv | ||||
| * | | | | | | pl_u: Resize buffers in shared font data getter to what game requests | Zach Hilman | 2018-11-15 | 1 | -0/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixes unmapped spam in SMP and buffer size errors in some other games | ||||
* | | | | | | | Merge pull request #1718 from ogniK5377/lets-go-softlock | bunnei | 2018-11-19 | 3 | -1/+18 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Implemented CalculateStandardUserSystemClockDifferenceByUser | ||||
| * | | | | | | | Implemented CalculateStandardUserSystemClockDifferenceByUser | David Marcec | 2018-11-17 | 3 | -1/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Seems pokemon calls this sometimes and it caused "random crashes" | ||||
* | | | | | | | | Merge pull request #1671 from DarkLordZach/vi-disconnect | bunnei | 2018-11-19 | 1 | -0/+22 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | vi: Implement TransactParcel for Disconnect and DetachBuffer | ||||
| * | | | | | | | | vi: Implement TransactParcel for Disconnect and DetachBuffer | Zach Hilman | 2018-11-17 | 1 | -0/+22 |
| | |_|_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | Used by homebrew on exit. According to switchbrew, returns an empty response parcel with one zero in it. | ||||
* | | | | | | | | Merge pull request #1728 from FearlessTobi/reset-signal | Mat M | 2018-11-18 | 1 | -1/+1 |
|\ \ \ \ \ \ \ \ | |_|_|_|/ / / / |/| | | | | | | | svc: ResetSignal is not stubbed | ||||
| * | | | | | | | svc: ResetSignal is not stubbed | Tobias | 2018-11-18 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | https://user-images.githubusercontent.com/20753089/48677874-b8e01c80-eb7b-11e8-8043-b99faa29022c.PNG | ||||
* | | | | | | | | Stubbed am:EnableApplicationCrashReport | MysticExile | 2018-11-17 | 2 | -10/+18 |
| | | | | | | | | |||||
* | | | | | | | | Merge pull request #1711 from ogniK5377/bluetooth-lets-go | bunnei | 2018-11-17 | 2 | -1/+145 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | Added various bluetooth based cmds for palma | ||||
| * | | | | | | | | Added various bluetooth based cmds for palma | David Marcec | 2018-11-16 | 2 | -1/+145 |
| | |_|_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | It seems palma is done through bluetooth, we need this for pokemon go however more research needs to be done when we actually get palma working. This is presumably used for transfering data between the controller and the console, it does not seem for actual input as far as I know. | ||||
* | | | | | | | | Merge pull request #1719 from bunnei/hwopus-fix | bunnei | 2018-11-17 | 1 | -1/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | hwopus: DecodeInterleavedWithPerformance: Fix ordering of output parameters. | ||||
| * | | | | | | | | hwopus: DecodeInterleavedWithPerformance: Fix ordering of output parameters. | bunnei | 2018-11-17 | 1 | -1/+1 |
| | |_|_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | - Fixes audio issues with Pokemon: Let's Go Pikachu & Eevee. | ||||
* / | | | | | | | kernel/errors: Clean up error codes | Lioncash | 2018-11-16 | 2 | -62/+32 |
|/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Similar to PR 1706, which cleans up the error codes for the filesystem code, but done for the kernel error codes. This removes the ErrCodes namespace and specifies the errors directly. This also fixes up any straggling lines of code that weren't using the named error codes where applicable. | ||||
* | | | | | | | Merge pull request #1638 from FreddyFunk/SetMemoryPermission-Stubbed | Mat M | 2018-11-16 | 2 | -1/+48 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Implement SetMemoryPermission | ||||
| * | | | | | | | Implement SetMemoryPermission | Frederic Laing | 2018-11-06 | 1 | -3/+39 |
| | | | | | | | | |||||
| * | | | | | | | Stubbed SetMemoryPermission | Frederic Laing | 2018-11-03 | 2 | -1/+12 |
| | |_|/ / / / | |/| | | | | | |||||
* | | | | | | | Merge pull request #1632 from DarkLordZach/keys-manager-optimizations | bunnei | 2018-11-16 | 10 | -14/+34 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | game_list: Optimize game list refresh | ||||
| * | | | | | | | filesystem: Cache RegisteredCacheUnion instead of constructing on demand | Zach Hilman | 2018-11-02 | 2 | -4/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents unnecessary re-reads of the metadata and unnecessary temporary objects. | ||||
| * | | | | | | | file_sys: Use common KeyManager in NCA container types | Zach Hilman | 2018-11-02 | 6 | -7/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Creates a single KeyManager for the entire container and then passes it into the NCA constructor, eliminating several unnecessary KeyManager reads. | ||||
| * | | | | | | | content_archive: Add optional KeyManager parameter to constructor | Zach Hilman | 2018-11-02 | 2 | -3/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows resuing a common KeyManager when a large amount of NCAs are handled by the same class. Should the parameter not be provided, a new KeyManager will be constructed, as was the default behavior prior to this. | ||||
* | | | | | | | | Merge pull request #1706 from lioncash/file-err | bunnei | 2018-11-16 | 4 | -33/+16 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | file_sys/errors: Clean up error code values | ||||
| * | | | | | | | | file_sys/errors: Remove currently unused filesystem error codes | Lioncash | 2018-11-16 | 1 | -10/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than keeping around unused values, we can just introduce them as needed. | ||||
| * | | | | | | | | file_sys/errors: Get rid of the ErrCodes namespace | Lioncash | 2018-11-16 | 1 | -17/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no real point to keeping the separate enum around, especially given the name of the error code itself is supposed to document what the value actually represents. | ||||
| * | | | | | | | | file_sys/errors: Extract FS-related error codes to file_sys/errors.h | Lioncash | 2018-11-16 | 4 | -14/+19 |
| | |_|/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | Keeps filesystem-related error codes in one spot. | ||||
* / | | | | | | | Added SetIsPalmaAllConnectable, SetPalmaBoostMode | David Marcec | 2018-11-16 | 1 | -2/+14 |
|/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | Currently unclear what these do yet, will be researched at a later time when we want to implement palma. | ||||
* | | | | | | | Fixed priority switching edge case for handheld (#1675) | David | 2018-11-16 | 1 | -12/+46 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fixed priority switching edge case for handheld We accidently used controller index instead of npad id * Moved NPadIdToIndex | ||||
* | | | | | | | Merge pull request #1699 from DarkLordZach/deterministic-rng-3 | bunnei | 2018-11-16 | 1 | -1/+2 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | csrng: Use random integer distribution instead of raw engine | ||||
| * | | | | | | | csrng: Use random integer distribution instead of raw engine | Zach Hilman | 2018-11-16 | 1 | -1/+2 |
| | |_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | | Prevents returning the same value every single call. | ||||
* | | | | | | | Merge pull request #1687 from lioncash/deduplication | bunnei | 2018-11-15 | 2 | -37/+13 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | kernel/thread: Deduplicate scheduler switching code | ||||
| * | | | | | | | kernel/thread: Deduplicate scheduler switching code | Lioncash | 2018-11-14 | 2 | -37/+13 |
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | The code in both places was the same verbatim, so we can extract it to a function to deduplicate the logic. | ||||
* | | | | | | | Merge pull request #1618 from DarkLordZach/dump-nso | bunnei | 2018-11-15 | 7 | -7/+48 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | patch_manager: Add support for dumping uncompressed NSOs | ||||
| * | | | | | | | patch_manager: Add support for dumping decompressed NSOs | Zach Hilman | 2018-10-29 | 2 | -1/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When enabled in settings, PatchNSO will dump the unmodified NSO that it was passed to a file named <build id>.nso in the dump root for the current title ID. | ||||
| * | | | | | | | settings: Add setting to control NSO dumping | Zach Hilman | 2018-10-29 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also adds UI option in Debug > Dump section, with the idea later things to be dumped (i.e. other game data or textures, etc) will use the same group box. | ||||
| * | | | | | | | bis_factory: Add getter for mod dump root for a title ID | Zach Hilman | 2018-10-29 | 4 | -6/+33 |
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | Equates to yuzu_dir/dump/<title id>/ | ||||
* | | | | | | | Merge pull request #1691 from lioncash/audren | bunnei | 2018-11-15 | 1 | -3/+3 |
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | | service/audren_u: Forward RequestUpdateAuto through the same function as RequestUpdate | ||||
| * | | | | | | service/audren_u: Forward RequestUpdateAuto through the same function as RequestUpdate | Lioncash | 2018-11-14 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Based off RE, they both currently go through the same codepath with no difference in behavior. | ||||
* | | | | | | | Merge pull request #1697 from lioncash/acc | bunnei | 2018-11-15 | 2 | -15/+23 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | acc/profile_manager: Minor cleanup-related changes | ||||
| * | | | | | | | profile_manager: Replace iterative loop with a ranged-for loop in ParseUserSaveFile() | Lioncash | 2018-11-14 | 1 | -4/+5 |
| | | | | | | | | |||||
| * | | | | | | | profile_manager: Move UUID Format function definitions into the cpp file | Lioncash | 2018-11-14 | 2 | -11/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids relying on fmt always being indirectly included. | ||||
* | | | | | | | | Merge pull request #1696 from lioncash/acc-cond | bunnei | 2018-11-15 | 1 | -2/+4 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | service/acc: Correct error case within TrySelectUserWithoutInteraction() | ||||
| * | | | | | | | | service/acc: Correct error case within TrySelectUserWithoutInteraction() | Lioncash | 2018-11-14 | 1 | -2/+4 |
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | empty() in this case will always return false, since the returned container is a std::array. Instead, check if all given users are invalid before returning the error code. | ||||
* | | | | | | | | Merge pull request #1690 from lioncash/nfp | bunnei | 2018-11-14 | 1 | -1/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | nfp: Correct erroneous sizeof expression within GetTagInfo() | ||||
| * | | | | | | | | nfp: Correct erroneous sizeof expression within GetTagInfo() | Lioncash | 2018-11-14 | 1 | -1/+1 |
| | |_|_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The previous expression would copy sizeof(size_t) amount of bytes (8 on a 64-bit platform) rather than the full 10 bytes comprising the uuid member. Given the source and destination types are the same, we can just use an assignment here instead. | ||||
* | | | | | | | | Merge pull request #1689 from lioncash/break | bunnei | 2018-11-14 | 1 | -0/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | hid/npad: Add missing break in switch statement within Controller_NPad::OnUpdate | ||||
| * | | | | | | | | hid/npad: Add missing break in switch statement within Controller_NPad::OnUpdate() | Lioncash | 2018-11-14 | 1 | -0/+1 |
| |/ / / / / / / | |||||
* | | | | | | | | Merge pull request #1688 from lioncash/unused | bunnei | 2018-11-14 | 1 | -2/+2 |
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | | service: Mark MakeFunctionString with the [[maybe_unused]] attribute. | ||||
| * | | | | | | | service: Mark MakeFunctionString with the [[maybe_unused]] attribute. | Lioncash | 2018-11-14 | 1 | -2/+2 |
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When yuzu is compiled in release mode this function is unused, however, when compiled in debug mode, it's used within a LOG_TRACE statement. This prevents erroneous compilation warnings about an unused function (that isn't actually totally unused). | ||||
* | | | | | | | Merge pull request #1679 from DarkLordZach/deterministic-rng-2 | bunnei | 2018-11-14 | 4 | -2/+28 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | svc: Use proper random entropy generation algorithm | ||||
| * | | | | | | svc: Use proper random entropy generation algorithm | Zach Hilman | 2018-11-13 | 4 | -2/+28 |
| |/ / / / / | |||||
* | | | | | | Merge pull request #1680 from lioncash/mem | bunnei | 2018-11-14 | 4 | -86/+98 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | kernel/process: Migrate heap-related memory management out of the process class and into the vm manager | ||||
| * | | | | | | vm_manager: Unstub GetTotalHeapUsage() | Lioncash | 2018-11-13 | 1 | -2/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that we've moved all of the heap-related stuff to the VMManager class, we can unstub this function, as the necessary members are visible now. | ||||
| * | | | | | | kernel/process: Migrate heap-related memory management out of the process class and into the vm manager | Lioncash | 2018-11-13 | 4 | -84/+97 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | Avoids a breach of responsibilities in the interface and keeps the direct code for memory management within the VMManager class. | ||||
* | | | | | | Merge pull request #1682 from lioncash/audio | bunnei | 2018-11-14 | 1 | -2/+23 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | hle/audren_u: Implement Get/SetRenderingTimeLimit | ||||
| * | | | | | | hle/audren_u: Implement Get/SetRenderingTimeLimit | Lioncash | 2018-11-13 | 1 | -2/+23 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | These appear to be a basic getter and setter pair, so these are fairly trivial to implement and get out of the way. | ||||
* | | | | | | Merge pull request #1608 from DarkLordZach/save-data-reader | bunnei | 2018-11-14 | 10 | -16/+260 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | [ns|fsp_srv]: Implement various functions to boot Checkpoint | ||||
| * | | | | | ns: Implement command 400: GetApplicationControlData | Zach Hilman | 2018-10-29 | 4 | -17/+75 |
| | | | | | | | | | | | | | | | | | | Returns the raw NACP bytes and the raw icon bytes into a title-provided buffer. Pulls from Registration Cache for control data, returning all zeros should it not exist. | ||||
| * | | | | | fsp_srv: Implement ISaveDataInfoReader | Zach Hilman | 2018-10-29 | 1 | -0/+144 |
| | | | | | | | | | | | | | | | | | | | | | | | | An object to read SaveDataInfo objects, which describe a unique save on the system. This implementation iterates through all the directories in the save data space and uses the paths to reconstruct the metadata. | ||||
| * | | | | | fsp_srv: Implement command 61: OpenSaveDataInfoReaderBySaveDataSpaceId | Zach Hilman | 2018-10-29 | 2 | -1/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | Needed by Checkpoint. Returns an object that can iterate through all savedata on the system. | ||||
| * | | | | | savedata_factory: Expose accessors for SaveDataSpace | Zach Hilman | 2018-10-29 | 4 | -14/+32 |
| | | | | | | |||||
| * | | | | | loader/nro: Call RegisterRomFS from Load | Zach Hilman | 2018-10-29 | 1 | -0/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | Allows NRO homebrew to use the RomFS in the ASET section. | ||||
| * | | | | | control_metadata: Add GetRawBytes function to NACP | Zach Hilman | 2018-10-29 | 2 | -0/+7 |
| |/ / / / | | | | | | | | | | | | | | | | Returns the raw bytes of the NACP file. Needed for GetApplicationControlData which returns the raw, unprocessed NACP to the game. | ||||
* | | | | | Merge pull request #1670 from DarkLordZach/deterministic-rng | bunnei | 2018-11-13 | 4 | -3/+15 |
|\ \ \ \ \ | | | | | | | | | | | | | csrng: Add config option to set RNG seed | ||||
| * | | | | | svc: Return random seed for svcGetInfo RandomEntropy | Zach Hilman | 2018-11-13 | 1 | -1/+2 |
| | | | | | | |||||
| * | | | | | settings: Add config option to set RNG seed | Zach Hilman | 2018-11-12 | 1 | -0/+2 |
| | | | | | | |||||
| * | | | | | csrng: Use std::mt19937 engine for random number generation | Zach Hilman | 2018-11-12 | 2 | -2/+11 |
| | |_|_|/ | |/| | | | |||||
* | | | | | Merge pull request #1665 from ogniK5377/GetClockSnapshot | bunnei | 2018-11-13 | 3 | -21/+132 |
|\ \ \ \ \ | |/ / / / |/| | | | | Implement GetClockSnapshot, ToPosixTime & ToPosixTimeWithMyRule | ||||
| * | | | | Added maybe_unused | David Marcec | 2018-11-10 | 2 | -2/+7 |
| | | | | | |||||
| * | | | | Added ToPosixTime & ToPosixTimeWithMyRule | David Marcec | 2018-11-10 | 1 | -2/+41 |
| | | | | | | | | | | | | | | | | | | | | Added instead of using a seperate PR to prevent conflicts | ||||
| * | | | | Added consts and static | David Marcec | 2018-11-10 | 1 | -6/+6 |
| | | | | | |||||
| * | | | | Implement GetClockSnapshot | David Marcec | 2018-11-09 | 3 | -21/+88 |
| | | | | | | | | | | | | | | | | | | | | Needed by megaman 11 | ||||
* | | | | | Merge pull request #1652 from FreddyFunk/static-cast | bunnei | 2018-11-11 | 1 | -2/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | configure_system: Fix compiler warning | ||||
| * | | | | | configure_system: Fix compiler warning | Frederic Laing | 2018-11-06 | 1 | -2/+2 |
| | | | | | | |||||
* | | | | | | Merge pull request #1656 from ogniK5377/message-queue | James Rowe | 2018-11-10 | 6 | -35/+138 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | Ability to switch between docked and undocked mode in-game | ||||
| * | | | | | Fixups | David Marcec | 2018-11-07 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | Ability to switch between docked and undocked mode in-game | David Marcec | 2018-11-07 | 6 | -35/+138 |
| |/ / / / | | | | | | | | | | | | | | | | Started implementation of the AM message queue mainly used in state getters. Added the ability to switch docked mode whilst in game without stopping emulation. Also removed some things which shouldn't be labelled as stubs as they're implemented correctly | ||||
* | | | | | Merge pull request #1658 from ogniK5377/holdtype-style | bunnei | 2018-11-08 | 1 | -0/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | Updated npad styles on holdtype switches | ||||
| * | | | | | Updated npad styles on holdtype switches | David Marcec | 2018-11-07 | 1 | -0/+2 |
| |/ / / / | | | | | | | | | | | | | | | | Fixes input for megaman | ||||
* | | | | | svcBreak now dumps information from the debug buffer passed (#1646) | David | 2018-11-08 | 1 | -0/+28 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * svcBreak now dumps information from the debug buffer passed info1 and info2 seem to somtimes hold an address to a buffer, this is usually 4 bytes or the size of the int and contains an error code. There's other circumstances where it can be something different so we hexdump these to examine them at a later date. * Addressed comments | ||||
* | | | | | fixed spelling error | David Marcec | 2018-11-07 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | Added missing log | David Marcec | 2018-11-07 | 1 | -0/+1 |
| | | | | | |||||
* | | | | | Implement acc:TrySelectUserWithoutInteraction | David Marcec | 2018-11-07 | 5 | -3/+25 |
|/ / / / | | | | | | | | | | | | | Needed for Shantae - Half-Genie Hero - Ultimate Edition! | ||||
* | | | | Merge pull request #1633 from ogniK5377/reload-input | bunnei | 2018-11-05 | 2 | -0/+5 |
|\ \ \ \ | | | | | | | | | | | Fixed HID crash when launching more than 1 game & signaled styleset change event | ||||
| * | | | | Fixed HID crash when launching more than 1 game & signaled syleset change event | David Marcec | 2018-11-02 | 2 | -0/+5 |
| | | | | | | | | | | | | | | | | | | | | This should fix crashes when launching multiple games in yuzu | ||||
* | | | | | Fix typo in BufferTransformFlags | Frederic Laing | 2018-11-04 | 1 | -2/+2 |
| |_|_|/ |/| | | | |||||
* | | | | Fixed incorrect hwopus assert | David Marcec | 2018-11-02 | 1 | -1/+1 |
|/ / / | |||||
* | | | Merge pull request #1615 from lioncash/input | bunnei | 2018-11-02 | 1 | -1/+2 |
|\ \ \ | | | | | | | | | configure_system: Contrain profile usernames to 32 characters | ||||
| * | | | configure_system: Contrain profile usernames to 32 characters | Lioncash | 2018-10-31 | 1 | -1/+2 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, we would let a user enter an unbounded name and then silently truncate away characters that went over the 32-character limit. This is kind of bad from the UX point of view, because we're essentially not doing what the user intended in certain scenarios. Instead, we clamp it to 32 characters and make that visually apparent in the dialog box to provide a name for a user. | ||||
* | | | Merge pull request #1604 from FearlessTobi/port-4369 | bunnei | 2018-11-01 | 2 | -0/+15 |
|\ \ \ | | | | | | | | | Port citra-emu/citra#4369: "compatdb: Use a seperate endpoint for testcase submission" | ||||
| * | | | compatdb: Use a seperate endpoint for testcase submission | fearlessTobi | 2018-10-28 | 2 | -0/+15 |
| | | | | |||||
* | | | | service/usb: Update IPdSession's function table | Lioncash | 2018-10-30 | 1 | -3/+3 |
| |_|/ |/| | | | | | | | | Updated based off information on SwitchBrew. | ||||
* | | | general: Remove unused boost inclusions where applicable | Lioncash | 2018-10-30 | 2 | -3/+0 |
| | | | | | | | | | | | | Cleans up unused includes and trims off some dependencies on externals. | ||||
* | | | global: Use std::optional instead of boost::optional (#1578) | Frederic L | 2018-10-30 | 24 | -144/+141 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * get rid of boost::optional * Remove optional references * Use std::reference_wrapper for optional references * Fix clang format * Fix clang format part 2 * Adressed feedback * Fix clang format and MacOS build | ||||
* | | | Merge pull request #1621 from lioncash/ipc | bunnei | 2018-10-30 | 3 | -6/+9 |
|\ \ \ | | | | | | | | | hle_ipc: Make GetDomainMessageHeader return a regular pointer | ||||
| * | | | hle_ipc: Add member function for querying the existence of a domain header | Lioncash | 2018-10-30 | 3 | -3/+6 |
| | | | | | | | | | | | | | | | | Gets rid of the need to call the getter and then check for null. | ||||
| * | | | hle_ipc: Make GetDomainMessageHeader return a regular pointer | Lioncash | 2018-10-30 | 2 | -3/+3 |
| | |/ | |/| | | | | | | | | | | Nothing requires the shared owner ship here, so we can just return a plain pointer. | ||||
* | | | core: Make System references const where applicable | Lioncash | 2018-10-28 | 2 | -3/+3 |
| | | | |||||
* | | | core: Add missing const variants of getters for the System class | Lioncash | 2018-10-28 | 2 | -10/+49 |
|/ / | | | | | | | | | | | Many of the Current<Thing> getters (as well as a few others) were missing const qualified variants, which makes it a pain to retrieve certain things from const qualified references to System. | ||||
* | | Merge pull request #1593 from lioncash/svc | bunnei | 2018-10-28 | 6 | -35/+128 |
|\ \ | | | | | | | svc: Implement svcGetInfo command 0xF0000002 | ||||
| * | | svc: Localize the GetInfo enum class to the function itself | Lioncash | 2018-10-26 | 2 | -32/+31 |
| | | | | | | | | | | | | Nothing from this enum is intended to be used outside of this function. | ||||
| * | | svc: Implement svcGetInfo command 0xF0000002 | Lioncash | 2018-10-26 | 6 | -4/+98 |
| |/ | | | | | | | | | | | | | | | | | | | This retrieves: if (curr_thread == handle_thread) { result = total_thread_ticks + (hardware_tick_count - last_context_switch_ticks); } else if (curr_thread == handle_thread && sub_id == current_core_index) { result = hardware_tick_count - last_context_switch_ticks; } | ||||
* | | file_sys/patch_manager: Remove unnecessary if-statements (#1586) | Frederic L | 2018-10-28 | 1 | -7/+6 |
| | | | | | | | | | | | | * remove unnecessary if-statements * Addressed feedback | ||||
* | | Merge pull request #1598 from DeeJayBro/delete-directory | bunnei | 2018-10-28 | 1 | -2/+26 |
|\ \ | | | | | | | service/filesystem: Implemented DeleteDirectory & DeleteDirectoryRecursive | ||||
| * | | service/filesystem: Add DirectoryDelete & DirectoryDeleteRecursively | DeeJayBro | 2018-10-27 | 1 | -2/+26 |
| |/ | |||||
* | | Merge pull request #1600 from DarkLordZach/nsp-secondary-loader-fix | bunnei | 2018-10-28 | 1 | -17/+20 |
|\ \ | | | | | | | loader/nsp: Move secondary loader initialization to constructor | ||||
| * | | loader/nsp: Move secondary loader initialization to constructor | Zach Hilman | 2018-10-27 | 1 | -17/+20 |
| |/ | | | | | | | Prevents nullptr bug when trying to dump the RomFS of an NSP resulting from secondary_loader not being initialized. | ||||
* / | key_manager: Use isxdigit instead of isdigit when reading key file | Zach Hilman | 2018-10-28 | 1 | -1/+1 |
|/ | | | | Crypto revisions are hex numbers and this function only checks if the string is valid for stoul in base 16, so it should be isxdigit. | ||||
* | Merge pull request #1430 from DarkLordZach/remove-promote-dir | bunnei | 2018-10-26 | 17 | -95/+1 |
|\ | | | | | vfs: Remove InterpretAsDirectory and related functions | ||||
| * | vfs: Remove InterpretAsDirectory and related functions | Zach Hilman | 2018-10-19 | 17 | -95/+1 |
| | | | | | | | | When writing VFS, it initally seemed useful to include a function to in-place convert container files into directories in one homogenous directory structure, but re-evaluating it now there have been plenty of chances to use it and there has always been a better way. Removing as it is unused and likely will not be used. | ||||
* | | Merge pull request #1569 from lioncash/amiibo | bunnei | 2018-10-26 | 2 | -3/+5 |
|\ \ | | | | | | | yuzu/main: Notify user of loading errors with Amiibo data | ||||
| * | | yuzu/main: Notify user of loading errors with Amiibo data | Lioncash | 2018-10-24 | 2 | -3/+5 |
| | | | | | | | | | | | | | | | We shouldn't silently continue if loading failed, since the general assumption is that no messages showing up implicitly indicates success. | ||||
* | | | ldr: Partially implement LoadNro. | bunnei | 2018-10-26 | 1 | -3/+49 |
| | | | | | | | | | | | | - This is an incomplete implementation. It was tested with Super Mario Party. | ||||
* | | | process: LoadModule should clear JIT instruction cache. | bunnei | 2018-10-26 | 1 | -0/+6 |
| | | | |||||
* | | | Kernel/Memory: Added a function to first a suitable guest address at which to allocate a region of a given size. | bunnei | 2018-10-26 | 2 | -0/+28 |
| | | | |||||
* | | | nro: Make LoadNro method accessible outside of apploader code. | bunnei | 2018-10-26 | 2 | -6/+18 |
| | | | |||||
* | | | ips_layer: Use rle_size instead of data_size in RLE patch application | Zach Hilman | 2018-10-25 | 1 | -1/+1 |
| | | | | | | | | | | | | Prevents a potential bug when using RLE records in an IPS patch. | ||||
* | | | Merge pull request #1579 from lioncash/usb | bunnei | 2018-10-25 | 1 | -21/+22 |
|\ \ \ | | | | | | | | | service/usb: Update service function tables | ||||
| * | | | service/usb: Update service function tables | Lioncash | 2018-10-25 | 1 | -21/+22 |
| | | | | | | | | | | | | | | | | Updated based off the information provided by Hexkyz on Switchbrew. | ||||
* | | | | Merge pull request #1576 from lioncash/acc-warn | bunnei | 2018-10-25 | 1 | -25/+27 |
|\ \ \ \ | | | | | | | | | | | service/acc: Silence compiler truncation warnings | ||||
| * | | | | service/acc: Move fallback image to file scope | Lioncash | 2018-10-25 | 1 | -14/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is just flat data, so it doesn't really need to be in the function itself. This also allows deduplicating the constant for the backup size in GetImageSize(). | ||||
| * | | | | service/acc: Silence compiler warnings | Lioncash | 2018-10-25 | 1 | -5/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Silences compiler warnings related to truncation. This also introduces a small helper function to perform the clamping of the image size. | ||||
| * | | | | service/acc: Early return in failure case in LoadImage() | Lioncash | 2018-10-25 | 1 | -8/+8 |
| |/ / / | | | | | | | | | | | | | Allows unindenting the other branch's code. | ||||
* | | | | Merge pull request #1577 from lioncash/err | bunnei | 2018-10-25 | 5 | -34/+16 |
|\ \ \ \ | | | | | | | | | | | kernel/error: Amend error return code values | ||||
| * | | | | kernel/errors: Remove now-unused, unnecessary, error codes | Lioncash | 2018-10-24 | 2 | -13/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that we've gotten the innaccurate error codes out of the way, we can finally toss away a bunch of these, trimming down the error codes to ones that are actually used and knocking out two TODO comments. | ||||
| * | | | | kernel/shared_memory: Return ERR_INVALID_MEMORY_PERMISSIONS instead of ERR_INVALID_COMBINATION | Lioncash | 2018-10-24 | 1 | -4/+3 |
| | | | | | | | | | | | | | | | | | | | | This is more consistent with what the kernel does. | ||||
| * | | | | kernel/server_port: Simplify emptiness check within ShouldWait() | Lioncash | 2018-10-24 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | kernel/server_port: Change error case return value in Accept() to ERR_NOT_FOUND | Lioncash | 2018-10-24 | 2 | -3/+1 |
| | | | | | | | | | | | | | | | | | | | | This is what the kernel does in this instance. | ||||
| * | | | | kernel/error: Remove leftover 3DS error codes | Lioncash | 2018-10-24 | 1 | -5/+0 |
| | | | | | | | | | | | | | | | | | | | | These are now entirely unused and can be removed. | ||||
| * | | | | kernel/svc: Amend returned error code for invalid priorities in CreateThread | Lioncash | 2018-10-24 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Like with the previous change, the kernel doesn't return NOT_AUTHORIZED here. It returns INVALID_THREAD_PRIORITY. | ||||
| * | | | | kernel/svc: Move and correct returned error code for invalid thread priorities in SetThreadPriority() | Lioncash | 2018-10-24 | 1 | -5/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All priority checks are supposed to occur before checking the validity of the thread handle, we're also not supposed to return ERR_NOT_AUTHORIZED here. | ||||
| * | | | | kernel/error: Add error code for invalid pointers | Lioncash | 2018-10-24 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | The kernel appears to return 0xE601 for this situation. Particularly in svcWaitSynchronization, svcReplyAndReceive, and svcGetThreadContext | ||||
| * | | | | kernel/error: Add error code for closed sessions | Lioncash | 2018-10-24 | 1 | -1/+3 |
| |/ / / | | | | | | | | | | | | | The kernel appears to return 0xF601 for this case. | ||||
* | | | | Merge pull request #1570 from lioncash/optional | bunnei | 2018-10-25 | 3 | -43/+48 |
|\ \ \ \ | | | | | | | | | | | profile_manager: Use std::optional instead of boost::optional | ||||
| * | | | | profile_manager: Use std::optional instead of boost::optional | Lioncash | 2018-10-24 | 3 | -43/+48 |
| |/ / / | | | | | | | | | | | | | | | | | Now that we can actually use std::optional on macOS, we don't need to continue using boost::optional here. | ||||
* | | | | Merge pull request #1564 from lioncash/npad | bunnei | 2018-10-24 | 1 | -2/+3 |
|\ \ \ \ | | | | | | | | | | | npad: Remove unused controller variable from OnInit() | ||||
| * | | | | npad: Remove unused controller variable from OnInit() | Lioncash | 2018-10-24 | 1 | -2/+3 |
| | |/ / | |/| | | | | | | | | | | | | | | This also gets rid of variable shadowing related to the lambda parameter a little bit below this code as well. | ||||
* | | | | Merge pull request #1563 from lioncash/frame | bunnei | 2018-10-24 | 1 | -4/+0 |
|\ \ \ \ | | | | | | | | | | | perf_stats: Remove unused variable within DoFrameLimiting() | ||||
| * | | | | perf_stats: Remove unused variable within DoFrameLimiting() | Lioncash | 2018-10-24 | 1 | -4/+0 |
| |/ / / | | | | | | | | | | | | | This hasn't been used since ba8ff096fdc9f7ab101851c4cd06c3244a7d84c3 | ||||
* | | | | Merge pull request #1562 from lioncash/aoc | bunnei | 2018-10-24 | 1 | -3/+3 |
|\ \ \ \ | | | | | | | | | | | aoc_u: Make use of previously-unused CheckAOCTitleIDMatchesBase() function | ||||
| * | | | | aoc_u: Make use of previously-unused CheckAOCTitleIDMatchesBase() function | Lioncash | 2018-10-24 | 1 | -3/+3 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just call the function instead of duplicating the code here. This also prevents an unused function warning. We also don't need to take the lambda capture by reference. It's just a u64 value, so by value is fine here. | ||||
* | | | | Merge pull request #1561 from lioncash/fs | bunnei | 2018-10-24 | 2 | -3/+6 |
|\ \ \ \ | |_|/ / |/| | | | file_sys: Remove unused variables | ||||
| * | | | vfs: Handle failure of file reading within VfsRawCopy() | Lioncash | 2018-10-24 | 1 | -2/+6 |
| | | | | | | | | | | | | | | | | Also gets rid of an unused variable. | ||||
| * | | | key_manager: Remove unused variable in DeriveBase() | Lioncash | 2018-10-24 | 1 | -1/+0 |
| |/ / | |||||
* | | | Merge pull request #1468 from DarkLordZach/profile-manager-ui | Mat M | 2018-10-24 | 5 | -30/+227 |
|\ \ \ | |/ / |/| | | qt: Add UI to manage emulated user profiles | ||||
| * | | profile_manager: Create save data if it doesn't exist on use | Zach Hilman | 2018-10-24 | 2 | -13/+37 |
| | | | |||||
| * | | acc: Fix account UUID duplication error | Zach Hilman | 2018-10-24 | 4 | -17/+47 |
| | | | |||||
| * | | configure_system: Clear selection after user delete | Zach Hilman | 2018-10-24 | 1 | -1/+1 |
| | | | |||||
| * | | profile_manager: Load user icons, names, and UUIDs from system save | Zach Hilman | 2018-10-24 | 5 | -28/+129 |
| | | | |||||
| * | | acc: Load user images from config dir | Zach Hilman | 2018-10-24 | 1 | -9/+45 |
| | | | |||||
| * | | am: Pass current user UUID to launch parameters | Zach Hilman | 2018-10-24 | 1 | -7/+9 |
| | | | |||||
| * | | profile_manager: Load users from emulator settings | Zach Hilman | 2018-10-24 | 2 | -5/+7 |
| | | | |||||
| * | | settings: Add users and current_user settings and remove username | Zach Hilman | 2018-10-24 | 1 | -1/+3 |
| | | | |||||
* | | | Merge pull request #1551 from ogniK5377/improved-svcbreak | bunnei | 2018-10-24 | 1 | -5/+51 |
|\ \ \ | |/ / |/| | | Added break types to svcBreak | ||||
| * | | Added assertion failed, reworked logging levels | David Marcec | 2018-10-23 | 1 | -16/+24 |
| | | | |||||
| * | | Added break types to svcBreak | David Marcec | 2018-10-23 | 1 | -4/+42 |
| | | | | | | | | | | | | There seems to be more such as type 1, and 2. Unsure what these currently are but when a game hits them we can investigate and add the rest | ||||
* | | | Added Amiibo support (#1390) | David | 2018-10-24 | 4 | -50/+295 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fixed conflict with nfp * Few fixups for nfc * Conflict 2 * Fixed AttachAvailabilityChangeEvent * Conflict 3 * Fixed byte padding * Refactored amiibo to not reside in "System" * Removed remaining references of nfc from system * used enum for Nfc GetStateOld * Added missing newline * Moved file operations to front end * Conflict 4 * Amiibos now use structs and added mutexes * Removed amiibo_path | ||||
* | | | Merge pull request #1515 from DarkLordZach/dlc-lfs | bunnei | 2018-10-24 | 4 | -5/+29 |
|\ \ \ | | | | | | | | | patch_manager: Add support for LayeredFS on DLC RomFS | ||||
| * | | | qt: Add support for dumping a DLC Data RomFS | Zach Hilman | 2018-10-18 | 2 | -0/+5 |
| | | | | |||||
| * | | | registered_cache: Deduplicate results of ListEntry and ListEntryFilter | Zach Hilman | 2018-10-17 | 2 | -2/+16 |
| | | | | | | | | | | | | | | | | Prevents a Entry from appearing in the list twice if the user has it installed in two places (e.g. User NAND and SDMC) | ||||
| * | | | fsp_srv: Apply patches to Data storage in OpenDataStorageByDataId | Zach Hilman | 2018-10-17 | 1 | -1/+5 |
| | | | | |||||
| * | | | patch_manager: Add support for using LayeredFS with Data | Zach Hilman | 2018-10-17 | 1 | -2/+3 |
| | | | | |||||
* | | | | Merge pull request #1540 from lioncash/handle | bunnei | 2018-10-24 | 8 | -98/+95 |
|\ \ \ \ | |_|/ / |/| | | | kernel/process: Make the handle table per-process | ||||
| * | | | kernel/process: Make the handle table per-process | Lioncash | 2018-10-20 | 8 | -98/+95 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the kernel, there isn't a singular handle table that everything gets tossed into or used, rather, each process gets its own handle table that it uses. This currently isn't an issue for us, since we only execute one process at the moment, but we may as well get this out of the way so it's not a headache later on. | ||||
* | | | | Merge pull request #1545 from DarkLordZach/psm | bunnei | 2018-10-22 | 4 | -0/+90 |
|\ \ \ \ | | | | | | | | | | | psm: Add psm service and stub commands 0 and 1 | ||||
| * | | | | psm: Stub GetChargerType | Zach Hilman | 2018-10-22 | 2 | -24/+27 |
| | | | | | | | | | | | | | | | Used by LovePotion Lua Homebrew. Stubbed as connected to official Nintendo Switch dock. | ||||
| * | | | | psm: Stub GetBatteryChargePercentage | Zach Hilman | 2018-10-21 | 2 | -1/+14 |
| | | | | | | | | | | | | | | | | | | | | Used by LovePotion Lua Homebrew. Stubbed to return 100% charge. | ||||
| * | | | | service: Add skeleton for psm service | Zach Hilman | 2018-10-21 | 4 | -0/+74 |
| |/ / / | | | | | | | | | | | | | Seems to be the power controller. Listed in switchbrew under the category PTM services. | ||||
* | | | | Merge pull request #1538 from lioncash/query | bunnei | 2018-10-22 | 1 | -1/+1 |
|\ \ \ \ | | | | | | | | | | | svc: Fix vma boundary check in svcQueryMemory | ||||
| * | | | | svc: Fix vma boundary check in svcQueryMemory | Lioncash | 2018-10-20 | 1 | -1/+1 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | This should be comparing against the queried process' vma_map, not the current process'. The only reason this hasn't become an issue yet is we currently only handle one process being active at any time. | ||||
* | | | | service: Add the basic skeleton for the NPNS services | Lioncash | 2018-10-21 | 4 | -2/+109 |
| | | | | |||||
* | | | | hid: Update service function table for hidbus | Lioncash | 2018-10-21 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
* | | | | am: Add the basic skeleton for the tcap service | Lioncash | 2018-10-21 | 4 | -0/+44 |
| | | | | | | | | | | | | | | | | Added based off information provided by Switchbrew. | ||||
* | | | | am: Update service function tables | Lioncash | 2018-10-21 | 4 | -15/+60 |
| | | | | | | | | | | | | | | | | Updated based off information from Switchbrew | ||||
* | | | | prepo: Update service function table. | Lioncash | 2018-10-21 | 1 | -8/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | Also introduces the new prepo:a2 service. Updated based off information provided by Switchbrew. | ||||
* | | | | lbl: Update service function table names | Lioncash | 2018-10-21 | 1 | -28/+28 |
| | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
* | | | | Added auto controller switching to supported controllers and single joycon button rotation | David Marcec | 2018-10-20 | 2 | -4/+189 |
|/ / / | | | | | | | | | | This is a subset of the better-hid-2 changes, this fixes input in various games which don't support dual joycons. This pr will search for the next best controller which is supported by the current game | ||||
* | | | Merge pull request #1520 from lioncash/san | bunnei | 2018-10-20 | 3 | -3/+50 |
|\ \ \ | | | | | | | | | svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemory | ||||
| * | | | svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemory | Lioncash | 2018-10-18 | 3 | -3/+50 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that the changes clarifying the address spaces has been merged, we can wrap the checks that the kernel performs when mapping shared memory (and other forms of memory) into its own helper function and then use those within MapSharedMemory and UnmapSharedMemory to complete the sanitizing checks that are supposed to be done. | ||||
* | | | | Merge pull request #1526 from lioncash/svc-id | bunnei | 2018-10-20 | 8 | -53/+163 |
|\ \ \ \ | | | | | | | | | | | service: Update function tables | ||||
| * | | | | es: Update service function tables | Lioncash | 2018-10-19 | 1 | -7/+11 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
| * | | | | audio: Update service function tables | Lioncash | 2018-10-19 | 1 | -17/+20 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
| * | | | | omm: Update service function tables | Lioncash | 2018-10-19 | 1 | -16/+18 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
| * | | | | nifm: Update service function tables | Lioncash | 2018-10-19 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by switchbrew. | ||||
| * | | | | hid: Update service function tables | Lioncash | 2018-10-19 | 1 | -6/+45 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
| * | | | | nim: Add the basic skeleton of the nim:eca service | Lioncash | 2018-10-19 | 1 | -0/+17 |
| | | | | | | | | | | | | | | | | | | | | Added based off information provided by Switchbrew | ||||
| * | | | | ns: Update service function table | Lioncash | 2018-10-19 | 1 | -6/+49 |
| | | | | | | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew. | ||||
| * | | | | set_cal: Update service function table | Lioncash | 2018-10-19 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | Updated based on information from Switchbrew. | ||||
* | | | | | Merge pull request #1530 from DarkLordZach/aoc-8 | bunnei | 2018-10-20 | 2 | -1/+16 |
|\ \ \ \ \ | | | | | | | | | | | | | aoc_u: Stub GetAddOnContentListChangedEvent | ||||
| * | | | | | aoc_u: Stub GetAddOnContentListChangedEvent | Zach Hilman | 2018-10-20 | 2 | -1/+16 |
| | |_|_|/ | |/| | | | | | | | | | | | | | This event signals the game when new DLC is purchased from the eShop while the game is running. Since, for the forseeable future, yuzu will not have this ability, it seems safe to stub with a dummy event that will never fire. This is needed to boot Sonic Mania Plus (update v1.04). | ||||
* | | | | | Merge pull request #1516 from lioncash/hid | bunnei | 2018-10-20 | 18 | -19/+33 |
|\ \ \ \ \ | | | | | | | | | | | | | hid: Minor cleanup-related changes | ||||
| * | | | | | hid/controller: Remove unused header inclusions | Lioncash | 2018-10-18 | 9 | -9/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | swap.h only needs to be present in the header for the type aliases and definitions, it's not actually needed in the cpp files though. input.h is just unused entirely in xpad.h | ||||
| * | | | | | hid/controller/npad: Remove unused dump_idx member variable | Lioncash | 2018-10-18 | 1 | -1/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | Given it's unused, we may as well toss it. | ||||
| * | | | | | hid/controller/npad: Remove unnecessary semicolon from the closing brace of LedPattern's constructor | Lioncash | 2018-10-18 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | hid/controller/npad: Remove #pragma once from the cpp file | Lioncash | 2018-10-18 | 1 | -2/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | This is only useful in headers. | ||||
| * | | | | | hid/controller/npad: Move npad_id_list into the cpp file | Lioncash | 2018-10-18 | 2 | -2/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is just a lookup table, and since it's private, there's nothing really stateful about it, so we can just move it into the cpp file. | ||||
| * | | | | | hid/controller/npad: Remove unnecessary const from void return type | Lioncash | 2018-10-18 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | This literally does nothing. | ||||
| * | | | | | hid/controller: Default the destructors of all controller types in the cpp file | Lioncash | 2018-10-18 | 16 | -0/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These classes are non-trivial and are definitely going to be changed in the future, so we default these to prevent issues with forward declarations, and to keep the compiler from inlining tear-down code. | ||||
| * | | | | | controller_base: Default the base class constructor and destructor in the cpp file | Lioncash | 2018-10-18 | 2 | -2/+4 |
| | |_|/ / | |/| | | | | | | | | | | | | | The destructor doesn't need to be a pure-virtual function. | ||||
* | | | | | crypto: Use compressed sizes in offset calculation for KIP decompression | Zach Hilman | 2018-10-20 | 1 | -1/+2 |
| |/ / / |/| | | | | | | | | | | | Fixes a fatal crash on start when deriving keys. | ||||
* | | | | Stubbed home blocking | David Marcec | 2018-10-19 | 2 | -4/+36 |
| |/ / |/| | | | | | | | | Needed by arms due to new hid rework | ||||
* | | | Merge pull request #1523 from lioncash/lock | bunnei | 2018-10-19 | 1 | -9/+15 |
|\ \ \ | | | | | | | | | svc: Add missing error checks in svcArbitrateLock/svcArbitrateUnlock | ||||
| * | | | svc: Check for word alignment of addresses within svcArbitrateLock/svcArbitrateUnlock | Lioncash | 2018-10-18 | 1 | -0/+8 |
| | | | | | | | | | | | | | | | | | | | | The kernel itself checks whether or not the provided addresses are word aligned before continuing, so we should be doing the same. | ||||
| * | | | common: Move Is4KBAligned() to alignment.h | Lioncash | 2018-10-18 | 1 | -9/+7 |
| | | | | | | | | | | | | | | | | | | | | Aligning on 4KB pages isn't a Switch-specific thing, so this can be moved to common so it can be used with other things as well. | ||||
* | | | | Merge pull request #1511 from lioncash/content | bunnei | 2018-10-19 | 2 | -258/+292 |
|\ \ \ \ | | | | | | | | | | | content_archive: Minor reorganization changes | ||||
| * | | | | content_archive: Simpify assignment of bktr_base_romfs in the constructor | Lioncash | 2018-10-16 | 1 | -2/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | std::move doesn't actually dereference the data, so it doesn't matter whether or not the type is null. | ||||
| * | | | | content_archive: Make IsValidNCA() an internally linked function | Lioncash | 2018-10-16 | 2 | -3/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | This is only ever used within the cpp file, so it can just be an internal function. | ||||
| * | | | | content_archive: Simplify rights ID check | Lioncash | 2018-10-16 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | This is the same as using std::any_of with an inverted predicate. | ||||
| * | | | | content_archive: Split loading into separate functions | Lioncash | 2018-10-16 | 2 | -253/+290 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The constructor alone is pretty large, the reading code should be split into its consistuent parts to make it easier to understand it without having to build a mental model of a 300+ line function. | ||||
| * | | | | content_archive: Pass and take NCASectionHeader instance by reference | Lioncash | 2018-10-16 | 2 | -3/+3 |
| | |_|/ | |/| | | | | | | | | | | | | | | Each header is 512 bytes in size, which is kind of an excessive amount to copy all the time when it's possible to avoid doing so. | ||||
* | | | | Merge pull request #1521 from ogniK5377/imp-mmu | bunnei | 2018-10-19 | 1 | -8/+42 |
|\ \ \ \ | | | | | | | | | | | Used better names for mm:u and fixed a bad stub | ||||
| * | | | | Used better names for mm:u and fixed bad stub | David Marcec | 2018-10-18 | 1 | -8/+42 |
| | |_|/ | |/| | | | | | | | | | | InitializeWithId needs to return an id which is a u32 which should be a non zero value | ||||
* | | | | core: Remove unnecessary assert in ArmInterface() | Lioncash | 2018-10-18 | 1 | -2/+1 |
| |_|/ |/| | | | | | | | | | | | CpuCore already does this sort of checking, so we can just call that instead of duplicating the assertions. | ||||
* | | | Merge pull request #1510 from lioncash/xci | bunnei | 2018-10-18 | 3 | -7/+8 |
|\ \ \ | |/ / |/| | | XCI: Add function for checking the existence of the program NCA | ||||
| * | | XCI: Add function for checking the existence of the program NCA | Lioncash | 2018-10-16 | 3 | -7/+8 |
| |/ | | | | | | | | | | | The only reason the getter existed was to check whether or not the program NCA was null. Instead, we can just provide a function to query for the existence of it, instead of exposing it entirely. | ||||
* | | Merge pull request #1444 from ogniK5377/better-hid | bunnei | 2018-10-18 | 22 | -648/+1720 |
|\ \ | | | | | | | "Better Hid" Rework Part 1 | ||||
| * | | Using dual joycons as the default controller | David Marcec | 2018-10-17 | 3 | -77/+59 |
| | | | | | | | | | | | | Reason for the change is to allow both docked and undocked mode to work | ||||
| * | | Wip | David Marcec | 2018-10-12 | 2 | -3/+23 |
| | | | |||||
| * | | Dynamically decide handheld variant based on supported npad id priority | David Marcec | 2018-10-11 | 3 | -19/+62 |
| | | | | | | | | | | | | Kirby input still doesn't work, should fix a lot of other games | ||||
| * | | Added BeginPermitVibrationSession and EndPermitVibrationSession | David Marcec | 2018-10-10 | 3 | -2/+26 |
| | | | | | | | | | | | | Used by Mario Party | ||||
| * | | Added GetLedPattern and HandheldVariant | David Marcec | 2018-10-10 | 3 | -6/+63 |
| | | | | | | | | | | | | HandheldVariant is for specific games which expect handheld controllers to be at position 8(kirby), however this doesn't fix all games as some games require handhelds to be at position 0(snipperclips) | ||||
| * | | Kirby expects handheld controllers to be at position 8 | David Marcec | 2018-10-10 | 1 | -2/+8 |
| | | | |||||
| * | | Added the ability to "disconnect" individual npads | David Marcec | 2018-10-10 | 3 | -16/+40 |
| | | | | | | | | | | | | Fixes arms | ||||
| * | | Removed unneeded forward declarations | David Marcec | 2018-10-10 | 2 | -13/+2 |
| | | | |||||
| * | | Addressed changes for better hid | David Marcec | 2018-10-10 | 19 | -167/+238 |
| | | | |||||
| * | | "Better Hid" rework part 1 | David Marcec | 2018-10-10 | 22 | -644/+1500 |
| | | | |||||
* | | | Merge pull request #1497 from bunnei/flush-framebuffers | bunnei | 2018-10-18 | 2 | -3/+3 |
|\ \ \ | | | | | | | | | Implement flushing in the rasterizer cache | ||||
| * | | | config: Rename use_accurate_framebuffers -> use_accurate_gpu_emulation. | bunnei | 2018-10-16 | 2 | -3/+3 |
| | |/ | |/| | | | | | | | - This will be used as a catch-all for slow-but-accurate GPU emulation paths. | ||||
* | | | Merge pull request #1498 from lioncash/aslr | bunnei | 2018-10-18 | 4 | -28/+44 |
|\ \ \ | | | | | | | | | svc: Clarify enum values for AddressSpaceBaseAddr and AddressSpaceSize in svcGetInfo() | ||||
| * | | | svc: Clarify enum values for AddressSpaceBaseAddr and AddressSpaceSize in svcGetInfo() | Lioncash | 2018-10-15 | 4 | -28/+44 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | So, one thing that's puzzled me is why the kernel seemed to *not* use the direct code address ranges in some cases for some service functions. For example, in svcMapMemory, the full address space width is compared against for validity, but for svcMapSharedMemory, it compares against 0xFFE00000, 0xFF8000000, and 0x7FF8000000 as upper bounds, and uses either 0x200000 or 0x8000000 as the lower-bounds as the beginning of the compared range. Coincidentally, these exact same values are also used in svcGetInfo, and also when initializing the user address space, so this is actually retrieving the ASLR extents, not the extents of the address space in general. | ||||
* | | | | Merge pull request #1509 from DarkLordZach/device-save-data | bunnei | 2018-10-18 | 1 | -1/+12 |
|\ \ \ \ | |_|/ / |/| | | | savedata_factory: Add DeviceSaveData and fix TemporaryStorage | ||||
| * | | | savedata_factory: Add TemporaryStorage SaveDataSpaceId | Zach Hilman | 2018-10-16 | 1 | -1/+4 |
| | | | | | | | | | | | | | | | | Required for TemporaryStorage saves (in addition to SaveDataType) | ||||
| * | | | savedata_factory: Add support for DeviceSaveData | Zach Hilman | 2018-10-16 | 1 | -0/+8 |
| | | | | | | | | | | | | | | | | Uses the same path as SaveData except with UID 0. Adds a warning if UID is not 0. | ||||
* | | | | Merge pull request #1443 from DarkLordZach/lower-loader-logs-1 | bunnei | 2018-10-16 | 2 | -3/+9 |
|\ \ \ \ | | | | | | | | | | | content_archive/patch_manager: Lower log levels to eliminate some unnecessary logs | ||||
| * | | | | patch_manager: Move non-Program RomFS patch log to Debug | Zach Hilman | 2018-10-13 | 1 | -2/+8 |
| | | | | | | | | | | | | | | | | | | | | Normal Program-type patches will still be logged to aid in debugging, but for others (mainly Control), it was moved to Debug. | ||||
| * | | | | content_archive: Move get key log to Trace level | Zach Hilman | 2018-10-13 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | Avoids printing live keys in the general log. | ||||
* | | | | | Implement VI ConvertScalingMode (#1475) | David | 2018-10-16 | 1 | -1/+49 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Implement VI ConvertScalingMode * Fixed push enum * Scale mode now uses Nintendo scale mode as an enum as well | ||||
* | | | | | Merge pull request #1502 from lioncash/unique | bunnei | 2018-10-16 | 11 | -56/+71 |
|\ \ \ \ \ | | | | | | | | | | | | | core: Convert shared_ptr instances into unique_ptr instances where applicable for System and Cpu | ||||
| * | | | | | core_cpu: Make Cpu scheduler instances unique_ptrs instead of shared_ptrs | Lioncash | 2018-10-15 | 9 | -27/+45 |
| | | | | | | |||||
| * | | | | | core: Make the live Cpu instances unique_ptrs instead of shared_ptrs | Lioncash | 2018-10-15 | 1 | -9/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no need for shared ownership here, as the only owning class instance of those Cpu instances is the System class itself. We can also make the thread_to_cpu map use regular pointers instead of shared_ptrs, given that the Cpu instances will always outlive the cases where they're used with that map. | ||||
| * | | | | | core: Make the exclusive monitor a unique_ptr instead of a shared_ptr | Lioncash | 2018-10-15 | 5 | -15/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Like the barrier, this is owned entirely by the System and will always outlive the encompassing state, so shared ownership semantics aren't necessary here. | ||||
| * | | | | | core: Make CPUBarrier a unique_ptr instead of a shared_ptr | Lioncash | 2018-10-15 | 3 | -11/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will always outlive the Cpu instances, since it's destroyed after we destroy the Cpu instances on shutdown, so there's no need for shared ownership semantics here. | ||||
* | | | | | | file_sys/registered_cache: Use unique_ptr and regular pointers instead of shared_ptrs where applicable | Lioncash | 2018-10-16 | 10 | -42/+41 |
| |_|/ / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The data retrieved in these cases are ultimately chiefly owned by either the RegisteredCache instance itself, or the filesystem factories. Both these should live throughout the use of their contained data. If they don't, it should be considered an interface/design issue, and using shared_ptr instances here would mask that, as the data would always be prolonged after the main owner's lifetime ended. This makes the lifetime of the data explicit and makes it harder to accidentally create cyclic references. It also makes the interface slightly more flexible than the previous API, as a shared_ptr can be created from a unique_ptr, but not the other way around, so this allows for that use-case if it ever becomes necessary in some form. | ||||
* | | | | | Merge pull request #1473 from lioncash/cmake | bunnei | 2018-10-16 | 1 | -2/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | web_service: Make linkage of web_service-related externals and the library private | ||||
| * | | | | | core/CMakeLists: Make all web_service-related libraries private | Lioncash | 2018-10-11 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that all external dependencies are hidden, we can remove json-headers from the publically linked libraries, as the use of this library is now completely hidden from external users of the web_service library. We can also make the web_services library private as well, considering it's not a requirement. If a library needs to link in web_service, it should be done explicitly -- not via indirect linking. | ||||
| * | | | | | core/CMakeLists: Use target_compile_definitions instead of add_definitions for specifying ENABLE_WEB_SERVICE | Lioncash | 2018-10-11 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids introducing the definition to the whole directory space and localizes it to being added to the library that needs it. | ||||
* | | | | | | file_sys/control_metadata: Get rid of magic constants | Lioncash | 2018-10-16 | 1 | -3/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These are just the size of the data being passed in, so we can specify that via the size() member function. | ||||
* | | | | | | Merge pull request #1494 from DarkLordZach/aoc-signature-fixes | bunnei | 2018-10-16 | 3 | -3/+20 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | aoc: Fix various bugs in current AOC implementation | ||||
| * | | | | | | aoc: Read DLC base title ID from RegisteredCache | Zach Hilman | 2018-10-15 | 3 | -2/+18 |
| | | | | | | | | | | | | | | | | | | | | | Falls back to title ID + 0x1000, which is what HOS does. | ||||
| * | | | | | | aoc: Return size in ListAddOnContent | Zach Hilman | 2018-10-14 | 1 | -1/+2 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1499 from lioncash/nro | bunnei | 2018-10-15 | 7 | -28/+39 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | nro/nso: Minor error handling changes | ||||
| * | | | | | | | nso: Return an optional address from LoadModule | Lioncash | 2018-10-15 | 5 | -16/+29 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If a malformed NSO is attempted to be loaded, we shouldn't continue onwards. We should be reporting an error and bailing out. | ||||
| * | | | | | | | nso: Make LoadModule take a VfsFile by const reference | Lioncash | 2018-10-15 | 3 | -11/+9 |
| | | | | | | | | |||||
| * | | | | | | | nro: Make LoadNro take a VfsFile by const reference | Lioncash | 2018-10-15 | 2 | -6/+6 |
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function doesn't need to care about ownership semantics, so we can just pass it a reference to the file itself, rather than a std::shared_ptr alias. | ||||
* | | | | | | | crypto: Various crypto fixes for quickstart guide | Zach Hilman | 2018-10-15 | 1 | -2/+2 |
| |_|_|/ / / |/| | | | | | |||||
* | | | | | | Merge pull request #1486 from lioncash/file | bunnei | 2018-10-14 | 4 | -63/+72 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | key_manager/partition_data_manager: Minor changes | ||||
| * | | | | | | partition_data_manager: Reserve and insert data within output vector in DecryptPackage2() | Lioncash | 2018-10-13 | 1 | -20/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just reserve the memory then perform successive insertions instead of needing to use memcpy. This also avoids the need to zero out the output vector's memory before performing the insertions. We can also std::move the output std::vector into the destination so that we don't need to make a completely new copy of the vector, getting rid of an unnecessary allocation. Additionally, we can use iterators to determine the beginning and end ranges of the std::vector instances that comprise the output vector, as the end of one range just becomes the beginning for the next successive range, and since std::vector's iterator constructor copies data within the range [begin, end), this is more straightforward and gets rid of the need to have an offset variable that keeps getting incremented to determine where to do the next std::memcpy. | ||||
| * | | | | | | partition_data_manager: Remove unused std::map instance within DecryptPackage2() | Lioncash | 2018-10-13 | 1 | -2/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Aside from emplacing elements into the map, the map itself is never actually queried for contained data. | ||||
| * | | | | | | partition_data_manager: Take package2_keys by const reference | Lioncash | 2018-10-13 | 2 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These are only ever read from, so we don't need to make a copy of all the keys here. | ||||
| * | | | | | | partition_data_manager: Move IV data to where it's needed in DecryptPackage2() | Lioncash | 2018-10-13 | 1 | -3/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given it's only used in one spot and has a fairly generic name, we can just specify it directly in the function call. This also the benefit of automatically moving it. | ||||
| * | | | | | | partition_data_manager: Remove commented out code | Lioncash | 2018-10-13 | 1 | -2/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Commented out code shouldn't be left in without a reason indicating why in a comment. | ||||
| * | | | | | | key_manager/partition_data_manager: Silence truncation compiler warnings | Lioncash | 2018-10-13 | 4 | -10/+15 |
| | | | | | | | |||||
| * | | | | | | partition_data_manager: Dehardcode array bounds | Lioncash | 2018-10-13 | 2 | -7/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Instead, we can make it part of the type and make named variables for them, so they only require one definition (and if they ever change for whatever reason, they only need to be changed in one spot). | ||||
| * | | | | | | partition_data_manager: Take VirtualFile by const reference in constructor | Lioncash | 2018-10-13 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given the VirtualFile instance isn't stored into the class as a data member, or written to, this can just be turned into a const reference, as the constructor doesn't need to make a copy of it. | ||||
| * | | | | | | partition_data_manager: Amend constructor initializer list order | Lioncash | 2018-10-13 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Orders the members in the exact order they would be initialized. This also prevents compiler warnings about this sort of thing. | ||||
| * | | | | | | partition_data_manager: Remove unused includes | Lioncash | 2018-10-13 | 2 | -4/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets unused includes out of the headers and moves them into the cpp file if they're used there instead. | ||||
| * | | | | | | key_manager: Use std::vector's insert() instead of std::copy with a back_inserter | Lioncash | 2018-10-13 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If the data is unconditionally being appended to the back of a std::vector, we can just directly insert it there without the need to insert all of the elements one-by-one with a std::back_inserter. | ||||
| * | | | | | | key_manager: Brace long conditional body | Lioncash | 2018-10-13 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If a conditional (or it's body) travels more than one line, it should be braced. | ||||
| * | | | | | | key_manager: Don't assume file seeks and reads will always succeed | Lioncash | 2018-10-13 | 1 | -7/+17 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given the filesystem should always be assumed to be volatile, we should check and bail out if a seek operation isn't successful. This'll prevent potentially writing/returning garbage data from the function in rare cases. This also allows removing a check to see if an offset is within the bounds of a file before perfoming a seek operation. If a seek is attempted beyond the end of a file, it will fail, so this essentially combines two checks into one in one place. | ||||
| * | | | | | | key_manager: Remove unnecessary seek in DeriveSDSeed() | Lioncash | 2018-10-13 | 1 | -1/+0 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given the file is opened a few lines above and no operations are done, other than check if the file is in a valid state, the read/write pointer will always be at the beginning of the file. | ||||
* | | | | | | Merge pull request #1491 from lioncash/reference | bunnei | 2018-10-14 | 5 | -15/+14 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | filesystem: Make CreateFactories() and InstallInterface() take a VfsFilesystem by reference | ||||
| * | | | | | filesystem: Make CreateFactories() and InstallInterface() take a VfsFilesystem instance by reference | Lioncash | 2018-10-13 | 5 | -15/+14 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Neither of these functions alter the ownership of the provided pointer, so we can simply make the parameters a reference rather than a direct shared pointer alias. This way we also disallow passing incorrect memory values like nullptr. | ||||
* | | | | | Merge pull request #1492 from lioncash/proc | bunnei | 2018-10-14 | 3 | -4/+50 |
|\ \ \ \ \ | | | | | | | | | | | | | svc: Implement svcGetProcessInfo | ||||
| * | | | | | svc: Implement svcGetProcessInfo | Lioncash | 2018-10-13 | 3 | -4/+50 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A fairly basic service function, which only appears to currently support retrieving the process state. This also alters the ProcessStatus enum to contain all of the values that a kernel process seems to be able of reporting with regards to state. | ||||
* / / / / | Stop all threads on svcBreak | David Marcec | 2018-10-14 | 1 | -0/+6 |
|/ / / / | | | | | | | | | | | | | This should help diagnose crashes easier and prevent many users thinking that a game is still running when in fact it's just an audio thread still running(this is typically not killed when svcBreak is hit since the game expects us to do this) | ||||
* | | | | Merge pull request #1409 from DarkLordZach/key-derivation | bunnei | 2018-10-13 | 7 | -74/+1569 |
|\ \ \ \ | | | | | | | | | | | crypto: Add support for full key derivation | ||||
| * | | | | partition_data_manager: Rename system files for hekate | Zach Hilman | 2018-10-07 | 4 | -178/+228 |
| | | | | | | | | | | | | | | | | | | | | x | ||||
| * | | | | crypto: Add PartitionDataManager | Zach Hilman | 2018-10-07 | 3 | -0/+692 |
| | | | | | | | | | | | | | | | | | | | | Keeps track of system files for key derivation | ||||
| * | | | | key_manager: Add support for loading keys from partition data | Zach Hilman | 2018-10-07 | 2 | -0/+88 |
| | | | | | |||||
| * | | | | key_manager: Add ETicket key derivation | Zach Hilman | 2018-10-07 | 3 | -2/+277 |
| | | | | | | | | | | | | | | | | | | | | Derives titlekeys | ||||
| * | | | | key_manager: Add base key derivation | Zach Hilman | 2018-10-07 | 2 | -4/+220 |
| | | | | | | | | | | | | | | | | | | | | Derives master keys, game encryption keys, and package1/2 keys | ||||
| * | | | | key_manager: Add BIS key getter | Zach Hilman | 2018-10-07 | 2 | -2/+19 |
| | | | | | |||||
| * | | | | key_manager: Add support for more keys | Zach Hilman | 2018-10-07 | 2 | -3/+99 |
| | | | | | | | | | | | | | | | | | | | | TSEC, SBK, BIS, and other Sources for proper derivation | ||||
| * | | | | key_manager: Add keyblob support | Zach Hilman | 2018-10-07 | 2 | -0/+14 |
| | | | | | |||||
| * | | | | key_manager: Add support for crypto revisions past 04 | Zach Hilman | 2018-10-07 | 1 | -43/+63 |
| | | | | | |||||
| * | | | | key_manager: Add support for comments in keyfiles | Zach Hilman | 2018-10-07 | 1 | -0/+3 |
| | | | | | |||||
| * | | | | vfs: Move forward declarations to separate file | Zach Hilman | 2018-10-07 | 2 | -9/+22 |
| | | | | | |||||
| * | | | | key_manager: Add support for console-specific keyfile | Zach Hilman | 2018-10-07 | 2 | -3/+13 |
| | | | | | |||||
| * | | | | key_manager: Rename KEK to Kek | Zach Hilman | 2018-10-07 | 2 | -8/+9 |
| | | | | | |||||
* | | | | | Merge pull request #1483 from lioncash/codeset | bunnei | 2018-10-13 | 7 | -83/+45 |
|\ \ \ \ \ | | | | | | | | | | | | | kernel/process: Make CodeSet a regular non-inherited object | ||||
| * | | | | | kernel/process: Make CodeSet a regular non-inherited object | Lioncash | 2018-10-12 | 7 | -83/+45 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These only exist to ferry data into a Process instance and end up going out of scope quite early. Because of this, we can just make it a plain struct for holding things and just std::move it into the relevant function. There's no need to make this inherit from the kernel's Object type. | ||||
* | | | | | | Merge pull request #1481 from lioncash/typo | bunnei | 2018-10-13 | 1 | -3/+3 |
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | | svc: Fix typos in sanitizing checks for MapMemory/UnmapMemory | ||||
| * | | | | | svc: Fix typos in sanitizing checks for MapMemory/UnmapMemory | Lioncash | 2018-10-12 | 1 | -3/+3 |
| |/ / / / | |||||
* | | | | | Merge pull request #1467 from ogniK5377/svcbreak-type-fix | bunnei | 2018-10-12 | 2 | -28/+36 |
|\ \ \ \ \ | | | | | | | | | | | | | Fixed incorrect types for svcBreak | ||||
| * | | | | | Changed all casts in svc_wrap.h to be static_cast instead | David Marcec | 2018-10-10 | 1 | -25/+28 |
| | | | | | | |||||
| * | | | | | Use a better name than "dont_kill_application" | David Marcec | 2018-10-10 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | signal_debugger seems like a more fitting name | ||||
| * | | | | | Fixed incorrect types for svcBreak | David Marcec | 2018-10-10 | 2 | -3/+8 |
| | |_|_|/ | |/| | | | | | | | | | | | | | svcBreak reason should be a u32, not a u64. | ||||
* | | | | | Merge pull request #1478 from ogniK5377/remap-invalidhandle-remap | bunnei | 2018-10-12 | 1 | -3/+10 |
|\ \ \ \ \ | | | | | | | | | | | | | Passing an invalid nmap handle to Remap should throw an error | ||||
| * | | | | | Returned an error before processing other remaps | David Marcec | 2018-10-12 | 1 | -6/+2 |
| | | | | | | |||||
| * | | | | | Passing an invalid nmap handle to Remap should throw an error | David Marcec | 2018-10-11 | 1 | -3/+14 |
| | |_|_|/ | |/| | | | | | | | | | | | | | Added error for invalid nmap handles | ||||
* | | | | | Merge pull request #1482 from lioncash/init | bunnei | 2018-10-12 | 1 | -4/+1 |
|\ \ \ \ \ | | | | | | | | | | | | | thread: Remove unnecessary memset from ResetThreadContext() | ||||
| * | | | | | thread: Remove unnecessary memset from ResetThreadContext() | Lioncash | 2018-10-12 | 1 | -4/+1 |
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | Regular value initialization is adequate here for zeroing out data. It also has the benefit of not invoking undefined behavior if a non-trivial type is ever added to the struct for whatever reason. | ||||
* | | | | | Merge pull request #1479 from ogniK5377/nmap-revamped | bunnei | 2018-10-12 | 1 | -12/+60 |
|\ \ \ \ \ | |/ / / / |/| | | | | Added error codes for nvmap | ||||
| * | | | | Made the minimum alignment more clear | David Marcec | 2018-10-12 | 1 | -2/+3 |
| | | | | | |||||
| * | | | | Added error codes for nvmap | David Marcec | 2018-10-11 | 1 | -12/+59 |
| |/ / / | |||||
* | | | | Merge pull request #1474 from ogniK5377/hwopus-decodeinterleavedwithperformance | bunnei | 2018-10-11 | 1 | -3/+34 |
|\ \ \ \ | | | | | | | | | | | HwOpus, Implemented DecodeInterleavedWithPerformance | ||||
| * | | | | HwOpus, Implemented DecodeInterleavedWithPerformance | David Marcec | 2018-10-11 | 1 | -3/+34 |
| |/ / / | | | | | | | | | | | | | Used by sonic ages | ||||
* | | | | Merge pull request #1472 from lioncash/san | bunnei | 2018-10-11 | 2 | -12/+81 |
|\ \ \ \ | | | | | | | | | | | svc: Add missing address range sanitizing checks to MapMemory/UnmapMemory | ||||
| * | | | | svc: Add missing address range sanitizing checks to MapMemory/UnmapMemory | Lioncash | 2018-10-11 | 2 | -12/+81 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This adds the missing address range checking that the service functions do before attempting to map or unmap memory. Given that both service functions perform the same set of checks in the same order, we can wrap these into a function and just call it from both functions, which deduplicates a little bit of code. | ||||
* / / / | nvhost_as_gpu: Flush CPU VAddr on UnmapBuffer. | bunnei | 2018-10-11 | 1 | -3/+4 |
|/ / / | |||||
* | | | kernel/thread: Use a regular pointer for the owner/current process | Lioncash | 2018-10-10 | 9 | -38/+39 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no real need to use a shared pointer in these cases, and only makes object management more fragile in terms of how easy it would be to introduce cycles. Instead, just do the simple thing of using a regular pointer. Much of this is just a hold-over from citra anyways. It also doesn't make sense from a behavioral point of view for a process' thread to prolong the lifetime of the process itself (the process is supposed to own the thread, not the other way around). | ||||
* | | | Merge pull request #1461 from lioncash/warn | bunnei | 2018-10-10 | 1 | -3/+3 |
|\ \ \ | | | | | | | | | ips_layer: Silence truncation and conversion warnings | ||||
| * | | | ips_layer: Silence truncation and conversion warnings | Lioncash | 2018-10-09 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | Makes type conversions explicit to avoid compiler warnings. | ||||
* | | | | Merge pull request #1464 from lioncash/unique | bunnei | 2018-10-10 | 6 | -15/+13 |
|\ \ \ \ | |_|/ / |/| | | | patch_manager: Return a std::unique_ptr from ParseControlNCA() and GetControlMetadata() instead of a std::shared_ptr | ||||
| * | | | patch_manager: Return a std::unique_ptr from ParseControlNCA() and GetControlMetadata() instead of a std::shared_ptr | Lioncash | 2018-10-09 | 6 | -15/+13 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Neither of these functions require the use of shared ownership of the returned pointer. This makes it more difficult to create reference cycles with, and makes the interface more generic, as std::shared_ptr instances can be created from a std::unique_ptr, but the vice-versa isn't possible. This also alters relevant functions to take NCA arguments by const reference rather than a const reference to a std::shared_ptr. These functions don't alter the ownership of the memory used by the NCA instance, so we can make the interface more generic by not assuming anything about the type of smart pointer the NCA is contained within and make it the caller's responsibility to ensure the supplied NCA is valid. | ||||
* | | | Merge pull request #1459 from ogniK5377/break | bunnei | 2018-10-09 | 1 | -5/+20 |
|\ \ \ | | | | | | | | | svcBreak, Signalling to the debugger should not kill execution | ||||
| * | | | Added bitfield instead of manually checking if the bit is set | David Marcec | 2018-10-09 | 1 | -4/+12 |
| | | | | |||||
| * | | | Actual kill execution when the bit isn't set, not the other way around | David Marcec | 2018-10-09 | 1 | -1/+1 |
| | | | | |||||
| * | | | svcBreak, Signalling to the debugger should not kill execution | David Marcec | 2018-10-09 | 1 | -5/+12 |
| | | | | | | | | | | | | | | | | When loading NROs, svcBreak is called to signal to the debugger that a new "module" is loaded. As no debugger is technically attached we shouldn't be killing the programs execution. | ||||
* | | | | Merge pull request #1465 from lioncash/telemetry | bunnei | 2018-10-09 | 2 | -7/+9 |
|\ \ \ \ | | | | | | | | | | | telemetry_session: Minor miscellaneous changes | ||||
| * | | | | telemetry_session: Remove doxygen comment for a non-existent parameter | Lioncash | 2018-10-09 | 1 | -1/+0 |
| | | | | | | | | | | | | | | | | | | | | There's no "func" parameter, so this can just be removed. | ||||
| * | | | | telemetry_session: Add missing includes | Lioncash | 2018-10-09 | 2 | -2/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Prevents potential compilation issues in the future by including missing headers for certain functions and types. | ||||
| * | | | | telemetry_session: Remove unimplemented FinalizeAsyncJob prototype | Lioncash | 2018-10-09 | 1 | -2/+0 |
| | | | | | | | | | | | | | | | | | | | | This isn't implemented anywhere, so it can just be removed. | ||||
| * | | | | telemetry_session: Use a std::array in GenerateTelemetryId() | Lioncash | 2018-10-09 | 1 | -2/+4 |
| | |/ / | |/| | | | | | | | | | | | | | | | | | | We don't need to potentially heap-allocate a std::string instance here, given the data is known ahead of time. We can just place it within an array and pass this to the mbedtls functions. | ||||
* | | | | ips_layer: Avoid constructing std::vector instances where not necessary | Lioncash | 2018-10-09 | 1 | -6/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | We can just compare the existing std::vector instance with a constexpr std::array containing the desired match. This is lighter resource-wise, as we don't need to allocate on the heap. | ||||
* | | | | ips_layer: Remove unnecessary explicit std::pair constructor in std::array | Lioncash | 2018-10-09 | 1 | -5/+13 |
| | | | | | | | | | | | | | | | | | | | | Makes the layout of the array consistent, by making all elements match, instead of special-casing the first one. | ||||
* | | | | ips_layer: Add missing includes | Lioncash | 2018-10-09 | 2 | -7/+17 |
| | | | | | | | | | | | | | | | | | | | | | | | | Adds missing includes to prevent potential compilation issues in the future. Also moves the definition of a struct into the cpp file, so that some includes don't need to be introduced within the header. | ||||
* | | | | ips_layer: std::move data within PatchIPS() and Apply() | Lioncash | 2018-10-09 | 1 | -2/+5 |
|/ / / | | | | | | | | | | | | | We don't need to make a copy of the read data, so we can std::move it into the make_shared call here. | ||||
* | | | Merge pull request #1423 from DarkLordZach/romfs-file-exts | bunnei | 2018-10-08 | 5 | -10/+38 |
|\ \ \ | | | | | | | | | fsmitm_romfsbuild: Add support for stubbing and IPS patches in LFS | ||||
| * | | | patch_manager: Avoid romfs_ext requirement for patching | Zach Hilman | 2018-10-04 | 1 | -4/+1 |
| | | | | |||||
| * | | | fsmitm_romfsbuild: Extract stubs and IPS to romfs_ext dir | Zach Hilman | 2018-10-04 | 5 | -21/+38 |
| | | | | |||||
| * | | | fsmitm_romfsbuild: Add support for stubbing and IPS patches in LFS | Zach Hilman | 2018-10-04 | 1 | -0/+14 |
| | | | | |||||
* | | | | Merge pull request #1424 from DarkLordZach/ips-witch | bunnei | 2018-10-08 | 4 | -23/+299 |
|\ \ \ \ | |_|/ / |/| | | | ips_layer: Add support for IPSwitch executable patches | ||||
| * | | | ips_layer: Fix inaccuracies with comments and flags | Zach Hilman | 2018-10-04 | 3 | -16/+51 |
| | | | | | | | | | | | | Specifically bugs/crashes that arise when putting them in positions that are legal but not typical, such as midline, between patch data, or between patch records. | ||||
| * | | | ips_layer: Deduplicate resource usage | Zach Hilman | 2018-10-04 | 3 | -31/+37 |
| | | | | |||||
| * | | | ips_layer: Add support for escape sequences and midline comments | Zach Hilman | 2018-10-04 | 3 | -8/+41 |
| | | | | | | | | | | | | | | | | More accurately follows IPSwitch specification. | ||||
| * | | | patch_manager: Add support for IPSwitch format patches | Zach Hilman | 2018-10-04 | 1 | -22/+56 |
| | | | | |||||
| * | | | ips_layer: Add IPSwitchCompiler to process IPSwitch format | Zach Hilman | 2018-10-04 | 2 | -0/+168 |
| |/ / | |||||
* | | | Merge pull request #1456 from ogniK5377/aoc-u-fixups | bunnei | 2018-10-08 | 1 | -5/+5 |
|\ \ \ | | | | | | | | | Fixed assertion due to CountAddOnContent & Casting warnings | ||||
| * | | | Fixed assertion due to CountAddOnContent | David Marcec | 2018-10-07 | 1 | -5/+5 |
| | |/ | |/| | | | | | | | | | | | | | Word count should be 3 since we're pushing a result code and a u32. Also fixed up compiler warnings due to casting | ||||
* | | | Merge pull request #1457 from ogniK5377/unmap-buffer | bunnei | 2018-10-08 | 1 | -1/+6 |
|\ \ \ | | | | | | | | | Unmapping an unmapped buffer should succeed | ||||
| * | | | Unmapping an unmapped buffer should succeed | David Marcec | 2018-10-08 | 1 | -1/+6 |
| |/ / | | | | | | | | | | Hardware tests show that trying to unmap an unmapped buffer already should always succeed. Hardware test was tested up to 32 iterations of attempting to unmap | ||||
* | | | nso/nro: Use default allocation size for arg_data | Zach Hilman | 2018-10-07 | 4 | -14/+20 |
| | | | |||||
* | | | cmd: Support passing game arguments from command line | Zach Hilman | 2018-10-07 | 2 | -2/+2 |
| | | | | | | | | | | | | Uses -p (--program) and following string as args. | ||||
* | | | settings: Add program_args string setting | Zach Hilman | 2018-10-07 | 1 | -0/+1 |
| | | | |||||
* | | | nso/nro: Add NSO arguments structure to data section | Zach Hilman | 2018-10-07 | 4 | -3/+38 |
|/ / | | | | | | | Only added if arguments string is non-empty and a pass is requested by loader. | ||||
* | | Merge pull request #1396 from DarkLordZach/packed-updates | bunnei | 2018-10-07 | 15 | -16/+128 |
|\ \ | | | | | | | loader: Add support for packed updates | ||||
| * | | romfs_factory: Extract packed update setter to new function | Zach Hilman | 2018-10-05 | 9 | -6/+36 |
| | | | |||||
| * | | patch_manager: Add support for NSP packed updates | Zach Hilman | 2018-10-05 | 1 | -2/+2 |
| | | | | | | | | | | | | Reads as Update (NSP) in add-ons | ||||
| * | | patch_manager: Add support for packed updates | Zach Hilman | 2018-10-05 | 4 | -5/+18 |
| | | | | | | | | | | | | Will prefer any installed update over the packed version. | ||||
| * | | loader: Add getter for packed update | Zach Hilman | 2018-10-05 | 6 | -3/+58 |
| | | | | | | | | | | | | Reads the update included with the game if it has one and adds the new ErrorNoPackedUpdate status. | ||||
| * | | loader: Add ReadRomFSIVFCOffset to NSP, XCI, and NAX loaders | Zach Hilman | 2018-10-05 | 6 | -6/+20 |
| |/ | | | | | | | Fixes errors with certain updates | ||||
* | | Merge pull request #1448 from ogniK5377/frontend-access | bunnei | 2018-10-07 | 4 | -0/+26 |
|\ \ | | | | | | | Ported #4296 from citra | ||||
| * | | Added forward define for ServerPort | David Marcec | 2018-10-06 | 2 | -4/+6 |
| | | | |||||
| * | | Ported #4296 from citra | David Marcec | 2018-10-06 | 3 | -1/+25 |
| | | | | | | | | | | | | This will allow us to easily remove the use of "NFC" in "System" | ||||
* | | | Merge pull request #1332 from FearlessTobi/port-web-backend | bunnei | 2018-10-06 | 4 | -14/+53 |
|\ \ \ | |/ / |/| | | Port web_service from Citra | ||||
| * | | Review comments -part 4 | fearlessTobi | 2018-10-02 | 1 | -0/+1 |
| | | | |||||
| * | | Address more review comments | fearlessTobi | 2018-10-02 | 1 | -1/+1 |
| | | | |||||
| * | | Address a bunch of review comments | fearlessTobi | 2018-10-02 | 2 | -6/+7 |
| | | | |||||
| * | | Port web_service from Citra | fearlessTobi | 2018-10-02 | 4 | -14/+51 |
| | | | |||||
* | | | kernel/mutex: Amend behavior of TransferMutexOwnership() | Lioncash | 2018-10-06 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This was the result of a typo accidentally introduced in e51d715700a35a8f14e5b804b6f7553c9a40888b. This restores the previous correct behavior. The behavior with the reference was incorrect and would cause some games to fail to boot. | ||||
* | | | thread: Make the scheduler pointer a regular pointer | balika011 | 2018-10-05 | 2 | -4/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Conceptually, it doesn't make sense for a thread to be able to persist the lifetime of a scheduler. A scheduler should be taking care of the threads; the threads should not be taking care of the scheduler. If the threads outlive the scheduler (or we simply don't actually terminate/shutdown the threads), then it should be considered a bug that we need to fix. Attributing this to balika011, as they opened #1317 to attempt to fix this in a similar way, but my refactoring of the kernel code caused quite a few conflicts. | ||||
* | | | Merge pull request #1439 from lioncash/thread | bunnei | 2018-10-05 | 14 | -206/+392 |
|\ \ \ | |_|/ |/| | | kernel/thread: Make all instance variables private | ||||
| * | | kernel/thread: Make all instance variables private | Lioncash | 2018-10-04 | 14 | -206/+392 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Many of the member variables of the thread class aren't even used outside of the class itself, so there's no need to make those variables public. This change follows in the steps of the previous changes that made other kernel types' members private. The main motivation behind this is that the Thread class will likely change in the future as emulation becomes more accurate, and letting random bits of the emulator access data members of the Thread class directly makes it a pain to shuffle around and/or modify internals. Having all data members public like this also makes it difficult to reason about certain bits of behavior without first verifying what parts of the core actually use them. Everything being public also generally follows the tendency for changes to be introduced in completely different translation units that would otherwise be better introduced as an addition to the Thread class' public interface. | ||||
* | | | Merge pull request #1415 from DarkLordZach/ips | bunnei | 2018-10-04 | 8 | -36/+255 |
|\ \ \ | | | | | | | | | file_sys: Add support for loading IPS patches | ||||
| * | | | nso: Optimize loading of IPS patches | Zach Hilman | 2018-10-02 | 5 | -51/+43 |
| | | | | | | | | | | | | | | | | Avoid resource-heavy classes and remove quasi-duplicated code. | ||||
| * | | | deconstructed_rom_directory: Force NSO loader to patch NSOs | Zach Hilman | 2018-10-01 | 1 | -1/+3 |
| | | | | |||||
| * | | | nso: Add framework to support patching of uncompressed NSOs | Zach Hilman | 2018-10-01 | 2 | -2/+17 |
| | | | | |||||
| * | | | patch_manager: Add PatchNSO function | Zach Hilman | 2018-10-01 | 3 | -0/+104 |
| | | | | | | | | | | | | | | | | While PatchExeFS operated on the entire directory, this function operates on the uncompressed NSO. Avoids copying decompression code to PatchManager. | ||||
| * | | | patch_manager: Use strings for patch type instead of enum | Zach Hilman | 2018-10-01 | 2 | -29/+33 |
| | | | | |||||
| * | | | file_sys: Implement function to apply IPS patches | Zach Hilman | 2018-10-01 | 2 | -0/+103 |
| | | | | |||||
| * | | | nso: Replace NSOHeader padding bytes with build ID | Zach Hilman | 2018-10-01 | 1 | -2/+1 |
| | |/ | |/| | |||||
* | | | Merge pull request #1434 from DarkLordZach/dlc-edge-case | bunnei | 2018-10-04 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | aoc_u: Fix edge case with DLC that causes breaks | ||||
| * | | | aoc_u: Fix edge case with DLC that causes breaks | Zach Hilman | 2018-10-03 | 1 | -1/+1 |
| |/ / | | | | | | | | | | In some games (Splatoon 2 and Splatoon 2 Splatfest World Premiere, notably), pass offset=0 and count=2047 into the ListAddOnContent method which should return all DLCs for the current title. The (presumably) intended behavior is to successfully return a empty array but because of a < v. <= in an if statement, a failure error code was returned causing these games to svcBreak. This fixes that if statement. | ||||
* | | | Merge pull request #1433 from lioncash/fs | bunnei | 2018-10-04 | 1 | -0/+2 |
|\ \ \ | | | | | | | | | services/fsp_srv: Amend service function table | ||||
| * | | | services/fsp_srv: Amend service function table | Lioncash | 2018-10-03 | 1 | -0/+2 |
| | |/ | |/| | | | | | | | | | | Adds new functions that have been given names to the table. Information is based off what is provided on Switchbrew. | ||||
* | | | Merge pull request #1436 from lioncash/view | bunnei | 2018-10-04 | 2 | -73/+101 |
|\ \ \ | | | | | | | | | submission_package: Cleanup and bug fixes | ||||
| * | | | submission_package: Avoid dangling std::string_view within SetTicketKeys() | Lioncash | 2018-10-03 | 1 | -2/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | GetName() returns a std::string by value, not by reference, so after the std::string_view is constructed, it's not well defined to actually execute any member functions of std::string_view that attempt to access the data, as the std::string has already been destroyed. Instead, we can just use a std::string and erase the last four characters. | ||||
| * | | | submission_package: Correct location of null check within SetTicketKeys() | Lioncash | 2018-10-03 | 1 | -3/+6 |
| | | | | | | | | | | | | | | | | | | | | If a ticket file was ever a null pointer, we'd cause a null pointer dereference, as we were calling GetExtension() on the pointer instance. | ||||
| * | | | submission_package: Use std::string's rfind() when looking for the extension in InitializeExeFSAndRomFS() | Lioncash | 2018-10-03 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | When searching for a file extension, it's generally preferable to begin the search at the end of the string rather than the beginning, as the whole string isn't going to be walked just to check for something at the end of it. | ||||
| * | | | submission_package: Ensure the 'extracted' member variable is always initialized | Lioncash | 2018-10-03 | 2 | -3/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If an error occurs when constructing the PartitionFilesystem instance, the constructor would be exited early, which wouldn't initialize the extracted data member, making it possible for other code to perform an uninitialized read by calling the public IsExtractedType() member function. This prevents that. | ||||
| * | | | submission_package: Move ExeFS and RomFS initialization to its own function | Lioncash | 2018-10-03 | 2 | -10/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Like the other two bits of factored out code, this can also be put within its own function. We can also modify the code so that it accepts a const reference to a std::vector of files, this way, we can deduplicate the file retrieval. Now the constructor for NSP isn't a combination of multiple behaviors in one spot. It's nice and separate. | ||||
| * | | | submission_package: Move NCA reading code to its own function | Lioncash | 2018-10-03 | 2 | -43/+48 |
| | | | | | | | | | | | | | | | | | | | | | | | | This too, is completely separate behavior from what is in the constructor, so we can move this to its own isolated function to keep everything self-contained. | ||||
| * | | | submission_package: Move ticket key setting to its own function | Lioncash | 2018-10-03 | 1 | -21/+28 |
| | | | | | | | | | | | | | | | | | | | | This behavior is entirely independent of the surrounding code, so it can be put in its own function to keep the behavior separate. | ||||
| * | | | submission_package: Invert conditionals within NSP's constructor to reduce nesting | Lioncash | 2018-10-03 | 1 | -45/+49 |
| |/ / | | | | | | | | | | We can use early continues here to reduce the amount of nesting. | ||||
* | | | Merge pull request #1432 from lioncash/lbl | bunnei | 2018-10-04 | 1 | -19/+19 |
|\ \ \ | | | | | | | | | service/lbl: Update service function table | ||||
| * | | | service/lbl: Update service function table | Lioncash | 2018-10-03 | 1 | -19/+19 |
| | |/ | |/| | | | | | | | | | | Amends the lbl service table to include new names of functions that were added to Switchbrew. | ||||
* | | | Merge pull request #1435 from lioncash/xci | bunnei | 2018-10-04 | 1 | -1/+3 |
|\ \ \ | |/ / |/| | | card_image: Ensure program_nca_status is always initialized | ||||
| * | | card_image: Ensure program_nca_status is always initialized | Lioncash | 2018-10-03 | 1 | -1/+3 |
| |/ | | | | | | | | | | | If any of the error paths before the NCA retrieval are taken, it'll result in program_nca_status being left in an inconsistent state. So we initialize it by default with a value indicating an error. | ||||
* | | aoc_u: Extract AccumulateAOCTitleIDs to separate function | Zach Hilman | 2018-10-01 | 2 | -21/+28 |
| | | |||||
* | | aoc_u: Implement GetAddOnContentBaseId | Zach Hilman | 2018-10-01 | 3 | -5/+8 |
| | | | | | | Command #5 | ||||
* | | aoc_u: Implement Count, List and Prepare AddOnContent | Zach Hilman | 2018-10-01 | 2 | -3/+78 |
| | | | | | | | | Commands #2, #3, and #7 | ||||
* | | romfs_factory: Read from all locations with StorageId None | Zach Hilman | 2018-10-01 | 1 | -26/+25 |
| | | | | | | | | Previous behavior was to assert. Seems to mirror expected game behavior. | ||||
* | | patch_manager: Add DLC recognition to PatchManager | Zach Hilman | 2018-10-01 | 2 | -0/+27 |
|/ | |||||
* | Merge pull request #1338 from raven02/service_vi | bunnei | 2018-09-30 | 1 | -1/+19 |
|\ | | | | | Implement ISystemDisplayService::GetDisplayMode | ||||
| * | Implement ISystemDisplayService::GetDisplayMode | raven02 | 2018-09-30 | 1 | -1/+19 |
| | | |||||
* | | kernel/svc: Implement svcGetThreadContext() | Lioncash | 2018-09-30 | 3 | -2/+37 |
| | | | | | | | | | | | | | | | | | | Now that we have all of the rearranging and proper structure sizes in place, it's fairly trivial to implement svcGetThreadContext(). In the 64-bit case we can more or less just write out the context as is, minus some minor value sanitizing. In the 32-bit case we'll need to clear out the registers that wouldn't normally be accessible from a 32-bit AArch32 exectuable (or process). | ||||
* | | kernel/process: Add a data member to determine if a process is 64-bit or not. | Lioncash | 2018-09-30 | 2 | -0/+11 |
| | | | | | | | | | | | | | | | | | | | | | | This will be necessary for the implementation of svcGetThreadContext(), as the kernel checks whether or not the process that owns the thread that has it context being retrieved is a 64-bit or 32-bit process. If the process is 32-bit, then the upper 15 general-purpose registers and upper 16 vector registers are cleared to zero (as AArch32 only has 15 GPRs and 16 128-bit vector registers. not 31 general-purpose registers and 32 128-bit vector registers like AArch64). | ||||
* | | kernel/process: Make data member variables private | Lioncash | 2018-09-30 | 16 | -72/+117 |
| | | | | | | | | | | | | | | Makes the public interface consistent in terms of how accesses are done on a process object. It also makes it slightly nicer to reason about the logic of the process class, as we don't want to expose everything to external code. | ||||
* | | arm_interface: Add missing fpsr/tpidr members to the ThreadContext struct | Lioncash | 2018-09-30 | 3 | -5/+15 |
| | | | | | | | | | | | | | | | | | | Internally within the kernel, it also includes a member variable for the floating-point status register, and TPIDR, so we should do the same here to match it. While we're at it, also fix up the size of the struct and add a static assertion to ensure it always stays the correct size. | ||||
* | | loader: Make the Load() function take a process as a regular reference, not a SharedPtr | Lioncash | 2018-09-29 | 18 | -42/+28 |
| | | | | | | | | | | | | | | | | A process should never require being reference counted in this situation. If the handle to a process is freed before this function is called, it's definitely a bug with our lifetime management, so we can put the requirement in place for the API that the process must be a valid instance. | ||||
* | | Merge pull request #1412 from lioncash/move | bunnei | 2018-09-29 | 2 | -3/+2 |
|\ \ | | | | | | | kernel/object: Remove unnecessary std::move from DynamicObjectCast() | ||||
| * | | kernel/object: Remove unnecessary std::move from DynamicObjectCast() | Lioncash | 2018-09-28 | 2 | -3/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | boost::static_pointer_cast for boost::intrusive_ptr (what SharedPtr is), takes its parameter by const reference. Given that, it means that this std::move doesn't actually do anything other than obscure what the function's actual behavior is, so we can remove this. To clarify, this would only do something if the parameter was either taking its argument by value, by non-const ref, or by rvalue-reference. | ||||
* | | | Merge pull request #1395 from lioncash/vm | bunnei | 2018-09-29 | 17 | -158/+413 |
|\ \ \ | | | | | | | | | process/vm_manager: Initial modifications to load NPDM metadata | ||||
| * | | | memory: Dehardcode the use of fixed memory range constants | Lioncash | 2018-09-25 | 11 | -75/+60 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The locations of these can actually vary depending on the address space layout, so we shouldn't be using these when determining where to map memory or be using them as offsets for calculations. This keeps all the memory ranges flexible and malleable based off of the virtual memory manager instance state. | ||||
| * | | | svc: Report correct memory-related values within some of the cases in svcGetInfo() | Lioncash | 2018-09-25 | 3 | -28/+41 |
| | | | | | | | | | | | | | | | | | | | | | | | | Previously, these were reporting hardcoded values, but given the regions can change depending on the requested address spaces, these need to report the values that the memory manager contains. | ||||
| * | | | memory: Dehardcode the use of a 36-bit address space | Lioncash | 2018-09-25 | 5 | -20/+56 |
| | | | | | | | | | | | | | | | | | | | | Given games can also request a 32-bit or 39-bit address space, we shouldn't be hardcoding the address space range as 36-bit. | ||||
| * | | | process/vm_manager: Amend API to allow reading parameters from NPDM metadata | Lioncash | 2018-09-24 | 10 | -38/+259 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than hard-code the address range to be 36-bit, we can derive the parameters from supplied NPDM metadata if the supplied exectuable supports it. This is the bare minimum necessary for this to be possible. The following commits will rework the memory code further to adjust to this. | ||||
* | | | | Merge pull request #1394 from lioncash/stream | bunnei | 2018-09-27 | 1 | -1/+1 |
|\ \ \ \ | |_|/ / |/| | | | stream: Preserve enum class type in GetState() | ||||
| * | | | stream: Preserve enum class type in GetState() | Lioncash | 2018-09-24 | 1 | -1/+1 |
| |/ / | | | | | | | | | | | | | | | | Preserves the meaning/type-safetiness of the stream state instead of making it an opaque u32. This makes it usable for other things outside of the service HLE context. | ||||
* | | | Merge pull request #1389 from PhiBabin/valgrind | Mat M | 2018-09-27 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | FPCR register was uninitialized at start up | ||||
| * | | | FPCR register was uninitialized at start up | Philippe Babin | 2018-09-23 | 1 | -1/+1 |
| | | | | |||||
* | | | | fsmitm_romfsbuild: std::move std::vector instances in Build() | Lioncash | 2018-09-26 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | Avoids making copies of large std::vector instances where it's trivially avoidable to do so. | ||||
* | | | | fsmitm_romfsbuild: Replace manual value aligning with Common::AlignUp() | Lioncash | 2018-09-26 | 1 | -12/+11 |
| | | | | | | | | | | | | | | | | | | | | Theres no need to do explicit bitwise arithmetic here, when we have a function that does this with a more descriptive name. | ||||
* | | | | Merge pull request #1399 from lioncash/sched | bunnei | 2018-09-26 | 4 | -14/+14 |
|\ \ \ \ | | | | | | | | | | | kernel/scheduler: Take ARM_Interface instances by reference | ||||
| * | | | | core_cpu: Make arm_interface instances a std::unique_ptr | Lioncash | 2018-09-25 | 2 | -4/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is only exposed by reference, so we can just make it a unique pointer to get rid of the need to also use reference counting for the pointer. | ||||
| * | | | | kernel/scheduler: Take ARM_Interface instance by reference in the constructor | Lioncash | 2018-09-25 | 3 | -10/+10 |
| |/ / / | | | | | | | | | | | | | | | | | It doesn't make sense to allow a scheduler to be constructed around a null pointer. | ||||
* | | | | Merge pull request #1400 from lioncash/header | bunnei | 2018-09-26 | 5 | -1/+7 |
|\ \ \ \ | | | | | | | | | | | service: Add missing headers inclusions where applicable | ||||
| * | | | | service: Add missing headers inclusions where applicable | Lioncash | 2018-09-25 | 5 | -1/+7 |
| | | | | | | | | | | | | | | | | | | | | Gets rid of a few indirect inclusions. | ||||
* | | | | | patch_manager: Invert conditionals within ApplyLayeredFS() | Lioncash | 2018-09-26 | 1 | -27/+30 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Avoids the need to nest code quite a bit by early-exiting in error cases. | ||||
* | | | | | vfs_vector: Amend initializer list order in VectorVfsFile's constructor initializer list | Lioncash | 2018-09-26 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Orders the initializer list members to be in the same order that they would be initialized in. Avoids compiler warnings. | ||||
* | | | | | fsmitm_romfsbuild: Avoid type truncation warnings | Lioncash | 2018-09-26 | 1 | -7/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Cast where explicitly necessary and in other cases we can simply modify the algorithm to accomodate larger data. | ||||
* | | | | | fsmitm_romfsbuild: Remove unnecessary constructors and initializers for RomFSBuildFileContext and RomFSBuildDirectoryContext | Lioncash | 2018-09-26 | 1 | -5/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | There's no need to duplicate in-class initializers with a constructor initializer list. std::strings also initialize to empty by default. | ||||
* | | | | | fsmitm_romfsbuild: Remove unnecessary loops in Build() | Lioncash | 2018-09-26 | 1 | -6/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The std::vector instances are already initially allocated with all entries having these values, there's no need to loop through and fill them with it again when they aren't modified. | ||||
* | | | | | fsmitm_romfsbuild: Make auto variable into a std::size_t variable within Build() | Lioncash | 2018-09-26 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | auto x = 0; auto-deduces x to be an int. This is undesirable when working with unsigned values. It also causes sign conversion warnings. Instead, we can make it a proper unsigned value with the correct width that the following expressions operate on. | ||||
* | | | | | vfs/etc: Append std:: to size_t usages | Lioncash | 2018-09-26 | 6 | -22/+23 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Given we just recently had a patch backport this from citra, let's try and keep the convention uniform. | ||||
* | | | | | vfs_concat/vfs_layered: Remove friend declarations from ConcatenatedVfsFile | Lioncash | 2018-09-26 | 8 | -61/+59 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given these are only added to the class to allow those functions to access the private constructor, it's a better approach to just make them static functions in the interface, to make the dependency explicit. | ||||
* | | | | | vfs_static: Remove template byte parameter from StaticVfsFile | Lioncash | 2018-09-25 | 4 | -42/+42 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This converts it into a regular constructor parameter. There's no need to make this a template parameter on the class when it functions perfectly well as a constructor argument. This also reduces the amount of code bloat produced by the compiler, as it doesn't need to generate the same code for multiple different instantiations of the same class type, but with a different fill value. | ||||
* | | | | | Merge pull request #1365 from DarkLordZach/lfs | bunnei | 2018-09-25 | 24 | -33/+1037 |
|\ \ \ \ \ | |/ / / / |/| | | | | file_sys: Add support for LayeredFS mods | ||||
| * | | | | fsmitm: Cleanup and modernize fsmitm port | Zach Hilman | 2018-09-24 | 21 | -377/+377 |
| | | | | | |||||
| * | | | | qt: Add UI elements for LayeredFS and related tools | Zach Hilman | 2018-09-22 | 2 | -2/+2 |
| | | | | | |||||
| * | | | | romfs: Implement CreateRomFS | Zach Hilman | 2018-09-22 | 2 | -4/+25 |
| | | | | | |||||
| * | | | | file_sys: Port Atmosphere-NX fs_mitm implementation | Zach Hilman | 2018-09-22 | 2 | -0/+474 |
| | | | | | |||||
| * | | | | filesystem: Add LayeredFS VFS directory getter | Zach Hilman | 2018-09-22 | 2 | -1/+14 |
| | | | | | |||||
| * | | | | bis_factory: Add mod directory VFS getter | Zach Hilman | 2018-09-22 | 3 | -3/+18 |
| | | | | | |||||
| * | | | | patch_manager: Add LayeredFS mods support | Zach Hilman | 2018-09-22 | 2 | -1/+44 |
| | | | | | |||||
| * | | | | vfs_concat: Rewrite and fix ConcatenatedVfsFile | Zach Hilman | 2018-09-22 | 2 | -14/+59 |
| | | | | | |||||
| * | | | | vfs_layered: Add LayeredVfsDirectory | Zach Hilman | 2018-09-22 | 2 | -0/+178 |
| | | | | | | | | | | | | | | | | | | | | Reads multiple dirs through as if a waterfall. | ||||
| * | | | | vfs_vector: Add VectorVfsFile | Zach Hilman | 2018-09-22 | 2 | -0/+75 |
| | | | | | | | | | | | | | | | | | | | | Maps a vector into the VFS interface. | ||||
| * | | | | vfs_static: Add StaticVfsFile | Zach Hilman | 2018-09-22 | 2 | -0/+78 |
| | | | | | | | | | | | | | | | | | | | | Always returns the template argument byte for all reads. Doesn't support writes. | ||||
| * | | | | vfs: Add and rewite VfsRawCopy functions | Zach Hilman | 2018-09-22 | 2 | -6/+36 |
| | | | | | |||||
| * | | | | vfs: Add GetEntries method | Zach Hilman | 2018-09-22 | 4 | -0/+32 |
| | | | | | | | | | | | | | | | | | | | | Maps name string to directory or file. | ||||
* | | | | | Merge pull request #1393 from tech4me/svc | bunnei | 2018-09-25 | 1 | -7/+7 |
|\ \ \ \ \ | | | | | | | | | | | | | svc: Updated svc names | ||||
| * | | | | | svc: Updated svc names | tech4me | 2018-09-24 | 1 | -7/+7 |
| | | | | | | |||||
* | | | | | | Implemented fatal:u properly (#1347) | David | 2018-09-24 | 3 | -4/+140 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Implemented fatal:u properly fatal:u now is properly implemented with all the ipc cmds. Error reports/Crash reports are also now implemented for fatal:u. Crash reports save to yuzu/logs/crash_reports/ The register dump is currently known as sysmodules send all zeros. If there are any non zero values for the "registers" or the unknown values, let me know! * Fatal:U fixups * Made fatal:u execution break more clear * Fatal fixups | ||||
* | | | | | | Stubbed IRS (#1349) | David | 2018-09-24 | 2 | -18/+167 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Stubbed IRS Currently we have no ideal way of implementing IRS. For the time being we should have the functions stubbed until we come up with a way to emulate IRS properly. * Added IRS to logging backend * Forward declared shared memory for irs | ||||
* | | | | | | Merge pull request #1354 from ogniK5377/ssl-version | bunnei | 2018-09-24 | 1 | -3/+3 |
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | | Corrected SSL::SetInterfaceVersion | ||||
| * | | | | | Corrected SSL::SetInterfaceVersion | David Marcec | 2018-09-19 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | Should be a single u32 | ||||
* | | | | | | Added audren:u#GetAudioRendererState | David Marcec | 2018-09-23 | 1 | -1/+8 |
| |_|_|/ / |/| | | | | |||||
* | | | | | svc: Move most process termination code to its own function within Process | Lioncash | 2018-09-21 | 3 | -32/+56 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Reduces the use of Process class members externally and keeps most code related to tearing down a process with the rest of the process code. | ||||
* | | | | | thread/process: Move TLS slot marking/freeing to the process class | Lioncash | 2018-09-21 | 4 | -68/+89 |
| |_|/ / |/| | | | | | | | | | | | | | | | | | | | Allows making several members of the process class private, it also avoids going through Core::CurrentProcess() just to retrieve the owning process. | ||||
* | | | | Added support for uncompressed NSOs (#1374) | David | 2018-09-21 | 1 | -3/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | * Added support for uncompressed NSOs * Moved compressed section check to NsoHeader | ||||
* | | | | Merge pull request #1372 from lioncash/thread | bunnei | 2018-09-21 | 3 | -5/+5 |
|\ \ \ \ | | | | | | | | | | | kernel/thread: Use owner_process when setting the page table in SetupMainThread() | ||||
| * | | | | kernel/thread: Use owner_process when setting the page table in SetupMainThread() | Lioncash | 2018-09-21 | 3 | -5/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The owning process of a thread is required to exist before the thread, so we can enforce this API-wise by using a reference. We can also avoid the reliance on the system instance by using that parameter to access the page table that needs to be set. | ||||
* | | | | | Merge pull request #1371 from lioncash/fwd-arm | bunnei | 2018-09-21 | 4 | -1/+10 |
|\ \ \ \ \ | | | | | | | | | | | | | arm_interface: Replace kernel vm_manager include with a forward declaration | ||||
| * | | | | | arm_interface: Replace kernel vm_manager include with a forward declaration | Lioncash | 2018-09-21 | 4 | -1/+10 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids an unnecessary inclusion and also uncovers three places where indirect inclusions were relied upon, which allows us to also resolve those. | ||||
* | | | | | Merge pull request #1364 from lioncash/content | bunnei | 2018-09-21 | 25 | -1/+45 |
|\ \ \ \ \ | | | | | | | | | | | | | file-sys: Default heavy-weight class destructors in the cpp file | ||||
| * | | | | | file-sys: Default heavy-weight class destructors in the cpp file | Lioncash | 2018-09-20 | 25 | -1/+45 |
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Several classes have a lot of non-trivial members within them, or don't but likely should have the destructor defaulted in the cpp file for future-proofing/being more friendly to forward declarations. Leaving the destructor unspecified allows the compiler to inline the destruction code all over the place, which is generally undesirable from a code bloat perspective. | ||||
* | | | | | Merge pull request #1368 from ogniK5377/nifm-fix | bunnei | 2018-09-21 | 1 | -1/+7 |
|\ \ \ \ \ | | | | | | | | | | | | | Added IRequest::Submit | ||||
| * | | | | | Fixed submit | David Marcec | 2018-09-20 | 1 | -2/+1 |
| | | | | | | |||||
| * | | | | | Added IRequest::Submit | David Marcec | 2018-09-20 | 1 | -1/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | This fixes updated versions of SMO. Currently unable to test as I don't have an updated version | ||||
* | | | | | | Revert GetRequestState | David Marcec | 2018-09-21 | 1 | -1/+1 |
| |_|/ / / |/| | | | | | | | | | | | | | | Even though setting this value to 3 is more correct. We break more games than we fix due to missing implementations. We should keep this as 0 for the time being | ||||
* | | | | | Merge pull request #1370 from Hedges/GDBClean | Mat M | 2018-09-20 | 1 | -1/+1 |
|\ \ \ \ \ | | | | | | | | | | | | | Correct endianness of BRK | ||||
| * | | | | | Correct endianness of BKPT | Jarek Syrylak | 2018-09-20 | 1 | -1/+1 |
| |/ / / / | |||||
* | | | | | Merge pull request #1362 from MerryMage/dynarmic | Mat M | 2018-09-20 | 1 | -0/+12 |
|\ \ \ \ \ | |/ / / / |/| | | | | externals: Update dynarmic to 171d116 | ||||
| * | | | | arm_dynarmic: Halt when BRK encountered | MerryMage | 2018-09-20 | 1 | -0/+1 |
| | | | | | |||||
| * | | | | arm_dynarmic: Support BKPT instruction | MerryMage | 2018-09-19 | 1 | -0/+11 |
| |/ / / | |||||
* | | | | Merge pull request #1358 from DarkLordZach/temp-storage | bunnei | 2018-09-20 | 1 | -4/+7 |
|\ \ \ \ | | | | | | | | | | | savedata_factory: Add TemporaryStorage SaveDataType | ||||
| * | | | | savedata_factory: Add TemporaryStorage SaveDataType | Zach Hilman | 2018-09-19 | 1 | -4/+7 |
| | |_|/ | |/| | | | | | | Seems to be used by NSO NES Emulator | ||||
* | | | | Merge pull request #1363 from lioncash/control | bunnei | 2018-09-20 | 2 | -14/+17 |
|\ \ \ \ | | | | | | | | | | | control_metadata: Move language name array definition to the cpp file | ||||
| * | | | | control_metadata: Remove unnecessary else within GetLanguageEntry() | Lioncash | 2018-09-20 | 1 | -8/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | There's no need to indent the code here, given the if case contains a return statement at the end of it. | ||||
| * | | | | control_metadata: Move language name array definition to the cpp file | Lioncash | 2018-09-20 | 2 | -6/+9 |
| | |/ / | |/| | | | | | | | | | | | | | | | | | | | | | | This was used in two different translation units (deconstructed_rom_directory and patch_manager). This means we'd be pointlessly duplicating the whole array twice due to it being defined within the header. | ||||
* | | | | Merge pull request #1361 from lioncash/nax | bunnei | 2018-09-20 | 4 | -19/+26 |
|\ \ \ \ | | | | | | | | | | | xts_archive/nax: Minor interface changes | ||||
| * | | | | xts_archive: Remove unused variables from CalculateHMAC256() | Lioncash | 2018-09-19 | 1 | -3/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These variables aren't used, which still has an impact, as std::vector cannot be optimized away by the compiler (it's constructor and destructor are both non-trivial), so this was just wasting memory. | ||||
| * | | | | xts_archive: Make AsNCA() return a std::unique_ptr instead of a std::shared_ptr | Lioncash | 2018-09-19 | 2 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | std::shared_ptr isn't strictly necessary here and is only ever used in contexts where the object doesn't depend on being shared. This also makes the interface more flexible, as it's possible to create a std::shared_ptr from a std::unique_ptr (std::shared_ptr has a constructor that accepts a std::unique_ptr), but not the other way around. | ||||
| * | | | | nax: Avoid re-parsing NAX data with GetFileType() | Lioncash | 2018-09-19 | 2 | -13/+19 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | An instance of the NAX apploader already has an existing NAX instance in memory. Calling directly into IdentifyType() directly would re-parse the whole file again into yet another NAX instance, only to toss it away again. This gets rid of unnecessary/redundant file parsing and allocations. | ||||
| * | | | | nax: Avoid unnecessary calls to AsNCA() in IdentifyType() | Lioncash | 2018-09-19 | 1 | -4/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | AsNCA() allocates an NCA instance every time it's called. In the current manner it's used, it's quite inefficient as it's making a redundant allocation. We can just amend the order of the conditionals to make it easier to just call it once. | ||||
| * | | | | xts_archive: Ensure NAX's type member is always initialized | Lioncash | 2018-09-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | Ensures that the member always has a deterministic value. | ||||
| * | | | | xts_archive: Amend initializer order of NAX's constructor | Lioncash | 2018-09-19 | 1 | -2/+2 |
| |/ / / | | | | | | | | | | | | | | | | | Orders the initializer list in the same order the members would be initialized. Avoids compiler warnings. | ||||
* | | | | Removed unneeded event clear | David Marcec | 2018-09-20 | 1 | -1/+0 |
| | | | | |||||
* | | | | Implemented NTC & IEnsureNetworkClockAvailabilityService | David Marcec | 2018-09-20 | 1 | -3/+100 |
|/ / / | | | | | | | | | | Needed because of the recent nim fixes | ||||
* | | | Reworked incorrect nifm stubs (#1355) | David | 2018-09-19 | 1 | -3/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Reworked incorrect nifm stubs Need confirmation on `CreateTemporaryNetworkProfile`, unsure which game uses it but according to reversing. It should return a uuid which we currently don't do. Any 0 client id is considered an invalid client id. GetRequestState 0 is considered invalid. * Fixups for nifm | ||||
* | | | Merge pull request #1359 from ogniK5377/nes | bunnei | 2018-09-19 | 3 | -7/+12 |
|\ \ \ | | | | | | | | | Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision | ||||
| * | | | Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision | David Marcec | 2018-09-19 | 3 | -7/+12 |
| | |/ | |/| | | | | | | | With these, `Nintendo Entertainment System - Nintendo Switch Online` loads | ||||
* | | | Removed MakeBuilder as it's not needed anymore | David Marcec | 2018-09-19 | 1 | -7/+0 |
| | | | |||||
* | | | Removed the use of rp.MakeBuilder | David Marcec | 2018-09-19 | 6 | -27/+26 |
|/ / | | | | | | | Due to keeping the code style consistent in the yuzu codebase. `rb = rp.MakeBuilder(...)` was replaced with `rb{ctx, ...}` | ||||
* | | Merge pull request #1348 from ogniK5377/GetImageSize | bunnei | 2018-09-19 | 1 | -1/+9 |
|\ \ | | | | | | | Implemented IProfile::GetImageSize | ||||
| * | | Implemented GetImageSize | David Marcec | 2018-09-18 | 1 | -1/+9 |
| | | | |||||
* | | | Merge pull request #1351 from ogniK5377/GetDefaultDisplayResolution | bunnei | 2018-09-19 | 2 | -1/+18 |
|\ \ \ | | | | | | | | | Implemented GetDefaultDisplayResolution | ||||
| * | | | Implemented GetDefaultDisplayResolution | David Marcec | 2018-09-18 | 2 | -1/+18 |
| |/ / | |||||
* | | | Merge pull request #1341 from lioncash/dependency | bunnei | 2018-09-19 | 2 | -2/+6 |
|\ \ \ | | | | | | | | | core/core_cpu: Replace exclusive monitor include with forward declaration | ||||
| * | | | core/core_cpu: Replace exclusive monitor include with forward declaration | Lioncash | 2018-09-18 | 2 | -2/+6 |
| |/ / | | | | | | | | | | | | | We don't need to include this as a dependency within the header. A regular forward declaration will suffice here. | ||||
* | | | Merge pull request #1346 from lioncash/svc | bunnei | 2018-09-19 | 1 | -37/+36 |
|\ \ \ | | | | | | | | | svc_wrap: Convert the PARAM macro into a function | ||||
| * | | | svc_wrap: Convert the PARAM macro into a function | Lioncash | 2018-09-18 | 1 | -37/+36 |
| |/ / | | | | | | | | | | | | | | | | This can just be a regular function, getting rid of the need to also explicitly undef the define at the end of the file. Given FuncReturn() was already converted into a function, it's #undef can also be removed. | ||||
* | | | Merge pull request #1350 from ogniK5377/Six-Axis-Stub | bunnei | 2018-09-19 | 1 | -4/+28 |
|\ \ \ | | | | | | | | | Stubbed ActivateConsoleSixAxisSensor & StartConsoleSixAxisSensor | ||||
| * | | | Added ActivateGesture | David Marcec | 2018-09-18 | 1 | -1/+7 |
| | | | | |||||
| * | | | Added StopSixAxisSensor | David Marcec | 2018-09-18 | 1 | -1/+7 |
| | | | | |||||
| * | | | Stubbed ActivateConsoleSixAxisSensor & StartConsoleSixAxisSensor | David Marcec | 2018-09-18 | 1 | -2/+14 |
| |/ / | |||||
* | | | Invalid default value of username in yuzu_cmd (#1334) | Philippe Babin | 2018-09-19 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fix bug where default username value for yuzu_cmd create an userprofile with uninitialize data as username * Fix format * Apply code review changes * Remove nullptr check | ||||
* | | | Merge pull request #1343 from lioncash/mutex | bunnei | 2018-09-18 | 2 | -2/+10 |
|\ \ \ | | | | | | | | | kernel/svc: Handle invalid address cases within svcArbitrateLock() and svcArbitrateUnlock() | ||||
| * | | | kernel/mutex: Replace ResultCode construction for invalid addresses with the named variant | Lioncash | 2018-09-18 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | We already have a ResultCode constant for the case of an invalid address, so we can just use it instead of re-rolling that ResultCode type. | ||||
| * | | | kernel/svc: Handle error cases for svcArbitrateLock() and svcArbitrateUnlock() | Lioncash | 2018-09-18 | 1 | -0/+8 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel does the equivalent of the following check before proceeding: if (address + 0x8000000000 < 0x7FFFE00000) { return ERR_INVALID_MEMORY_STATE; } which is essentially what our IsKernelVirtualAddress() function does. So we should also be checking for this. The kernel also checks if the given input addresses are 4-byte aligned, however our Mutex::TryAcquire() and Mutex::Release() functions already handle this, so we don't need to add code for this case. | ||||
* | | | Merge pull request #1344 from lioncash/arm | bunnei | 2018-09-18 | 7 | -99/+86 |
|\ \ \ | | | | | | | | | arm_interface: Remove ARM11-isms from the CPU interface | ||||
| * | | | arm_interface: Remove ARM11-isms from the CPU interface | Lioncash | 2018-09-18 | 7 | -99/+86 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | This modifies the CPU interface to more accurately match an AArch64-supporting CPU as opposed to an ARM11 one. Two of the methods don't even make sense to keep around for this interface, as Adv Simd is used, rather than the VFP in the primary execution state. This is essentially a modernization change that should have occurred from the get-go. | ||||
* / / | arm_dynarmic: Correct ExclusiveWrite128()'s operation | Lioncash | 2018-09-18 | 1 | -2/+2 |
|/ / | | | | | | | | | | | Previously the second half of the value being written would overwrite the first half. Thankfully this wasn't a bug that was being encountered, as the function is currently unused. | ||||
* | | Merge pull request #1312 from lioncash/fwd | bunnei | 2018-09-17 | 3 | -7/+9 |
|\ \ | | | | | | | service/vi: Replace includes with forward declarations where applicable | ||||
| * | | service/vi: Replace includes with forward declarations where applicable | Lioncash | 2018-09-13 | 3 | -7/+9 |
| | | | |||||
* | | | Merge pull request #1313 from lioncash/error | bunnei | 2018-09-17 | 1 | -1/+2 |
|\ \ \ | | | | | | | | | kernel/errors: Amend error code for ERR_NOT_FOUND | ||||
| * | | | kernel/errors: Amend error code for ERR_NOT_FOUND | Lioncash | 2018-09-13 | 1 | -1/+2 |
| |/ / | | | | | | | | | | | | | This is the value returned by the kernel for svcConnectToNamedPort() if the named port cannot be found. | ||||
* | | | Merge pull request #1318 from lioncash/errors-sm | bunnei | 2018-09-17 | 2 | -8/+6 |
|\ \ \ | | | | | | | | | services/sm: Amend error code constants | ||||
| * | | | services/sm: Amend error code constants | Lioncash | 2018-09-14 | 2 | -8/+6 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | Courtesy of @ogniK5377. This also moves them into the cpp file and limits the visibility to where they're directly used. It also gets rid of unused or duplicate error codes. | ||||
* | | | Merge pull request #1315 from lioncash/size | bunnei | 2018-09-17 | 2 | -19/+74 |
|\ \ \ | | | | | | | | | kernel/svc: Handle a few error cases within memory-related functions | ||||
| * | | | kernel/svc: Sanitize creation of shared memory via svcCreateSharedMemory() | Lioncash | 2018-09-14 | 1 | -2/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel caps the size limit of shared memory to 8589930496 bytes (or (1GB - 512 bytes) * 8), so approximately 8GB, where every GB has a 512 byte sector taken off of it. It also ensures the shared memory is created with either read or read/write permissions for both permission types passed in, allowing the remote permissions to also be set as "don't care". | ||||
| * | | | kernel/svc: Sanitize addresses, permissions, and sizes within svcMapSharedMemory() and svcUnmapSharedMemory() | Lioncash | 2018-09-14 | 1 | -17/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Part of the checking done by the kernel is to check if the given address and size are 4KB aligned, as well as checking if the size isn't zero. It also only allows mapping shared memory as readable or read/write, but nothing else, and so we shouldn't allow mapping as anything else either. | ||||
| * | | | kernel/svc: Sanitize addresses and sizes within svcMapMemory() and svcUnmapMemory() | Lioncash | 2018-09-14 | 1 | -0/+23 |
| | | | | | | | | | | | | | | | | | | | | The kernel checks if the addresses and given size is 4KB aligned before continuing onwards to map the memory. | ||||
| * | | | kernel/svc: Sanitize heap sizes within svcSetHeapSize() | Lioncash | 2018-09-14 | 2 | -0/+8 |
| |/ / | | | | | | | | | | | | | The kernel checks if the given size is a multiple of 2MB and <= to 4GB before going ahead and attempting to allocate that much memory. | ||||
* | | | Merge pull request #1328 from FearlessTobi/port-4192 | bunnei | 2018-09-17 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | Port #4192 from Citra: "svc: change unknown to thread in CreateThread" | ||||
| * | | | Port # #4192 from Citra: "svc: change unknown to thread in CreateThread" | Valentin Vanelslande | 2018-09-15 | 1 | -1/+1 |
| | |/ | |/| | |||||
* / | | Port #4182 from Citra: "Prefix all size_t with std::" | fearlessTobi | 2018-09-15 | 79 | -395/+409 |
|/ / | |||||
* | | Merge pull request #1310 from lioncash/kernel-ns | bunnei | 2018-09-14 | 4 | -9/+10 |
|\ \ | | | | | | | kernel/thread: Include thread-related enums within the kernel namespace | ||||
| * | | kernel/thread: Include thread-related enums within the kernel namespace | Lioncash | 2018-09-13 | 4 | -9/+10 |
| |/ | | | | | | | | | | | Previously, these were sitting outside of the Kernel namespace, which doesn't really make sense, given they're related to the Thread class which is within the Kernel namespace. | ||||
* | | Merge pull request #1309 from lioncash/nested | bunnei | 2018-09-14 | 3 | -12/+6 |
|\ \ | | | | | | | service: Use nested namespace specifiers where applicable | ||||
| * | | service: Use nested namespace specifiers where applicable | Lioncash | 2018-09-13 | 3 | -12/+6 |
| |/ | | | | | | | | | | | There were a few places where nested namespace specifiers weren't being used where they could be within the service code. This amends that to make the namespacing a tiny bit more compact. | ||||
* | | Merge pull request #1307 from lioncash/pl | bunnei | 2018-09-14 | 1 | -2/+4 |
|\ \ | |/ |/| | services/pl_u: Add missing Korean font to the fallback case for shared fonts | ||||
| * | services/pl_u: Add missing Korean font to the fallback case for shared fonts | Lioncash | 2018-09-13 | 1 | -2/+4 |
| | | | | | | | | Previously this wasn't using the Korean font at all. | ||||
* | | ipc: minor fix | Valentin Vanelslande | 2018-09-13 | 1 | -1/+1 |
|/ | |||||
* | Merge pull request #1163 from FearlessTobi/add-audio-stretching | bunnei | 2018-09-13 | 2 | -0/+4 |
|\ | | | | | audio_core: Add audio stretching support | ||||
| * | Add audio stretching support | fearlessTobi | 2018-09-08 | 2 | -0/+4 |
| | | |||||
* | | Merge pull request #1297 from lioncash/pl | bunnei | 2018-09-12 | 2 | -66/+88 |
|\ \ | | | | | | | pl_u: Eliminate mutable file-scope state | ||||
| * | | pl_u: Eliminate mutable file-scope state | Lioncash | 2018-09-12 | 2 | -66/+88 |
| | | | | | | | | | | | | | | | Converts the PL_U internals to use the PImpl idiom and makes the state part of the Impl struct, eliminating mutable global/file state. | ||||
* | | | Merge pull request #1303 from lioncash/error | bunnei | 2018-09-12 | 3 | -9/+11 |
|\ \ \ | | | | | | | | | kernel/errors: Amend invalid thread priority and invalid processor ID error codes | ||||
| * | | | svc: Return ERR_INVALID_PROCESSOR_ID in CreateThread() if an invalid processor ID is given | Lioncash | 2018-09-12 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | This is what the kernel does for an out-of-range processor ID. | ||||
| * | | | kernel/errors: Correct error codes for invalid thread priority and invalid processor ID | Lioncash | 2018-09-12 | 3 | -7/+9 |
| | | | | |||||
* | | | | svc: Do nothing if svcOutputDebugString() is given a length of zero | Lioncash | 2018-09-12 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | While unlikely, it does avoid constructing a std::string and unnecessarily calling into the memory code if a game or executable decides to be really silly about their logging. | ||||
* | | | | svc: Correct parameter type for OutputDebugString() | Lioncash | 2018-09-12 | 2 | -3/+3 |
|/ / / | | | | | | | | | | This should be a u64 to represent size. | ||||
* | | | Merge pull request #1296 from lioncash/prepo | bunnei | 2018-09-12 | 2 | -39/+40 |
|\ \ \ | | | | | | | | | service/prepo: Move class into the cpp file | ||||
| * | | | service/prepo: Move class into the cpp file | Lioncash | 2018-09-12 | 2 | -39/+40 |
| |/ / | | | | | | | | | | | | | | | | This doesn't need to be exposed within the header and be kept in the translation unit, eliminating the need to include anything within the header. | ||||
* / / | service/audio: Replace includes with forward declarations where applicable | Lioncash | 2018-09-12 | 7 | -17/+34 |
|/ / | | | | | | | | | A few headers were including other headers when a forward declaration can be used instead, allowing the include to be moved to the cpp file. | ||||
* | | Merge pull request #1291 from lioncash/default | bunnei | 2018-09-11 | 148 | -45/+291 |
|\ \ | | | | | | | hle/service: Default constructors and destructors in the cpp file where applicable | ||||
| * | | hle/service: Default constructors and destructors in the cpp file where applicable | Lioncash | 2018-09-11 | 148 | -45/+291 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When a destructor isn't defaulted into a cpp file, it can cause the use of forward declarations to seemingly fail to compile for non-obvious reasons. It also allows inlining of the construction/destruction logic all over the place where a constructor or destructor is invoked, which can lead to code bloat. This isn't so much a worry here, given the services won't be created and destroyed frequently. The cause of the above mentioned non-obvious errors can be demonstrated as follows: ------- Demonstrative example, if you know how the described error happens, skip forwards ------- Assume we have the following in the header, which we'll call "thing.h": \#include <memory> // Forward declaration. For example purposes, assume the definition // of Object is in some header named "object.h" class Object; class Thing { public: // assume no constructors or destructors are specified here, // or the constructors/destructors are defined as: // // Thing() = default; // ~Thing() = default; // // ... Some interface member functions would be defined here private: std::shared_ptr<Object> obj; }; If this header is included in a cpp file, (which we'll call "main.cpp"), this will result in a compilation error, because even though no destructor is specified, the destructor will still need to be generated by the compiler because std::shared_ptr's destructor is *not* trivial (in other words, it does something other than nothing), as std::shared_ptr's destructor needs to do two things: 1. Decrement the shared reference count of the object being pointed to, and if the reference count decrements to zero, 2. Free the Object instance's memory (aka deallocate the memory it's pointing to). And so the compiler generates the code for the destructor doing this inside main.cpp. Now, keep in mind, the Object forward declaration is not a complete type. All it does is tell the compiler "a type named Object exists" and allows us to use the name in certain situations to avoid a header dependency. So the compiler needs to generate destruction code for Object, but the compiler doesn't know *how* to destruct it. A forward declaration doesn't tell the compiler anything about Object's constructor or destructor. So, the compiler will issue an error in this case because it's undefined behavior to try and deallocate (or construct) an incomplete type and std::shared_ptr and std::unique_ptr make sure this isn't the case internally. Now, if we had defaulted the destructor in "thing.cpp", where we also include "object.h", this would never be an issue, as the destructor would only have its code generated in one place, and it would be in a place where the full class definition of Object would be visible to the compiler. ---------------------- End example ---------------------------- Given these service classes are more than certainly going to change in the future, this defaults the constructors and destructors into the relevant cpp files to make the construction and destruction of all of the services consistent and unlikely to run into cases where forward declarations are indirectly causing compilation errors. It also has the plus of avoiding the need to rebuild several services if destruction logic changes, since it would only be necessary to recompile the single cpp file. | ||||
* | | | externals: Place font data within cpp files | Lioncash | 2018-09-11 | 1 | -6/+6 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This places the font data within cpp files, which mitigates the possibility of the font data being duplicated within the binary if it's referred to in more than one translation unit in the future. It also stores the data within a std::array, which is more flexible when it comes to operating with the standard library. Furthermore, it makes the data arrays const. This is what we want, as it allows the compiler to store the data within the read-only segment. As it is, having several large sections of mutable data like this just leaves spots in memory that we can accidentally write to (via accidental overruns, what have you) and actually have it work. This ensures the font data remains the same no matter what. | ||||
* | | Use open-source shared fonts if no dumped file is available (#1269) | Tobias | 2018-09-11 | 2 | -2/+26 |
| | | | | | | | | | | | | * Add open-source shared fonts * Address review comments | ||||
* | | video_core: Move command buffer loop. | Markus Wick | 2018-09-10 | 2 | -31/+12 |
| | | | | | | | | This moves the hot loop into video_core. This refactoring shall reduce the CPU overhead of calling ProcessCommandList. | ||||
* | | Merge pull request #1276 from FearlessTobi/fix-stupid-stub | bunnei | 2018-09-10 | 2 | -4/+6 |
|\ \ | | | | | | | hid: Implement ReloadInputDevices | ||||
| * | | hid: Implement ReloadInputDevices | fearlessTobi | 2018-09-09 | 2 | -4/+6 |
| |/ | |||||
* / | service: Remove unused g_kernel_named_ports variable | Lioncash | 2018-09-10 | 1 | -2/+0 |
|/ | | | | | With the named port functionality all migrated over to the kernel, there's no need to keep this around anymore. | ||||
* | core: Migrate current_process pointer to the kernel | Lioncash | 2018-09-07 | 4 | -5/+34 |
| | | | | | | | | | | Given we now have the kernel as a class, it doesn't make sense to keep the current process pointer within the System class, as processes are related to the kernel. This also gets rid of a subtle case where memory wouldn't be freed on core shutdown, as the current_process pointer would never be reset, causing the pointed to contents to continue to live. | ||||
* | Merge pull request #1250 from lioncash/file-sys | bunnei | 2018-09-07 | 4 | -4/+16 |
|\ | | | | | file_sys/{nca_patch, patch_manager}: Amend unnecessary/missing includes. | ||||
| * | file_sys/nca_patch: Amend constructor initializer list order | Lioncash | 2018-09-06 | 1 | -2/+2 |
| | | | | | | | | | | | | Orders the elements in the initializer list in the order they're specified in the class. This prevents compiler warnings about initialization order. | ||||
| * | file_sys/nca_patch: Remove unnecessary includes | Lioncash | 2018-09-06 | 2 | -2/+9 |
| | | | | | | | | | | romfs.h doesn't need to be included in the header, the only real dependency here is common's swap.h that needs to be included. | ||||
| * | file_sys/patch_manager: Add missing includes | Lioncash | 2018-09-06 | 2 | -0/+5 |
| | | | | | | | | These includes were previously being satisfied indirectly. | ||||
* | | core/core: Remove unnecessary sm/controller include | Lioncash | 2018-09-06 | 5 | -2/+5 |
|/ | | | | | | | | | | The only reason this include was necessary, was because the constructor wasn't defaulted in the cpp file and the compiler would inline it wherever it was used. However, given Controller is forward declared, all those inlined constructors would see an incomplete type, causing a compilation failure. So, we just place the constructor in the cpp file, where it can see the complete type definition, allowing us to remove this include. | ||||
* | Merge pull request #1242 from lioncash/file-sys | bunnei | 2018-09-06 | 2 | -8/+17 |
|\ | | | | | file_sys/submission_package: Replace includes with forward declarations where applicable | ||||
| * | file_sys/submission_package: Correct constructor initialization list order | Lioncash | 2018-09-05 | 1 | -2/+2 |
| | | | | | | | | | | Orders the elements in the sequence to match the order in which they'll actually be initialized in. | ||||
| * | file_sys/submission_package: Replace includes with forward declarations where applicable | Lioncash | 2018-09-05 | 2 | -6/+15 |
| | | |||||
* | | bktr: Fix bucket overlap error | Zach Hilman | 2018-09-04 | 7 | -9/+9 |
| | | |||||
* | | drd: Parse title ID from program metadata | Zach Hilman | 2018-09-04 | 2 | -4/+29 |
| | | |||||
* | | patch_manager: Centralize Control-type NCA parsing | Zach Hilman | 2018-09-04 | 4 | -55/+74 |
| | | |||||
* | | nsp: Fix error masking issue with XCI files | Zach Hilman | 2018-09-04 | 3 | -6/+13 |
| | | | | | | | | Now display correct error instead of catch-all MissingProgramNCA | ||||
* | | game_list: Fix version display on non-NAND titles | Zach Hilman | 2018-09-04 | 3 | -8/+33 |
| | | |||||
* | | bktr: Add logging on successful patch | Zach Hilman | 2018-09-04 | 3 | -7/+24 |
| | | |||||
* | | bktr: Implement IVFC offset shifting | Zach Hilman | 2018-09-04 | 8 | -8/+36 |
| | | | | | | | | Fixes base game read errors | ||||
* | | bktr: Fix missing includes and optimize style | Zach Hilman | 2018-09-04 | 11 | -101/+107 |
| | | |||||
* | | loader: Add BKTR-specific error messages and codes | Zach Hilman | 2018-09-04 | 3 | -7/+28 |
| | | |||||
* | | loader: Ignore patches on NRO and DRD | Zach Hilman | 2018-09-04 | 4 | -0/+11 |
| | | |||||
* | | patch_manager: Add usages of patches to ExeFS | Zach Hilman | 2018-09-04 | 5 | -9/+41 |
| | | |||||
* | | file_sys: Add class to manage game patches | Zach Hilman | 2018-09-04 | 2 | -0/+132 |
| | | | | | | | | Right now only includes Updates, but should eventually contain all of the other patches we need. | ||||
* | | file_sys: Add BKTR patching mechanism | Zach Hilman | 2018-09-04 | 2 | -0/+352 |
| | | |||||
* | | content_archive: Add BKTR header parsing to NCA | Zach Hilman | 2018-09-04 | 2 | -19/+160 |
| | | |||||
* | | registration: Add RegisteredCacheUnion | Zach Hilman | 2018-09-04 | 4 | -0/+164 |
| | | | | | | | | Aggregates multiple caches into one interface | ||||
* | | game_list: Use RegisteredCacheUnion for installed | Zach Hilman | 2018-09-04 | 1 | -1/+1 |
| | | | | | | | | Reduces code | ||||
* | | aes_util: Fix error involving reads of less than 0x10 | Zach Hilman | 2018-09-04 | 1 | -0/+14 |
|/ | | | | Issues with block size are fixed by making all reads minimum length of 0x10 | ||||
* | main: Only show DRD deprecation warning once | Zach Hilman | 2018-09-04 | 6 | -3/+6 |
| | |||||
* | control_metadata: Use alternate language names if AmericanEnglish isn't available | Zach Hilman | 2018-09-04 | 2 | -4/+17 |
| | |||||
* | card_image: Add program title ID getter | Zach Hilman | 2018-09-04 | 2 | -0/+6 |
| | |||||
* | nsp: Comply with style and performance guidelines | Zach Hilman | 2018-09-04 | 7 | -29/+48 |
| | |||||
* | qt: Add UI support for NSP files | Zach Hilman | 2018-09-04 | 1 | -0/+4 |
| | |||||
* | registration: Add support for installing NSP files | Zach Hilman | 2018-09-04 | 2 | -10/+16 |
| | |||||
* | loader: Add AppLoader for NSP files | Zach Hilman | 2018-09-04 | 2 | -0/+182 |
| | |||||
* | card_image: Parse XCI secure partition with NSP | Zach Hilman | 2018-09-04 | 4 | -11/+38 |
| | | | | Eliminated duplicate code and adds support for Rev1+ carts | ||||
* | file_sys: Add Nintendo Submission Package (NSP) | Zach Hilman | 2018-09-04 | 2 | -0/+296 |
| | |||||
* | drd: Load title ID from program metadata | Zach Hilman | 2018-09-04 | 1 | -3/+1 |
| | | | | Previously only loaded from control metadata | ||||
* | loader: Add NSP file type and NSP-specific errors | Zach Hilman | 2018-09-04 | 2 | -2/+14 |
| | |||||
* | key_manager: Avoid autogeneration if key exists | Zach Hilman | 2018-09-04 | 1 | -3/+13 |
| | |||||
* | Merge pull request #1237 from degasus/optimizations | bunnei | 2018-09-04 | 2 | -3/+3 |
|\ | | | | | Optimizations | ||||
| * | core: Use a raw pointer in GetGPUDebugContext. | Markus Wick | 2018-09-04 | 2 | -3/+3 |
| | | | | | | | | This helper is called very often. The memory ownership shall not be transfered, so just return the raw pointer. | ||||
* | | Merge pull request #1223 from DarkLordZach/custom-nand-sd-dirs | bunnei | 2018-09-04 | 1 | -0/+2 |
|\ \ | | | | | | | file_sys: Allow for custom NAND/SD directories | ||||
| * | | settings: Save and load NAND/SD dirs from config | Zach Hilman | 2018-09-04 | 1 | -0/+2 |
| | | | |||||
* | | | Merge pull request #1235 from lioncash/forward-decl | bunnei | 2018-09-04 | 20 | -26/+62 |
|\ \ \ | | | | | | | | | file_sys: Replace includes with forward declarations where applicable | ||||
| * | | | file_sys: Replace includes with forward declarations where applicable | Lioncash | 2018-09-04 | 20 | -26/+62 |
| | |/ | |/| | | | | | | | | | | Cuts down on include dependencies, resulting in less files that need to be rebuilt when certain things are changed. | ||||
* | | | Merge pull request #1236 from degasus/microprofile | bunnei | 2018-09-04 | 2 | -2/+6 |
|\ \ \ | | | | | | | | | Update microprofile scopes. | ||||
| * | | | Update microprofile scopes. | Markus Wick | 2018-09-04 | 2 | -2/+6 |
| |/ / | | | | | | | | | | | | | | | | Blame the subsystems which deserve the blame :) The updated list is not complete, just the ones I've spotted on random sampling the stack trace. | ||||
* | | | Merge pull request #1230 from lioncash/ssl | bunnei | 2018-09-04 | 2 | -37/+39 |
|\ \ \ | |/ / |/| | | ssl: Move SSL class to cpp file | ||||
| * | | ssl: Move SSL class to cpp file | Lioncash | 2018-09-02 | 2 | -37/+39 |
| | | | | | | | | | | | | | | | | | | This isn't required to be visible to anything outside of the main source file, and will eliminate needing to rebuild anything else including the header if the SSL class needs to be changed in the future. | ||||
* | | | Merge pull request #1231 from lioncash/global | bunnei | 2018-09-04 | 5 | -19/+51 |
|\ \ \ | | | | | | | | | service: Migrate global named port map to the KernelCore class | ||||
| * | | | service: Migrate global named port map to the KernelCore class | Lioncash | 2018-09-02 | 5 | -19/+51 |
| | |/ | |/| | | | | | | | | | | | | | Now that we have a class representing the kernel in some capacity, we now have a place to put the named port map, so we move it over and get rid of another piece of global state within the core. | ||||
* / | | vfs_real: Forward declare IOFile | Lioncash | 2018-09-02 | 7 | -14/+31 |
|/ / | | | | | | | | | | | Eliminates the need to rebuild some source files if the file_util header ever changes. This also uncovered some indirect inclusions, which have also been fixed. | ||||
* | | Merge pull request #1213 from DarkLordZach/octopath-fs | bunnei | 2018-09-02 | 2 | -2/+30 |
|\ \ | | | | | | | filesystem/maxwell_3d: Various changes to boot Project Octopath Traveller | ||||
| * | | filesystem: Implement OpenReadOnlySaveDataFilesystem | Zach Hilman | 2018-09-01 | 2 | -1/+7 |
| | | | |||||
| * | | filesystem: Add OpenFileSystemWithPatch | Zach Hilman | 2018-09-01 | 2 | -1/+23 |
| |/ | |||||
* / | filesystem: Move dir retrieval after path checking in DeleteFile() | Lioncash | 2018-09-02 | 1 | -2/+5 |
|/ | | | | | We don't need to do the lookup if the path is considered empty currently. | ||||
* | core/core: Replace includes with forward declarations where applicable | Lioncash | 2018-08-31 | 18 | -43/+85 |
| | | | | | | | | | | | The follow-up to e2457418dae19b889b2ad85255bb95d4cd0e4bff, which replaces most of the includes in the core header with forward declarations. This makes it so that if any of the headers the core header was previously including change, then no one will need to rebuild the bulk of the core, due to core.h being quite a prevalent inclusion. This should make turnaround for changes much faster for developers. | ||||
* | gl_renderer: Cache textures, framebuffers, and shaders based on CPU address. | bunnei | 2018-08-31 | 3 | -38/+17 |
| | |||||
* | core: Make the main System class use the PImpl idiom | Lioncash | 2018-08-31 | 4 | -276/+383 |
| | | | | | | | | | | | | | core.h is kind of a massive header in terms what it includes within itself. It includes VFS utilities, kernel headers, file_sys header, ARM-related headers, etc. This means that changing anything in the headers included by core.h essentially requires you to rebuild almost all of core. Instead, we can modify the System class to use the PImpl idiom, which allows us to move all of those headers to the cpp file and forward declare the bulk of the types that would otherwise be included, reducing compile times. This change specifically only performs the PImpl portion. | ||||
* | kernel: Eliminate kernel global state | Lioncash | 2018-08-29 | 51 | -440/+665 |
| | | | | | | | | | | | | | | | | | | | | | | As means to pave the way for getting rid of global state within core, This eliminates kernel global state by removing all globals. Instead this introduces a KernelCore class which acts as a kernel instance. This instance lives in the System class, which keeps its lifetime contained to the lifetime of the System class. This also forces the kernel types to actually interact with the main kernel instance itself instead of having transient kernel state placed all over several translation units, keeping everything together. It also has a nice consequence of making dependencies much more explicit. This also makes our initialization a tad bit more correct. Previously we were creating a kernel process before the actual kernel was initialized, which doesn't really make much sense. The KernelCore class itself follows the PImpl idiom, which allows keeping all the implementation details sealed away from everything else, which forces the use of the exposed API and allows us to avoid any unnecessary inclusions within the main kernel header. | ||||
* | Merge pull request #1193 from lioncash/priv | bunnei | 2018-08-28 | 2 | -8/+8 |
|\ | | | | | gpu: Make memory_manager private | ||||
| * | gpu: Make memory_manager private | Lioncash | 2018-08-28 | 2 | -8/+8 |
| | | | | | | | | | | | | | | | | | | | | Makes the class interface consistent and provides accessors for obtaining a reference to the memory manager instance. Given we also return references, this makes our more flimsy uses of const apparent, given const doesn't propagate through pointers in the way one would typically expect. This makes our mutable state more apparent in some places. | ||||
* | | hle/result: Make ResultVal's move constructor as noexcept | Lioncash | 2018-08-28 | 1 | -1/+1 |
|/ | | | | | | | | | | | | | | | | | | | | | | | Many containers within the standard library provide different behaviors based on whether or not a move constructor/assignment operator can be guaranteed not to throw or not. Notably, implementations will generally use std::move_if_noexcept (or an internal implementation of it) to provide strong exception guarantees. If a move constructor potentially throws (in other words, is not noexcept), then certain behaviors will create copies, rather than moving the values. For example, consider std::vector. When a std::vector calls resize(), there are two ways the elements can be relocated to the new block of memory (if a reallocation happens), by copy, or by moving the existing elements into the new block of memory. If a type does not have a guarantee that it will not throw in the move constructor, a copy will happen. However, if it can be guaranteed that the move constructor won't throw, then the elements will be moved. This just allows ResultVal to be moved instead of copied all the time if ever used in conjunction with containers for whatever reason. | ||||
* | Merge pull request #1177 from lioncash/err | bunnei | 2018-08-28 | 4 | -12/+15 |
|\ | | | | | kernel/error: Amend several error codes | ||||
| * | kernel/error: Amend error code for ERR_MAX_CONNECTIONS_REACHED | Lioncash | 2018-08-25 | 1 | -2/+4 |
| | | | | | | | | | | | | We can make this error code an alias of the resource limit exceeded error code, allowing us to get rid of the lingering 3DS error code of the same type. | ||||
| * | kernel/error: Amend error code for ERR_PORT_NAME_TOO_LONG | Lioncash | 2018-08-25 | 1 | -2/+1 |
| | | | | | | | | | | We can treat this as an alias of TooLarge for documentation purposes. This also lets us get rid of another lingering 3DS-related error code. | ||||
| * | kernel/error: Add error code for the handle table being full | Lioncash | 2018-08-25 | 3 | -4/+4 |
| | | | | | | | | | | This replaces the lingering 3DS constant with the proper one, and utilizes it within HandleTable's Create() member function. | ||||
| * | kernel/error: Add error code for invalid memory permissions | Lioncash | 2018-08-25 | 2 | -3/+4 |
| | | |||||
| * | kernel/error: Correct kernel error code for invalid combination | Lioncash | 2018-08-25 | 1 | -1/+2 |
| | | |||||
* | | Merge pull request #1188 from lioncash/unused | bunnei | 2018-08-28 | 1 | -1/+0 |
|\ \ | | | | | | | vfs_real: Remove unused variable in CreateDirectoryRelative() | ||||
| * | | vfs_real: Remove unused variable in CreateDirectoryRelative() | Lioncash | 2018-08-27 | 1 | -1/+0 |
| |/ | |||||
* | | Merge pull request #1175 from lioncash/ns | bunnei | 2018-08-28 | 13 | -12/+42 |
|\ \ | | | | | | | core: Namespace all code in the arm subdirectory under the Core namespace | ||||
| * | | core: Namespace all code in the arm subdirectory under the Core namespace | Lioncash | 2018-08-25 | 13 | -12/+42 |
| | | | | | | | | | | | | Gets all of these types and interfaces out of the global namespace. | ||||
* | | | Merge pull request #1187 from lioncash/shadow | bunnei | 2018-08-28 | 1 | -3/+3 |
|\ \ \ | | | | | | | | | registered_cache: Get rid of variable shadowing in ProcessFiles() | ||||
| * | | | registered_cache: Get rid of variable shadowing in ProcessFiles() | Lioncash | 2018-08-27 | 1 | -3/+3 |
| | |/ | |/| | | | | | | | Prevents compiler warnings. | ||||
* | | | Merge pull request #1176 from lioncash/info | bunnei | 2018-08-27 | 1 | -2/+1 |
|\ \ \ | | | | | | | | | svc: Return process title ID if queried in GetInfo() | ||||
| * | | | svc: Return process title ID if queried in GetInfo() | Lioncash | 2018-08-25 | 1 | -2/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | We already have the variable itself set up to perform this task, so we can just return its value from the currently executing process instead of always stubbing it to zero. | ||||
* | | | | Merge pull request #1174 from lioncash/debug | bunnei | 2018-08-27 | 1 | -0/+1 |
|\ \ \ \ | | | | | | | | | | | debug_utils: Minor individual interface changes | ||||
| * | | | | debug_utils: Remove unused includes | Lioncash | 2018-08-25 | 1 | -0/+1 |
| | |_|/ | |/| | | | | | | | | | | | | | | Quite a bit of these aren't necessary directly within the debug_utils header and can be removed or included where actually necessary. | ||||
* | | | | Merge pull request #1162 from ogniK5377/ttf-plu | bunnei | 2018-08-27 | 1 | -5/+51 |
|\ \ \ \ | | | | | | | | | | | PL:U Added SharedFonts loading via TTF | ||||
| * | | | | Addressed plu TTF changes | David Marcec | 2018-08-23 | 1 | -6/+7 |
| | | | | | |||||
| * | | | | Added SharedFonts loading via TTF | David Marcec | 2018-08-23 | 1 | -5/+50 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | By having the following TTF files in your yuzu sysdata directory. You can load sharedfonts via TTF files. FontStandard.ttf FontChineseSimplified.ttf FontExtendedChineseSimplified.ttf FontChineseTraditional.ttf FontKorean.ttf FontNintendoExtended.ttf FontNintendoExtended2.ttf | ||||
* | | | | | Merge pull request #1168 from lioncash/header | bunnei | 2018-08-27 | 2 | -1/+4 |
|\ \ \ \ \ | | | | | | | | | | | | | hid: Move core include to cpp file | ||||
| * | | | | | hid: Move core include to cpp file | Lioncash | 2018-08-24 | 2 | -1/+4 |
| | |/ / / | |/| | | | | | | | | | | | | | | | | | | This isn't required to be in the header. Instead, directly include what this header needs and move it to the cpp file where it belongs. | ||||
* | | | | | Merge pull request #1171 from lioncash/true | bunnei | 2018-08-27 | 1 | -7/+4 |
|\ \ \ \ \ | | | | | | | | | | | | | core: Remove always true conditionals in Load() | ||||
| * | | | | | core: Remove always true conditionals in Load() | Lioncash | 2018-08-24 | 1 | -7/+4 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | These conditions are always true, since the outer conditional already checks for these conditions. | ||||
* | | | / | set: Fixed GetAvailableLanguageCodes() to follow the max_entries | tech4me | 2018-08-26 | 2 | -8/+45 |
| |_|_|/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rightnow, in games use GetAvailableLanguageCodes(), there is a WriteBuffer() with size larger than the buffer_size. (Core Critical core\hle\kernel\hle_ipc.cpp:WriteBuffer:296: size (0000000000000088) is greater than buffer_size (0000000000000078)) 0x88 = 17(languages) * 8 0x78 = 15(languages) * 8 GetAvailableLanguageCodes() can only support 15 languages. After firmware 4.0.0 there are 17 supported language instead of 15, to enable this GetAvailableLanguageCodes2() need to be used. So GetAvailableLanguageCodes() will be caped at 15 languages. Reference: http://switchbrew.org/index.php/Settings_services | ||||
* | | | | Merge pull request #1166 from lioncash/typo | Sebastian Valle | 2018-08-25 | 1 | -1/+1 |
|\ \ \ \ | |_|_|/ |/| | | | filesystem: Fix typo in log message | ||||
| * | | | filesystem: Fix typo in log message | Lioncash | 2018-08-24 | 1 | -1/+1 |
| |/ / | |||||
* | | | Merge pull request #1094 from DarkLordZach/nax0 | Mat M | 2018-08-25 | 27 | -81/+806 |
|\ \ \ | | | | | | | | | file_sys: Add support for NAX archives | ||||
| * | | | file_sys/crypto: Fix missing/unnecessary includes | Zach Hilman | 2018-08-25 | 9 | -5/+10 |
| | | | | |||||
| * | | | xci: Ignore NCA files with updates in secure | Zach Hilman | 2018-08-24 | 1 | -0/+3 |
| | | | | |||||
| * | | | content_archive: Add update title detection | Zach Hilman | 2018-08-24 | 2 | -0/+11 |
| | | | | | | | | | | | | | | | | This is needed because the title IDs of update NCAs will not use the update title ID. The only sure way to tell is to look for a partition with BKTR crypto. | ||||
| * | | | key_manager: Eliminate indexed for loop | Zach Hilman | 2018-08-23 | 1 | -6/+13 |
| | | | | |||||
| * | | | key_manager: Create keys dir if it dosen't exist | Zach Hilman | 2018-08-23 | 2 | -0/+2 |
| | | | | | | | | | | | | | | | | On call to WriteKeyToFile, so that the autogenerated file can be written. | ||||
| * | | | file_sys: Cut down on includes and copies | Zach Hilman | 2018-08-23 | 7 | -19/+30 |
| | | | | |||||
| * | | | crypto: Eliminate magic constants | Zach Hilman | 2018-08-23 | 4 | -32/+38 |
| | | | | |||||
| * | | | key_manager: Add support for autogenerated keys | Zach Hilman | 2018-08-23 | 2 | -3/+45 |
| | | | | | | | | | | | | | | | | Stored in a separate file than manual keys. | ||||
| * | | | key_manager: Add support for KEK and SD seed derivation | Zach Hilman | 2018-08-23 | 2 | -5/+135 |
| | | | | |||||
| * | | | key_manager: Switch to boost flat_map for keys | Zach Hilman | 2018-08-23 | 2 | -32/+14 |
| | | | | | | | | | | | | | | | | Should make key gets marginally faster. | ||||
| * | | | file_sys: Implement NAX containers | Zach Hilman | 2018-08-23 | 3 | -0/+238 |
| | | | | |||||
| * | | | registration: Add GetEntryUnparsed methods | Zach Hilman | 2018-08-23 | 2 | -0/+15 |
| | | | | | | | | | | | | | | | | Returns the file before calling parser on it. | ||||
| * | | | sdmc_factory: Add SDMC RegisteredCache getter | Zach Hilman | 2018-08-23 | 2 | -1/+14 |
| | | | | |||||
| * | | | vfs: Add GetOrCreateDirectoryRelative method | Zach Hilman | 2018-08-23 | 3 | -9/+13 |
| | | | | |||||
| * | | | filesystem: Add CreateFactories methods to fs | Zach Hilman | 2018-08-23 | 2 | -8/+11 |
| | | | | | | | | | | | | | | | | Allows frontend to create registration caches for use before a game has booted. | ||||
| * | | | filesystem: Add logging to registration getters | Zach Hilman | 2018-08-23 | 1 | -4/+25 |
| | | | | |||||
| * | | | loader: Add new NAX-specific errors and messages | Zach Hilman | 2018-08-23 | 2 | -1/+27 |
| | | | | |||||
| * | | | nax: Add AppLoader_NAX and update loader to support it | Zach Hilman | 2018-08-23 | 4 | -2/+121 |
| | | | | |||||
| * | | | xts_encryption_layer: Implement XTSEncryptionLayer | Zach Hilman | 2018-08-23 | 3 | -1/+81 |
| | | | | |||||
| * | | | aes_util: Make XTSTranscode stricter about sizes | Zach Hilman | 2018-08-23 | 1 | -5/+2 |
| | | | | | | | | | | | | | | | | XTS with Nintendo Tweak will fail mysteriously if the sector size is not 0x4000. Upgrade the critical log to an assert to prevent undefined behavior. | ||||
| * | | | ctr_encryption_layer: Fix bug when transcoding small data | Zach Hilman | 2018-08-23 | 1 | -5/+3 |
| | | | | | | | | | | | | | | | | Fixes a bug where data lengths of less than size 0x10 will fail or have misleading return values. | ||||
| * | | | xci: Fix error masking issue | Zach Hilman | 2018-08-23 | 3 | -5/+17 |
| | |/ | |/| | | | | | | | Prevents NCA-related errors from being masked into MissingProgramNCA or MissingKeyFile | ||||
* | | | Merge pull request #1065 from DarkLordZach/window-title | Zach Hilman | 2018-08-24 | 1 | -0/+7 |
|\ \ \ | |_|/ |/| | | qt: Add filename and title id to window title while running | ||||
| * | | qt: Add filename and title id to window title while running | Zach Hilman | 2018-08-23 | 1 | -0/+7 |
| |/ | |||||
* / | Added GetBootMode (#1107) | David | 2018-08-24 | 4 | -3/+25 |
|/ | | | | | | | | * Added GetBootMode Used by homebrew * Added enum for GetBootMode | ||||
* | Merge pull request #1136 from tech4me/master | bunnei | 2018-08-22 | 2 | -4/+4 |
|\ | | | | | qt/main: Port part of citra(#3411), open savedata works | ||||
| * | qt/main: Port part of citra(#3411), open savedata works | tech4me | 2018-08-21 | 2 | -4/+4 |
| | | |||||
* | | Merge pull request #840 from FearlessTobi/port-3353 | bunnei | 2018-08-22 | 3 | -7/+18 |
|\ \ | | | | | | | Port #3353 from Citra: "citra-qt: Add customizable speed limit target " | ||||
| * | | Port #3353 from Citra | fearlessTobi | 2018-08-21 | 3 | -7/+18 |
| | | | |||||
* | | | Added missing include for pl:u | David Marcec | 2018-08-22 | 1 | -0/+1 |
| | | | | | | | | | | | | Should fix any compile errors | ||||
* | | | PL:U Added BFTTF loading(Loading from System NAND dumps) (#1088) | David | 2018-08-22 | 1 | -25/+140 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Added bfttf loading We can now load system bfttf fonts from system archives AND shared memory dumps. This allows people who have installed their system nand dumps to yuzu to automatically get shared font support. We also now don't hard code the offsets or the sizes of the shared fonts and it's all calculated for us now. * Addressed plu fixups * Style changes for plu * Fixed logic error for plu and added more error checks. | ||||
* | | | Merge pull request #1145 from lioncash/fwd-decl | bunnei | 2018-08-22 | 5 | -4/+7 |
|\ \ \ | | | | | | | | | vfs: Replace mode.h include with forward declarations where applicable | ||||
| * | | | vfs: Replace mode.h include with forward declarations where applicable | Lioncash | 2018-08-21 | 5 | -4/+7 |
| | | | | | | | | | | | | | | | | | | | | Avoids the need to rebuild these source files if the mode header changes. | ||||
* | | | | am: Utilize std::array within PopLaunchParameter() | Lioncash | 2018-08-21 | 1 | -3/+4 |
|/ / / | | | | | | | | | | | | | | | | Gets rid of the potential for C array-to-pointer decay, and also makes pointer arithmetic to get the end of the copy range unnecessary. We can just use std::array's begin() and end() member functions. | ||||
* | | | Merge pull request #1143 from lioncash/inc | bunnei | 2018-08-21 | 2 | -1/+1 |
|\ \ \ | | | | | | | | | sdmc_factory: Remove unnecessary core include | ||||
| * | | | sdmc_factory: Remove unnecessary core include | Lioncash | 2018-08-21 | 2 | -1/+1 |
| | |/ | |/| | | | | | | | | | | This doesn't require the central core header to be included, it just needs the vfs headers. | ||||
* / | | perf_stats: Change MAX_LAG_TIME_US to an appropriate value | MerryMage | 2018-08-21 | 1 | -1/+1 |
|/ / | | | | | | | | | | | | | | | | | | | 25us is far too small, and would result in std::this_thread::sleep_for being called with this as a maximum value. This means that a guest application that produces frames instantly would only be limited to 40 kHz. 25ms is a more appropriate value, as it allows for a 60 Hz refresh rate while providing enough slack in the negative region. | ||||
* | | Merge pull request #1129 from lioncash/header | bunnei | 2018-08-21 | 8 | -8/+34 |
|\ \ | | | | | | | romfs_factory, service/filesystem: Use forward declarations where applicable | ||||
| * | | service/filesystem: Use forward declarations where applicable | Lioncash | 2018-08-21 | 6 | -5/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | Avoids the need to rebuild multiple source files if the filesystem code headers change. This also gets rid of a few instances of indirect inclusions being relied upon | ||||
| * | | romfs_factory: Remove unnecessary includes and use forward declarations where applicable | Lioncash | 2018-08-21 | 3 | -3/+12 |
| | | | | | | | | | | | | | | | | | | Avoids the need to rebuild whatever includes the romfs factory header if the loader header ever changes. We also don't need to include the main core header. We can instead include the headers we specifically need. | ||||
* | | | Merge pull request #1126 from lioncash/telem | bunnei | 2018-08-21 | 1 | -4/+4 |
|\ \ \ | | | | | | | | | telemetry_session: Don't allocate std::string instances for program lifetime in GetTelemetryId() and RegenerateTelemetryId() | ||||
| * | | | telemetry_session: Don't allocate std::string instances for program lifetime in GetTelemetryId() and RegenerateTelemetryId() | Lioncash | 2018-08-21 | 1 | -4/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | Given these functions aren't intended to be used frequently, there's no need to keep the std::string instances allocated for the whole lifetime of the program. It's just a waste of memory. | ||||
* | | | | Merge pull request #1122 from lioncash/acc | bunnei | 2018-08-21 | 4 | -57/+61 |
|\ \ \ \ | |_|/ / |/| | | | acc/profile_manager: General cleanup | ||||
| * | | | acc: Replace profile_manager include with a forward declaration | Lioncash | 2018-08-21 | 2 | -2/+6 |
| | | | | | | | | | | | | | | | | This is only used in a shared_ptr, so we can forward declare it. | ||||
| * | | | acc: Simplify WriteBuffer call within LoadImage() | Lioncash | 2018-08-21 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | We have an overload of WriteBuffer that accepts containers that satisfy the ContiguousContainer concept, which std::array does, so we only need to pass in the array itself. | ||||
| * | | | acc: Correct IProfile's constructor initializer list order | Lioncash | 2018-08-21 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | Arranges them in the order the members would be initialized | ||||
| * | | | acc: Remove unused DEFAULT_USER_ID | Lioncash | 2018-08-21 | 1 | -3/+0 |
| | | | | | | | | | | | | | | | | This is no longer used, so it can be removed. | ||||
| * | | | profile_manager: Use INVALID_UUID in the initializer of last_opened_user | Lioncash | 2018-08-21 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | Makes it a little bit more self-documenting. | ||||
| * | | | profile_manager: Remove unnecessary memcpy in GetProfileBaseAndData() | Lioncash | 2018-08-21 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | Given the source and destination types are the same std::array type, we can simply use regular assignment to perform the same behavior. | ||||
| * | | | profile_manager: Use type aliases for username data, profile data, and user arrays | Lioncash | 2018-08-21 | 2 | -19/+22 |
| | | | | | | | | | | | | | | | | | | | | Avoids the need to repeatedly specify the whole array type in multiple places. | ||||
| * | | | profile_manager: Take ProfileInfo by const reference where applicable | Lioncash | 2018-08-21 | 2 | -8/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | ProfileInfo is quite a large struct in terms of data, and we don't need to perform a copy in these instances, so we can just pass constant references instead. | ||||
| * | | | profile_manager: Make array parameter to CreateNewUser a const reference | Lioncash | 2018-08-21 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | This doesn't modify the passed in array, so this can be a const reference. | ||||
| * | | | profile_manager: Remove unnecessary static | Lioncash | 2018-08-21 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | This can just be constexpr like the others | ||||
| * | | | profile_manager: Simplify UUID's two param constructor, operator==, and operator bool | Lioncash | 2018-08-21 | 1 | -6/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | We can use the constructor initializer list and just compare the contained u128's together instead of comparing each element individually. Ditto for comparing against an invalid UUID. | ||||
| * | | | profile_manager: Move UUID generation function to the cpp file | Lioncash | 2018-08-21 | 2 | -10/+12 |
| | | | | | | | | | | | | | | | | | | | | This avoids needing to dump the contents of <random> into other files that include the profile manager header. | ||||
| * | | | profile_manager: Remove unnecessary std::move in AddToProfiles() and CreateNewUser() | Lioncash | 2018-08-20 | 1 | -2/+2 |
| | |/ | |/| | | | | | | | | | | | | | Moving a const reference isn't possible, so this just results in a copy (and given ProfileInfo is composed of trivial types and aggregates, a move wouldn't really do anything). | ||||
* | | | Merge pull request #1095 from DarkLordZach/sysarchives | bunnei | 2018-08-21 | 8 | -20/+100 |
|\ \ \ | |_|/ |/| | | filesystem: Add support for loading of system archives | ||||
| * | | registration: Add Data_Unknown5 NCAContentType | Zach Hilman | 2018-08-20 | 3 | -2/+3 |
| | | | |||||
| * | | filesystem: Add support for loading of system archives | Zach Hilman | 2018-08-19 | 7 | -20/+99 |
| | | | |||||
* | | | Merge pull request #1064 from lioncash/telemetry | bunnei | 2018-08-21 | 1 | -62/+7 |
|\ \ \ | |_|/ |/| | | common/telemetry: Migrate core-independent info gathering to common | ||||
| * | | common/telemetry: Migrate core-independent info gathering to common | Lioncash | 2018-08-15 | 1 | -62/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously core itself was the library containing the code to gather common information (build info, CPU info, and OS info), however all of this isn't core-dependent and can be moved to the common code and use the common interfaces. We can then just call those functions from the core instead. This will allow replacing our CPU detection with Xbyak's which has better detection facilities than ours. It also keeps more architecture-dependent code in common instead of core. | ||||
* | | | Merge pull request #1117 from ogniK5377/CheckFreeCommunicationPermission | bunnei | 2018-08-20 | 1 | -1/+8 |
|\ \ \ | | | | | | | | | Added CheckFreeCommunicationPermission | ||||
| * | | | Added CheckFreeCommunicationPermission | David Marcec | 2018-08-20 | 1 | -1/+8 |
| | |/ | |/| | | | | | | | This fixes save files not loading in splatoon 2 | ||||
* | | | Merge pull request #1017 from ogniK5377/better-account | bunnei | 2018-08-20 | 13 | -74/+440 |
|\ \ \ | |/ / |/| | | New account backend to allow for future extended support | ||||
| * | | Better UUID randomness | David Marcec | 2018-08-11 | 1 | -2/+7 |
| | | | |||||
| * | | Removed un-needed count from ListOpenUsers and ListAllUsers | David Marcec | 2018-08-11 | 1 | -4/+2 |
| | | | |||||
| * | | Added better explanations in the profile manager | David Marcec | 2018-08-11 | 2 | -1/+34 |
| | | | |||||
| * | | Code cleanup for profile manager | David Marcec | 2018-08-11 | 3 | -40/+47 |
| | | | |||||
| * | | Removed const from ProfileBase Invalidate | David Marcec | 2018-08-11 | 1 | -1/+1 |
| | | | |||||
| * | | fixed invalid uuid bool operator | David Marcec | 2018-08-11 | 1 | -1/+1 |
| | | | |||||
| * | | Added GetOpenUserCount | David Marcec | 2018-08-11 | 3 | -3/+14 |
| | | | |||||
| * | | Removed all for loops from the profile manager | David Marcec | 2018-08-11 | 1 | -9/+4 |
| | | | |||||
| * | | Added missing ListAllUsers count | David Marcec | 2018-08-11 | 1 | -1/+2 |
| | | | |||||
| * | | If statement style change | David Marcec | 2018-08-11 | 1 | -11/+19 |
| | | | |||||
| * | | Second round of account changes | David Marcec | 2018-08-11 | 3 | -18/+21 |
| | | | |||||
| * | | First round of account changes | David Marcec | 2018-08-11 | 3 | -49/+55 |
| | | | |||||
| * | | Refactored profile manager sharing | David Marcec | 2018-08-11 | 10 | -20/+28 |
| | | | |||||
| * | | Merge remote-tracking branch 'origin/master' into better-account | David Marcec | 2018-08-11 | 37 | -148/+758 |
| |\ \ | |||||
| * | | | Added IsUserRegistrationRequestPermitted | David Marcec | 2018-08-11 | 7 | -3/+19 |
| | | | | |||||
| * | | | Don't add user if the uuid already exists | David Marcec | 2018-08-09 | 1 | -0/+4 |
| | | | | |||||
| * | | | Open first user added | David Marcec | 2018-08-08 | 1 | -1/+3 |
| | | | | |||||
| * | | | Inital pass of account backend implementation | David Marcec | 2018-08-08 | 3 | -12/+22 |
| | | | | | | | | | | | | | | | | This commit verified working on puyo | ||||
| * | | | GetProfileBase and GetProfileBaseAndData added | David Marcec | 2018-08-08 | 3 | -44/+106 |
| | | | | |||||
| * | | | began initial implementation of "ProfileManager" | David Marcec | 2018-08-08 | 5 | -44/+202 |
| | | | | |||||
| * | | | Switched uuids from u128 to new UUID struct | David Marcec | 2018-08-08 | 2 | -10/+49 |
| | | | | |||||
* | | | | Implement SetIdleTimeDetectionExtension & GetIdleTimeDetectionExtension (#1059) | greggameplayer | 2018-08-17 | 2 | -2/+22 |
| | | | | | | | | | | | | * Used by Mario Tennis Aces | ||||
* | | | | Merge pull request #1090 from lioncash/ctor-assign | bunnei | 2018-08-17 | 1 | -0/+6 |
|\ \ \ \ | | | | | | | | | | | core: Delete System copy/move constructors and assignment operators | ||||
| * | | | | core: Delete System copy/move constructors and assignment operators | Lioncash | 2018-08-16 | 1 | -0/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents potentially making copies or doing silly things by accident with the System instance, particularly given our current core is designed (unfortunately) around one instantiable instance. This will prevent the accidental case of: auto instance = System::Instance(); being compiled without warning when it's supposed to be: auto& instance = System::Instance(); | ||||
* | | | | | Merge pull request #1093 from greggameplayer/GetDefaultDisplayResolutionChangeEvent | bunnei | 2018-08-17 | 2 | -1/+13 |
|\ \ \ \ \ | | | | | | | | | | | | | Implement GetDefaultDisplayResolutionChangeEvent | ||||
| * | | | | | correct coding style | greggameplayer | 2018-08-16 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | Implement GetDefaultDisplayResolutionChangeEvent | greggameplayer | 2018-08-16 | 2 | -1/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | Require by Toki Tori and Toki Tori 2+ | ||||
* | | | | | | Merge pull request #1087 from MerryMage/dynarmic | bunnei | 2018-08-17 | 1 | -0/+3 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | dynarmic: Update to 550d662 | ||||
| * | | | | | dynarmic: Update to 550d662 | MerryMage | 2018-08-16 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 550d662 load_store_exclusive: Define s == t state to be Constraint_NONE 0b69381 A64/translate: Allow for unpredictable behaviour to be defined 6d236d4 system: Implement MRS CNTFRQ_EL0 6cbb6fb A32/testenv: Add missing headers 6729328 externals: Update xbyak to v5.67 1812bd2 Squashed 'externals/xbyak/' changes from 2794cde7..671fc805 9a95802 externals: Document subtrees 714a840 A64: Implement SQ{ADD, SUB}, and UQ{ADD, SUB}'s vector variants 8cab459 A64: Implement UQADD/UQSUB's scalar variants 18a8151 ir: Add opcodes for unsigned saturating add and subtract a5660ee x64/reg_alloc: Use type alias for array returned by GetArgumentInfo() 29489b5 ir/value: Use type alias CoprocessorInfo for std::array<u8, 8> e23ba26 status_register_access: Add support for bits 0 and 1 of mask to MSR 55190bd fuzz_with_unicorn: Split utility functions into fuzz_util 23b049d A32/translate/load_store: Correct detection of writeback 7ec9f15 A32/translate: Add TranslateSingleInstruction efeecb4 A32/ir_emitter: Bug fix: IREmitter::ExceptionRaised using incorrect opcode 08d1d19 A32/decoders: Split instruction list into include file 2d929cc tests: Refactor unicorn_emu to allow for A32 unicorn f672368 microinstruction: Improve assert messages 7ebff50 emit_x64_vector: EmitVectorNarrow16: AVX512 implementation edce230 emit_x64_vector: EmitVectorNarrow32: prefer pblendw to loading constant | ||||
* | | | | | | Merge pull request #1085 from lioncash/namespace | bunnei | 2018-08-16 | 2 | -12/+14 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | common: Namespace hex_util.h/.cpp | ||||
| * | | | | | common: Namespace hex_util.h/.cpp | Lioncash | 2018-08-16 | 2 | -12/+14 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | It's in the common code, so it should be under the Common namespace like everything else. | ||||
* | | | | | Merge pull request #1075 from lioncash/include | bunnei | 2018-08-16 | 4 | -35/+22 |
|\ \ \ \ \ | |/ / / / |/| | | | | loader/{nca, xci}: Remove unnecessary includes and unused member variables | ||||
| * | | | | loader/nca: Remove unnecessary includes and member variables | Lioncash | 2018-08-15 | 2 | -20/+11 |
| | | | | | |||||
| * | | | | loader/xci: Remove unnecessary includes and member variables | Lioncash | 2018-08-15 | 2 | -15/+11 |
| | |_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | Many of these aren't necessary and will cause this file to be required to be recompiled whenever any changes to those files are made, which lengthens compile times for no reason. This also removes an unused metadata variable from AppLoader_XCI | ||||
* | | | | Merge pull request #1005 from DarkLordZach/registered-fmt | bunnei | 2018-08-16 | 24 | -58/+1135 |
|\ \ \ \ | | | | | | | | | | | file_sys: Add support for registration format | ||||
| * | | | | registration: Various style and documentation improvements | Zach Hilman | 2018-08-12 | 3 | -18/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fix logic in RealVfsFilesystem Create methods Remove magic numbers Fix regex errors | ||||
| * | | | | registration: Add support for force overwrite of installed | Zach Hilman | 2018-08-12 | 2 | -22/+48 |
| | | | | | |||||
| * | | | | vfs_real: Add CreateFullPath to Create* operations | Zach Hilman | 2018-08-12 | 2 | -13/+6 |
| | | | | | |||||
| * | | | | control_metadata: Remove unnecessary reference to base file | Zach Hilman | 2018-08-12 | 2 | -2/+1 |
| | | | | | |||||
| * | | | | romfs: Remove cyclic shared_ptr leak in romfs code | Zach Hilman | 2018-08-12 | 3 | -8/+8 |
| | | | | | |||||
| * | | | | registration: Update documentation and style | Zach Hilman | 2018-08-12 | 5 | -42/+69 |
| | | | | | |||||
| * | | | | nca_metadata: Remove unnecessary reference to base file | Zach Hilman | 2018-08-12 | 2 | -3/+2 |
| | | | | | |||||
| * | | | | bis_factory: Create NAND dirs if they don't exist | Zach Hilman | 2018-08-12 | 1 | -2/+9 |
| | | | | | |||||
| * | | | | registration: Take RawCopy function as parameter | Zach Hilman | 2018-08-12 | 2 | -10/+15 |
| | | | | | | | | | | | | | | | | | | | | Instead of defaulting to VfsRawCopy | ||||
| * | | | | registered_cache: Fix missing reading from yuzu_meta | Zach Hilman | 2018-08-12 | 1 | -7/+16 |
| | | | | | |||||
| * | | | | file_sys: Comply to style guidelines | Zach Hilman | 2018-08-12 | 6 | -27/+38 |
| | | | | | |||||
| * | | | | qt: Add 'Install to NAND' option to menu | Zach Hilman | 2018-08-12 | 2 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | Prompts for title type on NCA files. | ||||
| * | | | | file_sys: Add RegisteredCache | Zach Hilman | 2018-08-12 | 2 | -0/+543 |
| | | | | | | | | | | | | | | | | | | | | Manages NAND NCA get and install. | ||||
| * | | | | file_sys: Add support for parsing NCA metadata (CNMT) | Zach Hilman | 2018-08-12 | 3 | -0/+238 |
| | | | | | |||||
| * | | | | card_image: Add accessor for all NCAs in XCI | Zach Hilman | 2018-08-12 | 2 | -0/+5 |
| | | | | | |||||
| * | | | | vfs_real: Add CreateFullPath to CreateFile | Zach Hilman | 2018-08-12 | 1 | -3/+6 |
| | | | | | | | | | | | | | | | | | | | | Fixes bugs with calling CreateFile when the immediate directory does not exist. | ||||
| * | | | | filesystem: Add Open and Register functions for BISFactory | Zach Hilman | 2018-08-12 | 2 | -4/+23 |
| | | | | | |||||
| * | | | | bis_factory: Add partial implementation of BISFactory | Zach Hilman | 2018-08-12 | 2 | -0/+54 |
| | | | | | | | | | | | | | | | | | | | | Creates and stores RegisteredCaches for user and system NAND, as creation of a RegisteredCache is expensive. | ||||
| * | | | | loader: Join 0* files in directory if filename is 00 | Zach Hilman | 2018-08-12 | 1 | -1/+33 |
| | | | | | | | | | | | | | | | | | | | | i.e. Load the concatenated 00+01 if 01 exists as well. Needed for split NAND NCAs. | ||||
| * | | | | loader: Recognize filename '00' as NCA | Zach Hilman | 2018-08-12 | 1 | -0/+2 |
| | | | | | | | | | | | | | | | | | | | | Needed to avoid mismatch filetype warnings on split NAND NCAs | ||||
| * | | | | vfs: Add ConcatenatedVfsFile | Zach Hilman | 2018-08-12 | 2 | -0/+134 |
| | | | | | |||||
| * | | | | crypto: Remove hex utilities from key_manager | Zach Hilman | 2018-08-12 | 2 | -36/+2 |
| | | | | | | | | | | | | | | | | | | | | Move to hex_util.h in common | ||||
* | | | | | Merge pull request #1078 from lioncash/message | bunnei | 2018-08-16 | 1 | -2/+20 |
|\ \ \ \ \ | | | | | | | | | | | | | lm: Handle threads and modules within the logger | ||||
| * | | | | | lm: Use LOG_DEBUG for printing out trace logs | Lioncash | 2018-08-15 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Using LOG_TRACE here isn't a good idea because LOG_TRACE is only enabled when yuzu is compiled in debug mode. Debug mode is also quite slow, and so we're potentially throwing away logging messages that can provide value when trying to boot games. | ||||
| * | | | | | lm: Handle threads and modules within the logger | Lioncash | 2018-08-15 | 1 | -1/+19 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The thread field serves to indicate which thread a log is related to and provides the length of the thread's name, so we can print that out, ditto for modules. Now we can know what threads are potentially spawning off logging messages (for example Lydie & Suelle bounces between MainThread and LoadingThread when initializing the game). | ||||
* | | | | | | Merge pull request #1079 from lioncash/fmt | bunnei | 2018-08-16 | 3 | -12/+11 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | loader: Make ResultStatus directly compatible with fmt | ||||
| * | | | | | | loader: Make ResultStatus directly compatible with fmt | Lioncash | 2018-08-15 | 3 | -12/+11 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can make the enum class type compatible with fmt by providing an overload of operator<<. While we're at it, perform proper bounds checking. If something exceeds the array, it should be a hard fail, because it's, without a doubt, a programmer error in this case. | ||||
* | | | | | | Merge pull request #1051 from B3n30/UnscheduleEventThreadsafe | bunnei | 2018-08-16 | 3 | -1/+12 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Core::CoreTiming: add UnscheduleEventThreadsafe | ||||
| * | | | | | | Core::CoreTiming: add UnscheduleEventThreadsafe | B3n30 | 2018-08-13 | 3 | -1/+12 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1080 from lioncash/ret | bunnei | 2018-08-16 | 1 | -1/+1 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | sm/controller: Correct return value of QueryPointerBufferSize | ||||
| * | | | | | | | sm/controller: Correct return value of QueryPointerBufferSize | Lioncash | 2018-08-15 | 1 | -1/+1 |
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | This should be returning a u16 according to Switch Brew. | ||||
* / | | | | | | kernel/server_session: Add IsSession() member function | Lioncash | 2018-08-15 | 3 | -3/+8 |
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows querying the inverse of IsDomain() to make things more readable. This will likely also be usable in the event of implementing ConvertDomainToSession(). | ||||
* | | | | | | Merge pull request #1067 from lioncash/init | bunnei | 2018-08-15 | 1 | -3/+3 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | emu_window: Ensure WindowConfig members are always initialized | ||||
| * | | | | | | emu_window: Ensure WindowConfig members are always initialized | Lioncash | 2018-08-15 | 1 | -3/+3 |
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | Previously we weren't always initializing all members of the struct. Prevents potentially wonky behavior from occurring. | ||||
* | | | | | | Merge pull request #1073 from lioncash/3ds | bunnei | 2018-08-15 | 6 | -17/+0 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | loader: Remove address mapping remnants from citra | ||||
| * | | | | | | loader: Remove address mapping remnants from citra | Lioncash | 2018-08-15 | 6 | -17/+0 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | These mappings are leftovers from citra and don't apply to the Switch. | ||||
* | | | | | | Merge pull request #1072 from lioncash/svc | bunnei | 2018-08-15 | 1 | -2/+5 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | kernel/svc: Log svcBreak parameters | ||||
| * | | | | | | kernel/svc: Log svcBreak parameters | Lioncash | 2018-08-15 | 1 | -2/+5 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given if we hit here all is lost, we should probably be logging the break reason code and associated information to distinguish between the causes. | ||||
* | | | | | | Merge pull request #1056 from lioncash/mm | bunnei | 2018-08-15 | 2 | -46/+52 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | mm_u: Move interface class into the cpp file | ||||
| * | | | | | mm_u: Forward all old variants of functions to the new ones | Lioncash | 2018-08-14 | 1 | -5/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ensures both variants go through the same interface, and while we're at it, add Finalize to provide the inverse of Initialize for consistency. | ||||
| * | | | | | mm_u: Move implementation class into the cpp file | Lioncash | 2018-08-14 | 2 | -46/+46 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now if changes are ever made to the behavior of the class, it doesn't involve rebuilding everything that includes the mm_u header. | ||||
* | | | | | | Merge pull request #1055 from lioncash/init | bunnei | 2018-08-14 | 1 | -1/+1 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | audout_u: Correct IAudioOut initializer list order | ||||
| * | | | | | | audout_u: Correct IAudioOut initializer list order | Lioncash | 2018-08-14 | 1 | -1/+1 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | Orders elements in the precise order they'll be initialized. | ||||
* | | | | | | Merge pull request #1046 from ogniK5377/missing-channels | Mat M | 2018-08-14 | 6 | -0/+148 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Added missing channel devices | ||||
| * | | | | | Registered missing channel devices | David Marcec | 2018-08-13 | 1 | -0/+4 |
| | | | | | | |||||
| * | | | | | Added missing channel devices | David Marcec | 2018-08-13 | 5 | -0/+144 |
| | | | | | | |||||
* | | | | | | arm_dynarmic: Remove IsExecuting check from PrepareReschedule | MerryMage | 2018-08-13 | 1 | -3/+1 |
| |/ / / / |/| | | | | | | | | | | | | | | No longer required. HaltExecution is a no-op if it is not currently executing. | ||||
* | | | | | Merge pull request #1032 from lioncash/sanitize | bunnei | 2018-08-13 | 1 | -10/+10 |
|\ \ \ \ \ | | | | | | | | | | | | | vfs: Use sanitized paths within MoveFile() and MoveDirectory() | ||||
| * | | | | | vfs: Use sanitized paths within MoveFile() and MoveDirectory() | Lioncash | 2018-08-12 | 1 | -10/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously these were being unused (or partially unused). While we're at it, use better naming to make it visibly obvious which variant of the path is being used. | ||||
* | | | | | | Merge pull request #1031 from lioncash/verbosity | bunnei | 2018-08-13 | 2 | -7/+7 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | card_image: Simplify return statement of GetSubdirectories() | ||||
| * | | | | | | card_image: Use type aliases to shorten definitions | Lioncash | 2018-08-12 | 2 | -6/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | We have the aliases, so we may as well use 'em. | ||||
| * | | | | | | card_image: Simplify return statement of GetSubdirectories() | Lioncash | 2018-08-12 | 1 | -1/+1 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | We don't need to write out the construction long-form, we can just let the language itself work it out off the return type. | ||||
* | / / / / | kernel/object: Tighten object against data races | Lioncash | 2018-08-13 | 2 | -8/+9 |
| |/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Despite being covered by a global mutex, we should still ensure that the class handles its reference counts properly. This avoids potential shenanigans when it comes to data races. Given this is the root object that drives quite a bit of the kernel object hierarchy, ensuring we always have the correct behavior (and no races) is a good thing. | ||||
* | | | | | Merge pull request #1043 from Subv/timing | bunnei | 2018-08-13 | 3 | -2/+11 |
|\ \ \ \ \ | | | | | | | | | | | | | Use an approximated amortized amount of ticks when advancing timing. | ||||
| * | | | | | CPU/Timing: Use an approximated amortized amount of ticks when advancing timing. | Subv | 2018-08-13 | 2 | -1/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We divide the number of ticks to add by the number of cores (4) to obtain a more or less rough estimate of the actual number of ticks added. This assumes that all 4 cores are doing similar work. Previously we were adding ~4 times the number of ticks, thus making the games think that time was going way too fast. This lets us bypass certain hangs in some games like Breath of the Wild. We should modify our CoreTiming to support multiple cores (both running in a single thread, and in multiple host threads). | ||||
| * | | | | | Kernel/SVC: Don't reschedule the current core when creating a new thread. | Subv | 2018-08-13 | 1 | -1/+0 |
| |/ / / / | | | | | | | | | | | | | | | | The current core may have nothing to do with the core where the new thread was scheduled to run. In case it's the same core, then the following PrepareReshedule call will take care of that. | ||||
* | | | | | Merge pull request #1036 from lioncash/thread | bunnei | 2018-08-13 | 2 | -2/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | scheduler: Make HaveReadyThreads() a const member function | ||||
| * | | | | | scheduler: Make HaveReadyThreads() a const member function | Lioncash | 2018-08-12 | 2 | -2/+2 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | This function doesn't modify instance state, so the const qualifier can be added to it. | ||||
* | | | | | Merge pull request #1042 from Subv/races | bunnei | 2018-08-13 | 4 | -5/+13 |
|\ \ \ \ \ | | | | | | | | | | | | | Fixed a bunch of race conditions when running in multicore mode. | ||||
| * | | | | | Core/HLE: Make the 'reschedule_pending' flag atomic. | Subv | 2018-08-13 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | Another thread may write to this variable while the core in question is in the middle of checking for a reschedule request. | ||||
| * | | | | | CPU/HLE: Lock the HLE mutex before performing a reschedule. | Subv | 2018-08-13 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | Another thread might be in the middle of an SVC, thus altering the state of the schedulers. | ||||
| * | | | | | Kernel/Threads: Lock the HLE mutex when executing the wakeup callback. | Subv | 2018-08-13 | 1 | -0/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | Another thread might be in the middle of a reschedule, thus altering the state of the schedulers. | ||||
| * | | | | | Kernel/Thread: Always use the threadsafe option when scheduling wakeups. | Subv | 2018-08-13 | 2 | -4/+4 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | WakeAfterDelay might be called from any host thread, so err on the side of caution and use the thread-safe CoreTiming::ScheduleEventThreadsafe. Note that CoreTiming is still far from thread-safe, there may be more things we have to work on for it to be up to par with what we want. | ||||
* | | | | | Merge pull request #1041 from Subv/duplicated_mutex | bunnei | 2018-08-13 | 2 | -2/+22 |
|\ \ \ \ \ | | | | | | | | | | | | | Kernel/Mutex: Don't duplicate threads in the mutex waiter list. | ||||
| * | | | | | Kernel/Mutex: Don't duplicate threads in the mutex waiter list. | Subv | 2018-08-12 | 2 | -2/+22 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Exit from AddMutexWaiter early if the thread is already waiting for a mutex owned by the owner thread. This accounts for the possibility of a thread that is waiting on a condition variable being awakened twice in a row. Also added more validation asserts. This should fix one of the random crashes in Breath Of The Wild. | ||||
* | | | | | vfs: Make VfsFilesystem constructor explicit | Lioncash | 2018-08-12 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Makes it consistent with the other VFS interfaces and prevents implicit construction. | ||||
* | | | | | vfs: Make type hierarchy objects classes instead of structs | Lioncash | 2018-08-12 | 4 | -10/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | struct should be used when the data type is very simple or otherwise has no invariants associated with it. Given these are used to form a hierarchy, class should be used instead. | ||||
* | | | | | Merge pull request #1025 from ogniK5377/bad-cast | bunnei | 2018-08-12 | 4 | -4/+4 |
|\ \ \ \ \ | | | | | | | | | | | | | Fixed invalid cast in loader | ||||
| * | | | | | made ResultStatus a u16 | David Marcec | 2018-08-12 | 3 | -3/+3 |
| | | | | | | |||||
| * | | | | | Fixed invalid cast in loader | David Marcec | 2018-08-12 | 1 | -1/+1 |
| | |/ / / | |/| | | | | | | | | | | | | | GetMessageForResultStatus takes a u16, not a size_t. | ||||
* | | | | | Merge pull request #1035 from ogniK5377/audio-dev-revision-info | bunnei | 2018-08-12 | 2 | -1/+13 |
|\ \ \ \ \ | | | | | | | | | | | | | GetAudioDeviceServiceWithRevisionInfo (Used by Bloodstained: Curse of the Moon) | ||||
| * | | | | | GetAudioDeviceServiceWithRevisionInfo | David Marcec | 2018-08-12 | 2 | -1/+13 |
| | |/ / / | |/| | | | | | | | | | | | | | As we're not handling any anything about the revision data for GetAudioDeviceServiceWithRevisionInfo, it's currently marked as stubbed. However for games this shouldn't affect the result. Proper revision info would be more for homebrew. | ||||
* | | | | | Merge pull request #1028 from ogniK5377/aoa | bunnei | 2018-08-12 | 1 | -5/+26 |
|\ \ \ \ \ | | | | | | | | | | | | | Added GetAudioRendererSampleRate, GetAudioRendererSampleCount & GetAudioRendererMixBufferCount | ||||
| * | | | | | Pushed the requested sample rate instead of our fixed sample rate | David Marcec | 2018-08-12 | 1 | -4/+2 |
| | | | | | | |||||
| * | | | | | Added GetAudioRendererSampleRate, GetAudioRendererSampleCount & GetAudioRendererMixBufferCount | David Marcec | 2018-08-12 | 1 | -5/+28 |
| | |/ / / | |/| | | | | | | | | | | | | | GetAudioRendererSampleRate is set as a "STUB" as a game could check if the sample rate it sent and the sample rate it wants don't match. Just a thought of something which could happen so keeping it as stub for the mean time | ||||
* | | | | | hid: disable clang-format around tables | Lioncash | 2018-08-12 | 1 | -4/+5 |
| | | | | | | | | | | | | | | | | | | | | Prevents clang-format from butchering them. | ||||
* | | | | | hid: Stub DisconnectNpad() | Lioncash | 2018-08-12 | 1 | -1/+7 |
| |/ / / |/| | | | | | | | | | | | This is required by ARMS. | ||||
* | | | | Stub UpdateUserPresence | David Marcec | 2018-08-12 | 1 | -1/+8 |
|/ / / | | | | | | | | | | Needed for Retro City Rampage to go in game | ||||
* | | | Merge pull request #1022 from bunnei/fix-splat | bunnei | 2018-08-12 | 2 | -2/+103 |
|\ \ \ | | | | | | | | | Several Friend service fixes | ||||
| * | | | friend: Stub DeclareCloseOnlinePlaySession. | bunnei | 2018-08-12 | 1 | -1/+10 |
| | | | | | | | | | | | | | | | | - Used by Splatoon 2. | ||||
| * | | | friend: Fix CreateFriendService to return an IFriendService interface. | bunnei | 2018-08-12 | 1 | -2/+86 |
| | | | | |||||
| * | | | server_session: Provide more useful information and don't crash on bad IPC request. | bunnei | 2018-08-12 | 1 | -0/+8 |
| | | | | |||||
* | | | | core: Namespace EmuWindow | Lioncash | 2018-08-12 | 4 | -5/+16 |
|/ / / | | | | | | | | | | Gets the class out of the global namespace. | ||||
* | | | Merge pull request #970 from DarkLordZach/loader-errors | bunnei | 2018-08-12 | 14 | -103/+219 |
|\ \ \ | | | | | | | | | loader: Add more descriptive errors | ||||
| * | | | loader: Add more descriptive errors | Zach Hilman | 2018-08-10 | 14 | -103/+219 |
| | |/ | |/| | | | | Full list of new errors and descriptions in core/loader/loader.h | ||||
* / | | video_core; Get rid of global g_toggle_framelimit_enabled variable | Lioncash | 2018-08-11 | 2 | -5/+2 |
|/ / | | | | | | | | | | | | | | | | | Instead, we make a struct for renderer settings and allow the renderer to update all of these settings, getting rid of the need for global-scoped variables. This also uncovered a few indirect inclusions for certain headers, which this commit also fixes. | ||||
* | | Merge pull request #997 from lioncash/const-func | bunnei | 2018-08-10 | 4 | -4/+4 |
|\ \ | | | | | | | core: Make function reference parameters const where applicable | ||||
| * | | buffer_queue: Make reference parameter of SetPreallocatedBuffer const | Lioncash | 2018-08-09 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | This is simply copied by value, so there's no need to make it a modifiable reference. While we're at it, make the names of the parameters match its definition. | ||||
| * | | hle_ipc: Make WriteToOutgoingCommandBuffer()'s reference parameter const | Lioncash | 2018-08-09 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | This function doesn't modify anything within the reference Thread instance. | ||||
* | | | Merge pull request #990 from lioncash/entry | bunnei | 2018-08-10 | 2 | -9/+12 |
|\ \ \ | | | | | | | | | fsp_srv: Emplace entries first when building index instead of emplacing last | ||||
| * | | | fsp_srv: Use std::string_view's copy() function instead of strncpy() | Lioncash | 2018-08-09 | 2 | -8/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | Given elements inserted into a vector are zeroed out, we can just copy MAX_LEN - 1 elements and the data will already be properly null terminated. | ||||
| * | | | fsp_srv: Emplace entries first when building index instead of emplacing last | Lioncash | 2018-08-09 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The current way were doing it would require copying a 768 character buffer (part of the Entry struct) to the new element in the vector. Given it's a plain array, std::move won't eliminate that. Instead, we can emplace an instance directly into the destination buffer and then fill it out, avoiding the need to perform any unnecessary copies. Given this is done in a loop, we can request the destination to allocate all of the necessary memory ahead of time, avoiding the need to potentially keep reallocating over and over on every few insertions into the vector. | ||||
* | | | | Merge pull request #897 from DarkLordZach/vfs-accuracy-2 | bunnei | 2018-08-10 | 13 | -113/+560 |
|\ \ \ \ | |_|/ / |/| | | | vfs: Add VfsFilesystem and fix RealVfs* implementations | ||||
| * | | | vfs: Fix documentation | Zach Hilman | 2018-08-09 | 1 | -2/+2 |
| | | | | |||||
| * | | | vfs: Fix typo in VfsFilesystem docs | Zach Hilman | 2018-08-09 | 1 | -1/+1 |
| | | | | |||||
| * | | | file_util: Use enum instead of bool for specifing path behavior | Zach Hilman | 2018-08-09 | 1 | -17/+27 |
| | | | | |||||
| * | | | loader: Remove unused IdentifyFile overload | Zach Hilman | 2018-08-09 | 2 | -12/+0 |
| | | | | |||||
| * | | | vfs: Use RealVfsFilesystem for fs-operations in RealVfsDirectory | Zach Hilman | 2018-08-09 | 1 | -2/+10 |
| | | | | |||||
| * | | | file_sys: Add missing include in savedata_factory | Zach Hilman | 2018-08-09 | 1 | -0/+1 |
| | | | | |||||
| * | | | core: Port core to VfsFilesystem for file access | Zach Hilman | 2018-08-09 | 6 | -13/+34 |
| | | | | |||||
| * | | | vfs: Add unreachable assert to file permissions converter | Zach Hilman | 2018-08-09 | 1 | -1/+3 |
| | | | | |||||
| * | | | vfs: Add RealVfsFilesystem implementation | Zach Hilman | 2018-08-09 | 2 | -81/+290 |
| | | | | |||||
| * | | | vfs: Add VfsFilesystem interface and default implementation | Zach Hilman | 2018-08-09 | 2 | -3/+211 |
| | | | | |||||
| * | | | filesystem: Remove unnecessary if conditions | Zach Hilman | 2018-08-09 | 1 | -1/+1 |
| | | | | |||||
* | | | | Merge pull request #986 from mailwl/acc-loadimage | bunnei | 2018-08-09 | 1 | -1/+22 |
|\ \ \ \ | |/ / / |/| | | | Service/Account: stub LoadImage function | ||||
| * | | | Service/Account: stub LoadImage function | mailwl | 2018-08-08 | 1 | -1/+22 |
| | |/ | |/| | |||||
* | | | Merge pull request #978 from bunnei/fixioctl | bunnei | 2018-08-09 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | nvhost_gpu: Don't over copy IoctlSubmitGpfifo. | ||||
| * | | | nvhost_gpu: Don't over copy IoctlSubmitGpfifo. | bunnei | 2018-08-08 | 1 | -1/+1 |
| | | | | |||||
* | | | | Merge pull request #975 from bunnei/am-stub | bunnei | 2018-08-08 | 2 | -1/+9 |
|\ \ \ \ | |_|_|/ |/| | | | am: Stub SetScreenShotImageOrientation. | ||||
| * | | | am: Stub SetScreenShotImageOrientation. | bunnei | 2018-08-08 | 2 | -1/+9 |
| |/ / | | | | | | | | | | - Used by Super Mario Odyssey. | ||||
* | | | Merge pull request #850 from DarkLordZach/icon-meta | bunnei | 2018-08-08 | 12 | -8/+128 |
|\ \ \ | | | | | | | | | Add Icons and Metadata Support | ||||
| * | | | loader: Add icon and title support to XCI | Zach Hilman | 2018-08-07 | 6 | -3/+43 |
| | | | | |||||
| * | | | Use const where applicable | Zach Hilman | 2018-08-07 | 2 | -2/+2 |
| | | | | |||||
| * | | | Avoid parsing RomFS to directory in NCA | Zach Hilman | 2018-08-07 | 7 | -6/+86 |
| | | | | |||||
* | | | | Merge pull request #958 from lioncash/nv-global | bunnei | 2018-08-08 | 5 | -11/+22 |
|\ \ \ \ | |_|_|/ |/| | | | nvdrv: Get rid of global std::weak_ptr | ||||
| * | | | nvdrv: Get rid of global std::weak_ptr | Lioncash | 2018-08-08 | 5 | -11/+22 |
| | |/ | |/| | | | | | | | | | | Rather than use global state, we can simply pass the instance into the NVFlinger instance directly. | ||||
* | | | Merge pull request #965 from lioncash/unused-files | bunnei | 2018-08-08 | 3 | -126/+0 |
|\ \ \ | | | | | | | | | hle: Remove unused romfs.cpp/.h | ||||
| * | | | hle: Remove unused romfs.cpp/.h | Lioncash | 2018-08-08 | 3 | -126/+0 |
| |/ / | | | | | | | | | | These files are no longer used, so we can get rid of them. | ||||
* | | | Merge pull request #974 from lioncash/acc | bunnei | 2018-08-08 | 2 | -2/+2 |
|\ \ \ | | | | | | | | | acc: Add missing function table entries for GetUserCount | ||||
| * | | | acc: Add missing function table entries for GetUserCount | Lioncash | 2018-08-08 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | Given this is stubbed within the common module in 5ac7b84, it should be added to the other relevant tables as well. | ||||
* | | | | hid: fix IsSixAxisSensorAtRest() response | mailwl | 2018-08-08 | 1 | -1/+1 |
|/ / / | |||||
* / / | acc: Stub GetUserCount. (#973) | bunnei | 2018-08-08 | 3 | -1/+9 |
|/ / | | | | | - Used by Pokken Tournament DX. | ||||
* | | Merge pull request #920 from DarkLordZach/titlekey | bunnei | 2018-08-07 | 2 | -7/+39 |
|\ \ | | | | | | | content_archive: Add support for titlekey cryptography | ||||
| * | | content_archive: Add support for titlekey cryptography | Zach Hilman | 2018-08-04 | 2 | -7/+39 |
| | | | |||||
* | | | Merge pull request #957 from lioncash/event | bunnei | 2018-08-07 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | nvflinger: Correct typo in name of composition event | ||||
| * | | | nvflinger: Correct typo in name of composition event | Lioncash | 2018-08-07 | 1 | -1/+1 |
| | |/ | |/| | |||||
* | | | Merge pull request #954 from lioncash/hid | bunnei | 2018-08-07 | 1 | -0/+1 |
|\ \ \ | | | | | | | | | services/hid: Add ActivateNpadWithRevision() to the hid function info array | ||||
| * | | | services/hid: Add ActivateNpadWithRevision() to the hid function info array | Lioncash | 2018-08-07 | 1 | -0/+1 |
| |/ / | | | | | | | | | | Updated based off the information on Switch Brew. | ||||
* | | | Merge pull request #960 from lioncash/apm | bunnei | 2018-08-07 | 3 | -0/+34 |
|\ \ \ | | | | | | | | | service/apm: Add the apm:sys service | ||||
| * | | | service/apm: Add the apm:sys service | Lioncash | 2018-08-07 | 3 | -0/+34 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton of the apm:sys service based off the information on Switch Brew. | ||||
* | | | Merge pull request #955 from lioncash/view | bunnei | 2018-08-07 | 2 | -3/+10 |
|\ \ \ | | | | | | | | | nvflinger: Use std::string_view in OpenDisplay() | ||||
| * | | | nvflinger: Get rid of indirect inclusions | Lioncash | 2018-08-07 | 2 | -1/+7 |
| | | | | |||||
| * | | | nvflinger: Use std::string_view in OpenDisplay() | Lioncash | 2018-08-07 | 2 | -2/+3 |
| |/ / | | | | | | | | | | | | | | | | We don't need to use a std::string here, given all that's done is comparing the character sequence against another. This allows passing regular const char* without needing to heap allocate. | ||||
* | | | Merge pull request #953 from lioncash/time | bunnei | 2018-08-07 | 1 | -2/+2 |
|\ \ \ | | | | | | | | | service/time: Amend command IDs of ToPosixTime() and ToPosixTimeWithMyRule() | ||||
| * | | | service/time: Amend command IDs of ToPosixTime() and ToPosixTimeWithMyRule() | Lioncash | 2018-08-07 | 1 | -2/+2 |
| |/ / | | | | | | | | | | Updates the ID of these based off the information on Switch Brew. | ||||
* | | | Merge pull request #956 from lioncash/nv | bunnei | 2018-08-07 | 13 | -16/+18 |
|\ \ \ | | | | | | | | | nvdrv: Get rid of indirect inclusions | ||||
| * | | | nvdrv: Make Ioctl()'s definition match its prototype | Lioncash | 2018-08-07 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | The only reason this wasn't a compilation error is because we use little-endian systems. | ||||
| * | | | nvdrv: Get rid of indirect inclusions | Lioncash | 2018-08-07 | 12 | -15/+17 |
| |/ / | |||||
* | | | Merge pull request #952 from lioncash/usb | bunnei | 2018-08-07 | 4 | -0/+257 |
|\ \ \ | | | | | | | | | service: Add usb services | ||||
| * | | | service: Add usb services | Lioncash | 2018-08-07 | 4 | -0/+257 |
| |/ / | | | | | | | | | | Adds basic skeleton for the usb services based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #949 from lioncash/priv | bunnei | 2018-08-07 | 3 | -7/+21 |
|\ \ \ | | | | | | | | | client_port: Make all data members private | ||||
| * | | | client_port: Make all data members private | Lioncash | 2018-08-07 | 3 | -7/+21 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | These members don't need to be entirely exposed, we can instead expose an API to operate on them without directly needing to mutate them We can also guard against overflow/API misuse this way as well, given active_sessions is an unsigned value. | ||||
* / / | loader: Fix scope error in DeconstructedRomDirectory | Zach Hilman | 2018-08-07 | 1 | -1/+1 |
|/ / | |||||
* | | Merge pull request #931 from DarkLordZach/nca-as-drd | bunnei | 2018-08-07 | 4 | -37/+24 |
|\ \ | | | | | | | loader: Make AppLoader_NCA rely on directory loading code | ||||
| * | | loader: Make AppLoader_NCA rely on directory loading code | Zach Hilman | 2018-08-06 | 4 | -37/+24 |
| | | | | | | | | | Eliminates duplicate code shared between their Load methods, after all the only difference is how the romfs is handled. | ||||
* | | | GDBStub works with both Unicorn and Dynarmic now (#941) | Hedges | 2018-08-07 | 4 | -2/+26 |
| | | | | | | | | | | | | | | | | | | * GDBStub works with both Unicorn and Dynarmic now * Tidy up | ||||
* | | | Merge pull request #940 from lioncash/private | bunnei | 2018-08-07 | 1 | -4/+8 |
|\ \ \ | | | | | | | | | kernel/event: Make data members private | ||||
| * | | | kernel/event: Make data members private | Lioncash | 2018-08-06 | 1 | -4/+8 |
| | | | | | | | | | | | | | | | | | | | | Instead we can simply provide accessors to the required data instead of giving external read/write access to the variables directly. | ||||
* | | | | Merge pull request #934 from lioncash/chrono | bunnei | 2018-08-07 | 4 | -16/+16 |
|\ \ \ \ | |/ / / |/| | | | core_timing: Make GetGlobalTimeUs() return std::chrono::microseconds | ||||
| * | | | perf_stats: Correct literal used for MAX_LAG_TIME_US | Lioncash | 2018-08-06 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | ms is shorthand for milliseconds, not microseconds, and given there's no comment indicating that this was intentional, it probably wasn't. | ||||
| * | | | core_timing: Make GetGlobalTimeUs() return std::chrono::microseconds | Lioncash | 2018-08-06 | 4 | -14/+14 |
| |/ / | | | | | | | | | | | | | Enforces the time unit being returned and also allows using the standard time utilities to manipulate it. | ||||
* | | | Merge pull request #933 from lioncash/memory | bunnei | 2018-08-06 | 1 | -12/+11 |
|\ \ \ | | | | | | | | | memory: Correct prototype of ZeroBlock | ||||
| * | | | memory: Make prototype parameter names match their definitions | Lioncash | 2018-08-06 | 1 | -5/+5 |
| | | | | | | | | | | | | | | | | Keeps the code consistent. | ||||
| * | | | memory: Correct prototype of ZeroBlock | Lioncash | 2018-08-06 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | Previously, the prototype wasn't matching the definition, which has a Processor parameter before the destination address. | ||||
| * | | | memory: Remove unnecessary const qualifiers in prototypes | Lioncash | 2018-08-06 | 1 | -9/+8 |
| |/ / | | | | | | | | | | | | | These aren't necessary, as value-wise const only matters in the definition. | ||||
* | | | Service/Audio: audout_a.cpp: remove pragma once | mailwl | 2018-08-06 | 1 | -2/+0 |
| | | | |||||
* | | | Merge pull request #932 from lioncash/func | bunnei | 2018-08-06 | 2 | -9/+9 |
|\ \ \ | | | | | | | | | core_timing: Use transparent functors where applicable | ||||
| * | | | core_timing: Convert typedef into a type alias | Lioncash | 2018-08-06 | 1 | -4/+4 |
| | | | | | | | | | | | | | | | | Makes the alias a little more readable from left-to-right. | ||||
| * | | | core_timing: Use transparent functors where applicable | Lioncash | 2018-08-06 | 1 | -5/+5 |
| |/ / | | | | | | | | | | | | | | | | Gets rid of the need to hardcode the type in multiple places. This will now be deduced automatically, based off the elements in the container being provided to the algorithm. | ||||
* | | | Merge pull request #929 from lioncash/addr | bunnei | 2018-08-06 | 2 | -83/+89 |
|\ \ \ | | | | | | | | | gdbstub: Minor changes | ||||
| * | | | gdbstub: Use type alias for breakpoint maps | Lioncash | 2018-08-05 | 1 | -37/+42 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than having to type out the full std::map type signature, we can just use a straightforward alias. While we're at it, rename GetBreakpointList to GetBreakpointMap, which makes the name more accurate. We can also get rid of unnecessary u64 static_casts, since VAddr is an alias for a u64. | ||||
| * | | | gdbstub: Move all file-static variables into the GDBStub namespace | Lioncash | 2018-08-05 | 1 | -35/+36 |
| | | | | | | | | | | | | | | | | | | | | Keeps everything under the same namespace. While we're at it, enclose them all within an inner anonymous namespace. | ||||
| * | | | gdbstub: Replace PAddr alias with VAddr | Lioncash | 2018-08-05 | 2 | -14/+14 |
| | | | | | | | | | | | | | | | | In all cases, a virtual address is being passed in, not a physical one. | ||||
* | | | | Merge pull request #930 from lioncash/thread | bunnei | 2018-08-06 | 1 | -15/+15 |
|\ \ \ \ | | | | | | | | | | | address_arbiter: Return by value from GetThreadsWaitingOnAddress() | ||||
| * | | | | address_arbiter: Return by value from GetThreadsWaitingOnAddress() | Lioncash | 2018-08-05 | 1 | -15/+15 |
| |/ / / | | | | | | | | | | | | | | | | | In all cases the vector being supplied is empty, so we can just return by value in these instances. | ||||
* | | | | Merge pull request #925 from bunnei/audren | bunnei | 2018-08-06 | 4 | -233/+16 |
|\ \ \ \ | |_|/ / |/| | | | Implement audren audio output | ||||
| * | | | audio_core: Implement audren_u audio playback. | bunnei | 2018-08-05 | 2 | -218/+9 |
| | | | | |||||
| * | | | audio_core: Use s16 where possible for audio samples. | bunnei | 2018-08-05 | 1 | -3/+3 |
| | | | | |||||
| * | | | audio_core: Port codec code from Citra for ADPCM decoding. | bunnei | 2018-08-05 | 2 | -11/+3 |
| | | | | |||||
| * | | | audio_core: Streams need unique names for CoreTiming. | bunnei | 2018-08-04 | 1 | -1/+1 |
| | |/ | |/| | |||||
* | | | Merge pull request #912 from lioncash/global-var | bunnei | 2018-08-05 | 7 | -27/+57 |
|\ \ \ | |_|/ |/| | | video_core: Eliminate the g_renderer global variable | ||||
| * | | renderer_base: Make Rasterizer() return the rasterizer by reference | Lioncash | 2018-08-04 | 3 | -7/+7 |
| | | | | | | | | | | | | | | | | | | | | | All calling code assumes that the rasterizer will be in a valid state, which is a totally fine assumption. The only way the rasterizer wouldn't be is if initialization is done incorrectly or fails, which is checked against in System::Init(). | ||||
| * | | video_core: Eliminate the g_renderer global variable | Lioncash | 2018-08-04 | 7 | -24/+54 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We move the initialization of the renderer to the core class, while keeping the creation of it and any other specifics in video_core. This way we can ensure that the renderer is initialized and doesn't give unfettered access to the renderer. This also makes dependencies on types more explicit. For example, the GPU class doesn't need to depend on the existence of a renderer, it only needs to care about whether or not it has a rasterizer, but since it was accessing the global variable, it was also making the renderer a part of its dependency chain. By adjusting the interface, we can get rid of this dependency. | ||||
* | | | Merge pull request #924 from lioncash/arp | bunnei | 2018-08-05 | 4 | -0/+95 |
|\ \ \ | | | | | | | | | service: Add arp services | ||||
| * | | | service: Add arp services | Lioncash | 2018-08-05 | 4 | -0/+95 |
| | |/ | |/| | | | | | | | | | | Adds the basic skeleton of the arp services based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #921 from lioncash/view | bunnei | 2018-08-05 | 5 | -35/+35 |
|\ \ \ | | | | | | | | | core/crypto: Minor changes | ||||
| * | | | aes_util: Add static assertion to Transcode() and XTSTranscode() to ensure well-defined behavior | Lioncash | 2018-08-04 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | These functions should only be given trivially-copyable types. | ||||
| * | | | aes_util: Make CalculateNintendoTweak() an internally linked function | Lioncash | 2018-08-04 | 2 | -12/+10 |
| | | | | | | | | | | | | | | | | | | | | This function doesn't directly depend on class state, so it can be hidden entirely from the interface in the cpp file. | ||||
| * | | | aes_util: Make Transcode() a const member function | Lioncash | 2018-08-04 | 2 | -8/+9 |
| | | | | | | | | | | | | | | | | This doesn't modify member state, so it can be made const. | ||||
| * | | | core/crypto: Remove unnecessary includes | Lioncash | 2018-08-04 | 4 | -5/+5 |
| | | | | |||||
| * | | | key_manager: Use regular std::string instead of std::string_view | Lioncash | 2018-08-04 | 2 | -10/+7 |
| |/ / | | | | | | | | | | | | | | | | | | | The benefit of std::string_view comes from the idea of avoiding copies (essentially acting as a non-owning view), however if we're just going to copy into a local variable immediately, there's not much benefit gained here. | ||||
* / / | service: Remove redundant #pragma once directives | Lioncash | 2018-08-04 | 5 | -10/+0 |
|/ / | | | | | | | | | These don't do anything within .cpp files (we don't include cpp files, so...) | ||||
* | | Merge pull request #849 from DarkLordZach/xci | bunnei | 2018-08-04 | 26 | -62/+1318 |
|\ \ | |/ |/| | XCI and Encrypted NCA Support | ||||
| * | Add missing parameter to files.push_back() | Zach Hilman | 2018-08-01 | 1 | -5/+5 |
| | | |||||
| * | Fix merge conflicts with opus and update docs | Zach Hilman | 2018-08-01 | 2 | -1/+3 |
| | | |||||
| * | Use more descriptive error codes and messages | Zach Hilman | 2018-08-01 | 7 | -19/+51 |
| | | |||||
| * | Use static const instead of const static | Zach Hilman | 2018-08-01 | 1 | -2/+2 |
| | | |||||
| * | Use ErrorEncrypted where applicable and fix no keys crash | Zach Hilman | 2018-08-01 | 4 | -17/+37 |
| | | |||||
| * | Add missing includes and use const where applicable | Zach Hilman | 2018-08-01 | 11 | -24/+40 |
| | | |||||
| * | Allow key loading from %YUZU_DIR%/keys in addition to ~/.switch | Zach Hilman | 2018-08-01 | 2 | -7/+20 |
| | | |||||
| * | Make XCI comply to review and style guidelines | Zach Hilman | 2018-08-01 | 14 | -455/+222 |
| | | |||||
| * | Extract mbedtls to cpp file | Zach Hilman | 2018-08-01 | 4 | -86/+126 |
| | | |||||
| * | Add missing string.h include | Zach Hilman | 2018-08-01 | 1 | -0/+1 |
| | | |||||
| * | Update mbedtls and fix compile error | Zach Hilman | 2018-08-01 | 1 | -0/+1 |
| | | |||||
| * | Remove files that are not used | Zach Hilman | 2018-08-01 | 24 | -42/+1406 |
| | | |||||
* | | Merge pull request #913 from lioncash/unused-func | bunnei | 2018-08-04 | 1 | -16/+0 |
|\ \ | | | | | | | memory: Remove unused GetSpecialHandlers() function | ||||
| * | | memory: Remove unused GetSpecialHandlers() function | Lioncash | 2018-08-03 | 1 | -16/+0 |
| | | | | | | | | | | | | This is just unused code, so we may as well get rid of it. | ||||
* | | | Merge pull request #914 from lioncash/codeset | bunnei | 2018-08-04 | 5 | -20/+41 |
|\ \ \ | | | | | | | | | kernel/process: Use accessors instead of class members for referencing segment array | ||||
| * | | | kernel/process: Use std::array where applicable | Lioncash | 2018-08-03 | 1 | -1/+2 |
| | | | | |||||
| * | | | kernel/process: Use accessors instead of class members for referencing segment array | Lioncash | 2018-08-03 | 5 | -20/+40 |
| |/ / | | | | | | | | | | | | | | | | | | | Using member variables for referencing the segments array increases the size of the class in memory for little benefit. The same behavior can be achieved through the use of accessors that just return the relevant segment. | ||||
* / / | kernel/thread: Fix potential crashes introduced in 26de4bb521b1ace7af76eff4f6956cb23ac0d58c | Lioncash | 2018-08-04 | 3 | -13/+38 |
|/ / | | | | | | | | | | | This amends cases where crashes can occur that were missed due to the odd way the previous code was set up (using 3DS memory regions that don't exist). | ||||
* | | Merge pull request #908 from lioncash/memory | bunnei | 2018-08-03 | 14 | -502/+29 |
|\ \ | | | | | | | core/memory: Get rid of 3DS leftovers | ||||
| * | | core/memory: Get rid of 3DS leftovers | Lioncash | 2018-08-03 | 14 | -502/+29 |
| | | | | | | | | | | | | Removes leftover code from citra that isn't needed. | ||||
* | | | Added ability to change username & language code in the settings ui. Added IProfile::Get and SET::GetLanguageCode for libnx tests (#851) | David | 2018-08-03 | 5 | -5/+47 |
| | | | |||||
* | | | Merge pull request #898 from lioncash/mig | bunnei | 2018-08-03 | 4 | -0/+53 |
|\ \ \ | |/ / |/| | | service: Add migration services | ||||
| * | | service: Add migration services | Lioncash | 2018-08-02 | 4 | -0/+53 |
| | | | | | | | | | | | | | | | Adds the basic skeleton for the mig:usr service based off information provided by Switch Brew. | ||||
* | | | Merge pull request #892 from lioncash/global | bunnei | 2018-08-03 | 3 | -11/+11 |
|\ \ \ | | | | | | | | | video_core: Make global EmuWindow instance part of the base renderer … | ||||
| * | | | video_core: Make global EmuWindow instance part of the base renderer class | Lioncash | 2018-08-02 | 3 | -11/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes the global a member of the RendererBase class. We also change this to be a reference. Passing any form of null pointer to these functions is incorrect entirely, especially given the code itself assumes that the pointer would always be in a valid state. This also makes it easier to follow the lifecycle of instances being used, as we explicitly interact the renderer with the rasterizer, rather than it just operating on a global pointer. | ||||
* | | | | Merge pull request #894 from lioncash/object | bunnei | 2018-08-03 | 43 | -155/+185 |
|\ \ \ \ | | | | | | | | | | | kernel: Move object class to its own source files | ||||
| * | | | | kernel: Move object class to its own source files | Lioncash | 2018-08-02 | 43 | -155/+185 |
| | |/ / | |/| | | | | | | | | | | | | | | | | | | General moving to keep kernel object types separate from the direct kernel code. Also essentially a preliminary cleanup before eliminating global kernel state in the kernel code. | ||||
* | | | | Merge pull request #904 from lioncash/static | bunnei | 2018-08-03 | 1 | -8/+6 |
|\ \ \ \ | | | | | | | | | | | kernel/thread: Minor changes | ||||
| * | | | | kernel/thread: Make GetFreeThreadLocalSlot()'s loop indices size_t | Lioncash | 2018-08-02 | 1 | -8/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids using a u32 to compare against a range of size_t, which can be a source of warnings. While we're at it, compress a std::tie into a structured binding. | ||||
| * | | | | kernel/thread: Make GetFreeThreadLocalSlot() reference parameter a const reference | Lioncash | 2018-08-02 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | This function only reads the data being referenced, it doesn't modify it, so we can turn the reference into a const reference. | ||||
| * | | | | kernel/thread: Make GetFreeThreadLocalSlot() internally linked | Lioncash | 2018-08-02 | 1 | -1/+1 |
| |/ / / | | | | | | | | | | | | | | | | | This function isn't used outside of this translation unit, so we can make it internally linked. | ||||
* | | | | Merge pull request #905 from lioncash/vma | bunnei | 2018-08-03 | 3 | -23/+23 |
|\ \ \ \ | | | | | | | | | | | kernel/vm_manager: Minor changes | ||||
| * | | | | kernel/vm_manager: Convert loop into std::any_of() | Lioncash | 2018-08-02 | 1 | -4/+4 |
| | | | | | |||||
| * | | | | kernel/vm_manager: Use const where applicable | Lioncash | 2018-08-02 | 3 | -19/+19 |
| | | | | | | | | | | | | | | | | | | | | Makes our immutable state explicit. | ||||
| * | | | | kernel/vm_manager: Use the VAddr type alias in CarveVMA() | Lioncash | 2018-08-02 | 1 | -2/+2 |
| |/ / / | | | | | | | | | | | | | These two variables correspond to address ranges. | ||||
* | | | | Merge pull request #903 from lioncash/copy | bunnei | 2018-08-03 | 1 | -3/+6 |
|\ \ \ \ | | | | | | | | | | | vfs_vector: Minor changes | ||||
| * | | | | vfs_vector: Remove unused variable in FindAndRemoveVectorElement() | Lioncash | 2018-08-02 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | This wasn't being used for anything, so it can be removed. | ||||
| * | | | | vfs_vector: Avoid unnecessary copies where applicable | Lioncash | 2018-08-02 | 1 | -2/+5 |
| |/ / / | | | | | | | | | | | | | | | | | The lambda elements should be taken by const reference here, and we can move the virtual directory passed to ReplaceFileWithSubdirectory() | ||||
* | | | | Merge pull request #899 from lioncash/unused | bunnei | 2018-08-02 | 7 | -334/+0 |
|\ \ \ \ | | | | | | | | | | | hw: Remove unused files | ||||
| * | | | | hw: Remove unused files | Lioncash | 2018-08-02 | 7 | -334/+0 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | None of these files are used in any meaningful way. They're just leftovers from citra. Also has the benefit of getting rid of an unused global variable. | ||||
* | | | | Merge pull request #891 from lioncash/ns | bunnei | 2018-08-02 | 1 | -0/+447 |
|\ \ \ \ | | | | | | | | | | | service/ns: Add missing ns services | ||||
| * | | | | service/ns: Add missing ns services | Lioncash | 2018-08-02 | 1 | -0/+447 |
| | |/ / | |/| | | | | | | | | | | | | | | | | | | Implements the basic skeleton of ns:am2, ns:ec, ns:rid, ns:rt, ns:su, ns:vm, and ns:web based off the information provided by Switch Brew and SwIPC. | ||||
* | | | | service: Add psc services | Lioncash | 2018-08-02 | 4 | -0/+96 |
| |/ / |/| | | | | | | | | | | | Adds the basic skeleton for the psc services based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #888 from lioncash/caps | bunnei | 2018-08-02 | 4 | -0/+171 |
|\ \ \ | | | | | | | | | service: Add capture services | ||||
| * | | | service: Add capture services | Lioncash | 2018-08-01 | 4 | -0/+171 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton for the capture services based off information provided by Switch Brew. | ||||
* | | | Merge pull request #890 from lioncash/logger | bunnei | 2018-08-02 | 1 | -4/+4 |
|\ \ \ | | | | | | | | | lm: Amend name of ILogger | ||||
| * | | | lm: Amend name of ILogger | Lioncash | 2018-08-01 | 1 | -4/+4 |
| |/ / | | | | | | | | | | | | | Previously this was being registered with the name "Logger". While we're at it, also change the name of the class to match it. | ||||
* | | | Merge pull request #889 from lioncash/fsp | bunnei | 2018-08-02 | 6 | -0/+89 |
|\ \ \ | | | | | | | | | service/filesystem: Add fsp:ldr and fsp:pr services | ||||
| * | | | service/filesystem: Add fsp:ldr and fsp:pr services | Lioncash | 2018-08-01 | 6 | -0/+89 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton for the remaining fsp services based off information provided by Switch Brew. | ||||
* / / | service: Add bpc and pcv services | Lioncash | 2018-08-01 | 6 | -0/+179 |
|/ / | | | | | | | | | Adds the basic skeleton for the remaining pcv-related services based off information on Switch Brew. | ||||
* | | Merge pull request #882 from lioncash/unused | bunnei | 2018-08-01 | 1 | -6/+0 |
|\ \ | |/ |/| | kernel/thread: Remove unimplemented function prototype | ||||
| * | kernel/thread: Remove unimplemented function prototype | Lioncash | 2018-08-01 | 1 | -6/+0 |
| | | | | | | | | | | Given there's no implementation, we may as well remove the code entirely. | ||||
* | | Merge pull request #871 from bunnei/audio-config | bunnei | 2018-08-01 | 1 | -0/+5 |
|\ \ | |/ |/| | audio_core: Add configuration settings. | ||||
| * | audio_core: Add configuration settings. | bunnei | 2018-08-01 | 1 | -0/+5 |
| | | |||||
* | | Merge pull request #877 from lioncash/remove | bunnei | 2018-08-01 | 6 | -104/+0 |
|\ \ | | | | | | | kernel: Remove unused object_address_table.cpp/.h | ||||
| * | | kernel: Remove unused object_address_table.cpp/.h | Lioncash | 2018-07-31 | 6 | -104/+0 |
| | | | | | | | | | | | | | | | | | | These source files were entirely unused throughout the rest of the codebase. This also has the benefit of getting rid of a global variable as well. | ||||
* | | | Merge pull request #880 from lioncash/audio | bunnei | 2018-08-01 | 14 | -2/+289 |
|\ \ \ | |_|/ |/| | | service/audio: Add missing services | ||||
| * | | service/audio: Add missing services | Lioncash | 2018-08-01 | 14 | -2/+289 |
| | | | | | | | | | | | | | | | Adds the missing audctl service, as well as the :a and :d services for audin, audout, audrec, and audren. | ||||
* | | | Merge pull request #876 from lioncash/include | bunnei | 2018-08-01 | 23 | -28/+47 |
|\ \ \ | | | | | | | | | kernel: Remove unnecessary includes | ||||
| * | | | kernel: Remove unnecessary includes | Lioncash | 2018-07-31 | 23 | -28/+47 |
| | |/ | |/| | | | | | | | | | | Removes unnecessary direct dependencies in some headers and also gets rid of indirect dependencies that were being relied on to be included. | ||||
* | | | Merge pull request #879 from lioncash/audio | bunnei | 2018-08-01 | 1 | -1/+1 |
|\ \ \ | |_|/ |/| | | audout_u: Remove std::move in OpenAudioOutImpl() | ||||
| * | | audout_u: Remove std::move in OpenAudioOutImpl() | Lioncash | 2018-07-31 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | Previously the code was using the values from params further below after it was std::moved. Thankfully, given AudoutParams is a trivially copyable struct, the values would have simply been copied in this instance and not invalidated to garbage values. | ||||
* | | | Merge pull request #869 from Subv/ubsan | bunnei | 2018-07-31 | 2 | -6/+17 |
|\ \ \ | | | | | | | | | Corrected a few error cases detected by asan/ubsan | ||||
| * | | | nvhost_gpu: Added checks to ensure we don't read past the end of the entries when handling a GPU command list. | Subv | 2018-07-31 | 1 | -3/+6 |
| | | | | |||||
| * | | | nvhost_ctrl_gpu: Only read the input parameters if they are actually there. | Subv | 2018-07-31 | 1 | -3/+11 |
| | | | | | | | | | | | | | | | | Passing nullptr to memcpy is undefined behavior. | ||||
* | | | | Merge pull request #875 from lioncash/fgm | bunnei | 2018-07-31 | 4 | -0/+94 |
|\ \ \ \ | | | | | | | | | | | service: Add fgm services | ||||
| * | | | | service: Add fgm services | Lioncash | 2018-07-31 | 4 | -0/+94 |
| | |_|/ | |/| | | | | | | | | | | | | | | Adds the basic skeleton for the fgm services based off the information provided by Switch Brew. | ||||
* | | | | Merge pull request #874 from lioncash/am | bunnei | 2018-07-31 | 8 | -0/+156 |
|\ \ \ \ | |_|_|/ |/| | | | service/am: Add missing am services | ||||
| * | | | service/am: Add missing am services | Lioncash | 2018-07-31 | 8 | -0/+156 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton for missing am services idle:sys, omm, and spsm based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #870 from lioncash/init | bunnei | 2018-07-31 | 1 | -9/+7 |
|\ \ \ | | | | | | | | | arm_dynarmic: Correct initializer list order | ||||
| * | | | arm_dynarmic: Make SetTlsAddress() prototype and definition consistent | Lioncash | 2018-07-31 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | Makes the definition use the same type aliases as in its prototype. | ||||
| * | | | arm_dynarmic: Remove unnecessary qualifying of ThreadContext | Lioncash | 2018-07-31 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | Given the ARM_Dynarmic class inherits from ARM_Interface, we don't need to qualify here. | ||||
| * | | | arm_dynarmic: Correct initializer list order | Lioncash | 2018-07-31 | 1 | -5/+3 |
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | Amends the initializer list to be in the same order that each variable would be initialized in. We also do this to ensure we don't use a bogus uninitialized instance of the exclusive monitor within MakeJit() We can also remove the jit member from the initializer list as this is initialized by PageTableChanged() | ||||
* / / | service: Add the pcie service | Lioncash | 2018-07-31 | 4 | -0/+83 |
|/ / | | | | | | | | | Adds the basic skeleton of the pcie service based off information on Switch Brew. | ||||
* | | audio_core: Move to audout_u impl. | bunnei | 2018-07-31 | 4 | -13/+6 |
| | | | | | | | | - This is necessary so streams are created on the same thread. | ||||
* | | Implemented various hwopus functions (#853) | David | 2018-07-31 | 3 | -6/+132 |
| | | |||||
* | | Merge pull request #858 from lioncash/cast | bunnei | 2018-07-30 | 1 | -3/+2 |
|\ \ | | | | | | | partition_filesystem: Remove dynamic_cast in PrintDebugInfo() | ||||
| * | | partition_filesystem: Remove dynamic_cast in PrintDebugInfo() | Lioncash | 2018-07-29 | 1 | -3/+2 |
| | | | | | | | | | | | | | | | | | | | | | We shouldn't be upcasting our file instances. Given a PartitionFilesystem is currently designed to accept any arbitrary VfsFile instances, casting to a more specific type than that is just bad design, and shows an interface design issue. | ||||
* | | | Merge pull request #857 from lioncash/wlan | bunnei | 2018-07-30 | 4 | -1/+192 |
|\ \ \ | | | | | | | | | service: Add wlan services | ||||
| * | | | service: Add wlan services | Lioncash | 2018-07-29 | 4 | -1/+192 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton for the wlan services based off the information on Switch Brew. | ||||
* | | | Merge pull request #856 from lioncash/btm | bunnei | 2018-07-30 | 4 | -0/+140 |
|\ \ \ | | | | | | | | | service: Add btm services | ||||
| * | | | service/btm: Add basic implementation of GetCoreImpl() | Lioncash | 2018-07-29 | 1 | -1/+35 |
| | | | | | | | | | | | | | | | | Based off information on SwIPC and Switch Brew. | ||||
| * | | | service: Add btm services | Lioncash | 2018-07-29 | 4 | -0/+106 |
| |/ / | | | | | | | | | | | | | Adds the skeleton for the btm services based off the information on Switch Brew. | ||||
* / / | Add some HID commands (#843) | Hexagon12 | 2018-07-30 | 1 | -2/+16 |
|/ / | | | | | | | | | | | * Added some HID commands * Addressed comments | ||||
* | | Merge pull request #847 from lioncash/ncm | bunnei | 2018-07-28 | 4 | -0/+78 |
|\ \ | | | | | | | service: Add ncm services | ||||
| * | | service: Add ncm services | Lioncash | 2018-07-27 | 4 | -0/+78 |
| | | | | | | | | | | | | | | | Adds the basic skeleton for the ncm services based off information on Switch Brew. | ||||
* | | | Merge pull request #846 from lioncash/mii | bunnei | 2018-07-28 | 4 | -0/+126 |
|\ \ \ | | | | | | | | | service: Add mii services | ||||
| * | | | service: Add mii services | Lioncash | 2018-07-27 | 4 | -0/+126 |
| | | | | | | | | | | | | | | | | | | | | Adds the skeleton for the mii services based off information provided by Switch Brew | ||||
* | | | | Merge pull request #842 from bunnei/audio-core | bunnei | 2018-07-28 | 5 | -94/+124 |
|\ \ \ \ | | | | | | | | | | | Initial implementation of Audio Core | ||||
| * | | | | audout: Implement IAudioOut interface with AudioCore. | bunnei | 2018-07-28 | 2 | -93/+114 |
| | | | | | |||||
| * | | | | core: Add AudioCore to global state. | bunnei | 2018-07-28 | 2 | -0/+9 |
| | | | | | |||||
| * | | | | audio_core: Add initial code for keeping track of audout state. | bunnei | 2018-07-28 | 1 | -1/+1 |
| | |/ / | |/| | | |||||
* / | | | RomFS Extraction | Zach Hilman | 2018-07-28 | 12 | -20/+351 |
|/ / / | |||||
* | | | Merge pull request #845 from lioncash/nfc | bunnei | 2018-07-27 | 4 | -0/+241 |
|\ \ \ | | | | | | | | | service: Add nfc services | ||||
| * | | | service/nfc: Implement Create[x]Interface functions | Lioncash | 2018-07-27 | 1 | -4/+43 |
| | | | | | | | | | | | | | | | | These simply return the respective interface. | ||||
| * | | | service: Add nfc services | Lioncash | 2018-07-27 | 4 | -0/+202 |
| |/ / | | | | | | | | | | | | | Adds the skeleton of the nfc service based off the information provided on Switch Brew. | ||||
* | | | Merge pull request #844 from lioncash/lbl | bunnei | 2018-07-27 | 4 | -0/+109 |
|\ \ \ | | | | | | | | | service: Add the lbl service | ||||
| * | | | service/lbl: Implement EnableVrMode, DisableVrMode and GetVrMode | Lioncash | 2018-07-27 | 1 | -3/+35 |
| | | | | | | | | | | | | | | | | | | | | Implements these functions according to the information available on Switch Brew. | ||||
| * | | | service: Add the lbl service | Lioncash | 2018-07-27 | 4 | -0/+77 |
| |/ / | | | | | | | | | | | | | Adds the skeleton of the lbl service based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #841 from lioncash/btdrv | bunnei | 2018-07-27 | 4 | -1/+93 |
|\ \ \ | |/ / |/| | | service: Add the btdrv service | ||||
| * | | service: Add the btdrv service | Lioncash | 2018-07-27 | 4 | -1/+93 |
| | | | | | | | | | | | | Adds the skeleton for the btdrv service based off the information provided by Switch Brew | ||||
* | | | Merge pull request #837 from lioncash/priv | bunnei | 2018-07-27 | 1 | -5/+17 |
|\ \ \ | | | | | | | | | kernel/timer: Make data members private where applicable | ||||
| * | | | kernel/timer: Make data members private where applicable | Lioncash | 2018-07-26 | 1 | -5/+17 |
| | | | | | | | | | | | | | | | | | | | | Instead, we can just expose functions that return the queryable state instead of letting anything modify it. | ||||
* | | | | service/hid: Add the hidbus, hid:dbg, hid:sys, and hid:tmp services | Lioncash | 2018-07-26 | 1 | -0/+220 |
| | | | | |||||
* | | | | service/hid: Add the xcd:sys service | Lioncash | 2018-07-26 | 4 | -0/+57 |
| | | | | |||||
* | | | | service/hid: Add irs services | Lioncash | 2018-07-26 | 4 | -0/+75 |
| |/ / |/| | | |||||
* | | | Merge pull request #834 from lioncash/grc | bunnei | 2018-07-26 | 4 | -0/+50 |
|\ \ \ | | | | | | | | | service: Add the grc:c service | ||||
| * | | | service: Add the grc:c service | Lioncash | 2018-07-26 | 4 | -0/+50 |
| |/ / | | | | | | | | | | | | | Adds the basic skeleton for the grc:c service based off the information provided by Switch Brew. | ||||
* | | | Merge pull request #832 from lioncash/nim | bunnei | 2018-07-26 | 4 | -0/+143 |
|\ \ \ | | | | | | | | | service: Add the nim services | ||||
| * | | | service: Add the nim services | Lioncash | 2018-07-26 | 4 | -0/+143 |
| |/ / | | | | | | | | | | | | | Adds the skeleton for the nim services based off information from Switch Brew. | ||||
* | | | Merge pull request #831 from lioncash/ldn | bunnei | 2018-07-26 | 4 | -0/+162 |
|\ \ \ | | | | | | | | | service: Add ldn services | ||||
| * | | | service: Add ldn services | Lioncash | 2018-07-26 | 4 | -0/+162 |
| |/ / | | | | | | | | | | Adds ldn services based off information provided by Switch Brew. | ||||
* | | | Merge pull request #830 from lioncash/socket | bunnei | 2018-07-26 | 6 | -0/+95 |
|\ \ \ | |_|/ |/| | | service/sockets: Add missing socket services | ||||
| * | | service/sockets: Add ethc:c and ethc:i services | Lioncash | 2018-07-26 | 4 | -0/+66 |
| | | | |||||
| * | | service/sockets: Add missing bsdcfg socket service | Lioncash | 2018-07-26 | 3 | -0/+29 |
| |/ | |||||
* | | Merge pull request #827 from lioncash/log | bunnei | 2018-07-26 | 2 | -40/+35 |
|\ \ | |/ |/| | service/lm: Minor changes | ||||
| * | lm: Move LM's class declaration into the cpp file | Lioncash | 2018-07-26 | 2 | -37/+31 |
| | | | | | | | | | | This isn't used directly outside of this translation unit, so we can hide it from external use. | ||||
| * | lm: Amend names of Initialize() in Logger and Initialize() in LM | Lioncash | 2018-07-26 | 2 | -7/+7 |
| | | | | | | | | Amends these to match the information on Switch Brew. | ||||
| * | lm: Add missing function entry to Logger's function table | Lioncash | 2018-07-26 | 1 | -0/+1 |
| | | |||||
* | | Merge pull request #828 from lioncash/ldr | Sebastian Valle | 2018-07-26 | 4 | -0/+101 |
|\ \ | | | | | | | service: Add ldr services | ||||
| * | | service: Add ldr services | Lioncash | 2018-07-26 | 4 | -0/+101 |
| | | | | | | | | | | | | | | | Adds the skeleton for the ldr-related services based off the information provided on Switch Brew. | ||||
* | | | Merge pull request #826 from lioncash/erpt | Sebastian Valle | 2018-07-26 | 6 | -0/+143 |
|\ \ \ | | | | | | | | | service: Add erpt and eupld services | ||||
| * | | | service: Add eupld services | Lioncash | 2018-07-26 | 4 | -0/+72 |
| | | | | | | | | | | | | | | | | | | | | Adds the skeleton for the eupld services based off information on Switch Brew. | ||||
| * | | | service: Add the erpt services | Lioncash | 2018-07-26 | 4 | -0/+71 |
| | |/ | |/| | | | | | | | | | | Adds the basic skeleton of the erpt service based off information on Switch Brew. | ||||
* | | | Merge pull request #823 from lioncash/nifm | Sebastian Valle | 2018-07-26 | 9 | -141/+30 |
|\ \ \ | |_|/ |/| | | service/nifm: Deduplicate interface code | ||||
| * | | service/nifm: Deduplicate interface code | Lioncash | 2018-07-25 | 9 | -141/+30 |
| | | | | | | | | | | | | | | | Rather than having the same code for each nifm service variant, we can centralize it on one class and get rid of a bit of extra code. | ||||
* | | | Merge pull request #824 from lioncash/nvdrv | bunnei | 2018-07-26 | 2 | -5/+7 |
|\ \ \ | | | | | | | | | service/nvdrv: Minor changes | ||||
| * | | | service/nvdrv: Take std::string in Open() by const reference | Lioncash | 2018-07-25 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids copies from being made, since the string is only ever used for lookup, the data is never transfered anywhere. Ideally, we'd use a std::string_view here, but devices is a std::unordered_map, not a std::map, so we can't use heterogenous lookup here. | ||||
| * | | | service/nvdrv: Use std::move where applicable | Lioncash | 2018-07-25 | 1 | -3/+5 |
| |/ / | | | | | | | | | | | | | | | | | | | Avoids unnecessary reference count increments and decrements. In one case, we don't need to make a shared_ptr copy at all, just to call a member function. | ||||
* | | | Merge pull request #822 from lioncash/pm | bunnei | 2018-07-26 | 4 | -0/+90 |
|\ \ \ | |_|/ |/| | | service: Add pm services | ||||
| * | | service: Add pm services | Lioncash | 2018-07-25 | 4 | -0/+90 |
| |/ | | | | | | | | | Adds the skeleton for the process management services based off information on Switch Brew. | ||||
* / | service: Add the es service | Lioncash | 2018-07-25 | 4 | -0/+77 |
|/ | | | | | Adds the skeleton for the ETicket service based off the information on Switch Brew | ||||
* | Merge pull request #801 from lioncash/time | Mat M | 2018-07-25 | 6 | -64/+16 |
|\ | | | | | time: Add the time:a service | ||||
| * | time: Add the time:a service | Lioncash | 2018-07-25 | 3 | -10/+11 |
| | | | | | | | | Given we already have time:s and time:u, we should also have time:a | ||||
| * | time: Simplify interface creation | Lioncash | 2018-07-24 | 6 | -64/+15 |
| | | | | | | | | We can use one instance of the interface instead of duplicating code. | ||||
* | | Merge pull request #804 from lioncash/log | Mat M | 2018-07-25 | 1 | -1/+3 |
|\ \ | | | | | | | svc: Log parameters in SetMemoryAttribute() | ||||
| * | | svc: Log parameters in SetMemoryAttribute() | Lioncash | 2018-07-24 | 1 | -1/+3 |
| | | | | | | | | | | | | Provides slightly more context than only logging out the address value. | ||||
* | | | Merge pull request #803 from MerryMage/core_timing_util | bunnei | 2018-07-25 | 12 | -114/+146 |
|\ \ \ | | | | | | | | | core_timing: Split off utility functions into core_timing_util | ||||
| * | | | core_timing: Split off utility functions into core_timing_util | MerryMage | 2018-07-24 | 12 | -105/+137 |
| | | | | |||||
| * | | | CMakeLists: Sort filenames | MerryMage | 2018-07-24 | 1 | -9/+9 |
| | | | | |||||
* | | | | Merge pull request #800 from lioncash/set | bunnei | 2018-07-25 | 3 | -5/+33 |
|\ \ \ \ | | | | | | | | | | | set_sys: Implement SetColorSetId() | ||||
| * | | | | set_sys: Implement SetColorSetId() | Lioncash | 2018-07-24 | 2 | -5/+25 |
| | | | | | |||||
| * | | | | ipc_helper: Add helper member function for popping enum values to RequestParser | Lioncash | 2018-07-24 | 1 | -0/+8 |
| | |_|/ | |/| | | |||||
* | | | | Merge pull request #806 from lioncash/friend | bunnei | 2018-07-25 | 6 | -48/+15 |
|\ \ \ \ | | | | | | | | | | | friend: Deduplicate interfaces | ||||
| * | | | | friend: Add friend:m, friend:s, and friend:v services | Lioncash | 2018-07-24 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Given we already have friend:a and friend:u, we should add the remaining services as well. | ||||
| * | | | | friend/interface: Add missing CreateDaemonSuspendSessionService() to the function handler table | Lioncash | 2018-07-24 | 1 | -0/+1 |
| | | | | | |||||
| * | | | | friend: Deduplicate interfaces | Lioncash | 2018-07-24 | 6 | -48/+11 |
| | |_|/ | |/| | | |||||
* | | | | Merge pull request #805 from lioncash/sign | bunnei | 2018-07-24 | 1 | -4/+7 |
|\ \ \ \ | | | | | | | | | | | svc: Resolve sign comparison warnings in WaitSynchronization() | ||||
| * | | | | svc: Resolve sign comparison warnings in WaitSynchronization() | Lioncash | 2018-07-24 | 1 | -4/+7 |
| |/ / / | | | | | | | | | | | | | | | | | The loop's induction variable was signed, but we were comparing against an unsigned variable. | ||||
* / / / | deconstructed_rom_directory: Remove unused FindRomFS() function | Lioncash | 2018-07-24 | 1 | -29/+0 |
|/ / / | |||||
* | | | Merge pull request #798 from lioncash/const | bunnei | 2018-07-24 | 2 | -3/+3 |
|\ \ \ | | | | | | | | | arm_dynarmic: Make MakeJit() a const member function | ||||
| * | | | arm_dynarmic: Make MakeJit() a const member function | Lioncash | 2018-07-24 | 2 | -3/+3 |
| |/ / | | | | | | | | | | | | | This functions doesn't modify instance state, so it can be a made a const member function. | ||||
* | | | Merge pull request #797 from lioncash/explicit | bunnei | 2018-07-24 | 5 | -5/+5 |
|\ \ \ | | | | | | | | | core: Make converting constructors explicit where applicable | ||||
| * | | | core: Make converting constructors explicit where applicable | Lioncash | 2018-07-24 | 5 | -5/+5 |
| |/ / | | | | | | | | | | | | | Avoids unwanted implicit conversions. Thankfully, given the large amount of cleanup in past PRs, only this tiny amount is left over to cover. | ||||
* | | | Merge pull request #795 from lioncash/decl | bunnei | 2018-07-24 | 1 | -3/+0 |
|\ \ \ | | | | | | | | | apm/interface: Remove redundant declaration of InstallInterfaces() | ||||
| * | | | apm/interface: Remove redundant declaration of InstallInterfaces() | Lioncash | 2018-07-24 | 1 | -3/+0 |
| |/ / | | | | | | | | | | This is already declared in apm/apm.h | ||||
* | | | Merge pull request #794 from lioncash/ref | bunnei | 2018-07-24 | 1 | -1/+1 |
|\ \ \ | |_|/ |/| | | mutex: Pass SharedPtr to GetHighestPriorityMutexWaitingThread() by reference | ||||
| * | | mutex: Pass SharedPtr to GetHighestPriorityMutexWaitingThread() by reference | Lioncash | 2018-07-24 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | The pointed to thread's members are simply observed in this case, so we don't need to copy it here. | ||||
* | | | Merge pull request #793 from lioncash/priv | bunnei | 2018-07-24 | 2 | -17/+19 |
|\ \ \ | | | | | | | | | ipc_helpers: Make member variables of ResponseBuilder private | ||||
| * | | | hle_ipc: Make constructors explicit where applicable | Lioncash | 2018-07-24 | 2 | -12/+13 |
| | | | | |||||
| * | | | ipc_helpers: Make member variables of ResponseBuilder private | Lioncash | 2018-07-24 | 1 | -5/+6 |
| |/ / | | | | | | | | | | These aren't used externally at all, so they can be made private. | ||||
* | | | Merge pull request #785 from lioncash/fs | bunnei | 2018-07-24 | 1 | -3/+3 |
|\ \ \ | |_|/ |/| | | partition_filesystem: Use std::move where applicable | ||||
| * | | partition_filesystem: Use std::move where applicable | Lioncash | 2018-07-24 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | Avoids copying a std::string instance and avoids unnecessary atomic reference count incrementing and decrementing. | ||||
* | | | VFS Regression and Accuracy Fixes (#776) | Zach Hilman | 2018-07-24 | 3 | -36/+62 |
| |/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Regression and Mode Fixes * Review Fixes * string_view correction * Add operator& for FileSys::Mode * Return std::string from SanitizePath * Farming Simulator Fix * Use != With mode operator& | ||||
* | | Merge pull request #786 from lioncash/exclusive | bunnei | 2018-07-24 | 3 | -22/+18 |
|\ \ | | | | | | | exclusive_monitor: Use consistent type alias for u64 | ||||
| * | | exclusive_monitor: Use consistent type alias for u64 | Lioncash | 2018-07-24 | 3 | -22/+18 |
| |/ | | | | | | | | | Uses the same type aliases we use for virtual addresses, and converts one lingering usage of std::array<uint64_t, 2> to u128 for consistency. | ||||
* | | Merge pull request #784 from lioncash/loader | bunnei | 2018-07-24 | 1 | -1/+1 |
|\ \ | | | | | | | loader: Minor cleanup | ||||
| * | | loader: Remove unnecessary constructor call in IdentifyFile() | Lioncash | 2018-07-23 | 1 | -1/+1 |
| |/ | | | | | | | | | | | RealVfsFile inherits from VfsFile, the instance from std::make_shared is already compatible with the function argument type, making the copy constructor call unnecessary. | ||||
* | | Merge pull request #783 from lioncash/linker | bunnei | 2018-07-24 | 2 | -7/+4 |
|\ \ | | | | | | | linker: Remove unused parameter from WriteRelocations() | ||||
| * | | linker: Remove unused parameter from WriteRelocations() | Lioncash | 2018-07-23 | 2 | -7/+4 |
| |/ | | | | | | | | | is_jump_relocation is never used within the function, so we can just remove it. | ||||
* | | Merge pull request #782 from lioncash/file | bunnei | 2018-07-24 | 2 | -14/+33 |
|\ \ | | | | | | | loader/nro: Minor changes | ||||
| * | | nro: Replace inclusion with a forward declaration | Lioncash | 2018-07-23 | 2 | -1/+8 |
| | | | | | | | | | | | | | | | It's sufficient to use a forward declaration instead of a direct inclusion here. | ||||
| * | | nro: Make bracing consistent | Lioncash | 2018-07-23 | 1 | -10/+24 |
| | | | | | | | | | | | | | | | Makes the code more uniform, and also braces cases where the body of an unbraced conditional travels more than one line. | ||||
| * | | nro: Make constructor explicit | Lioncash | 2018-07-23 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | Makes it consistent with the other Apploader constructors, and prevents implicit conversions. | ||||
| * | | nro: Remove unused forward declaration | Lioncash | 2018-07-23 | 1 | -2/+0 |
| |/ | | | | | | | This isn't used anywhere in the header. | ||||
* | | Merge pull request #780 from lioncash/move | bunnei | 2018-07-24 | 1 | -11/+22 |
|\ \ | | | | | | | vi: Minor changes | ||||
| * | | vi: Add std::is_trivially_copyable checks to Read and Write functions | Lioncash | 2018-07-23 | 1 | -2/+13 |
| | | | | | | | | | | | | | | | | | | It's undefined behavior to memcpy an object that isn't considered trivially copyable, so put a compile-time check in to make sure this doesn't occur. | ||||
| * | | vi: std::move std::vector in constructors where applicable | Lioncash | 2018-07-23 | 1 | -9/+9 |
| | | | | | | | | | | | | | | | | | | | | | Allows avoiding unnecessary copies of the vector depending on the calling code. While we're at it, remove a redundant no-parameter base constructor call | ||||
* | | | Merge pull request #779 from lioncash/shared | bunnei | 2018-07-24 | 8 | -263/+0 |
|\ \ \ | |_|/ |/| | | hle: Remove unused config_mem and shared_page source files | ||||
| * | | hle: Remove config_mem.h/.cpp | Lioncash | 2018-07-23 | 6 | -102/+0 |
| | | | | | | | | | | | | | | | This is just an unused hold-over from citra, so we can get rid of this to trim off an exposed global, among other things. | ||||
| * | | hle: Remove shared_page.h/.cpp | Lioncash | 2018-07-23 | 6 | -161/+0 |
| |/ | | | | | | | This is a holdover from citra that's essentially unused. | ||||
* | | Merge pull request #695 from DarkLordZach/nro-asset | bunnei | 2018-07-23 | 5 | -1/+215 |
|\ \ | | | | | | | NRO Assets and NACP File Format | ||||
| * | | NRO Assets and NACP file format | Zach Hilman | 2018-07-23 | 5 | -1/+215 |
| | | | | | | | | | | | | | | | | | | Cleanup Review fixes | ||||
* | | | set: Add missing log call in GetAvailableLanguageCodeCount() | Lioncash | 2018-07-23 | 1 | -0/+2 |
| |/ |/| | | | | | Forgot to include this in 22f448b6327044076959e338811ee576f3dcf093 | ||||
* | | Merge pull request #777 from lioncash/lang | bunnei | 2018-07-23 | 2 | -23/+31 |
|\ \ | |/ |/| | set: Amend return value of GetAvailableLanguageCodes() | ||||
| * | set: Implement GetAvailableLanguageCodeCount() | Lioncash | 2018-07-23 | 2 | -21/+29 |
| | | | | | | | | This just returns the size of the language code buffer. | ||||
| * | set: Correct return code size of value in GetAvailableLanguageCodes() | Lioncash | 2018-07-23 | 1 | -2/+2 |
| | | | | | | | | The return code should be 32-bit in size. | ||||
* | | Merge pull request #774 from Subv/atomic_signal | bunnei | 2018-07-22 | 1 | -7/+31 |
|\ \ | |/ |/| | Kernel/SVC: Perform atomic accesses in SignalProcessWideKey as per the real kernel. | ||||
| * | Kernel/SVC: Perform atomic accesses in SignalProcessWideKey as per the real kernel. | Subv | 2018-07-22 | 1 | -7/+31 |
| | | |||||
* | | Merge pull request #768 from lioncash/string-view | bunnei | 2018-07-22 | 8 | -93/+158 |
|\ \ | |/ |/| | file_util, vfs: Use std::string_view where applicable | ||||
| * | vfs: Correct file_p variable usage within InterpretAsDirectory() | Lioncash | 2018-07-22 | 1 | -2/+5 |
| | | | | | | | | | | | | | | | | | | ReplaceFileWithSubdirectory() takes a VirtualFile and a VirtualDir, but it was being passed a string as one of its arguments. The only reason this never caused issues is because this template isn't instantiated anywhere yet. This corrects an issue before it occurs. | ||||
| * | file_util, vfs: Use std::string_view where applicable | Lioncash | 2018-07-22 | 8 | -91/+153 |
| | | | | | | | | | | Avoids unnecessary construction of std::string instances where applicable. | ||||
* | | Implement exclusive monitor | MerryMage | 2018-07-22 | 9 | -13/+160 |
|/ | |||||
* | file_util: Use a u64 to represent number of entries | Lioncash | 2018-07-22 | 2 | -4/+4 |
| | | | | | This avoids a truncating cast on size. I doubt we'd ever traverse a directory this large, however we also shouldn't truncate sizes away. | ||||
* | Merge pull request #760 from lioncash/path | bunnei | 2018-07-22 | 3 | -5/+7 |
|\ | | | | | file_util: Use an enum class for GetUserPath() | ||||
| * | file_util: Use an enum class for GetUserPath() | Lioncash | 2018-07-21 | 3 | -5/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | Instead of using an unsigned int as a parameter and expecting a user to always pass in the correct values, we can just convert the enum into an enum class and use that type as the parameter type instead, which makes the interface more type safe. We also get rid of the bookkeeping "NUM_" element in the enum by just using an unordered map. This function is generally low-frequency in terms of calls (and I'd hope so, considering otherwise would mean we're slamming the disk with IO all the time) so I'd consider this acceptable in this case. | ||||
* | | GPU: Implement the NVGPU_IOCTL_CHANNEL_KICKOFF_PB ioctl2 command. | Subv | 2018-07-21 | 3 | -6/+34 |
|/ | | | | | This behaves quite similarly to the SubmitGPFIFO command. Referenced from Ryujinx. Many thanks to @gdkchan for investigating this! | ||||
* | Merge pull request #754 from lioncash/part | bunnei | 2018-07-21 | 2 | -8/+20 |
|\ | | | | | partition_filesystem, vfs_real: Minor changes | ||||
| * | vfs_real: Remove redundant copying of std::vector instances in GetFiles() and GetSubdirectories() | Lioncash | 2018-07-21 | 1 | -2/+3 |
| | | | | | | | | | | We already return by value, so we don't explicitly need to make the copy. | ||||
| * | partition_filesystem, vfs_real: Add missing standard includes | Lioncash | 2018-07-21 | 2 | -0/+4 |
| | | |||||
| * | partition_filesystem, vfs_real: Use std::move in ReplaceFileWithSubdirectory() where applicable | Lioncash | 2018-07-21 | 2 | -2/+3 |
| | | | | | | | | Avoids unnecessary atomic increment and decrement operations. | ||||
| * | partition_filesystem, vfs_real: Use std::distance() instead of subtraction | Lioncash | 2018-07-21 | 2 | -4/+10 |
| | | | | | | | | This is a little bit more self-documenting on what is being done here. | ||||
* | | Merge pull request #750 from lioncash/ctx | bunnei | 2018-07-21 | 3 | -9/+0 |
|\ \ | | | | | | | arm_interface: Remove unused tls_address member of ThreadContext | ||||
| * | | arm_interface: Remove unused tls_address member of ThreadContext | Lioncash | 2018-07-21 | 3 | -9/+0 |
| |/ | | | | | | | | | Currently, the TLS address is set within the scheduler, making this member unused. | ||||
* | | Merge pull request #755 from lioncash/ctor | bunnei | 2018-07-21 | 1 | -8/+8 |
|\ \ | | | | | | | file_sys/errors: Remove redundant object constructor calls | ||||
| * | | file_sys/errors: Remove redundant object constructor calls | Lioncash | 2018-07-21 | 1 | -8/+8 |
| |/ | | | | | | | | | Given we're already constructing the error code, we don't need to call the constructor inside of it. | ||||
* | | Merge pull request #751 from Subv/tpidr_el0 | bunnei | 2018-07-21 | 8 | -0/+39 |
|\ \ | | | | | | | CPU: Save and restore the TPIDR_EL0 system register on every context switch | ||||
| * | | CPU: Save and restore the TPIDR_EL0 system register on every context switch. | Subv | 2018-07-21 | 8 | -0/+39 |
| | | | | | | | | | | | | Note that there's currently a dynarmic bug preventing this register from being written. | ||||
* | | | Merge pull request #753 from lioncash/const | bunnei | 2018-07-21 | 4 | -21/+15 |
|\ \ \ | | | | | | | | | vfs: Minor changes | ||||
| * | | | vfs_offset: Simplify TrimToFit() | Lioncash | 2018-07-21 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | We can simply use std::clamp() here, instead of using an equivalent with std::max() and std::min(). | ||||
| * | | | vfs: Make WriteBytes() overload taking a std::vector pass the std::vector by const reference | Lioncash | 2018-07-21 | 4 | -4/+4 |
| | | | | | | | | | | | | | | | | | | | | Given the data is intended to be directly written, there's no need to take the std::vector by value and copy the data. | ||||
| * | | | vfs: Use variable template variants of std::is_trivially_copyable | Lioncash | 2018-07-21 | 1 | -13/+6 |
| | | | | | | | | | | | | | | | | Provides the same behavior, but with less writing | ||||
| * | | | vfs: Amend constness on pointers in WriteBytes() and WriteArrays() member functions to be const qualified | Lioncash | 2018-07-21 | 1 | -3/+3 |
| | |/ | |/| | | | | | | | | | | These functions don't modify the data being pointed to, so these can be pointers to const data | ||||
* | | | Merge pull request #752 from Subv/vfs_load | bunnei | 2018-07-21 | 1 | -5/+2 |
|\ \ \ | |/ / |/| | | Loader: Only print the module names and addresses if they actually exist. | ||||
| * | | Loader: Only print the module names and addresses if they actually exist. | Subv | 2018-07-21 | 1 | -5/+2 |
| |/ | |||||
* | | Merge pull request #742 from bunnei/misc-apm | bunnei | 2018-07-21 | 1 | -1/+16 |
|\ \ | | | | | | | apm: Improve stub for GetPerformanceConfiguration. | ||||
| * | | apm: Improve stub for GetPerformanceConfiguration. | bunnei | 2018-07-20 | 1 | -1/+16 |
| | | | |||||
* | | | ipc_helpers: Add PushEnum() member function to ResponseBuilder | Lioncash | 2018-07-20 | 1 | -0/+19 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows pushing strongly-typed enum members without the need to always cast them at the call sites. Note that we *only* allow strongly-typed enums in this case. The reason for this is that strongly typed enums have a guaranteed defined size, so the size of the data being pushed is always deterministic. With regular enums this can be a little more error-prone, so we disallow them. This function simply uses the underlying type of the enum to determine the size of the data. For example, if an enum is defined as: enum class SomeEnum : u16 { SomeEntry }; if PushEnum(SomeEnum::SomeEntry); is called, then it will push a u16-size amount of data. | ||||
* | | Merge pull request #740 from Subv/acc_crash | bunnei | 2018-07-20 | 1 | -6/+8 |
|\ \ | | | | | | | HLE/ACC: Stub IManagerForApplication::GetAccountId to return an error. | ||||
| * | | HLE/ACC: Stub IManagerForApplication::GetAccountId to return an error. | Subv | 2018-07-20 | 1 | -6/+8 |
| |/ | | | | | | | | | | | And make IManagerForApplication::CheckAvailability always return false. Returning a bogus id from GetAccountId causes games to crash on boot. We should investigate this with a hwtest and either stub it properly or implement it. | ||||
* | | Merge pull request #737 from lioncash/move | bunnei | 2018-07-20 | 4 | -5/+9 |
|\ \ | | | | | | | filesys/loader: std::move VirtualFile instances in constructors where applicable | ||||
| * | | loader/{nca, nro}: std::move VirtualFile in the constructors where applicable | Lioncash | 2018-07-20 | 2 | -2/+4 |
| | | | | | | | | | | | | This avoids unnecessary atomic reference count increments and decrements | ||||
| * | | vfs_offset: std::move file and name parameters of OffsetVfsFile | Lioncash | 2018-07-20 | 2 | -3/+5 |
| | | | | | | | | | | | | | | | Avoids potentially unnecessary atomic reference count incrementing and decrementing, as well as string copying. | ||||
* | | | Merge pull request #736 from lioncash/null | bunnei | 2018-07-20 | 2 | -3/+6 |
|\ \ \ | | | | | | | | | audout_u/audren_u: Ensure null terminators are written out in ListAudioOutsImpl(), ListAudioDeviceName(), and GetActiveAudioDeviceName() | ||||
| * | | | audren_u: Use a std::array instead of std::string for holding the audio interface/device name | Lioncash | 2018-07-20 | 1 | -2/+4 |
| | | | | | | | | | | | | | | | | | | | | std::string doesn't include the null-terminator in its data() + size() range. This ensures that the null-terminator will also be written to the buffer | ||||
| * | | | audout_u: Use a std::array instead of std::string for holding the audio interface name | Lioncash | 2018-07-20 | 1 | -1/+2 |
| |/ / | | | | | | | | | | | | | | | | Uses a type that doesn't potentially dynamically allocate, and ensures that the name of the interface is properly null-terminated when writing it to the buffer. | ||||
* | | | Merge pull request #734 from lioncash/thread | bunnei | 2018-07-20 | 9 | -71/+70 |
|\ \ \ | | | | | | | | | thread: Convert ThreadStatus into an enum class | ||||
| * | | | thread: Convert ThreadStatus into an enum class | Lioncash | 2018-07-20 | 9 | -71/+70 |
| |/ / | | | | | | | | | | | | | Makes the thread status strongly typed, so implicit conversions can't happen. It also makes it easier to catch mistakes at compile time. | ||||
* | | | Merge pull request #733 from lioncash/dirs | bunnei | 2018-07-20 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | partition_filesystem: Return pfs_dirs member variable within GetSubdirectories() | ||||
| * | | | partition_filesystem: Return pfs_dirs member variable within GetSubdirectories() | Lioncash | 2018-07-20 | 1 | -1/+1 |
| |/ / | | | | | | | | | | | | | This should be returned here, otherwise pfs_dirs is effectively only ever added to, but never read. | ||||
* | | | Merge pull request #732 from lioncash/unused | bunnei | 2018-07-20 | 1 | -17/+6 |
|\ \ \ | |_|/ |/| | | nso: Minor changes | ||||
| * | | nso: Silence implicit sign conversion warnings | Lioncash | 2018-07-20 | 1 | -4/+6 |
| | | | |||||
| * | | nso: Remove unused function ReadSegment() | Lioncash | 2018-07-20 | 1 | -13/+0 |
| |/ | |||||
* / | pl_u: Simplify WriteBuffer() calls in GetSharedFontInOrderOfPriority() | Lioncash | 2018-07-20 | 1 | -3/+3 |
|/ | | | | With the new overload, we can simply pass the container directly. | ||||
* | Merge pull request #726 from lioncash/overload | bunnei | 2018-07-20 | 5 | -10/+25 |
|\ | | | | | hle_ipc: Introduce generic WriteBuffer overload for multiple container types | ||||
| * | hle_ipc: Introduce generic WriteBuffer overload for multiple container types | Lioncash | 2018-07-19 | 5 | -10/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This introduces a slightly more generic variant of WriteBuffer(). Notably, this variant doesn't constrain the arguments to only accepting std::vector instances. It accepts whatever adheres to the ContiguousContainer concept in the C++ standard library. This essentially means, std::array, std::string, and std::vector can be used directly with this interface. The interface no longer forces you to solely use containers that dynamically allocate. To ensure our overloads play nice with one another, we only enable the container-based WriteBuffer if the argument is not a pointer, otherwise we fall back to the pointer-based one. | ||||
* | | Merge pull request #725 from lioncash/bytes | bunnei | 2018-07-20 | 1 | -3/+3 |
|\ \ | | | | | | | pl_u: Specify correct size for buffers in GetSharedFontInOrderOfPriority() | ||||
| * | | pl_u: Specify correct size for buffers in GetSharedFontInOrderOfPriority() | Lioncash | 2018-07-19 | 1 | -3/+3 |
| |/ | | | | | | | | | This WriteBuffer overload expects its size argument to be in bytes, not elements. | ||||
* | | Merge pull request #728 from Subv/acc_profile | bunnei | 2018-07-20 | 1 | -7/+16 |
|\ \ | | | | | | | HLE/ACC: Change the default user id and small improvements to the way we handle profiles | ||||
| * | | HLE/ACC: Return an IProfile that is consistent with what was requested. | Subv | 2018-07-19 | 1 | -5/+15 |
| | | | | | | | | | | | | | | | The default username for now is "yuzu". We should eventually allow the creation of users in the emulator and have the ability to modify their parameters. | ||||
| * | | HLE/ACC: Change the default user id to be consistent with what we tell games on startup. | Subv | 2018-07-19 | 1 | -2/+1 |
| | | | | | | | | | | | | In IApplicationFunctions::PopLaunchParameter we tell the games that they were launched as user id 1. | ||||
* | | | Merge pull request #727 from Subv/acc_users | bunnei | 2018-07-20 | 1 | -4/+6 |
|\ \ \ | | | | | | | | | HLE/ACC: Write a single whole user id in ListAllUsers and ListOpenUsers. | ||||
| * | | | HLE/ACC: Write a single whole user id in ListAllUsers and ListOpenUsers. | Subv | 2018-07-19 | 1 | -4/+6 |
| |/ / | | | | | | | | | | We only emulate a single user id for now. | ||||
* | | | Merge pull request #724 from lioncash/printf | bunnei | 2018-07-20 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | pl_u: Remove printf specifier in log call in a log call in GetSharedFontInOrderOfPriority() | ||||
| * | | | pl_u: Remove printf specifier in log call in a log call in GetSharedFontInOrderOfPriority() | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | |/ | |/| | | | | | | | This can just use the fmt specifiers and be type-agnostic. | ||||
* | | | Merge pull request #723 from lioncash/gdb | bunnei | 2018-07-20 | 1 | -7/+7 |
|\ \ \ | | | | | | | | | gdbstub: Get rid of a few signed/unsigned comparisons | ||||
| * | | | gdbstub: Get rid of a few signed/unsigned comparisons | Lioncash | 2018-07-19 | 1 | -7/+7 |
| | | | | | | | | | | | | | | | | Ensures both operands in comparisons are the same signedness. | ||||
* | | | | Merge pull request #722 from lioncash/signed | bunnei | 2018-07-20 | 2 | -8/+4 |
|\ \ \ \ | | | | | | | | | | | hid: Resolve a signed/unsigned comparison warning | ||||
| * | | | | hid: Use a ranged-for loops in UpdatePadCallback | Lioncash | 2018-07-19 | 1 | -7/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Modernizes the loops themselves while also getting rid of a signed/unsigned comparison in a loop condition. | ||||
| * | | | | hid: Use HID_NUM_LAYOUTS constant for indicating size of the layouts array | Lioncash | 2018-07-19 | 1 | -1/+1 |
| |/ / / | | | | | | | | | | | | | Gets rid of the use of a magic constant | ||||
* | | | | Merge pull request #721 from lioncash/svc | bunnei | 2018-07-20 | 1 | -3/+4 |
|\ \ \ \ | | | | | | | | | | | svc: Correct always true assertion case in SetThreadCoreMask | ||||
| * | | | | svc: Correct always true assertion case in SetThreadCoreMask | Lioncash | 2018-07-19 | 1 | -3/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The reason this would never be true is that ideal_processor is a u8 and THREADPROCESSORID_DEFAULT is an s32. In this case, it boils down to how arithmetic conversions are performed before performing the comparison. If an unsigned value has a lesser conversion rank (aka smaller size) than the signed type being compared, then the unsigned value is promoted to the signed value (i.e. u8 -> s32 happens before the comparison). No sign-extension occurs here either. An alternative phrasing: Say we have a variable named core and it's given a value of -2. u8 core = -2; This becomes 254 due to the lack of sign. During integral promotion to the signed type, this still remains as 254, and therefore the condition will always be true, because no matter what value the u8 is given it will never be -2 in terms of 32 bits. Now, if one type was a s32 and one was a u32, this would be entirely different, since they have the same bit width (and the signed type would be converted to unsigned instead of the other way around) but would still have its representation preserved in terms of bits, allowing the comparison to be false in some cases, as opposed to being true all the time. --- We also get rid of two signed/unsigned comparison warnings while we're at it. | ||||
* | | | | | Merge pull request #719 from lioncash/docs | bunnei | 2018-07-20 | 2 | -5/+5 |
|\ \ \ \ \ | | | | | | | | | | | | | loader: Amend Doxygen comments | ||||
| * | | | | | loader: Amend Doxygen comments | Lioncash | 2018-07-19 | 2 | -5/+5 |
| |/ / / / | | | | | | | | | | | | | | | | These weren't adjusted when VFS was introduced | ||||
* | | | | | Merge pull request #718 from lioncash/read | bunnei | 2018-07-20 | 1 | -4/+6 |
|\ \ \ \ \ | | | | | | | | | | | | | loader/nso: Check if read succeeded in IdentifyFile() before checking magic value | ||||
| * | | | | | loader/nso: Check if read succeeded in IdentifyFile() before checking magic value | Lioncash | 2018-07-19 | 1 | -4/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We should always assume the filesystem is volatile and check each IO operation. While we're at it reorganize checks so that early-out errors are near one another. | ||||
* | | | | | | Merge pull request #717 from lioncash/explicit | bunnei | 2018-07-20 | 22 | -25/+25 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | hle/service: Make constructors explicit where applicable | ||||
| * | | | | | | hle/service: Make constructors explicit where applicable | Lioncash | 2018-07-19 | 22 | -25/+25 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | Prevents implicit construction and makes these lingering non-explicit constructors consistent with the rest of the other classes in services. | ||||
* | | | | | | Merge pull request #716 from lioncash/construct | bunnei | 2018-07-19 | 1 | -9/+4 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | nvflinger: Emplace Display instances directly | ||||
| * | | | | | | nvflinger: Emplace Display instances directly | Lioncash | 2018-07-19 | 1 | -9/+4 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can use emplace_back to construct the Display instances directly, instead of constructing them separately and copying them, avoiding the need to copy std::string and std::vector instances that are part of the Display struct. | ||||
* | | | | | | Merge pull request #715 from lioncash/const-ref | bunnei | 2018-07-19 | 1 | -1/+1 |
|\ \ \ \ \ \ | |_|_|_|_|/ |/| | | | | | nvdrv: Take std::string by const reference in GetDevice() | ||||
| * | | | | | nvdrv: Take std::string by const reference in GetDevice() | Lioncash | 2018-07-19 | 1 | -1/+1 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | This is only ever used as a lookup into the device map, so we don't need to take the std::string instance by value here. | ||||
* | | | | | Merge pull request #720 from Subv/getentrytype_root | Sebastian Valle | 2018-07-19 | 1 | -0/+4 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | Filesystem: Return EntryType::Directory for the root directory. | ||||
| * | | | | Filesystem: Return EntryType::Directory for the root directory. | Subv | 2018-07-19 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | It is unknown if this is correct behavior, but it makes sense and fixes a regression with Stardew Valley. | ||||
* | | | | | Merge pull request #714 from lioncash/index | Sebastian Valle | 2018-07-19 | 1 | -1/+1 |
|\ \ \ \ \ | | | | | | | | | | | | | hle_ipc: Amend usage of buffer_index within one of HLERequestContext's WriteBuffer() overloads | ||||
| * | | | | | hle_ipc: Amend usage of buffer_index within one of HLERequestContext's WriteBuffer() overloads | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, the buffer_index parameter was unused, causing all writes to use the buffer index of zero, which is not necessarily what is wanted all the time. Thankfully, all current usages don't use a buffer index other than zero, so this just prevents a bug before it has a chance to spring. | ||||
* | | | | | | Merge pull request #712 from lioncash/fsp | bunnei | 2018-07-19 | 1 | -17/+22 |
|\ \ \ \ \ \ | |_|_|_|_|/ |/| | | | | | fsp_srv: Misc individual changes | ||||
| * | | | | | fsp_srv: Remove unnecessary vector construction in IFile's Write() function | Lioncash | 2018-07-19 | 1 | -2/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can avoid constructing a std::vector here by simply passing a pointer to the original data and the size of the copy we wish to perform to the backend's Write() function instead, avoiding copying the data where it's otherwise not needed. | ||||
| * | | | | | fsp_srv: Remove unnecessary std::vector construction in IDirectory's Read() function | Lioncash | 2018-07-19 | 1 | -10/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We were using a second std::vector as a buffer to convert another std::vector's data into a byte sequence, however we can just use pointers to the original data and use them directly with WriteBuffer, which avoids copying the data at all into a separate std::vector. We simply cast the pointers to u8* (which is allowed by the standard, given std::uint8_t is an alias for unsigned char on platforms that we support). | ||||
| * | | | | | fsp_srv: Make IStorage constructor explicit | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | Prevents implicit conversions. | ||||
| * | | | | | fsp_srv: Add missing includes | Lioncash | 2018-07-19 | 1 | -0/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of relying on indirect inclusions. | ||||
| * | | | | | fsp_srv: Resolve sign-mismatch warnings in assertion comparisons | Lioncash | 2018-07-19 | 1 | -3/+3 |
| | | | | | | |||||
| * | | | | | fsp_srv: Respect write length in Write() | Lioncash | 2018-07-19 | 1 | -4/+5 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously we were just copying the data whole-sale, even if the length was less than the total data size. This effectively makes the actual_data vector useless, which is likely not intended. Instead, amend this to only copy the given length amount of data. At the same time, we can avoid zeroing out the data before using it by passing iterators to the constructor instead of a size. | ||||
* | | | | | Merge pull request #713 from lioncash/filesys | bunnei | 2018-07-19 | 1 | -3/+3 |
|\ \ \ \ \ | | | | | | | | | | | | | filesystem: Minor changes | ||||
| * | | | | | filesystem: std::move VirtualDir instance in VfsDirectoryServiceWrapper's constructor | Lioncash | 2018-07-19 | 1 | -1/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | Avoids unnecessary atomic reference count incrementing and decrementing | ||||
| * | | | | | filesystem: Use std::string's empty() function instead of comparing against a literal | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is simply a basic value check as opposed to potentially doing string based operations (unlikely, but still, avoiding it is free). | ||||
| * | | | | | filesystem: Remove pragma disabling global optimizations | Lioncash | 2018-07-19 | 1 | -2/+0 |
| |/ / / / | | | | | | | | | | | | | | | | This was just an artifact missed during PR review. | ||||
* | | | | | Merge pull request #694 from lioncash/warn | bunnei | 2018-07-19 | 2 | -6/+4 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | loader/{nro, nso}: Resolve compilation warnings | ||||
| * | | | | loader/nro: Resolve sign mismatch warnings | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | loader/nso: Remove unnecessary vector resizes | Lioncash | 2018-07-19 | 1 | -4/+2 |
| | | | | | | | | | | | | | | | | | | | | We can just initialize these vectors directly via their constructor. | ||||
| * | | | | loader/nso: Resolve sign mismatch warnings | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | Merge pull request #703 from lioncash/const | bunnei | 2018-07-19 | 2 | -2/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | savedata_factory: Make SaveDataDescriptor's DebugInfo() function a const member function | ||||
| * | | | | | savedata_factory: Make SaveDataDescriptor's DebugInfo() function a const member function | Lioncash | 2018-07-19 | 2 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | This function doesn't alter class state. | ||||
* | | | | | | Merge pull request #702 from lioncash/initialize | bunnei | 2018-07-19 | 2 | -24/+15 |
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | | partition_filesystem: Ensure all class members of PartitionFilesystem are initialized | ||||
| * | | | | | partition_filesystem: Ensure all class members of PartitionFilesystem are initialized | Lioncash | 2018-07-19 | 2 | -24/+15 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously is_hfs and pfs_header members wouldn't be initialized in the constructor, as they were stored in locals instead. This would result in things like GetName() and PrintDebugInfo() behaving incorrectly. While we're at it, initialize the members to deterministic values as well, in case loading ever fails. | ||||
* | | | | | Merge pull request #701 from lioncash/moving | bunnei | 2018-07-19 | 2 | -2/+10 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | content_archive: Minor changes | ||||
| * | | | | content_archive: Make IsDirectoryExeFS() take a shared_ptr as a const reference | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | There's no need to take this by value when it's possible to avoid unnecessary copies entirely like this. | ||||
| * | | | | content_archive: Add missing standard includes | Lioncash | 2018-07-19 | 1 | -0/+5 |
| | | | | | |||||
| * | | | | content_archive: std::move VirtualFile in NCA's constructor | Lioncash | 2018-07-19 | 1 | -1/+4 |
| |/ / / | | | | | | | | | | | | | | | | | Gets rid of unnecessary atomic reference count incrementing and decrementing. | ||||
* | | | | Merge pull request #699 from lioncash/vfs | bunnei | 2018-07-19 | 1 | -6/+6 |
|\ \ \ \ | |_|_|/ |/| | | | vfs: Deduplicate accumulation code in VfsDirectory's GetSize() | ||||
| * | | | vfs: Deduplicate accumulation code in VfsDirectory's GetSize() | Lioncash | 2018-07-19 | 1 | -6/+6 |
| |/ / | | | | | | | | | | We can just use a generic lambda to avoid writing the same thing twice. | ||||
* | | | Merge pull request #692 from lioncash/assign | bunnei | 2018-07-19 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | address_arbiter: Correct assignment within an assertion statement in WakeThreads() | ||||
| * | | | address_arbiter: Correct assignment within an assertion statement in WakeThreads() | Lioncash | 2018-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | This was introduced within 4f81bc4e1bd12e4df7410c6790ba818d8dbba9c0, and considering there's no comment indicating that this is intentional, this is very likely a bug. | ||||
* | | | | Merge pull request #690 from lioncash/move | bunnei | 2018-07-19 | 9 | -16/+26 |
|\ \ \ \ | |_|/ / |/| | | | core/memory, core/hle/kernel: Use std::move where applicable | ||||
| * | | | core/memory, core/hle/kernel: Use std::move where applicable | Lioncash | 2018-07-19 | 9 | -16/+26 |
| | | | | | | | | | | | | | | | | Avoids pointless copies | ||||
* | | | | Merge pull request #691 from lioncash/guard | bunnei | 2018-07-19 | 1 | -0/+2 |
|\ \ \ \ | |_|_|/ |/| | | | service/prepo: Add missing header guard | ||||
| * | | | service/prepo: Add missing header guard | Lioncash | 2018-07-19 | 1 | -0/+2 |
| | |/ | |/| | |||||
* | | | Merge pull request #688 from lioncash/comma | bunnei | 2018-07-19 | 1 | -22/+12 |
|\ \ \ | | | | | | | | | vm_manager: Add missing commas to string literal array elements in GetMemoryStateName() | ||||
| * | | | vm_manager: Add missing commas to string literal array elements in GetMemoryStateName() | Lioncash | 2018-07-19 | 1 | -22/+12 |
| | |/ | |/| | | | | | | | | | | Without these, this would perform concatenation, which is definitely not what we want here. | ||||
* | | | Merge pull request #693 from lioncash/unused | bunnei | 2018-07-19 | 1 | -7/+0 |
|\ \ \ | | | | | | | | | core/memory: Remove unused function GetSpecialHandlers() and an unused variable in ZeroBlock() | ||||
| * | | | core/memory: Remove unused function GetSpecialHandlers() and an unused variable in ZeroBlock() | Lioncash | 2018-07-19 | 1 | -7/+0 |
| | |/ | |/| | |||||
* | | | Merge pull request #687 from lioncash/instance | bunnei | 2018-07-19 | 3 | -7/+11 |
|\ \ \ | | | | | | | | | core: Don't construct instance of Core::System, just to access its live instance | ||||
| * | | | core: Make System's default constructor private | Lioncash | 2018-07-19 | 2 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | This makes it a compilation error to construct additional instances of the System class directly, preventing accidental wasteful constructions over and over. | ||||
| * | | | core: Don't construct instance of Core::System, just to access its live instance | Lioncash | 2018-07-19 | 2 | -7/+7 |
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | This would result in a lot of allocations and related object construction, just to toss it all away immediately after the call. These are definitely not intentional, and it was intended that all of these should have been accessing the static function GetInstance() through the name itself, not constructed instances. | ||||
* | | | Virtual Filesystem 2: Electric Boogaloo (#676) | Zach Hilman | 2018-07-19 | 49 | -1862/+1807 |
| |/ |/| | | | | | | | | | | | | | | | | | * Virtual Filesystem * Fix delete bug and documentate * Review fixes + other stuff * Fix puyo regression | ||||
* | | Fill in more fields in TouchScreenEntryTouch | Zach Hilman | 2018-07-18 | 1 | -4/+9 |
| | | |||||
* | | Single touch support | Zach Hilman | 2018-07-18 | 1 | -4/+19 |
|/ | |||||
* | vi: Change TransactionId::CancelBuffer to LOG_CRITICAL. | bunnei | 2018-07-18 | 1 | -1/+1 |
| | |||||
* | vi: Fix size for ListDisplays default display. | bunnei | 2018-07-18 | 1 | -2/+2 |
| | |||||
* | vi: Partially implement buffer crop parameters. | bunnei | 2018-07-18 | 6 | -10/+26 |
| | |||||
* | General Filesystem and Save Data Fixes (#670) | Zach Hilman | 2018-07-17 | 16 | -212/+256 |
| | |||||
* | Merge pull request #671 from MerryMage/clear-exclusive-state | bunnei | 2018-07-17 | 6 | -0/+11 |
|\ | | | | | scheduler: Clear exclusive state when switching contexts | ||||
| * | scheduler: Clear exclusive state when switching contexts | MerryMage | 2018-07-16 | 6 | -0/+11 |
| | | |||||
* | | Merge pull request #672 from SciresM/to_address_fix | bunnei | 2018-07-17 | 1 | -2/+4 |
|\ \ | | | | | | | svc:: Fix bug in svcWaitForAddress | ||||
| * | | Kernel/Arbiter: Fix bug in WaitIfLessThan | Michael Scire | 2018-07-17 | 1 | -2/+4 |
| |/ | |||||
* / | nvflinger: Fix for BufferQueue event handling. | bunnei | 2018-07-17 | 6 | -32/+21 |
|/ | |||||
* | HID: Update controllers less often | James Rowe | 2018-07-15 | 1 | -3/+3 |
| | |||||
* | Merge pull request #663 from Subv/bsd | bunnei | 2018-07-15 | 1 | -2/+1 |
|\ | | | | | Services/BSD: Corrected the return for StartMonitoring according to SwIPC | ||||
| * | Services/BSD: Corrected the return for StartMonitoring according to SwIPC. | Subv | 2018-07-14 | 1 | -2/+1 |
| | | |||||
* | | Merge pull request #662 from Subv/delete_file | bunnei | 2018-07-14 | 1 | -2/+4 |
|\ \ | | | | | | | FileSys: Append the requested path to the filesystem base path in DeleteFile | ||||
| * | | FileSys: Append the requested path to the filesystem base path in DeleteFile. | Subv | 2018-07-14 | 1 | -2/+4 |
| |/ | | | | | | | We were trying to delete things in the current directory instead of the actual filesystem directory. This may fix some savedata issues in some games. | ||||
* / | No need to use ASSERT_MSG with an empty message | David Marcec | 2018-07-14 | 1 | -2/+2 |
|/ | |||||
* | More improvements to GDBStub (#653) | Hedges | 2018-07-13 | 7 | -49/+172 |
| | | | | | | | | | | | * More improvements to GDBStub - Debugging of threads should work correctly with source and assembly level stepping and modifying registers and memory, meaning threads and callstacks are fully clickable in VS. - List of modules is available to the client, with assumption that .nro and .nso are backed up by an .elf with symbols, while deconstructed ROMs keep N names. - Initial support for floating point registers. * Tidy up as requested in PR feedback * Tidy up as requested in PR feedback | ||||
* | We only need to alert for memory pool changes | David Marcec | 2018-07-13 | 1 | -2/+0 |
| | |||||
* | initialized voice status and unused sizes in the update data header | David Marcec | 2018-07-13 | 1 | -1/+3 |
| | |||||
* | Merge pull request #648 from ogniK5377/no-net | bunnei | 2018-07-12 | 1 | -3/+21 |
|\ | | | | | Let games/application know that we're offline | ||||
| * | Added IsWirelessCommunicationEnabled, IsEthernetCommunicationEnabled, IsAnyInternetRequestAccepted | David Marcec | 2018-07-12 | 1 | -3/+21 |
| | | | | | | | | Since we have no socket implementation we should be returning 0 to indicate we're currently offline. | ||||
* | | Audout "Auto" functions | David Marcec | 2018-07-12 | 2 | -14/+14 |
|/ | | | | Audout autos are identical to their counterpart except for the buffer type which yuzu already handles for us. | ||||
* | Merge pull request #559 from Subv/mount_savedata | bunnei | 2018-07-12 | 2 | -2/+12 |
|\ | | | | | Services/FS: Return the correct error code when trying to mount a nonexistent savedata. | ||||
| * | Services/FS: Return the correct error code when trying to mount a nonexistent savedata. | Subv | 2018-06-19 | 2 | -2/+12 |
| | | |||||
* | | hid: Fix timestamps and controller type. | bunnei | 2018-07-11 | 1 | -7/+5 |
| | | | | | | | | - This fixes user input in SMO. | ||||
* | | Merge pull request #644 from ogniK5377/getconfig-err | bunnei | 2018-07-11 | 1 | -17/+2 |
|\ \ | | | | | | | NvOsGetConfigU32 production impl | ||||
| * | | NvOsGetConfigU32 production impl | David Marcec | 2018-07-10 | 1 | -17/+2 |
| | | | | | | | | | | | | | | | Settings are only used when RMOS_SET_PRODUCTION_MODE is set to 0. If production mode is set, the error code 0x30006 is returned instead | ||||
* | | | Merge pull request #642 from bunnei/create-save-dir | bunnei | 2018-07-10 | 1 | -0/+9 |
|\ \ \ | |/ / |/| | | savedata_factory: Always create a save directory for games. | ||||
| * | | savedata_factory: Always create a save directory for games. | bunnei | 2018-07-08 | 1 | -0/+9 |
| | | | |||||
* | | | nvhost_ctrl: Fix NvOsGetConfigU32 for Snipper Clips. | bunnei | 2018-07-08 | 1 | -1/+1 |
|/ / | |||||
* | | Revert "Virtual Filesystem (#597)" | bunnei | 2018-07-08 | 42 | -1682/+1618 |
| | | | | | | | | This reverts commit 77c684c1140f6bf3fb7d4560d06d2efb1a2ee5e2. | ||||
* | | Virtual Filesystem (#597) | Zach Hilman | 2018-07-06 | 42 | -1618/+1682 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Add VfsFile and VfsDirectory classes * Finish abstract Vfs classes * Implement RealVfsFile (computer fs backend) * Finish RealVfsFile and RealVfsDirectory * Finished OffsetVfsFile * More changes * Fix import paths * Major refactor * Remove double const * Use experimental/filesystem or filesystem depending on compiler * Port partition_filesystem * More changes * More Overhaul * FSP_SRV fixes * Fixes and testing * Try to get filesystem to compile * Filesystem on linux * Remove std::filesystem and document/test * Compile fixes * Missing include * Bug fixes * Fixes * Rename v_file and v_dir * clang-format fix * Rename NGLOG_* to LOG_* * Most review changes * Fix TODO * Guess 'main' to be Directory by filename | ||||
* | | Update AudioRenderer Voice Sections (#614) | David | 2018-07-03 | 1 | -0/+87 |
| | | | | | | | | | | | | | | | | * voice section updating * fixed slight offset miscalculation * fixed overflow | ||||
* | | Update clang format | James Rowe | 2018-07-03 | 25 | -114/+106 |
| | | |||||
* | | Rename logging macro back to LOG_* | James Rowe | 2018-07-03 | 79 | -556/+556 |
| | | |||||
* | | GPU: Remove a surface from the cache when its backing memory is being unmapped from the GPU's MMU. | Subv | 2018-07-01 | 1 | -0/+5 |
| | | |||||
* | | nvmap: Return the address of the nvmap object when Freeing it for the last time. | Subv | 2018-07-01 | 2 | -4/+11 |
| | | | | | | | | This behavior is confirmed by reverse engineering. | ||||
* | | Merge pull request #595 from bunnei/raster-cache | bunnei | 2018-06-29 | 2 | -0/+3 |
|\ \ | | | | | | | Rewrite the OpenGL rasterizer cache | ||||
| * | | settings: Add a configuration for use_accurate_framebuffers. | bunnei | 2018-06-27 | 2 | -0/+3 |
| | | | |||||
* | | | Merge pull request #588 from mailwl/hwopus | bunnei | 2018-06-28 | 4 | -0/+53 |
|\ \ \ | |/ / |/| | | Service/Audio: add hwopus service, stub GetWorkBufferSize function | ||||
| * | | Service/Audio: add hwopus service, stub GetWorkBufferSize function | mailwl | 2018-06-25 | 4 | -0/+53 |
| | | | |||||
* | | | Send the correct RequestUpdateAudioRenderer revision in the output header (#587) | David | 2018-06-25 | 1 | -1/+1 |
|/ / | | | | | | | | | | | | | | | * We should be returning our revision instead of what is requested. Hardware test on a 5.1.0 console * Added sysversion comment | ||||
* | | Removed duplicate structs, changed AudioRendererResponse -> UpdateDataHeader (#583) | David | 2018-06-24 | 2 | -34/+21 |
| | | | | | | | | | | | | | | | | | | | | * Removed duplicate structs, changed AudioRendererResponse -> UpdateDataHeader According to game symbols(SMO), there's references to UpdateDataHeader which seems to be what AudioRendererResponse actually is * oops * AudioRendererParameters should be AudioRendererParameter according to SMO | ||||
* | | Fixed RequestUpdateAudioRenderer deadlocks and calculated section sizes properly (#580) | David | 2018-06-23 | 2 | -44/+76 |
| | | | | | | | | | | * Fixed RequestUpdateAudioRenderer deadlocks and calculated section sizes properly This fixes RequestUpdateAudioRenderer deadlocks in games like Puyo Puyo Tetris and games which require a proper section size in games such as Retro City Rampage. This fixes causes various games to start rendering or trying to render | ||||
* | | Merge pull request #579 from SciresM/master | bunnei | 2018-06-22 | 11 | -9/+308 |
|\ \ | | | | | | | svc: Fully implement svcSignalToAddress and svcWaitForAddress | ||||
| * | | Kernel/Arbiters: Fix casts, cleanup comments/magic numbers | Michael Scire | 2018-06-22 | 4 | -17/+27 |
| | | | |||||
| * | | Add additional missing format. | Michael Scire | 2018-06-22 | 2 | -21/+27 |
| | | | |||||
| * | | Run clang-format on PR. | Michael Scire | 2018-06-22 | 3 | -180/+181 |
| | | | |||||
| * | | Kernel/Arbiters: HLE is atomic, adjust code to reflect that. | Michael Scire | 2018-06-22 | 2 | -37/+13 |
| | | | |||||
| * | | Kernel/Arbiters: Initialize arb_wait_address in thread struct. | Michael Scire | 2018-06-21 | 3 | -1/+7 |
| | | | |||||
| * | | Kernel/Arbiters: Clear WaitAddress in SignalToAddress | Michael Scire | 2018-06-21 | 1 | -0/+1 |
| | | | |||||
| * | | Kernel/Arbiters: Mostly implement SignalToAddress | Michael Scire | 2018-06-21 | 4 | -10/+110 |
| | | | |||||
| * | | Kernel/Arbiters: Implement WaitForAddress | Michael Scire | 2018-06-21 | 4 | -6/+67 |
| | | | |||||
| * | | Kernel/Arbiters: Add stubs for 4.x SignalToAddress/WaitForAddres SVCs. | Michael Scire | 2018-06-21 | 7 | -9/+147 |
| | | | |||||
* | | | IPC: skip empty buffer write | mailwl | 2018-06-22 | 1 | -0/+5 |
| | | | | | | | | | | | | prevent yuzu crash, if games, like Axiom Verge, trying to read 0 bytes from file | ||||
* | | | Merge pull request #577 from mailwl/audren-update | bunnei | 2018-06-22 | 2 | -49/+60 |
|\ \ \ | | | | | | | | | Service/Audio: update audren:u service | ||||
| * | | | Service/Audio: update audren:u service | mailwl | 2018-06-21 | 2 | -49/+60 |
| |/ / | |||||
* / / | Add support for decrypted NCA files (#567) | Zach Hilman | 2018-06-21 | 9 | -15/+452 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Start to add NCA support in loader * More nca stuff * More changes to nca.cpp * Now identifies decrypted NCA cont. * Game list fixes and more structs and stuff * More updates to Nca class * Now reads ExeFs (i think) * ACTUALLY LOADS EXEFS! * RomFS loads and games execute * Cleanup and Finalize * plumbing, cleanup and testing * fix some things that i didnt think of before * Preliminary Review Changes * Review changes for bunnei and subv | ||||
* | | Build: Fixed some MSVC warnings in various parts of the code. | Subv | 2018-06-20 | 5 | -10/+11 |
| | | |||||
* | | Implement GetAvailableLanguageCodes2 (#575) | greggameplayer | 2018-06-19 | 1 | -4/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | * Implement GetAvailableLanguageCodes2 * Revert "Implement GetAvailableLanguageCodes2" This reverts commit caadd9eea3497ae2a13382aecb8ca29e1c02c5af. * Implement GetAvailableLanguageCodes2 * Implement GetAvailableLanguageCodes2 | ||||
* | | Merge pull request #561 from DarkLordZach/fix-odyssey-input-crash | bunnei | 2018-06-19 | 1 | -0/+4 |
|\ \ | | | | | | | Avoid initializing single-joycon layouts with handheld controller | ||||
| * | | Narrow down filter of layout configs | Zach Hilman | 2018-06-14 | 2 | -10/+5 |
| | | | |||||
| * | | Move loop condition to free function | Zach Hilman | 2018-06-13 | 1 | -4/+9 |
| | | | |||||
| * | | Avoid initializing single-joycon layouts with handheld controller | Zach Hilman | 2018-06-13 | 2 | -1/+5 |
| | | | |||||
* | | | Merge pull request #572 from Armada651/user-except-stub | bunnei | 2018-06-18 | 1 | -0/+5 |
|\ \ \ | |/ / |/| | | svc: Add a stub for UserExceptionContextAddr. | ||||
| * | | svc: Add a stub for UserExceptionContextAddr. | Jules Blok | 2018-06-18 | 1 | -0/+5 |
| | | | |||||
* | | | hid: Update all layouts and only show handheld as connected, fixes libnx input for P1_AUTO | shinyquagsire23 | 2018-06-12 | 2 | -2/+3 |
| |/ |/| | |||||
* | | Common/string_util: add StringFromBuffer function | mailwl | 2018-06-07 | 1 | -22/+9 |
| | | | | | | | | convert input buffer (std::vector<u8>) to string, stripping zero chars | ||||
* | | Merge pull request #522 from mailwl/mm-u | bunnei | 2018-06-07 | 4 | -0/+83 |
|\ \ | | | | | | | Service/MM: add service and stub some functions | ||||
| * | | Remove unused header files | mailwl | 2018-06-06 | 1 | -2/+0 |
| | | | |||||
| * | | Small fixes | mailwl | 2018-06-05 | 2 | -6/+8 |
| | | | |||||
| * | | Service/MM: add service and stub some functions | mailwl | 2018-06-05 | 4 | -0/+83 |
| | | | |||||
* | | | Merge pull request #503 from mailwl/nfp-stubs | bunnei | 2018-06-07 | 1 | -7/+101 |
|\ \ \ | | | | | | | | | Service/nfp:user : stub some functions. | ||||
| * | | | Stub IUser::AttachAvailabilityChangeEvent | mailwl | 2018-06-06 | 1 | -5/+23 |
| | | | | |||||
| * | | | Correct function results | mailwl | 2018-06-04 | 1 | -4/+16 |
| | | | | |||||
| * | | | Service/nfp:user : stub some functions. | mailwl | 2018-06-04 | 1 | -6/+70 |
| | | | | | | | | | | | | | | | | Used by Zelda: BoTW | ||||
* | | | | nvdrv/devices/nvidia_ctrl_gpu : add IoctlCommands with their params (#524) | greggameplayer | 2018-06-06 | 2 | -0/+53 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * add IoctlCommands with their params in nvidia_ctrl_gpu.h * add function related to the changes done previously * fix clang-format * delete trailing whitespace * correct mistake | ||||
* | | | | Merge pull request #529 from bunnei/am-nifm-stubs | Sebastian Valle | 2018-06-06 | 3 | -2/+23 |
|\ \ \ \ | | | | | | | | | | | Stub SetConnectionConfirmationOption, GetPseudoDeviceId | ||||
| * | | | | nifm: Stub out IRequest::SetConnectionConfirmationOption. | bunnei | 2018-06-06 | 1 | -1/+10 |
| | | | | | |||||
| * | | | | am: Stub out IApplicationFunctions::GetPseudoDeviceId. | bunnei | 2018-06-06 | 2 | -1/+13 |
| | |/ / | |/| | | |||||
* / | | | GDB Stub Improvements (#508) | Hedges | 2018-06-06 | 4 | -27/+194 |
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | * GDB Stub should work now. * Applied clang-format. * Replaced htonll with swap64. * Tidy up. | ||||
* | | | Nvdrv/devices/nvhost_gpu : Add some IoctlCommands with their params (#511) | greggameplayer | 2018-06-04 | 1 | -0/+47 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Add some IoctlCommand with their params to nvhost_gpu * fix clang-format * delete trailing whitespace * fix some clang-format * delete one other trailing whitespace * last clang-format fix | ||||
* | | | am: Implement ILibraryAppletAccessor::PopOutData. | bunnei | 2018-06-04 | 1 | -1/+11 |
| | | | |||||
* | | | am: ISelfController:LaunchableEvent should be sticky. | bunnei | 2018-06-04 | 1 | -1/+1 |
| | | | |||||
* | | | am: Stub out ILibraryAppletAccessor Start and GetResult methods. | bunnei | 2018-06-04 | 1 | -2/+16 |
|/ / | |||||
* | | am: Implement ILibraryAppletAccessor::PushInData. | bunnei | 2018-06-04 | 1 | -43/+55 |
| | | |||||
* | | am: Implement IStorageAccessor::Write. | bunnei | 2018-06-04 | 1 | -1/+17 |
| | | |||||
* | | am: Cleanup IStorageAccessor::Read. | bunnei | 2018-06-04 | 1 | -5/+3 |
| | | |||||
* | | am: Implement ILibraryAppletCreator::CreateStorage. | bunnei | 2018-06-04 | 2 | -21/+34 |
| | | |||||
* | | Merge pull request #484 from mailwl/nvhost-nvdec | bunnei | 2018-06-03 | 4 | -0/+74 |
|\ \ | | | | | | | Services/nvdrv: add '/dev/nvhost-nvdec' device | ||||
| * | | Services/nvdrv: add '/dev/nvhost-nvdec' device | mailwl | 2018-05-30 | 4 | -0/+74 |
| | | | |||||
* | | | Kernel/Threads: A thread waking up by timeout from a WaitProcessWideKey may already have an assigned lock owner. | Subv | 2018-06-02 | 1 | -2/+5 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This situation may happen like so: Thread 1 with low priority calls WaitProcessWideKey with timeout. Thread 2 with high priority calls WaitProcessWideKey without timeout. Thread 3 calls SignalProcessWideKey - Thread 2 acquires the lock and awakens. - Thread 1 can't acquire the lock and is put to sleep with the lock owner being Thread 2. Thread 1's timeout expires, with the lock owner still being set to Thread 2. | ||||
* | | | Service/time: implement posix time to calendar conversion | mailwl | 2018-06-01 | 2 | -14/+72 |
| | | | |||||
* | | | Merge pull request #488 from Subv/thread_masks | bunnei | 2018-06-01 | 3 | -4/+31 |
|\ \ \ | | | | | | | | | Kernel/SVC: Corrected the behavior of svcSetThreadCoreMask for core values -2 and -3. | ||||
| * | | | Kernel/Thread: Corrected a typo that caused the affinity mask to never be changed. | Subv | 2018-05-31 | 1 | -2/+2 |
| | | | | |||||
| * | | | Kernel/SVC: Support special core values -2 and -3 in svcSetThreadCoreMask. | Subv | 2018-05-31 | 2 | -1/+28 |
| | | | | | | | | | | | | | | | | Also added some proper error handling. | ||||
| * | | | Kernel/Thread: Corrected a typo in an assert about the processor id. | Subv | 2018-05-30 | 1 | -1/+1 |
| |/ / | |||||
* | | | add IPC CommandType & Some HID FunctionInfo (#487) | greggameplayer | 2018-05-30 | 2 | -0/+33 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * add some CommandType * add some hid FunctionInfo * add some other HID FunctionInfo * delete non useful comments | ||||
* | | | nvhost_ctrl: Stub out IocCtrlEventRegister. | bunnei | 2018-05-30 | 2 | -0/+10 |
| | | | |||||
* | | | nvhost_ctrl: Stub out IocCtrlEventWaitAsyncCommand. | bunnei | 2018-05-30 | 2 | -5/+9 |
|/ / | |||||
* | | Service/BCAT: add module and services | mailwl | 2018-05-28 | 6 | -0/+118 |
| | | |||||
* | | Merge pull request #475 from ogniK5377/nvos-getconfig | bunnei | 2018-05-27 | 1 | -1/+1 |
|\ \ | | | | | | | NvOsGetConfigU32 should return null instead of 0 for default output value | ||||
| * | | NvOsGetConfigU32 should return null instead of 0 for default output | David Marcec | 2018-05-27 | 1 | -1/+1 |
| | | | |||||
* | | | am: Stub IApplicationFunctions GetDisplayVersion. | bunnei | 2018-05-26 | 2 | -1/+10 |
|/ / | |||||
* | | Add & correct miscellaneous things (#470) | greggameplayer | 2018-05-26 | 4 | -4/+55 |
| | | | | | | | | | | | | | | | | | | | | | | | | * add some InfoType * correct OpenApplicationProxy cmd number * add IDisplayController functions * fix clang-format * add more system languages | ||||
* | | Merge pull request #466 from mailwl/nv-timeout | bunnei | 2018-05-26 | 2 | -0/+16 |
|\ \ | | | | | | | Stub NVGPU_IOCTL_CHANNEL_SET_TIMEOUT | ||||
| * | | Stub NVGPU_IOCTL_CHANNEL_SET_TIMEOUT | mailwl | 2018-05-24 | 2 | -0/+16 |
| | | | | | | | | | | | | Used in Nintendo Labo ToyCon 1&2 | ||||
* | | | GetAudioRendererWorkBufferSize impl (#465) | David | 2018-05-26 | 2 | -2/+88 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * GetAudioRendererWorkBufferSize impl Impl of GetAudioRendererWorkBufferSize based on RE, if this can be cleaned up, please contribute! * Naming conventions * Removed unneeded placeholder * lioncache changes * fixed const * switched to Common::AlignUp | ||||
* | | | Stubbed NVGPU_GPU_IOCTL_ZBC_SET_TABLE (#463) | David | 2018-05-25 | 2 | -0/+22 |
|/ / | | | | | We have no clue on what this actually does yet so stubbing it since it's just input only should be fine for now | ||||
* | | Fix deadlocks caused from HID having too many layouts | David Marcec | 2018-05-24 | 1 | -1/+1 |
| | | | | | | | | Games such as SMO deadlock if we have more than 2 layouts | ||||
* | | Merge pull request #460 from greggameplayer/patch-6 | bunnei | 2018-05-23 | 1 | -2/+8 |
|\ \ | | | | | | | Add & correct some error modules | ||||
| * | | Add & correct some error modules | greggameplayer | 2018-05-23 | 1 | -2/+8 |
| | | | |||||
* | | | Merge pull request #459 from greggameplayer/patch-5 | bunnei | 2018-05-23 | 3 | -29/+117 |
|\ \ \ | | | | | | | | | Add ioctl commands with their params and size check | ||||
| * | | | change some functions | greggameplayer | 2018-05-23 | 1 | -6/+6 |
| | | | | | | | | | | | | according to the changes made previously | ||||
| * | | | correct placement and add size check | greggameplayer | 2018-05-23 | 1 | -21/+25 |
| | | | | |||||
| * | | | Add ioctl commands with their params and size check | greggameplayer | 2018-05-23 | 1 | -2/+86 |
| |/ / | |||||
* | | | Merge pull request #454 from Subv/signal_processwide | bunnei | 2018-05-23 | 1 | -83/+74 |
|\ \ \ | |/ / |/| | | Kernel/SVC: Signal the highest priority threads first in svcSignalProcessWideKey | ||||
| * | | Kernel/SVC: Signal the highest priority threads first in svcSignalProcessWideKey. | Subv | 2018-05-19 | 1 | -51/+68 |
| | | | |||||
| * | | Kernel/Threads: Reschedule the proper core when operating on that core's threads. | Subv | 2018-05-19 | 1 | -2/+6 |
| | | | |||||
| * | | SVC: Removed unused WaitSynchronization1 function | Subv | 2018-05-19 | 1 | -30/+0 |
| | | | |||||
* | | | Implemented NVHOST_IOCTL_CHANNEL_GET_WAITBASE (#440) | David | 2018-05-22 | 2 | -1/+20 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Implemented NVHOST_IOCTL_CHANNEL_GET_WAITBASE struct + 4 seems to be hard coded at 0 and struct + 0 seems to be ignored? * IocGetWaitbase -> IocChannelGetWaitbaseCommand * Added super late fixes | ||||
* | | | Merge pull request #456 from Subv/unmap_buffer | bunnei | 2018-05-21 | 4 | -1/+98 |
|\ \ \ | | | | | | | | | Implemented nvhost-as-gpu's UnmapBuffer and nvmap's Free ioctls. | ||||
| * | | | GPU: Implemented the nvmap Free ioctl. | Subv | 2018-05-20 | 2 | -1/+48 |
| | | | | | | | | | | | | | | | | It releases a reference to an nvmap object | ||||
| * | | | GPU: Implemented nvhost-as-gpu's UnmapBuffer ioctl. | Subv | 2018-05-20 | 2 | -0/+50 |
| |/ / | | | | | | | | | | It removes a mapping previously created with the MapBufferEx ioctl. | ||||
* | | | Correct audio command numbers & add or rename some functions (#455) | greggameplayer | 2018-05-21 | 5 | -34/+34 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Add unknown function at the number command 2 * correct audout:u commands numbers * correct audrec:u cmd number & add Unknown function * correct IAudioDevice command numbers * correct codecctl cmd numbers & rename the 8 function * correct place of unknown function & fix clang-format | ||||
* | | | Merge pull request #457 from Subv/mutex_waiters | bunnei | 2018-05-21 | 1 | -1/+0 |
|\ \ \ | | | | | | | | | Mutex: Do not assert when the mutex waiting threads list isn't empty on mutex release. | ||||
| * | | | Mutex: Do not assert when the mutex waiting threads list isn't empty on mutex release. | Subv | 2018-05-20 | 1 | -1/+0 |
| |/ / | | | | | | | | | | A thread may own multiple mutexes at the same time, and only release one of them while other threads are waiting for the other mutexes. | ||||
* | | | Merge pull request #445 from greggameplayer/patch-2 | bunnei | 2018-05-21 | 3 | -6/+7 |
|\ \ \ | | | | | | | | | Properly rename functions of Fatal Module & add ThrowFatal to this module | ||||
| * | | | rename fatal:u functions & add ThrowFatal | greggameplayer | 2018-05-18 | 1 | -2/+3 |
| | | | | |||||
| * | | | Properly update fatal.h void name | greggameplayer | 2018-05-18 | 1 | -2/+2 |
| | | | | |||||
| * | | | Properly rename fatal module functions | greggameplayer | 2018-05-18 | 1 | -2/+2 |
| |/ / | |||||
* | | | Merge pull request #443 from ogniK5377/ipc-500 | Sebastian Valle | 2018-05-20 | 3 | -1/+7 |
|\ \ \ | | | | | | | | | Added IPC RequestWithContext & ControlWithContext | ||||
| * | | | Added RequestWithContext & ControlWithContext | David Marcec | 2018-05-17 | 3 | -1/+7 |
| |/ / | |||||
* | | | Add and correct some Error Modules (#444) | greggameplayer | 2018-05-20 | 1 | -6/+40 |
| | | | | | | | | | | | | * Add and correct some Error Modules | ||||
* | | | Updated nfp with more service names | Hexagon12 | 2018-05-13 | 1 | -24/+24 |
|/ / | |||||
* | | Merge pull request #436 from bunnei/multi-core | bunnei | 2018-05-11 | 17 | -181/+577 |
|\ \ | | | | | | | Initial support for multi-core | ||||
| * | | core: Add several missing docstrings. | bunnei | 2018-05-11 | 1 | -0/+8 |
| | | | |||||
| * | | thread: Rename mask to affinity_masks. | bunnei | 2018-05-11 | 3 | -4/+4 |
| | | | |||||
| * | | core: Run all CPU cores separately, even in single-thread mode. | bunnei | 2018-05-11 | 2 | -13/+23 |
| | | | |||||
| * | | thread: Support core change on ResumeFromWait and improve ChangeCore. | bunnei | 2018-05-11 | 1 | -37/+68 |
| | | | |||||
| * | | scheduler: Protect scheduling functions with a global mutex. | bunnei | 2018-05-11 | 2 | -0/+18 |
| | | | |||||
| * | | thread: Initialize ideal_core and mask members. | bunnei | 2018-05-11 | 1 | -0/+2 |
| | | | |||||
| * | | threading: Reschedule only on cores that are necessary. | bunnei | 2018-05-11 | 4 | -3/+10 |
| | | | |||||
| * | | svc: Implement GetThreadCoreMask and SetThreadCoreMask. | bunnei | 2018-05-11 | 1 | -7/+22 |
| | | | |||||
| * | | thread: Implement ChangeCore function. | bunnei | 2018-05-11 | 2 | -1/+58 |
| | | | |||||
| * | | svc: SignalProcessWideKey should apply to all cores. | bunnei | 2018-05-11 | 1 | -43/+50 |
| | | | |||||
| * | | svc: Implement GetCurrentProcessorNumber. | bunnei | 2018-05-11 | 1 | -2/+2 |
| | | | |||||
| * | | core: Add a configuration setting for use_multi_core. | bunnei | 2018-05-11 | 5 | -17/+39 |
| | | | |||||
| * | | core: Support session close with multicore. | bunnei | 2018-05-11 | 4 | -16/+47 |
| | | | |||||
| * | | core: Implement multicore support. | bunnei | 2018-05-11 | 11 | -75/+110 |
| | | | |||||
| * | | core: Create a thread for each CPU core, keep in lock-step with a barrier. | bunnei | 2018-05-11 | 4 | -18/+94 |
| | | | |||||
| * | | core: Move common CPU core things to its own class. | bunnei | 2018-05-11 | 5 | -58/+135 |
| | | | |||||
* | | | More accurate GetTPCMasks impl | David Marcec | 2018-05-11 | 2 | -4/+8 |
|/ / | |||||
* | | Stubs for QLaunch (#428) | Hexagon12 | 2018-05-07 | 4 | -5/+221 |
| | | | | | | | | | | | | | | | | | | | | * Stubs for QLaunch * Wiped unrelated stuff * Addressed comment * Dropped GetPopFromGeneralChannelEvent | ||||
* | | hid: Tweaks, Analog Sticks (#435) | Max Thomas | 2018-05-07 | 3 | -68/+224 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | * hid: Update mouse/keyboard state * hid: Working analog sticks * hid: Nits * hid: Nits * hid: Update mystery sections * hid: Tweaks | ||||
* | | Merge pull request #434 from lioncash/vdtor | bunnei | 2018-05-03 | 3 | -1/+13 |
|\ \ | | | | | | | memory_hook: Default virtual destructor in the cpp file | ||||
| * | | memory_hook: Default virtual destructor in the cpp file | Lioncash | 2018-05-03 | 3 | -1/+13 |
| | | | | | | | | | | | | | | | Prevents creating multiple copies of the vtable in every translation unit that uses the class. Also silences a -Wweak-vtables warning | ||||
* | | | core_timing: Don't include the log header in core timing's header | Lioncash | 2018-05-03 | 2 | -48/+55 |
|/ / | | | | | | | | | Avoids propagating logging macros and facilities to files that may not need them. This also allows hiding an internal constant. | ||||
* | | Merge pull request #431 from lioncash/fmt | bunnei | 2018-05-02 | 28 | -103/+104 |
|\ \ | | | | | | | general: Make formatting of logged hex values more straightforward | ||||
| * | | general: Make formatting of logged hex values more straightforward | Lioncash | 2018-05-02 | 28 | -103/+104 |
| | | | | | | | | | | | | | | | | | | This makes the formatting expectations more obvious (e.g. any zero padding specified is padding that's entirely dedicated to the value being printed, not any pretty-printing that also gets tacked on). | ||||
* | | | ipc: Add support for PopIpcInterface() method. | bunnei | 2018-05-02 | 4 | -0/+23 |
|/ / | | | | | | | - This can be used for domain objects as inputs to service functions. | ||||
* | | Merge pull request #429 from Subv/ioctl_corruption | bunnei | 2018-05-01 | 2 | -5/+0 |
|\ \ | | | | | | | GPU: Don't write to invalid memory locations when handling ioctls that don't have an output. | ||||
| * | | GPU: Don't write to invalid memory locations when handling ioctls that don't have an output. | Subv | 2018-05-01 | 2 | -5/+0 |
| | | | |||||
* | | | GetSharedFontInOrderOfPriority (#381) | David | 2018-05-01 | 4 | -24/+54 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * GetSharedFontInOrderOfPriority * Update pl_u.cpp * Ability to use ReadBuffer and WriteBuffer with different buffer indexes, fixed up GetSharedFontInOrderOfPriority * switched to NGLOG * Update pl_u.cpp * Update pl_u.cpp * language_code is actually language code and not index * u32->u64 * final cleanups | ||||
* | | core_timing: Namespace all functions and constants in core_timing's header | Lioncash | 2018-04-30 | 9 | -14/+18 |
| | | | | | | | | All of these variables and functions are related to timings and should be within the namespace. | ||||
* | | string_util: Remove StringFromFormat() and related functions | Lioncash | 2018-04-30 | 2 | -4/+3 |
| | | | | | | | | Given we utilize fmt, we don't need to provide our own functions for formatting anymore | ||||
* | | am: Fix GetDesiredLanguage implementation. | bunnei | 2018-04-29 | 1 | -2/+4 |
| | | |||||
* | | set: Fix GetAvailableLanguageCodes implementation. | bunnei | 2018-04-29 | 2 | -6/+45 |
| | | |||||
* | | core: Replace usages of LOG_GENERIC with new fmt-capable equivalents | Lioncash | 2018-04-27 | 3 | -6/+4 |
| | | |||||
* | | general: Convert assertion macros over to be fmt-compatible | Lioncash | 2018-04-27 | 11 | -27/+26 |
| | | |||||
* | | Merge pull request #380 from ogniK5377/service-impl | bunnei | 2018-04-27 | 11 | -13/+138 |
|\ \ | | | | | | | Implemented some useful interfaces needed for games. | ||||
| * | | Switched to NGLOG_WARNING | David Marcec | 2018-04-27 | 3 | -4/+4 |
| | | | |||||
| * | | Merge branch 'master' of https://github.com/yuzu-emu/yuzu into service-impl | David Marcec | 2018-04-26 | 84 | -1072/+1018 |
| |\ \ | |||||
| * | | | Added PREPO to logging backend, Removed comments from SaveReportWithUser | David Marcec | 2018-04-26 | 2 | -13/+2 |
| | | | | |||||
| * | | | GetIUserInterface->CreateUserInterface, Added todos and stub logs. Playreport->PlayReport. | David Marcec | 2018-04-23 | 9 | -25/+63 |
| | | | | |||||
| * | | | lioncash proposed changes | David | 2018-04-22 | 1 | -2/+2 |
| | | | | |||||
| * | | | Implemented GetIUserInterface properly, Playreport and SSL::SetInterfaceVersion. Fixed ipc issues with IAudioDevice(wrong ids) | David Marcec | 2018-04-22 | 11 | -11/+109 |
| | | | | |||||
* | | | | core: Replace remaining old non-generic logger usages with fmt-capable equivalents | Lioncash | 2018-04-26 | 6 | -28/+28 |
| |/ / |/| | | | | | | | | | | | | | | LOG_GENERIC usages will be amended in a follow-up to keep API changes separate from interface changes, as it will require removing a parameter from the relevant function in the VMManager class. | ||||
* | | | core/gdbstub: Move logging macros to new fmt-compatible ones | Lioncash | 2018-04-26 | 1 | -38/+37 |
| | | | |||||
* | | | core/hw: Move logging macros over to fmt-capable ones | Lioncash | 2018-04-26 | 2 | -8/+10 |
| | | | |||||
* | | | Merge pull request #398 from lioncash/kernel | bunnei | 2018-04-26 | 11 | -107/+110 |
|\ \ \ | | | | | | | | | kernel: Migrate logging macros to fmt-compatible ones | ||||
| * | | | kernel/shared_memory: Remove unnecessary semicolon at end of ConvertPermissions() | Lioncash | 2018-04-26 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | Functions don't need to be terminated by semicolons. | ||||
| * | | | kernel: Migrate logging macros to fmt-compatible ones | Lioncash | 2018-04-26 | 11 | -106/+109 |
| | | | | |||||
* | | | | Merge pull request #387 from Subv/maxwell_2d | bunnei | 2018-04-26 | 1 | -0/+4 |
|\ \ \ \ | | | | | | | | | | | GPU: Partially implemented the 2D surface copy engine | ||||
| * | | | | Memory: Added a missing shortcut for Memory::CopyBlock for the current process. | Subv | 2018-04-25 | 1 | -0/+4 |
| | | | | | |||||
* | | | | | Merge pull request #395 from lioncash/file-sys | bunnei | 2018-04-26 | 8 | -68/+59 |
|\ \ \ \ \ | |_|/ / / |/| | | | | file-sys: Move logging macros over to the new fmt-capable ones | ||||
| * | | | | file-sys: convert a StringFromFormat call into fmt::format in GetFullPath() | Lioncash | 2018-04-25 | 1 | -4/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Lessens the amount to read and gets rid of the PRIX64 macro, allowing us to use a single string for the whole path, making it easier to read. | ||||
| * | | | | file-sys: Move logging macros over to the new fmt-capable ones | Lioncash | 2018-04-25 | 8 | -64/+58 |
| |/ / / | |||||
* | | | | Merge pull request #390 from mailwl/pctl-module | bunnei | 2018-04-25 | 7 | -39/+71 |
|\ \ \ \ | | | | | | | | | | | Service/PCTL: convert to module, add services, stub | ||||
| * | | | | Service/PCTL: convert to module, add services, stub | mailwl | 2018-04-25 | 7 | -39/+71 |
| |/ / / | | | | | | | | | | | | | PCTL::CreateServiceWithoutInitialize and IParentalControlService::Initialize, required by Kirby Star Allies | ||||
* | | | | core/memory: Amend address widths in asserts | Lioncash | 2018-04-25 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | Addresses are 64-bit, these formatting specifiers are simply holdovers from citra. Adjust them to be the correct width. | ||||
* | | | | core/memory: Move logging macros over to new fmt-capable ones | Lioncash | 2018-04-25 | 1 | -22/+24 |
|/ / / | | | | | | | | | | While we're at it, correct addresses to print all 64 bits where applicable, which were holdovers from citra. | ||||
* | | | Merge pull request #388 from bunnei/refactor-rasterizer-cache | bunnei | 2018-04-25 | 2 | -17/+50 |
|\ \ \ | | | | | | | | | Refactor rasterizer cache | ||||
| * | | | gl_rasterizer_cache: Update to be based on GPU addresses, not CPU addresses. | bunnei | 2018-04-25 | 2 | -17/+50 |
| | | | | |||||
* | | | | loader: Move old logging macros over to new fmt-capable ones | Lioncash | 2018-04-25 | 5 | -26/+25 |
|/ / / | |||||
* | | | service: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -5/+5 |
| | | | |||||
* | | | vi: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -26/+27 |
| | | | |||||
* | | | time: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -12/+12 |
| | | | |||||
* | | | ssl: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -3/+3 |
| | | | |||||
* | | | spl: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -1/+1 |
| | | | |||||
* | | | sockets: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -7/+8 |
| | | | |||||
* | | | sm: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -9/+8 |
| | | | |||||
* | | | set: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -2/+2 |
| | | | |||||
* | | | pctl: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -1/+1 |
| | | | |||||
* | | | nvflinger: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -3/+3 |
| | | | |||||
* | | | nvdrv: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 7 | -60/+61 |
| | | | |||||
* | | | ns: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -6/+6 |
| | | | |||||
* | | | nifm: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -11/+11 |
| | | | |||||
* | | | nfp: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -1/+1 |
| | | | |||||
* | | | lm: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -6/+6 |
| | | | |||||
* | | | hid: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -25/+25 |
| | | | |||||
* | | | friend: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -1/+1 |
| | | | |||||
* | | | filesystem: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -30/+29 |
| | | | |||||
* | | | fatal: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -2/+2 |
| | | | |||||
* | | | audio: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 2 | -21/+21 |
| | | | |||||
* | | | apm: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -3/+3 |
| | | | |||||
* | | | aoc: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -2/+2 |
| | | | |||||
* | | | am: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 3 | -50/+50 |
| | | | |||||
* | | | acc: Move logging macros over to new fmt-compatible ones | Lioncash | 2018-04-24 | 1 | -10/+10 |
| | | | |||||
* | | | Service/FS: implement IFileSystem::RenameFile | mailwl | 2018-04-24 | 6 | -8/+36 |
| | | | |||||
* | | | Merge pull request #370 from Subv/sync_primitives | bunnei | 2018-04-23 | 14 | -443/+238 |
|\ \ \ | | | | | | | | | Kernel: Reworked the new kernel synchronization primitives. | ||||
| * | | | Kernel: Implemented mutex priority inheritance. | Subv | 2018-04-23 | 4 | -10/+94 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Verified with a hwtest and implemented based on reverse engineering. Thread A's priority will get bumped to the highest priority among all the threads that are waiting for a mutex that A holds. Once A releases the mutex and ownership is transferred to B, A's priority will return to normal and B's priority will be bumped. | ||||
| * | | | Kernel: Use 0x2C as default main thread priority for homebrew and lone NRO/NSOs | Subv | 2018-04-21 | 3 | -3/+3 |
| | | | | |||||
| * | | | Qt: Update the WaitTree widget to show info about the current mutex of each thread. | Subv | 2018-04-21 | 3 | -8/+8 |
| | | | | |||||
| * | | | Kernel: Remove unused ConditionVariable class. | Subv | 2018-04-21 | 6 | -150/+0 |
| | | | | |||||
| * | | | Kernel: Remove old and unused Mutex code. | Subv | 2018-04-21 | 4 | -209/+3 |
| | | | | |||||
| * | | | Kernel: Properly implemented svcWaitProcessWideKey and svcSignalProcessWideKey | Subv | 2018-04-21 | 1 | -83/+46 |
| | | | | | | | | | | | | | | | | They work in tandem with guest code to provide synchronization primitives along with svcArbitrateLock/Unlock | ||||
| * | | | Kernel: Corrected the implementation of svcArbitrateLock and svcArbitrateUnlock. | Subv | 2018-04-21 | 6 | -22/+126 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Switch mutexes are no longer kernel objects, they are managed in userland and only use the kernel to handle the contention case. Mutex addresses store a special flag value (0x40000000) to notify the guest code that there are still some threads waiting for the mutex to be released. This flag is updated when a thread calls ArbitrateUnlock. TODO: * Fix svcWaitProcessWideKey * Fix svcSignalProcessWideKey * Remove the Mutex class. | ||||
* | | | | Merge pull request #384 from Subv/nvhost-remap | bunnei | 2018-04-23 | 2 | -0/+57 |
|\ \ \ \ | | | | | | | | | | | Nvdrv/nvhost-as-gpu: Implemented the ioctl REMAP command. | ||||
| * | | | | NvDrv/nvhost-as-gpu: Ensure that the object passed to MapBufferEx has already been allocated. | Subv | 2018-04-23 | 1 | -0/+10 |
| | | | | | | | | | | | | | | | | | | | | Also added a consistency check and a comment for the case when the object id is different than its handle. The real nvservices doesn't make a distinction between ids and handles, each object gets an unique handle which doubles as its id. | ||||
| * | | | | Nvdrv/nvhost-as-gpu: Implemented the ioctl REMAP command. | Subv | 2018-04-23 | 2 | -0/+47 |
| | |/ / | |/| | | | | | | | | | | It takes a previously-reserved (AllocateSpace) GPU memory address and maps it to the address of the nvmap object passed to Remap. | ||||
* / | | | Nvdrv: Assert when receiving an unimplemented ioctl in the nv* handlers. | Subv | 2018-04-23 | 5 | -5/+5 |
|/ / / | |||||
* | | | Merge pull request #372 from lioncash/enum | bunnei | 2018-04-21 | 3 | -38/+38 |
|\ \ \ | | | | | | | | | resource_limit: Make ResourceTypes an enum class | ||||
| * | | | resource_limit: Make ResourceTypes an enum class | Lioncash | 2018-04-21 | 3 | -38/+38 |
| | | | | | | | | | | | | | | | | Prevents enum identifiers from leaking into the surrounding scope. | ||||
* | | | | core: Relocate g_service_manager to the System class | Lioncash | 2018-04-21 | 6 | -38/+66 |
|/ / / | | | | | | | | | | | | | Converts the service manager from a global into an instance-based variable. | ||||
* | | | Merge pull request #340 from mailwl/vi-update | bunnei | 2018-04-20 | 1 | -7/+27 |
|\ \ \ | |/ / |/| | | Service/VI: stub SetLayerVisibility, fix GetDisplayResolution output | ||||
| * | | Service/VI: stub SetLayerVisibility, fix GetDisplayResolution output | mailwl | 2018-04-17 | 1 | -7/+27 |
| | | | | | | | | | | | | | | | both SetLayerVisibility() functions used in Lego games, GetDisplayResolution() fixed according switchbrew.org | ||||
* | | | Merge pull request #367 from lioncash/clamp | bunnei | 2018-04-20 | 1 | -1/+2 |
|\ \ \ | | | | | | | | | math_util: Remove the Clamp() function | ||||
| * | | | math_util: Remove the Clamp() function | Lioncash | 2018-04-20 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | C++17 adds clamp() to the standard library, so we can remove ours in favor of it. | ||||
* | | | | Merge pull request #360 from lioncash/namespaces | bunnei | 2018-04-20 | 136 | -570/+273 |
|\ \ \ \ | | | | | | | | | | | service: Use nested namespace specifiers where applicable | ||||
| * | | | | service: Use nested namespace specifiers where applicable | Lioncash | 2018-04-20 | 136 | -570/+273 |
| |/ / / | | | | | | | | | | | | | Tidies up namespace declarations | ||||
* | | | | Merge pull request #363 from lioncash/array-size | bunnei | 2018-04-20 | 1 | -1/+2 |
|\ \ \ \ | | | | | | | | | | | common_funcs: Remove ARRAY_SIZE macro | ||||
| * | | | | common_funcs: Remove ARRAY_SIZE macro | Lioncash | 2018-04-20 | 1 | -1/+2 |
| |/ / / | | | | | | | | | | | | | C++17 has non-member size() which we can just call where necessary. | ||||
* | | | | Merge pull request #358 from lioncash/explicit | bunnei | 2018-04-20 | 2 | -4/+3 |
|\ \ \ \ | | | | | | | | | | | disk_filesystem: Minor changes | ||||
| * | | | | disk_filesystem: Remove unused total_entries_in_directory member from Disk_Directory | Lioncash | 2018-04-20 | 1 | -1/+0 |
| | | | | | |||||
| * | | | | disk_filesystem: Remove redundant initializer in Disk_Directory's constructor | Lioncash | 2018-04-20 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | disk_filesystem: Make constructors explicit where applicable | Lioncash | 2018-04-20 | 1 | -2/+2 |
| |/ / / | |||||
* / / / | vi: Remove redundant initializers in the constructors | Lioncash | 2018-04-20 | 1 | -9/+5 |
|/ / / | |||||
* | | | nvflinger: Call MicroProfileFlip on NVFlinger::Compose. | bunnei | 2018-04-19 | 1 | -0/+3 |
| | | | |||||
* | | | Merge pull request #341 from shinyquagsire23/pfs-hfs-impl | bunnei | 2018-04-17 | 3 | -0/+214 |
|\ \ \ | |/ / |/| | | file_sys: Add HFS/PFS helper component | ||||
| * | | file_sys: Use NGLOG | shinyquagsire23 | 2018-04-17 | 1 | -5/+5 |
| | | | |||||
| * | | file_sys: tweaks | shinyquagsire23 | 2018-04-16 | 2 | -6/+7 |
| | | | |||||
| * | | file_sys: Add HFS/PFS helper component | shinyquagsire23 | 2018-04-16 | 3 | -0/+213 |
| | | | |||||
* | | | Various service name fixes - part 2 (rebased) (#322) | Hexagon12 | 2018-04-17 | 13 | -11/+207 |
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Updated ACC with more service names * Updated SVC with more service names * Updated set with more service names * Updated sockets with more service names * Updated SPL with more service names * Updated time with more service names * Updated vi with more service names | ||||
* | | Merge pull request #338 from bunnei/unrequire-shared-font | bunnei | 2018-04-15 | 1 | -17/+14 |
|\ \ | | | | | | | pl_u: Use empty shared font if none is available. | ||||
| * | | pl_u: Use empty shared font if none is available. | bunnei | 2018-04-15 | 1 | -17/+14 |
| | | | | | | | | | | | | - Makes games work in lieu of shared_font.bin. | ||||
* | | | fsp_srv: Implement DeleteFile. | bunnei | 2018-04-15 | 6 | -9/+27 |
|/ / | | | | | | | - Used by Binding of Isaac. | ||||
* | | Merge pull request #332 from bunnei/fix-total-mem-usage | bunnei | 2018-04-15 | 1 | -1/+1 |
|\ \ | | | | | | | vm_manager: Increase GetTotalMemoryUsage value. | ||||
| * | | vm_manager: Increase GetTotalMemoryUsage value. | bunnei | 2018-04-15 | 1 | -1/+1 |
| | | | | | | | | | | | | - Gets Binding of Isaac running. | ||||
* | | | fsp_srv: Implement IFile::Flush. | bunnei | 2018-04-15 | 1 | -1/+9 |
|/ / | |||||
* | | Merge pull request #323 from Hexagon12/stub-hid | bunnei | 2018-04-13 | 1 | -1/+7 |
|\ \ | | | | | | | Service/HID: Stubbed out GetPlayerLedPattern | ||||
| * | | Stubbed out GetPlayerLedPattern | Hexagon12 | 2018-04-13 | 1 | -1/+7 |
| | | | |||||
* | | | Fixed normal params in GetDisplayResolution | Hexagon12 | 2018-04-13 | 1 | -1/+1 |
|/ / | |||||
* | | Merge pull request #319 from Hexagon12/service-name-fix | bunnei | 2018-04-13 | 21 | -65/+413 |
|\ \ | | | | | | | Various service name fixes - part 1 | ||||
| * | | Various fixes and clang | Hexagon12 | 2018-04-11 | 6 | -115/+108 |
| | | | |||||
| * | | Decimal change | Hexagon12 | 2018-04-10 | 1 | -4/+4 |
| | | | |||||
| * | | Updated pctl:a with new service names. | Hexagon12 | 2018-04-10 | 1 | -4/+101 |
| | | | |||||
| * | | Updated nvmemp with new service names. | Hexagon12 | 2018-04-10 | 1 | -4/+4 |
| | | | |||||
| * | | Updated nvdrv with more service names. | Hexagon12 | 2018-04-10 | 1 | -0/+7 |
| | | | |||||
| * | | Updated pl:u with more service names. | Hexagon12 | 2018-04-10 | 1 | -1/+3 |
| | | | |||||
| * | | Updated hid with more service names. | Hexagon12 | 2018-04-10 | 1 | -0/+50 |
| | | | |||||
| * | | Updated friend:u with more service names. | Hexagon12 | 2018-04-10 | 1 | -1/+2 |
| | | | |||||
| * | | Updated the unknown name | Hexagon12 | 2018-04-10 | 1 | -1/+1 |
| | | | |||||
| * | | Updated friend:a with more service names. | Hexagon12 | 2018-04-10 | 1 | -1/+2 |
| | | | |||||
| * | | Updated fsp-srv with more service names. | Hexagon12 | 2018-04-10 | 1 | -4/+102 |
| | | | |||||
| * | | Updated CodecCtl with more service names. | Hexagon12 | 2018-04-10 | 1 | -3/+3 |
| | | | |||||
| * | | Updated audren with more service names. | Hexagon12 | 2018-04-10 | 1 | -10/+14 |
| | | | |||||
| * | | Updated audrec with more service names. | Hexagon12 | 2018-04-10 | 1 | -7/+9 |
| | | | |||||
| * | | Updated audout with more service names. | Hexagon12 | 2018-04-10 | 1 | -13/+16 |
| | | | |||||
| * | | Updated audin with more service names. | Hexagon12 | 2018-04-10 | 1 | -9/+16 |
| | | | |||||
| * | | Updated AOC with more service names. | Hexagon12 | 2018-04-10 | 1 | -0/+1 |
| | | | |||||
| * | | Updated AppletOE with more service names. | Hexagon12 | 2018-04-10 | 1 | -0/+1 |
| | | | |||||
| * | | Updated AppletAE with more service names. | Hexagon12 | 2018-04-10 | 1 | -0/+1 |
| | | | |||||
| * | | Updated AM with more service names. | Hexagon12 | 2018-04-10 | 1 | -2/+82 |
| | | | |||||
* | | | Service/SSL: update service according switchbrew | mailwl | 2018-04-11 | 2 | -1/+98 |
| | | | |||||
* | | | Service/ACC: convert to module, add acc:aa, acc:su, acc:u1 services | mailwl | 2018-04-10 | 11 | -127/+342 |
|/ / | |||||
* | | Fix spelling of Initialize | James Rowe | 2018-04-07 | 2 | -3/+3 |
| | | |||||
* | | core, main.h: Abort on 32Bit ROMs (#309) | N00byKing | 2018-04-06 | 4 | -0/+11 |
| | | | | | | | | | | | | * core, main.h: Abort on 32Bit ROMs * main.cpp: Fix Grammar | ||||
* | | svc: Stub out SetThreadActivity, GetThreadContext. | bunnei | 2018-04-03 | 2 | -2/+19 |
| | | |||||
* | | audren_u: Stub out GetActiveAudioDeviceName. | bunnei | 2018-04-03 | 1 | -1/+13 |
| | | |||||
* | | audout_u: Implement GetAudioOutState. | bunnei | 2018-04-03 | 1 | -1/+8 |
| | | |||||
* | | nifm: GetResult does not return a data field. | bunnei | 2018-04-03 | 1 | -2/+1 |
| | | |||||
* | | vi: Implement GetDisplayResolution. | bunnei | 2018-04-03 | 2 | -0/+26 |
| | | |||||
* | | shared_memory: Remove incorrect 3ds-specific check. | bunnei | 2018-04-03 | 1 | -12/+0 |
| | | |||||
* | | service: Add friend:u interface. | bunnei | 2018-04-03 | 4 | -0/+41 |
| | | |||||
* | | Merge pull request #276 from N00byKing/acctoyuzu | bunnei | 2018-04-03 | 2 | -4/+4 |
|\ \ | | | | | | | Change Telemetry Names to yuzu and remove links to citra | ||||
| * | | telemetry_session.h: Reword Documentation Comment from citra to yuzu | N00byKing | 2018-03-27 | 1 | -2/+2 |
| | | | |||||
| * | | Change Telemetry Names to yuzu | N00byKing | 2018-03-27 | 1 | -2/+2 |
| | | | |||||
* | | | Merge pull request #304 from daniellimws/fix-openbsd | bunnei | 2018-04-03 | 1 | -6/+6 |
|\ \ \ | | | | | | | | | Fix build on OpenBSD | ||||
| * | | | externals: Update fmt to 4d35f94 | Daniel Lim Wee Soong | 2018-04-02 | 1 | -6/+6 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Versions prior to this didn't compile on OpenBSD due to unconditional use of the non-standard strtod_l() function. The fmt::MemoryWriter API has been removed in the intervening versions, so replace its use with fmt::memory_buffer and fmt::format_to. The library also no longer provides the fmt::fmt ALIAS, so define it in externals/CMakeLists.txt. | ||||
* | | | | deconstructed_rom_directory.cpp: Fix Typo | N00byKing | 2018-04-03 | 1 | -1/+1 |
|/ / / | |||||
* | | | Merge pull request #297 from bunnei/hid-touch-state | bunnei | 2018-04-02 | 1 | -5/+21 |
|\ \ \ | | | | | | | | | hid: Write empty touch screen state. | ||||
| * | | | hid: Write empty touch screen state. | bunnei | 2018-04-01 | 1 | -5/+21 |
| | | | | |||||
* | | | | hle_ipc, fsp_srv: Cleanup logging. | bunnei | 2018-04-01 | 2 | -3/+3 |
| | | | | |||||
* | | | | hid: Stub out GetSupportedNpadStyleSet. | bunnei | 2018-03-31 | 1 | -0/+8 |
| | | | | |||||
* | | | | hle_ipc: Do not ensure write buffer size. | bunnei | 2018-03-31 | 1 | -2/+5 |
| | | | | |||||
* | | | | fsp_srv: Implement GetSize and SetSize. | bunnei | 2018-03-31 | 2 | -4/+24 |
| | | | | |||||
* | | | | memory: Fix stack region. | bunnei | 2018-03-31 | 6 | -10/+12 |
|/ / / | |||||
* | | | audren_u: Stub QueryAudioDeviceSystemEvent and GetActiveChannelCount. | bunnei | 2018-03-30 | 1 | -8/+36 |
| | | | |||||
* | | | svc: Stub GetThreadCoreMask. | bunnei | 2018-03-30 | 2 | -3/+26 |
| | | | |||||
* | | | service: Add NFP module interface. | bunnei | 2018-03-30 | 6 | -0/+99 |
| | | | | | | | | | | | | | | | | | | service: Initialize NFP service. Log: Add NFP service as a log subtype. | ||||
* | | | result: Check against self-assignment in ResultVal's copy assignment operator | Lioncash | 2018-03-29 | 1 | -0/+3 |
| | | | | | | | | | | | | Avoids doing work that doesn't need to be done. | ||||
* | | | settings: Remove unused CpuCore class. | bunnei | 2018-03-27 | 1 | -5/+0 |
| | | | |||||
* | | | config: Use simplified checkbox (from Citra) for CPU JIT. | bunnei | 2018-03-27 | 3 | -10/+7 |
| | | | |||||
* | | | config: Rename is_docked to use_docked_mode to be consistent with other config bools. | bunnei | 2018-03-27 | 2 | -6/+6 |
| | | | |||||
* | | | config: Add setting for whether the system is docked or not. | bunnei | 2018-03-27 | 2 | -2/+9 |
|/ / | |||||
* | | memory: Fix cast for ReadBlock/WriteBlock/ZeroBlock/CopyBlock. | bunnei | 2018-03-27 | 1 | -4/+8 |
| | | |||||
* | | memory: Add RasterizerMarkRegionCached code and cleanup. | bunnei | 2018-03-27 | 2 | -200/+195 |
| | | |||||
* | | Merge pull request #280 from bunnei/misc-service-fixes | bunnei | 2018-03-25 | 5 | -8/+66 |
|\ \ | | | | | | | Minor changes to VI, PL, HID, and AUDREN | ||||
| * | | audren_u: Fix GetAudioDevice. | bunnei | 2018-03-25 | 2 | -7/+48 |
| | | | |||||
| * | | hid: Stub out SetNpadJoyAssignmentModeDual. | bunnei | 2018-03-25 | 1 | -1/+7 |
| | | | |||||
| * | | pl_u: Add RequestLoad. | bunnei | 2018-03-25 | 2 | -0/+11 |
| | | | |||||
* | | | Merge pull request #273 from Subv/textures | bunnei | 2018-03-25 | 1 | -0/+11 |
|\ \ \ | | | | | | | | | GPU: Added code to unswizzle textures and ported the surface viewer from citra | ||||
| * | | | GPU: Make the debug_context variable a member of the frontend instead of a global. | Subv | 2018-03-25 | 1 | -0/+11 |
| |/ / | |||||
* / / | Service/sockets: add bsd:s, nsd:a, nsd:u services | mailwl | 2018-03-25 | 8 | -32/+96 |
|/ / | |||||
* | | arm_dynarmic: Fix timing | MerryMage | 2018-03-24 | 1 | -7/+3 |
| | | |||||
* | | Merge pull request #265 from bunnei/tegra-progress-2 | bunnei | 2018-03-24 | 4 | -7/+66 |
|\ \ | | | | | | | Tegra progress 2 | ||||
| * | | renderer_opengl: Fixes for properly flushing & rendering the framebuffer. | bunnei | 2018-03-23 | 1 | -6/+0 |
| | | | |||||
| * | | memory: Fix typo in RasterizerFlushVirtualRegion. | bunnei | 2018-03-23 | 1 | -3/+3 |
| | | | |||||
| * | | memory: RasterizerFlushVirtualRegion should also check process image region. | bunnei | 2018-03-23 | 1 | -0/+1 |
| | | | |||||
| * | | rasterizer: Flush and invalidate regions should be 64-bit. | bunnei | 2018-03-23 | 2 | -3/+3 |
| | | | |||||
| * | | renderer_opengl: Better handling of framebuffer transform flags. | bunnei | 2018-03-23 | 2 | -3/+3 |
| | | | |||||
| * | | nvdisp_disp0: Always flush and invalidate framebuffer region. | bunnei | 2018-03-23 | 1 | -0/+7 |
| | | | | | | | | | | | | - Workaround for texture forwarding until we have a better place. | ||||
| * | | memory: Port RasterizerFlushVirtualRegion from Citra. | bunnei | 2018-03-23 | 2 | -1/+58 |
| | | | |||||
| * | | video_core: Move FramebufferInfo to FramebufferConfig in GPU. | bunnei | 2018-03-23 | 1 | -3/+3 |
| | | | |||||
* | | | Merge pull request #255 from Subv/sd_card | bunnei | 2018-03-24 | 12 | -48/+329 |
|\ \ \ | | | | | | | | | FS: Implemented access to the SD card | ||||
| * | | | FS: Move the file open mode calculation to a separate function. | Subv | 2018-03-23 | 1 | -7/+14 |
| | | | | |||||
| * | | | FS: Implemented IFileSystem::CreateDirectory. | Subv | 2018-03-21 | 6 | -7/+29 |
| | | | | |||||
| * | | | FS: Implemented IFileSystem's OpenDirectory function. | Subv | 2018-03-20 | 1 | -0/+28 |
| | | | | | | | | | | | | | | | | Note that the filter parameter is not yet implemented. | ||||
| * | | | FS: Added the IDirectory IPC interface and implemented its two functions. | Subv | 2018-03-20 | 1 | -0/+51 |
| | | | | |||||
| * | | | FS: Implement DiskFileSystem's OpenDirectory interface. | Subv | 2018-03-20 | 5 | -6/+19 |
| | | | | |||||
| * | | | FS: Implement DiskFileSystem::GetEntryType for existing files/directories. | Subv | 2018-03-20 | 1 | -2/+4 |
| | | | | |||||
| * | | | FS: Updated the Directory Entry structure to match the Switch. | Subv | 2018-03-20 | 5 | -30/+84 |
| | | | | |||||
| * | | | FS: Support the file Append open mode. | Subv | 2018-03-20 | 2 | -2/+23 |
| | | | | |||||
| * | | | FS: Implement MountSdCard. | Subv | 2018-03-20 | 1 | -2/+6 |
| | | | | |||||
| * | | | FS: Added an SDMC archive factory and registered it to the SDMC archive on startup. | Subv | 2018-03-20 | 5 | -0/+79 |
| | | | | |||||
* | | | | Service/SSL: add ssl service | mailwl | 2018-03-23 | 4 | -0/+43 |
| | | | | |||||
* | | | | Remove more N3DS References | N00byKing | 2018-03-22 | 2 | -20/+0 |
| | | | | |||||
* | | | | Service/spl: add module and services | mailwl | 2018-03-22 | 8 | -0/+174 |
| |/ / |/| | | |||||
* | | | Service/vi: convert services to module | mailwl | 2018-03-21 | 8 | -212/+160 |
| | | | |||||
* | | | Service: add fatal:u, fatal:p services | mailwl | 2018-03-20 | 8 | -0/+144 |
| | | | |||||
* | | | Clang Fixes | N00byKing | 2018-03-19 | 4 | -8/+9 |
| | | | |||||
* | | | oops | N00byKing | 2018-03-19 | 1 | -3/+3 |
| | | | |||||
* | | | More Warning cleanups | N00byKing | 2018-03-19 | 3 | -3/+3 |
| | | | |||||
* | | | Clean Warnings (?) | N00byKing | 2018-03-19 | 14 | -19/+19 |
|/ / | |||||
* | | Merge pull request #193 from N00byKing/3184_2_robotic_boogaloo | bunnei | 2018-03-19 | 7 | -41/+41 |
|\ \ | | | | | | | Implement Pull #3184 from citra: core/arm: Improve timing accuracy before service calls in JIT (Rebased) | ||||
| * | | Implements citra-emu/citra#3184 | N00byKing | 2018-02-25 | 7 | -41/+41 |
| | | | |||||
* | | | vi: Remove DequeueBuffer and wait until next available buffer. | bunnei | 2018-03-19 | 3 | -12/+49 |
| | | | |||||
* | | | hle_ipc: Add SleepClientThread to block current thread within HLE routines. | bunnei | 2018-03-19 | 2 | -0/+47 |
| | | | |||||
* | | | hle_ipc: Use shared_ptr instead of unique_ptr to allow copies. | bunnei | 2018-03-19 | 2 | -9/+9 |
| | | | |||||
* | | | hle_ipc: Remove GetPointer(..) usage with WriteToOutgoingCommandBuffer. | bunnei | 2018-03-19 | 3 | -7/+14 |
| | | | |||||
* | | | thread: Add THREADSTATUS_WAIT_HLE_EVENT, remove THREADSTATUS_WAIT_ARB. | bunnei | 2018-03-19 | 3 | -20/+6 |
| | | | |||||
* | | | nvflinger: Remove superfluous buffer format check. | bunnei | 2018-03-17 | 1 | -3/+1 |
| | | | |||||
* | | | process: MirrorMemory should use MemoryState::Mapped. | bunnei | 2018-03-17 | 1 | -1/+1 |
| | | | |||||
* | | | process: Unmap previously allocated heap. | bunnei | 2018-03-16 | 1 | -1/+3 |
| | | | |||||
* | | | arm_interface: Support unmapping previously mapped memory. | bunnei | 2018-03-16 | 6 | -2/+18 |
| | | | |||||
* | | | svc: Use more correct values for GetInfo MapRegion and NewMapRegion. | bunnei | 2018-03-16 | 3 | -29/+5 |
| | | | |||||
* | | | kernel: Move stack region outside of application heap. | bunnei | 2018-03-16 | 6 | -11/+6 |
| | | | |||||
* | | | memory: Add regions for map region, "new" map region, etc. | bunnei | 2018-03-16 | 1 | -19/+29 |
| | | | |||||
* | | | process: Fix stack memory state. | bunnei | 2018-03-16 | 1 | -2/+4 |
| | | | |||||
* | | | MemoryState: Add additional memory states and improve naming. | bunnei | 2018-03-16 | 5 | -18/+45 |
| | | | |||||
* | | | IGeneralService: fix function list | mailwl | 2018-03-16 | 1 | -2/+3 |
| | | | |||||
* | | | Service/NIFM: stub cancel function | mailwl | 2018-03-16 | 1 | -1/+6 |
| | | | |||||
* | | | Service/NIFM: convert to module | mailwl | 2018-03-16 | 8 | -122/+75 |
| | | | |||||
* | | | core: Move process creation out of global state. | bunnei | 2018-03-14 | 20 | -66/+81 |
| | | | |||||
* | | | Merge pull request #229 from Subv/ensuresavedata_impl | bunnei | 2018-03-04 | 12 | -43/+91 |
|\ \ \ | | | | | | | | | FS: Make EnsureSaveData create the save data if it doesn't already exist. | ||||
| * | | | FS: Use the correct error code when trying to open files that don't exist. | Subv | 2018-03-04 | 2 | -26/+6 |
| | | | | |||||
| * | | | FS: Stubbed CreateSaveData. It currently does nothing. | Subv | 2018-03-04 | 2 | -0/+15 |
| | | | | |||||
| * | | | FS: Make EnsureSaveData create the savedata folder when called for the first time. | Subv | 2018-03-04 | 8 | -17/+70 |
| | | | | |||||
* | | | | CoreTiming: Unschedule the pending events when an Interface is destroyed. | Subv | 2018-03-04 | 3 | -2/+10 |
|/ / / | |||||
* | | | Merge pull request #226 from Subv/buffer_queue_event | bunnei | 2018-03-03 | 1 | -0/+3 |
|\ \ \ | | | | | | | | | Vi: Signal the BufferQueue's Native Handle right after ReleaseBuffer is called | ||||
| * | | | Vi: Signal the BufferQueue's Native Handle right after ReleaseBuffer is called. | Subv | 2018-03-03 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | This prevents a thread starvation issue in Puyo Puyo Tetris. We should hwtest this behavior and figure out where exactly this event is signaled. | ||||
* | | | | Service/Set: add more services | mailwl | 2018-03-03 | 12 | -10/+348 |
|/ / / | |||||
* | | | Merge pull request #216 from Subv/savedata | bunnei | 2018-03-02 | 20 | -39/+541 |
|\ \ \ | | | | | | | | | Implemented the SaveData archive and MountSaveData. | ||||
| * | | | SaveData: Use the current titleid when opening the savedata archive. | Subv | 2018-03-02 | 1 | -2/+3 |
| | | | | |||||
| * | | | Kernel: Store the program id in the Process class instead of the CodeSet class. | Subv | 2018-03-02 | 7 | -21/+20 |
| | | | | | | | | | | | | | | | | There may be many CodeSets per Process, so it's wasteful and overcomplicated to store the program id in each of them. | ||||
| * | | | FS: Implement MountSaveData and some of the IFile interface. | Subv | 2018-03-02 | 2 | -0/+189 |
| | | | | |||||
| * | | | Filesystem: Added a SaveData Factory and associated Disk_FileSystem. | Subv | 2018-03-02 | 10 | -16/+329 |
| | | | | |||||
| * | | | ResultCode: Mark any error code that isn't 0 as an error. | Subv | 2018-02-27 | 1 | -2/+2 |
| | |/ | |/| | |||||
* / | | thread: Clear the process list on shutdown. | Jules Blok | 2018-02-27 | 1 | -1/+3 |
|/ / | |||||
* | | Merge pull request #207 from mailwl/duplicatesession | bunnei | 2018-02-27 | 3 | -6/+12 |
|\ \ | | | | | | | IPC: add domain header to response if only it exists in request | ||||
| * | | Add warning if Domain request has no domain message header | mailwl | 2018-02-20 | 1 | -0/+3 |
| | | | |||||
| * | | Fix: change check for domain order and existance of domain message header | mailwl | 2018-02-20 | 3 | -3/+4 |
| | | | |||||
| * | | IPC: add domain header to response if only it exists in request | mailwl | 2018-02-20 | 3 | -6/+8 |
| | | | |||||
* | | | Merge pull request #215 from N00byKing/umapsharedmmry | bunnei | 2018-02-26 | 2 | -1/+17 |
|\ \ \ | | | | | | | | | UnmapSharedMemory | ||||
| * | | | (Hopefully) Fix MinGW Build | N00byKing | 2018-02-25 | 1 | -1/+1 |
| | | | | |||||
| * | | | Add UnmapSharedMemory | N00byKing | 2018-02-25 | 2 | -1/+17 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | C++11 requires spaces on the Identifier Add inttypes include clang | ||||
* | | | | file_sys: Style tweaks | shinyquagsire23 | 2018-02-26 | 2 | -11/+5 |
| | | | | | | | | | | | | | | | | Asdf | ||||
* | | | | loader: Check error on NPDM load, use TID for CodeSet | shinyquagsire23 | 2018-02-25 | 3 | -6/+10 |
| | | | | |||||
* | | | | loader: Use NPDM information when loading NSOs | shinyquagsire23 | 2018-02-25 | 2 | -4/+15 |
| | | | | |||||
* | | | | file_sys: Add support for parsing NPDM files | shinyquagsire23 | 2018-02-25 | 3 | -0/+276 |
| | | | | |||||
* | | | | Merge pull request #212 from mailwl/stubs | bunnei | 2018-02-24 | 10 | -9/+112 |
|\ \ \ \ | | | | | | | | | | | Stub some functions | ||||
| * | | | | Stub more functions | mailwl | 2018-02-22 | 7 | -8/+90 |
| | | | | | |||||
| * | | | | Stub am::SetScreenShotPermission, and bsd::StartMonitoring functions | mailwl | 2018-02-22 | 5 | -1/+22 |
| |/ / / | |||||
* | | | | Merge pull request #217 from shinyquagsire23/time-s-missing | bunnei | 2018-02-23 | 1 | -0/+4 |
|\ \ \ \ | | | | | | | | | | | time: Add missing time:s functions, used for libnx | ||||
| * | | | | time: Add missing time:s functions, used for libnx | shinyquagsire23 | 2018-02-23 | 1 | -0/+4 |
| |/ / / | |||||
* | | | | Merge pull request #210 from MerryMage/f/dynarmic/sysreg | bunnei | 2018-02-23 | 2 | -2/+33 |
|\ \ \ \ | |/ / / |/| | | | arm_dynarmic: Implement system registers and provide more hooks | ||||
| * | | | dynarmic: Update to 6b4c6b0 | MerryMage | 2018-02-21 | 1 | -2/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 6b4c6b0 impl: Update PC when raising exception 7a1313a A64: Implement FDIV (vector) b2d781d system: Raise exception for YIELD, WFE, WFI, SEV, SEVL b277bf5 Correct FPSR and FPCR 7673933 A64: Implement USHL 8d0e558 A64: Implement UCVTF (vector, integer), scalar variant da9a4f8 A64: Partially implement FCVTZU (scalar, fixed-point) and FCVTZS (scalar, fixed-point) 7479684 A64: Implement system register TPIDR_EL0 0fd75fd A64: Implement system registers FPCR and FPSR 31e370c A64: Implement system register CNTPCT_EL0 9a88fd3 A64: Implement system register CTR_EL0 1d16896 A64: Implement NEG (vector) 3184edf IR: Add IR instruction ZeroVector 31f8fbc emit_x64_floating_point: Add maybe_unused to preprocess parameter 567eb1a A64: Implement FMINNM (scalar) c6d8fa1 A64: Implement FMAXNM (scalar) 616056d constant_pool: Add frame parameter a3747cb A64: Implement ADDP (scalar) 5cd5d9f reg_alloc: Only exchange GPRs dd0452a A64: Implement DUP (element), scalar variant e5732ea emit_x64_floating_point: Correct FP{Max,Min}{32,64} implementations for -0/+0 40eb9c3 A64: Implement FMAX (scalar), FMIN (scalar) 7cef39b fuzz_with_unicorn: QEMU's implementation of FCVT is incorrect 826dce2 travis: Switch unicorn repository 9605f28 a64/config: Allow NaN emulation accuracy to be set e9435bc a64_emit_x64: Add conf to A64EmitContext 30b596d fuzz_with_unicorn: Explicitly test floating point instructions be292a8 A64: Implement FSQRT (scalar) 3c42d48 backend_x64: Accurately handle NaNs 4aefed0 fuzz_with_unicorn: Print AArch64 disassembly | ||||
| * | | | arm_dynarmic: LOG_INFO on unicorn fallback | MerryMage | 2018-02-21 | 1 | -0/+4 |
| | | | | |||||
| * | | | memory: LOG_ERROR when falling off end of page table | MerryMage | 2018-02-21 | 1 | -0/+11 |
| |/ / | |||||
* | | | Merge pull request #211 from shinyquagsire23/time_local | bunnei | 2018-02-22 | 3 | -0/+9 |
|\ \ \ | | | | | | | | | time: Add GetStandardLocalSystemClock, used by libnx | ||||
| * | | | time: Add GetStandardLocalSystemClock, used by libnx | shinyquagsire23 | 2018-02-22 | 3 | -0/+9 |
| |/ / | |||||
* / / | core: Fix scheduler-shutdown related crash | MerryMage | 2018-02-21 | 1 | -5/+9 |
|/ / | |||||
* | | Merge pull request #206 from mailwl/aoc-listaddoncontent | bunnei | 2018-02-20 | 2 | -2/+26 |
|\ \ | | | | | | | Service/AOC: stub ListAddOnContent function | ||||
| * | | Service/AOC: stub ListAddOnContent function | mailwl | 2018-02-20 | 2 | -2/+26 |
| | | | |||||
* | | | acc_u0: Stub ListOpenUsers service function. | bunnei | 2018-02-19 | 2 | -1/+11 |
| | | | |||||
* | | | service: Add Friend service interface. | bunnei | 2018-02-19 | 6 | -0/+100 |
|/ / | |||||
* | | Merge pull request #202 from bunnei/scheduler-cleanup | bunnei | 2018-02-19 | 10 | -378/+237 |
|\ \ | | | | | | | Scheduler cleanup | ||||
| * | | scheduler: Cleanup based on PR feedback. | bunnei | 2018-02-19 | 3 | -5/+4 |
| | | | |||||
| * | | kernel: Use Scheduler class for threading. | bunnei | 2018-02-18 | 5 | -173/+24 |
| | | | |||||
| * | | kernel: Add Scheduler, which encapsulates the scheduling loading from Thread module. | bunnei | 2018-02-18 | 3 | -0/+210 |
| | | | |||||
| * | | core: Use shared_ptr for cpu_core. | bunnei | 2018-02-18 | 2 | -6/+4 |
| | | | |||||
| * | | kernel: Remove unused address_arbiter code. | bunnei | 2018-02-18 | 5 | -199/+0 |
| | | | |||||
* | | | AM: Corrected the response in EnsureSaveData. | Subv | 2018-02-19 | 1 | -1/+2 |
|/ / | | | | | | | | | The values are still unknown and the function is still considered a stub. Puyo Puyo Tetris now tries to call fsp-srv:MountSaveData. | ||||
* | | Merge pull request #201 from Subv/ipc_delay_ | bunnei | 2018-02-18 | 4 | -50/+63 |
|\ \ | | | | | | | Kernel/IPC: Add a small delay after each SyncRequest to prevent thread starvation. | ||||
| * | | Kernel/IPC: Add a small delay after each SyncRequest to prevent thread starvation. | Subv | 2018-02-18 | 4 | -50/+63 |
| | | | | | | | | | | | | | | | | | | | | | | | | Ported from citra PR #3091 The delay specified here is from a Nintendo 3DS, and should be measured in a Nintendo Switch. This change is enough to prevent Puyo Puyo Tetris's main thread starvation. | ||||
* | | | Merge pull request #200 from Subv/bufferproducerfence | bunnei | 2018-02-18 | 5 | -28/+68 |
|\ \ \ | |/ / |/| | | Make the fence handling in Vi a little less of a hack. | ||||
| * | | nvmap: Make IocFromId return the same existing handle instead of creating a new one. | Subv | 2018-02-17 | 1 | -5/+2 |
| | | | | | | | | | | | | Games like Puyo Puyo Tetris and BOTW seem to depend on the buffer always having the same handle | ||||
| * | | Parcel: Ensure we don't read past the end of the parcels in Vi. | Subv | 2018-02-17 | 1 | -0/+5 |
| | | | |||||
| * | | Vi: Mark all fences as NO_FENCE in the DequeueBuffer response parcel. | Subv | 2018-02-17 | 1 | -2/+2 |
| | | | |||||
| * | | Vi: Always write the IGBPBuffer in the RequestBuffer response parcel. | Subv | 2018-02-17 | 1 | -1/+2 |
| | | | | | | | | | | | | This may break libnx homebrew due to a bug in libnx but is required by official games since they always assume that the buffer will be there. | ||||
| * | | nvhost-ctrl: Stub NVHOST_IOCTL_CTRL_EVENT_WAIT. | Subv | 2018-02-15 | 2 | -0/+25 |
| | | | |||||
| * | | Vi: Mark the fences as valid in the DequeueBuffer response parcel. | Subv | 2018-02-15 | 1 | -0/+3 |
| | | | |||||
| * | | Vi: Added a missing u32 in the DequeueBuffer response parcel. | Subv | 2018-02-15 | 1 | -0/+1 |
| | | | |||||
| * | | Vi: Don't write the IGBPBuffer in the IGBPRequestBufferResponseParcel. | Subv | 2018-02-15 | 1 | -4/+2 |
| | | | |||||
| * | | Vi: Properly write the BufferProducerFence object in the DequeueBuffer response parcel. | Subv | 2018-02-15 | 2 | -18/+28 |
| | | | |||||
* | | | Service/hid: stub some functions | mailwl | 2018-02-16 | 4 | -1/+98 |
| | | | |||||
* | | | shared_memory: Remove some checks. | bunnei | 2018-02-15 | 1 | -13/+0 |
| | | | |||||
* | | | pl_u: Implement basic shared font loading from RAM dump. | bunnei | 2018-02-15 | 6 | -0/+182 |
| | | | |||||
* | | | hid: Stub GetVibrationDeviceInfo and SendVibrationValues. | bunnei | 2018-02-15 | 1 | -0/+15 |
|/ / | |||||
* | | Merge pull request #188 from bunnei/refactor-buffer-descriptor | bunnei | 2018-02-15 | 11 | -108/+102 |
|\ \ | | | | | | | Refactor IPC buffer descriptor interface | ||||
| * | | hle_ipc: Remove const from WriteBuffer size. | bunnei | 2018-02-14 | 2 | -2/+2 |
| | | | |||||
| * | | hle_ipc: Add GetReadBufferSize and check write buffer size. | bunnei | 2018-02-14 | 2 | -0/+10 |
| | | | |||||
| * | | service: Remove remaining uses of BufferDescriptor*. | bunnei | 2018-02-14 | 5 | -14/+8 |
| | | | |||||
| * | | audio: Use WriteBuffer instead of BufferDescriptorB. | bunnei | 2018-02-14 | 2 | -9/+3 |
| | | | |||||
| * | | vi: Eliminate direct usage of BufferDescriptorB. | bunnei | 2018-02-14 | 1 | -14/+3 |
| | | | |||||
| * | | nvdrv: Use ReadBuffer/WriteBuffer functions for Ioctl. | bunnei | 2018-02-14 | 1 | -17/+5 |
| | | | |||||
| * | | vi: Use ReadBuffer/WriteBuffer functions for TransactParcel. | bunnei | 2018-02-14 | 1 | -44/+19 |
| | | | |||||
| * | | hle_ipc: Add helper functions for reading and writing buffers. | bunnei | 2018-02-14 | 1 | -4/+2 |
| | | | |||||
| * | | hle_ipc: Add helper functions for reading and writing buffers. | bunnei | 2018-02-14 | 3 | -0/+55 |
| | | | |||||
| * | | vi: Fix TransactParcelAuto to support both buffer formats. | bunnei | 2018-02-14 | 1 | -25/+16 |
| | | | |||||
* | | | Fix fps counter to correctly measure frame end when there was no frame to draw | James Rowe | 2018-02-14 | 1 | -0/+2 |
| |/ |/| | |||||
* | | memory: Silence formatting sepecifier warnings | Lioncash | 2018-02-14 | 1 | -21/+30 |
| | | |||||
* | | nso: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -2/+4 |
| | | |||||
* | | deconstructed_rom_directory: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -3/+4 |
| | | |||||
* | | nvdrv/interface: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -1/+2 |
| | | |||||
* | | nvmap: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -1/+2 |
| | | |||||
* | | nvhost_gpu: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -6/+8 |
| | | |||||
* | | nvhost_ctrl: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -2/+2 |
| | | |||||
* | | nvhost_ctrl_gpu: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -3/+4 |
| | | |||||
* | | nvhost_as_gpu: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -5/+7 |
| | | |||||
* | | thread: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -2/+3 |
| | | |||||
* | | vm_manager: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -5/+7 |
| | | |||||
* | | gdbstub: Silence formatting specifier warnings | Lioncash | 2018-02-14 | 1 | -6/+9 |
|/ | |||||
* | audren_u: Schedule reoccuring event. (#183) | bunnei | 2018-02-14 | 2 | -6/+36 |
| | | | | | | * audren_u: Schedule reoccuring event. * audren_u: Stub GetAudioRenderersProcessMasterVolume, and misc. changes. | ||||
* | Merge pull request #181 from bunnei/vi-fixes-2 | bunnei | 2018-02-14 | 1 | -17/+36 |
|\ | | | | | VI cleanup and add a hack for booting games | ||||
| * | vi: Add FENCE_HACK, which is useful for booting BOTW. | bunnei | 2018-02-13 | 1 | -7/+21 |
| | | |||||
| * | vi: Stub TransactParcel CancelBuffer. | bunnei | 2018-02-13 | 1 | -0/+2 |
| | | |||||
| * | TransactParcel: Move WriteBlock to narrowest scope. | bunnei | 2018-02-13 | 1 | -10/+13 |
| | | |||||
* | | Merge pull request #184 from mailwl/lm | bunnei | 2018-02-13 | 1 | -20/+49 |
|\ \ | |/ |/| | Service/lm: add support to multiline logs | ||||
| * | Service/lm: add support to multiline logs | mailwl | 2018-02-13 | 1 | -20/+49 |
| | | |||||
* | | arm_dynarmic: Support direct page table access | MerryMage | 2018-02-12 | 2 | -10/+19 |
|/ | |||||
* | Merge pull request #179 from gdkchan/audren_stubs | bunnei | 2018-02-12 | 1 | -2/+76 |
|\ | | | | | Stub RequestUpdateAudioRenderer, StartAudioRenderer and StopAudioRenderer | ||||
| * | Add RequestUpdateAudioRenderer, StartAudioRenderer and StopAudioRenderer stubs to audren:u | gdkchan | 2018-02-12 | 1 | -2/+76 |
| | | |||||
* | | Merge pull request #178 from Subv/command_buffers | bunnei | 2018-02-12 | 10 | -174/+27 |
|\ \ | |/ |/| | GPU: Added a command processor to decode the GPU pushbuffers and forward the commands to their respective engines | ||||
| * | Make a GPU class in VideoCore to contain the GPU state. | Subv | 2018-02-12 | 10 | -183/+24 |
| | | | | | | | | Also moved the GPU MemoryManager class to video_core since it makes more sense for it to be there. | ||||
| * | GPU: Added a command processor to decode the GPU pushbuffers and forward the commands to their respective engines. | Subv | 2018-02-12 | 3 | -3/+5 |
| | | |||||
| * | nvdrv: Make the GPU memory manager available to nvhost-gpu. | Subv | 2018-02-12 | 3 | -6/+16 |
| | | |||||
* | | vi: Parse IGBPQueueBufferRequestParcel params and expose buffer flip vertical. | bunnei | 2018-02-12 | 6 | -11/+46 |
| | | |||||
* | | vi: Fix OpenLayer and CreateStrayLayer. | bunnei | 2018-02-11 | 1 | -6/+8 |
|/ | |||||
* | fsp_srv: Stub MountSdCard. | bunnei | 2018-02-10 | 2 | -0/+9 |
| | |||||
* | apm: Refactor service impl. to support multiple ports. | bunnei | 2018-02-10 | 5 | -58/+102 |
| | |||||
* | vi: Implement TransactParcelAuto. | bunnei | 2018-02-10 | 1 | -32/+46 |
| | |||||
* | nvflinger: (Hack) Use first available buffer if none are found. | bunnei | 2018-02-10 | 1 | -1/+5 |
| | |||||
* | IGBPQueueBufferRequestParcel: Don't enforce buffer length. | bunnei | 2018-02-10 | 1 | -1/+0 |
| | | | | - Another fix for libnx. | ||||
* | IGBPRequestBufferResponseParcel: Fix response for libnx. | bunnei | 2018-02-10 | 1 | -7/+4 |
| | |||||
* | Merge pull request #171 from bunnei/libnx-fixes | bunnei | 2018-02-09 | 6 | -9/+38 |
|\ | | | | | Various fixes for libnx, etc. | ||||
| * | nvdrv: Fix QueryEvent for libnx. | bunnei | 2018-02-09 | 2 | -4/+8 |
| | | |||||
| * | IApplicationDisplayService::CloseDisplay: Fix response params size. | bunnei | 2018-02-09 | 1 | -1/+1 |
| | | |||||
| * | nvhost_ctrl_gpu: Implement ZCullGetInfo. | bunnei | 2018-02-09 | 1 | -2/+14 |
| | | |||||
| * | acc_u0: Implement ListAllUsers. | bunnei | 2018-02-09 | 2 | -2/+15 |
| | | |||||
* | | dynarmic: Update to 41ae12263 | MerryMage | 2018-02-09 | 2 | -31/+45 |
|/ | | | | Changes: Primarily implementing more A64 instructions | ||||
* | nvhost_as_gpu: Implement AllocateSpace and MapBufferEx. | bunnei | 2018-02-08 | 2 | -10/+33 |
| | |||||
* | nvdrv: Add MemoryManager class to track GPU memory. | bunnei | 2018-02-08 | 3 | -0/+162 |
| | |||||
* | nvmap: Refactor to expose nvmap objects. | bunnei | 2018-02-08 | 2 | -19/+22 |
| | |||||
* | nvhost_as_gpu: Add nvmap as a class member. | bunnei | 2018-02-08 | 3 | -2/+9 |
| | |||||
* | Service: stub some functions in am, audio, time, vi services | mailwl | 2018-02-07 | 9 | -6/+191 |
| | |||||
* | Service/hid: stub SetNpadHandheldActivationMode | mailwl | 2018-02-06 | 1 | -0/+7 |
| | |||||
* | Merge pull request #165 from bunnei/puyo-fixes | bunnei | 2018-02-06 | 4 | -2/+23 |
|\ | | | | | Stubs for HID, AM, and a mutex fix | ||||
| * | mutex: Update hasWaiters on release. | bunnei | 2018-02-06 | 1 | -0/+1 |
| | | |||||
| * | hid: Stub ActivateTouchScreen and SetNpadJoyHoldType. | bunnei | 2018-02-06 | 1 | -2/+14 |
| | | |||||
| * | IApplicationFunctions: Stub out EnsureSaveData. | bunnei | 2018-02-06 | 2 | -0/+8 |
| | | |||||
* | | Extra nvdrv support (#162) | David | 2018-02-06 | 17 | -37/+765 |
|/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * FinishInitalize needed for 3.0.1+ games * nvdrv:s and nvdrv:t both use NVDRV * Most settings return 0 on hardware, disabled NV_MEMORY_PROFILER for now. NVN_THROUGH_OPENGL & NVRM_GPU_PREVENT_USE are a few interesting settings to look at. Carefully choosing settings can help with drawing graphics later on * Initial /dev/nvhost-gpu support * ZCullBind * Stubbed SetErrorNotifier * Fixed SetErrorNotifier log, Added SetChannelPriority * Allocate GPFIFO Ex2, Allocate Obj Ctx, Submit GPFIFO * oops * Fixed up naming/structs/enums. Used vector instead of array for "gpfifo_entry" * Added missing fixes * /dev/nvhost-ctrl-gpu * unneeded struct * Forgot u32 in enum class * Automatic descriptor swapping for ioctls, fixed nvgpu_gpu_get_tpc_masks_args being incorrect size * nvdrv#QueryEvent * Renamed logs for nvdrv * Refactor ioctl so nv_result isn't needed * /dev/nvhost-as-gpu * Fixed Log service naming, CtxObjects now u32, renamed all structs, added static_asserts to structs, used INSERT_PADDING_WORDS instead of u32s * nvdevices now uses "Ioctl" union, * IoctlGpfifoEntry now uses bit field * final changes | ||||
* | Merge pull request #164 from ogniK5377/libnx_sm_fix | bunnei | 2018-02-05 | 1 | -0/+2 |
|\ | | | | | Don't call UNIMPLEMENTED for 'empty services', just return error code | ||||
| * | Dont call UNIMPLEMENTED for 'empty services', just return error code | David Marcec | 2018-02-05 | 1 | -0/+2 |
| | | |||||
* | | Changed .istorage to .romfs | David Marcec | 2018-02-05 | 2 | -5/+5 |
|/ | |||||
* | set: GetAvailableLanguageCodes should not return lang_codes size. | bunnei | 2018-02-05 | 1 | -2/+3 |
| | |||||
* | nvflinger: Signal BufferQueue native handle event. | bunnei | 2018-02-05 | 1 | -0/+1 |
| | | | | - This gets BOTW booting. | ||||
* | logger: Add Time service logging category. | bunnei | 2018-02-05 | 1 | -10/+10 |
| | |||||
* | logger: Add SET service logging category. | bunnei | 2018-02-05 | 1 | -1/+1 |
| | |||||
* | logger: Add PCTL service logging category. | bunnei | 2018-02-05 | 1 | -1/+1 |
| | |||||
* | logger: Add LM service logging category. | bunnei | 2018-02-05 | 1 | -2/+2 |
| | |||||
* | logger: Add APM service logging category. | bunnei | 2018-02-05 | 1 | -2/+3 |
| | |||||
* | lm: Ensure log string is non-empty before checking back(). | bunnei | 2018-02-05 | 1 | -1/+1 |
| | |||||
* | logger: Add NIFM service logging category. | bunnei | 2018-02-05 | 4 | -11/+11 |
| | |||||
* | logger: Add VI service logging category. | bunnei | 2018-02-05 | 4 | -21/+20 |
| | |||||
* | hid: Stub out several functions. | bunnei | 2018-02-05 | 1 | -1/+39 |
| | |||||
* | hid: Implement CreateActiveVibrationDeviceList. | bunnei | 2018-02-04 | 1 | -0/+25 |
| | |||||
* | logger: Use Service_HID category where applicable. | bunnei | 2018-02-04 | 1 | -2/+2 |
| | |||||
* | logger: Use Service_NVDRV category where applicable. | bunnei | 2018-02-04 | 2 | -10/+10 |
| | |||||
* | logger: Add AM service logging category. | bunnei | 2018-02-04 | 3 | -42/+42 |
| | |||||
* | logger: Add "account" service logging category. | bunnei | 2018-02-04 | 1 | -8/+8 |
| | |||||
* | acc_u0: Stub out GetLastOpenedUser. | bunnei | 2018-02-04 | 2 | -0/+10 |
| | |||||
* | Merge pull request #160 from bunnei/svc-improvements | bunnei | 2018-02-04 | 5 | -24/+32 |
|\ | | | | | Several SVC fixes and improvements | ||||
| * | GetInfo: Implement IsCurrentProcessBeingDebugged. | bunnei | 2018-02-04 | 1 | -0/+3 |
| | | |||||
| * | WaitProcessWideKeyAtomic: Handle case where condition variable was already created. | bunnei | 2018-02-04 | 3 | -13/+17 |
| | | |||||
| * | svc: SharedMemory size should be 64-bits and cleanup. | bunnei | 2018-02-03 | 3 | -11/+11 |
| | | |||||
| * | ArbitrateLock: Assert that requesting_thread is current_thread. | bunnei | 2018-02-03 | 1 | -0/+1 |
| | | |||||
* | | acc:u0 : stub GetAccountId | mailwl | 2018-02-04 | 1 | -1/+9 |
|/ | |||||
* | Merge pull request #157 from bunnei/fix-duplicate-session | bunnei | 2018-02-03 | 1 | -4/+9 |
|\ | | | | | controller: DuplicateSession should return a ClientSession. | ||||
| * | controller: DuplicateSession should return a ClientSession. | bunnei | 2018-02-03 | 1 | -4/+9 |
| | | |||||
* | | Service:nifm: add nifm:a, nifm:s and nifm:u services | mailwl | 2018-02-03 | 10 | -0/+378 |
|/ | |||||
* | Service/am: Add AppletAE service (#153) | mailwl | 2018-02-02 | 7 | -379/+571 |
| | | | | | | * Add AppletAE, step 1: move common interfaces to am.h * Add AppletAE, step 2 | ||||
* | Merge pull request #154 from mailwl/vi_create_stray_array | bunnei | 2018-02-02 | 1 | -0/+1 |
|\ | | | | | vi::CreateStrayLayer : add padding to request | ||||
| * | vi::CreateStrayLayer : add padding to request | mailwl | 2018-02-02 | 1 | -0/+1 |
| | | |||||
* | | Merge pull request #155 from mailwl/vi-services | bunnei | 2018-02-02 | 6 | -0/+128 |
|\ \ | | | | | | | Services/vi: add vi:s and vi:u services | ||||
| * | | Services/vi: add vi:s and vi:u services | mailwl | 2018-02-02 | 6 | -0/+128 |
| |/ | |||||
* | | Merge pull request #152 from shinyquagsire23/sharedmem-valid-bounds | bunnei | 2018-02-02 | 1 | -1/+2 |
|\ \ | |/ |/| | shared_memory: Only mark addresses as invalid if they are within the heap | ||||
| * | shared_memory: Only mark addresses as invalid if they are within the heap | shinyquagsire23 | 2018-01-30 | 1 | -1/+2 |
| | | |||||
* | | [WIP] sfdnsres: stub (#146) | mailwl | 2018-01-30 | 5 | -2/+52 |
|/ | | | sfdnsres: Add several stubs | ||||
* | Merge pull request #148 from MerryMage/feature/special-memory | bunnei | 2018-01-27 | 8 | -415/+243 |
|\ | | | | | memory: Replace all memory hooking with Special regions | ||||
| * | memory: Replace all memory hooking with Special regions | MerryMage | 2018-01-27 | 8 | -415/+243 |
| | | |||||
* | | time: Implement ISteadyClock::GetCurrentTimePoint. | bunnei | 2018-01-26 | 2 | -1/+22 |
| | | |||||
* | | audout_u: Various cleanups. | bunnei | 2018-01-25 | 1 | -29/+17 |
| | | |||||
* | | ResponseBuilder: Use a bit field for customizing instead of always_move_handles. | bunnei | 2018-01-25 | 3 | -11/+21 |
| | | |||||
* | | time: Stub GetSystemClockContext function. | bunnei | 2018-01-25 | 2 | -2/+17 |
| | | |||||
* | | server_session: Fix scenario where all domain handlers are closed. | bunnei | 2018-01-25 | 1 | -3/+3 |
| | | |||||
* | | hle: Rename RequestBuilder to ResponseBuilder. | bunnei | 2018-01-25 | 19 | -128/+129 |
| | | |||||
* | | service: Fix all incorrect IPC response headers. | bunnei | 2018-01-25 | 14 | -82/+42 |
| | | |||||
* | | ipc_helpers: Make interface domain agnostic and add header validation. | bunnei | 2018-01-25 | 2 | -25/+58 |
| | | |||||
* | | hle: Integrate Domain handling into ServerSession. | bunnei | 2018-01-25 | 7 | -38/+74 |
| | | |||||
* | | hle: Remove Domain and SyncObject kernel objects. | bunnei | 2018-01-25 | 10 | -169/+2 |
| | | |||||
* | | handle_table: Remove ConvertSessionToDomain. | bunnei | 2018-01-25 | 2 | -17/+0 |
| | | |||||
* | | audout:u OpenAudioOut and IAudioOut (#138) | st4rk | 2018-01-25 | 2 | -14/+166 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Updated the audout:u and IAudioOut, now it might work with RetroArch without trigger an assert, however it's not the ideal implementation * Updated the audout:u and IAudioOut, now it might work with RetroArch without trigger an assert, however it's not the ideal implementation * audout:u OpenAudioOut implementation and IAudioOut cmd 1,2,3,4,5 implementation * using an enum for audio_out_state as well as changing its initialize to member initializer list * Minor fixes, added Service_Audio for LOG_*, changed PcmFormat enum to EnumClass * Minor fixes, added Service_Audio for LOG_*, changed PcmFormat enum to EnumClass * added missing Audio loggin subclass, minor fixes, clang comment breakline * Solving backend logging conflict * minor fix * Fixed duplicated Service NVDRV in backend.cpp, my bad | ||||
* | | Fix time returning epoch time in milliseconds rather than in seconds | gdkchan | 2018-01-24 | 1 | -1/+1 |
| | | |||||
* | | Correct Spelling | N00byKing | 2018-01-23 | 1 | -2/+2 |
| | | |||||
* | | Merge pull request #135 from Subv/no_ports | bunnei | 2018-01-23 | 5 | -65/+67 |
|\ \ | | | | | | | IPC: Don't create unnecessary ports when returning sub interfaces. | ||||
| * | | Services: Added a todo about returning interfaces as domain objects in lm, hid and time. | Subv | 2018-01-23 | 3 | -0/+12 |
| | | | |||||
| * | | Time: Don't create unnecessary ports when retrieving the clock service sessions. | Subv | 2018-01-22 | 1 | -33/+27 |
| | | | |||||
| * | | HID: Don't create an unnecessary port in CreateAppletResource. | Subv | 2018-01-22 | 1 | -13/+13 |
| | | | |||||
| * | | LM: Don't create an unnecessary port in Initialize. | Subv | 2018-01-22 | 2 | -15/+10 |
| | | | |||||
| * | | IPC: Don't create an unnecessary port when using PushIpcInterface outside of a domain. | Subv | 2018-01-22 | 1 | -4/+5 |
| | | | |||||
* | | | Merge pull request #133 from Subv/nvflinger2 | bunnei | 2018-01-22 | 9 | -17/+59 |
|\ \ \ | |/ / |/| | | AppletOE: Stubbed CreateManagedDisplayLayer to create a new layer in the default display. | ||||
| * | | AppletOE: Stubbed CreateManagedDisplayLayer to create a new layer in the Default display. | Subv | 2018-01-22 | 1 | -0/+14 |
| | | | | | | | | | | | | This function is used by libnx to obtain a new layer. | ||||
| * | | AppletOE: Make ISelfController keep a reference to nvflinger. | Subv | 2018-01-22 | 5 | -10/+32 |
| | | | | | | | | | | | | It'll be needed when we implement CreateManagedDisplayLayer. | ||||
| * | | Services: Vi shouldn't be responsible for creating nvflinger. | Subv | 2018-01-22 | 5 | -7/+13 |
| | | | | | | | | | | | | It is now created during Service initialization and passed to all the services that need it. | ||||
* | | | Merge pull request #134 from gdkchan/audout_hid_fix | bunnei | 2018-01-22 | 3 | -2/+21 |
|\ \ \ | |/ / |/| | | Stub OpenAudioOut and fix a issue with HID IAppletResource | ||||
| * | | Stub OpenAudioOut and fix a issue with HID IAppletResource being created more than once | gdkchan | 2018-01-22 | 3 | -2/+21 |
| | | | |||||
* | | | VI: Move BufferQueue and NVFlinger to their own folder/namespace. | Subv | 2018-01-22 | 9 | -363/+452 |
|/ / | |||||
* | | Added stubs for audio services. (#116) | st4rk | 2018-01-22 | 12 | -5/+309 |
| | | | | | | | | | | | | * stubs for audout:u, audin:u, audrec:u, audren:u, codecctl and decoding tables with nullptr for future implementations * fixing the changes requested (remove private, explicit) | ||||
* | | Merge pull request #131 from lioncash/enum | bunnei | 2018-01-22 | 2 | -12/+13 |
|\ \ | | | | | | | nvmap: Make IoctlCommands an enum class | ||||
| * | | nvmap: Add a return 0 underneath the UNIMPLEMENTED macro | Lioncash | 2018-01-21 | 1 | -0/+1 |
| | | | | | | | | | | | | This macro resolves to an empty macro in release builds. | ||||
| * | | nvmap: Make IoctlCommands an enum class | Lioncash | 2018-01-21 | 2 | -12/+12 |
| | | | | | | | | | | | | Prevents the enum values from polluting the surrounding scope | ||||
* | | | Added nvmemp, Added /dev/nvhost-ctrl, SetClientPID now stores pid (#114) | David | 2018-01-21 | 8 | -5/+162 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Added nvmemp, Added /dev/nvhost-ctrl, SetClientPID now stores pid * used clang-format-3.9 instead * lowercase pid * Moved nvmemp handlers to cpp * Removed unnecessary logging for NvOsGetConfigU32. Cleaned up log and changed to LOG_DEBUG * using std::arrays instead of c arrays * nvhost get config now uses std::array completely * added pid logging back * updated cmakelist * missing includes * added array, removed memcpy * clang-format6.0 | ||||
* | | | Merge pull request #128 from Subv/parcel_query | bunnei | 2018-01-21 | 2 | -0/+58 |
|\ \ \ | | | | | | | | | VI: Implement the Query transaction of IHOSBinderDriver, and stubbed some results. | ||||
| * | | | VI: Implement the Query transaction of IHOSBinderDriver, and stubbed some results. | Subv | 2018-01-21 | 2 | -0/+58 |
| | |/ | |/| | |||||
* | | | file_sys: Clang format fixes. | bunnei | 2018-01-21 | 3 | -4/+4 |
| | | | |||||
* | | | fsp_srv: Various improvements to IStorage:Read implementation. | bunnei | 2018-01-21 | 5 | -48/+79 |
| | | | |||||
* | | | deconstructed_rom_directory: Implement istorage loading for RomFS. | bunnei | 2018-01-21 | 2 | -2/+71 |
| | | | |||||
* | | | filesystem: Implement basic IStorage functionality. | David Marcec | 2018-01-21 | 6 | -0/+258 |
| | | | |||||
* | | | file_sys: Cleanup to better match Switch file system constructs. | bunnei | 2018-01-21 | 10 | -63/+136 |
| | | | | | | | | | | | | file_sys: Add factory class for RomFS file system. | ||||
* | | | file_sys: Remove disk_archive, savedata_archive, and title_metadata. | bunnei | 2018-01-21 | 7 | -835/+0 |
| | | | |||||
* | | | archive_backend: Minor changes to match Switch IFileSystem. | bunnei | 2018-01-21 | 5 | -26/+26 |
| | | | |||||
* | | | file_sys: Repurpose 3DS IVFC code for Switch ROMFS. | bunnei | 2018-01-21 | 3 | -51/+43 |
| |/ |/| | |||||
* | | gdbstub: Update registers and sizes for aarch64 | Rozlette | 2018-01-21 | 1 | -113/+155 |
|/ | | | | | | | | | | | | | | | | | This gets gdbstub working at least to the point where clients can communicate with it. What works: - Reading/writing GPRegs - Reading/writing memory - Interrupting the emulated program and continuing What does NOT work: - Breakpoints. Sizes have been updated to u64, but support will need to be added in the interpreter for them to work. - VRegs. Mostly because my gdb was having issues with 128-bit regs for some reason. However, the current u128 representation is a bit awkward to use and should probably be updated first. | ||||
* | Merge pull request #72 from N00byKing/patch-2 | bunnei | 2018-01-21 | 1 | -1/+0 |
|\ | | | | | Implement Pull #3275 from citra: core: Don't Shutdown before we've even Init-ed | ||||
| * | Update core.cpp | N00byKing | 2018-01-17 | 1 | -1/+0 |
| | | |||||
* | | Merge pull request #92 from gdkchan/nro_refactor | bunnei | 2018-01-21 | 1 | -2/+2 |
|\ \ | | | | | | | Fix NRO entry point | ||||
| * | | Fix NRO Entry Point | gdkchan | 2018-01-18 | 1 | -2/+2 |
| | | | |||||
* | | | Merge pull request #122 from tgsm/time-remove-pragma | bunnei | 2018-01-21 | 2 | -4/+0 |
|\ \ \ | | | | | | | | | service/time: remove accidental #pragmas | ||||
| * | | | service/time: remove accidental #pragmas | tgsm | 2018-01-21 | 2 | -4/+0 |
| | | | | |||||
* | | | | loader: Minor style fix in deconstructed_rom_directory | Rozlette | 2018-01-21 | 1 | -1/+0 |
|/ / / | |||||
* | | | Merge pull request #117 from jroweboy/clang-format | bunnei | 2018-01-21 | 43 | -57/+62 |
|\ \ \ | | | | | | | | | Clang format as a build target | ||||
| * | | | Format: Run the new clang format on everything | James Rowe | 2018-01-21 | 43 | -57/+62 |
| | | | | |||||
* | | | | Merge pull request #120 from Rozelette/master | bunnei | 2018-01-20 | 1 | -0/+3 |
|\ \ \ \ | | | | | | | | | | | memory: Return false for large VAddr in IsValidVirtualAddress | ||||
| * | | | | memory: Return false for large VAddr in IsValidVirtualAddress | Rozlette | 2018-01-20 | 1 | -0/+3 |
| |/ / / | |||||
* | | | | loader: Clean up ctors and includes. | bunnei | 2018-01-20 | 10 | -18/+22 |
| | | | | |||||
* | | | | loader: Add DeconstructedRomDirectory for game dumps. | bunnei | 2018-01-20 | 5 | -0/+156 |
| | | | | |||||
* | | | | loader: Refactor to also pass filepath into IdentifyType. | bunnei | 2018-01-20 | 8 | -19/+19 |
| | | | | |||||
* | | | | nso: Remove code specific to directory loading. | bunnei | 2018-01-20 | 2 | -17/+6 |
|/ / / | |||||
* | | | Port citra #3352 to yuzu (#103) | River City Ransomware | 2018-01-20 | 3 | -4/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Port citra #3352 to yuzu This change allows non x86_64 architectures to compile yuzu by skipping the building of dynarmic * Fixed clang-format errors * fixes more clang-format errors | ||||
* | | | Added CreateSharedMemory & UNIMPLEMENTED() for non existent services. (#113) | David | 2018-01-20 | 3 | -1/+23 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Added svcCreateSharedMemory * Services which are not implemented now throw UNIMPLEMENTED() * clang-format * changed perms to u32 * removed camelcase | ||||
* | | | Fixes some cast warnings, partial port of citra #3064 (#106) | River City Ransomware | 2018-01-20 | 6 | -21/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | * Fixes some cast warnings, partially fixes citra #3064 * Converted casts to uint32_t to u32 * Ran clang-format | ||||
* | | | Merge pull request #112 from Rozelette/master | bunnei | 2018-01-19 | 1 | -0/+16 |
|\ \ \ | | | | | | | | | ISelfController: Stub LockExit and UnlockExit | ||||
| * | | | ISelfController: Stub LockExit and UnlockExit | Rozlette | 2018-01-19 | 1 | -0/+16 |
| | | | | |||||
* | | | | acc, set, applet_oe: stub various functions, add set service (#105) | goaaats | 2018-01-19 | 8 | -0/+161 |
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Stubs for various acc:u0 funcs needed * Stub for GetDesiredLanguage in IApplicationFunctions * Add set service + stubs needed for games * Fix formatting * Implement IProfile, IManagerForApplication, return bool in CheckAvailability, style fixes * Remove IProfile::Get(needs more research), fix IPC response sizes | ||||
* | | | Merge pull request #109 from bunnei/libnx-fixes | bunnei | 2018-01-19 | 6 | -1/+26 |
|\ \ \ | | | | | | | | | Fix svcGetInfo for libnx | ||||
| * | | | nvdrv: Stub SetClientPID. | bunnei | 2018-01-19 | 2 | -0/+13 |
| | | | | |||||
| * | | | svc: Fix svcGetInfo MapRegionBaseAddr. | bunnei | 2018-01-19 | 3 | -1/+9 |
| | | | | |||||
| * | | | svc: Add additional fields to MemoryInfo struct. | bunnei | 2018-01-19 | 1 | -0/+4 |
| | | | | |||||
* | | | | Merge pull request #97 from bunnei/time-stub | bunnei | 2018-01-19 | 2 | -4/+12 |
|\ \ \ \ | | | | | | | | | | | time: Stub out GetTotalLocationNameCount and some cleanup. | ||||
| * | | | | time: Stub out GetTotalLocationNameCount and some cleanup. | bunnei | 2018-01-19 | 2 | -4/+12 |
| | | | | | |||||
* | | | | | time: Add new line to ends of files. | bunnei | 2018-01-19 | 4 | -4/+4 |
| | | | | | |||||
* | | | | | applet_oe: Clang-format. | bunnei | 2018-01-19 | 1 | -2/+1 |
|/ / / / | |||||
* / / / | Fix dispdrv typo | gdkchan | 2018-01-19 | 1 | -1/+1 |
|/ / / | |||||
* | | | Merge pull request #100 from Rozelette/master | bunnei | 2018-01-19 | 7 | -32/+113 |
|\ \ \ | |/ / |/| | | time: Refactor time:* to use a single shared module | ||||
| * | | time: Fix use of CamelCase in ToCalendarTimeWithMyRule | Rozlette | 2018-01-18 | 1 | -6/+6 |
| | | | |||||
| * | | time: Refactor time:* to use a single shared module | Rozlette | 2018-01-18 | 7 | -26/+107 |
| | | | |||||
* | | | Stub PopLaunchParameter and implement Buffer C Descriptors reading on hle_ipc (#96) | gdkchan | 2018-01-18 | 5 | -7/+127 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Stub PopLaunchParameter and implement Buffer C Descriptors reading * Address PR feedback * Ensure we push a u64 not a size_t * Fix formatting | ||||
* | | | Start to implement/stub BSD:U and SFDNSRES services (#78) | flerovium^-^ | 2018-01-18 | 7 | -0/+159 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * bsd: start stubbing bsd:u and sfdnsres * bsd: stubbed RegisterClient * bsd: attempt to get past socket() * bsd: fix some wrong assumptions about IPC * bsd: fix format specifiers * bsd: stubbed Connect() * bsd: stubbed SendTo() * made requested changes * sockets: respect alphabetical order at service installation * run clang-format * bsd: start stubbing bsd:u and sfdnsres * bsd: stubbed RegisterClient * bsd: attempt to get past socket() * bsd: fix some wrong assumptions about IPC * bsd: fix format specifiers * bsd: stubbed Connect() * bsd: stubbed SendTo() * made requested changes * sockets: respect alphabetical order at service installation * run clang-format * run clang-format (2) | ||||
* | | | Merge pull request #95 from bunnei/lm-skip-byte | bunnei | 2018-01-18 | 1 | -0/+7 |
|\ \ \ | |/ / |/| | | lm: Minor logging fix to skip a byte. | ||||
| * | | lm: Minor logging fix to skip a byte. | bunnei | 2018-01-18 | 1 | -0/+7 |
| | | | |||||
* | | | Merge pull request #84 from lioncash/cmake | bunnei | 2018-01-18 | 1 | -170/+167 |
|\ \ \ | | | | | | | | | CMakeLists: Derive the source directory grouping from targets themselves | ||||
| * | | | CMakeLists: Derive the source directory grouping from targets themselves | Lioncash | 2018-01-18 | 1 | -170/+167 |
| | | | | | | | | | | | | | | | | | | | | Removes the need to store to separate SRC and HEADER variables, and then construct the target in most cases. | ||||
* | | | | Merge pull request #91 from lioncash/svc | bunnei | 2018-01-18 | 1 | -9/+9 |
|\ \ \ \ | | | | | | | | | | | svc: Minor clarity changes | ||||
| * | | | | svc: Rename some entries to match their analogue on SwitchBrew | Lioncash | 2018-01-18 | 1 | -7/+7 |
| | | | | | | | | | | | | | | | | | | | | Makes the codebase a little more consistent with regards to available documentation. Also amends the duplicate case where there was a similar entry at 0x72 named ConnectToPort. | ||||
| * | | | | svc: Add CreateJitMemory and MapJitMemory svc strings | Lioncash | 2018-01-18 | 1 | -2/+2 |
| |/ / / | | | | | | | | | | | | | Makes the table match SwitchBrew for these entries | ||||
* | | | | Merge pull request #90 from lioncash/vi-override | bunnei | 2018-01-18 | 1 | -20/+21 |
|\ \ \ \ | | | | | | | | | | | vi: Minor clean up/correctness changes | ||||
| * | | | | vi: Make constructors explicit where applicable | Lioncash | 2018-01-18 | 1 | -13/+14 |
| | | | | | | | | | | | | | | | | | | | | Prevents implicit conversions. | ||||
| * | | | | vi: Add missing override specifiers | Lioncash | 2018-01-18 | 1 | -7/+7 |
| |/ / / | |||||
* | | | | Merge pull request #89 from lioncash/vi-vector | bunnei | 2018-01-18 | 1 | -2/+3 |
|\ \ \ \ | |_|/ / |/| | | | vi: Copy data directly into the std::vector within Parcel's ReadBlock function | ||||
| * | | | vi: Copy data directly into the std::vector within Parcel's ReadBlock function | Lioncash | 2018-01-18 | 1 | -2/+3 |
| |/ / | | | | | | | | | | | | | Previously this would unnecessarily zero-initialize the vector before copying the actual data into the vector instance. | ||||
* | | | controller: Use DuplicateSession for DuplicateSessionEx. | bunnei | 2018-01-18 | 2 | -1/+8 |
| | | | |||||
* | | | Merge pull request #80 from gdkchan/nro_fix | bunnei | 2018-01-18 | 1 | -20/+9 |
|\ \ \ | |/ / |/| | | Fix NRO loading | ||||
| * | | Fix NRO loading | gdkchan | 2018-01-18 | 1 | -20/+9 |
| | | | |||||
* | | | Merge pull request #73 from N00byKing/3093 | bunnei | 2018-01-18 | 2 | -0/+2 |
|\ \ \ | |/ / |/| | | Implement Pull #3093 from citra: Added missing headers to CMakeLists.txt and fixed includes. | ||||
| * | | Update CMakeLists.txt | N00byKing | 2018-01-17 | 1 | -0/+1 |
| | | | |||||
| * | | Update title_metadata.h | N00byKing | 2018-01-17 | 1 | -0/+1 |
| | | | |||||
* | | | Merge pull request #76 from Rozelette/master | bunnei | 2018-01-17 | 5 | -85/+164 |
|\ \ \ | | | | | | | | | TIME: consolidate time:* interfaces, stub functions and structs | ||||
| * | | | TIME: consolidate time:* interfaces, stub functions and structs | Rozlette | 2018-01-17 | 5 | -85/+164 |
| | | | | |||||
* | | | | Remove relocation on NSO/NRO | gdkchan | 2018-01-17 | 3 | -19/+2 |
|/ / / | |||||
* | | | Merge pull request #64 from shinyquagsire23/hid-timing | bunnei | 2018-01-17 | 1 | -3/+3 |
|\ \ \ | | | | | | | | | hid: Adjust timing based on actual hardware | ||||
| * | | | hid: Adjust timing based on actual hardware | shinyquagsire23 | 2018-01-17 | 1 | -3/+3 |
| | | | | |||||
* | | | | Merge pull request #70 from flerovii/nvdrv-close | bunnei | 2018-01-17 | 4 | -0/+26 |
|\ \ \ \ | | | | | | | | | | | nvdrv: stubbed Close(cmd 2) | ||||
| * | | | | nvdrv: stubbed Close(cmd 2) | Frederic Meyer | 2018-01-17 | 4 | -0/+26 |
| | | | | | |||||
* | | | | | svc: Clang-format fix. | bunnei | 2018-01-17 | 1 | -6/+4 |
| |_|_|/ |/| | | | |||||
* | | | | Merge pull request #62 from bunnei/domain-close-handle | bunnei | 2018-01-17 | 3 | -3/+35 |
|\ \ \ \ | |/ / / |/| | | | Implement IPC domain command CloseVirtualHandle | ||||
| * | | | hle_ipc: Clang format. | bunnei | 2018-01-17 | 1 | -2/+3 |
| | | | | |||||
| * | | | ipc: Implement domain command CloseVirtualHandle. | bunnei | 2018-01-17 | 3 | -3/+34 |
| | | | | |||||
* | | | | Fix gdbstub typo, fixes Citra #3318 | River City Ransomware | 2018-01-17 | 1 | -1/+1 |
| |/ / |/| | | | | | Core::System().GetInstance().IsPoweredOn() -> Core::System::GetInstance().IsPoweredOn() | ||||
* | | | Merge pull request #60 from jroweboy/game-frame | bunnei | 2018-01-17 | 2 | -1/+4 |
|\ \ \ | |/ / |/| | | UI: Fix frame rate perf stats | ||||
| * | | UI: Fix frame rate perf stats | James Rowe | 2018-01-17 | 2 | -1/+4 |
| | | | | | | | | | | | | Adds in a missing EndGameFrame when nvdrv swaps buffers | ||||
* | | | Merge pull request #34 from shinyquagsire23/hid-sharedmem-layouts-circbufs-meta | bunnei | 2018-01-17 | 2 | -88/+125 |
|\ \ \ | |/ / |/| | | hid: Write to all layouts, implement circular buffers, set up controller metadata. | ||||
| * | | hid: clang-format | shinyquagsire23 | 2018-01-17 | 1 | -3/+3 |
| | | | |||||
| * | | hid: Adjust for style guide | shinyquagsire23 | 2018-01-17 | 2 | -63/+68 |
| | | | |||||
| * | | hid: Write to all layouts, implement circular buffers, set up controller metadata. | shinyquagsire23 | 2018-01-16 | 2 | -39/+71 |
| |/ | |||||
* | | acc_u0: Add IPC interface and stub InitializeApplicationInfo. | bunnei | 2018-01-17 | 6 | -0/+86 |
| | | |||||
* | | applet_oe: Fix GetOperationMode and GetPerformanceMode. | bunnei | 2018-01-17 | 1 | -2/+2 |
| | | |||||
* | | NV: Implemented the nvdrv service, which uses the same interface as nvdrv:a | Subv | 2018-01-17 | 4 | -16/+18 |
| | | |||||
* | | NV: Move the nvdrv classes into the Nvidia namespace, and move the functionality to a s single module that services call. | Subv | 2018-01-17 | 13 | -165/+95 |
| | | |||||
* | | VI: Stubbed GetNativeHandle, Create/DestroyStrayLayer and CloseDisplay | Subv | 2018-01-17 | 2 | -3/+85 |
| | | |||||
* | | Services: Stubbed APM::OpenSession and the ISession interface. | Subv | 2018-01-17 | 3 | -2/+53 |
| | | | | | | | | | | | | # Conflicts: # src/core/hle/service/am/applet_oe.cpp # src/core/hle/service/apm/apm.cpp | ||||
* | | AppletOE: Stub a bunch of functions required by libnx homebrew. | Subv | 2018-01-17 | 1 | -4/+62 |
| | | |||||
* | | SVC: Correct some return values in svcGetInfo and added TitleId and PrivilegedProcessId stubs. | Subv | 2018-01-17 | 1 | -6/+21 |
| | | | | | | | | | | # Conflicts: # src/core/hle/kernel/svc.cpp | ||||
* | | SVC: Add 4.0.0+ comment to GetInfoType enum values. | Subv | 2018-01-17 | 1 | -0/+1 |
| | | |||||
* | | IPC: Push domain objects as move handles when not in a domain. | Subv | 2018-01-17 | 2 | -2/+28 |
| | | |||||
* | | Merge pull request #52 from ogniK5377/fsp | bunnei | 2018-01-17 | 6 | -5/+90 |
|\ \ | | | | | | | added more svcGetInfo pairs for 3.0.0+ support, Changed HEAP_SIZE and TLS_AREA_VADDR. changed mem usage & heap usage stub added, ISelfController, IApplication function stubs. Added SetThreadCoreMask | ||||
| * | | Update memory.h | David | 2018-01-17 | 1 | -2/+2 |
| | | | |||||
| * | | SetThreadCoreMask stub, time to implement fsp | David Marcec | 2018-01-16 | 1 | -1/+6 |
| | | | |||||
| * | | implemented more of ISelfController and IApplicationFunctions | David Marcec | 2018-01-16 | 1 | -0/+53 |
| | | | |||||
| * | | Added more svcGetInfo pairs | David Marcec | 2018-01-16 | 4 | -2/+29 |
| | | | |||||
| * | | Increased heap size and changed tls area vaddr | David Marcec | 2018-01-16 | 1 | -2/+2 |
| | | | |||||
* | | | Merge pull request #44 from Rozelette/master | bunnei | 2018-01-16 | 1 | -3/+7 |
|\ \ \ | | | | | | | | | nso: Modify .bss size calculation logic | ||||
| * | | | nso: Modify .bss size calculation logic | Rozlette | 2018-01-16 | 1 | -3/+7 |
| | |/ | |/| | |||||
* | | | clang-format | MerryMage | 2018-01-16 | 13 | -37/+31 |
| |/ |/| | |||||
* | | Build: Automagically handle unicorn | James Rowe | 2018-01-16 | 1 | -1/+1 |
| | | | | | | | | | | | | | | On MSVC if unicorn isn't found, fallback to bundled unicorn On everything else, fallback to building unicorn in externals Also fixes loading unicorn in msvc | ||||
* | | Build: Add unicorn as a submodule and build it if needed | James Rowe | 2018-01-16 | 1 | -1/+1 |
|/ | | | | | | | Adds a cmake custom target that will build unicorn on first compile and uses this in the build scripts as well. Updates Appveyor and Travis build scripts to work with the new unicorn build, and updates the paths to all of the different artifacts. | ||||
* | nso: Load subsdk4 if available. | bunnei | 2018-01-15 | 1 | -1/+1 |
| | |||||
* | pctl: Clang format. | bunnei | 2018-01-15 | 1 | -1/+1 |
| | |||||
* | pctl: GetService should return an IParentalControlService interface. | bunnei | 2018-01-15 | 1 | -3/+8 |
| | |||||
* | applet_oe: Stub SetFocusHandlingMode, GetCurrentFocusState, SetTerminateResult. | bunnei | 2018-01-15 | 1 | -2/+55 |
| | |||||
* | settings: Fix button mappings array to have correct entries. | bunnei | 2018-01-15 | 1 | -2/+6 |
| | |||||
* | Merge pull request #16 from shinyquagsire23/hid-sharedmem-impl-start | bunnei | 2018-01-15 | 3 | -17/+450 |
|\ | | | | | HID Sharedmem Impl Start | ||||
| * | hid: Bare-minimum sharedmem input | shinyquagsire23 | 2018-01-15 | 2 | -2/+88 |
| | | |||||
| * | hid: Remove redundant HID prefix on structs/enums | shinyquagsire23 | 2018-01-15 | 1 | -73/+73 |
| | | |||||
| * | settings: Screenshot button | shinyquagsire23 | 2018-01-15 | 1 | -0/+2 |
| | | |||||
| * | settings: adjust button configs for Switch controllers | shinyquagsire23 | 2018-01-15 | 1 | -17/+50 |
| | | |||||
| * | hid: Add sharedmem structs | shinyquagsire23 | 2018-01-15 | 1 | -0/+312 |
| | | |||||
* | | vi: Add IManagerDisplayService::CloseDisplay function | bsaleil | 2018-01-15 | 1 | -0/+10 |
|/ | |||||
* | Games expect 15 for ICommonStateGetter::ReceiveMessage in order to continue execution | David Marcec | 2018-01-15 | 1 | -1/+1 |
| | |||||
* | renderer: Render previous frame when no new one is available. | bunnei | 2018-01-15 | 1 | -1/+4 |
| | |||||
* | lm: Fix IPC header for Initialize. | bunnei | 2018-01-15 | 1 | -1/+1 |
| | |||||
* | time: Implement GetStandardUserSystemClock, GetCurrentTime. | bunnei | 2018-01-15 | 6 | -1/+121 |
| | |||||
* | audio: Add files to CMake. | bunnei | 2018-01-15 | 2 | -1/+4 |
| | |||||
* | hid: Remove unused registered_loggers. | bunnei | 2018-01-15 | 1 | -3/+0 |
| | |||||
* | audio: Stub out AudOutU::ListAudioOuts. | bunnei | 2018-01-15 | 5 | -0/+84 |
| | |||||
* | hid: Implement IAppletResource::GetSharedMemoryHandle. | bunnei | 2018-01-15 | 3 | -14/+68 |
| | |||||
* | shared_memory: Minor fixes and cleanup. | bunnei | 2018-01-14 | 1 | -6/+6 |
| | |||||
* | svc: Implement svcMapSharedMemory. | bunnei | 2018-01-14 | 2 | -1/+38 |
| | |||||
* | kernel: Increase default stack size to 64K. | bunnei | 2018-01-14 | 1 | -1/+1 |
| | |||||
* | Add missing FileType declarations in GuessFromExtension and GetFileTypeString | Thog | 2018-01-14 | 1 | -0/+8 |
| | |||||
* | Update dynarmic to bc73004 | MerryMage | 2018-01-13 | 1 | -12/+17 |
| | | | | | | | | | | | | | | | | | | bc73004 a64_merge_interpret_blocks: Remove debug output 4e656ed tests/A64: Randomize PSTATE.<NZCV> fd9530b A64: Optimization: Merge interpret blocks 3c9eb04 testenv: Use format constants 324f3fc tests/A64: Unicorn interface fixes 98ecbe7 tests/A64: Fuzz against unicorn b1d38e7 tests/A64: Move TestEnvironment to own header 5218ad9 A64/data_processing_pcrel: bug: ADR{,P} instructions sign extend their immediate b1a8c39 A64/data_processing_addsub: bug: {ADD,SUB}S (extended register) instructions write to ZR when d = 31 64827fb a64_emit_x64: bug: A64CallSupervisor trampled callee-save registers 1bfa04d emit_x64: bug: OP m/r64, imm32 form instructions sign-extend their immediate on x64 edadeea A64 inferface: Use two argument static_assert 9ab1304 A64: Add ExceptionRaised IR instruction 6843eed Update readme 7438d07 A64/translate: Add TranslateSingleInstruction function | ||||
* | Fix build on macOS and linux | MerryMage | 2018-01-13 | 1 | -2/+0 |
| | |||||
* | arm_unicorn: Log unmapped memory access address. | bunnei | 2018-01-13 | 1 | -1/+1 |
| | |||||
* | yuzu: Update license text to be consistent across project. | bunnei | 2018-01-13 | 61 | -61/+61 |
| | |||||
* | Remove settings issues in sdl and fix a few files that broke in mingw | James Rowe | 2018-01-13 | 2 | -4/+1 |
| | |||||
* | Removing unused settings and yuzu rebranding | James Rowe | 2018-01-13 | 2 | -53/+0 |
| | |||||
* | Remove gpu debugger and get yuzu qt to compile | James Rowe | 2018-01-13 | 5 | -69/+1 |
| | |||||
* | Remove references to PICA and rasterizers in video_core | James Rowe | 2018-01-13 | 13 | -1492/+1 |
| | |||||
* | core: Gut out cryptop, since it doesn't compile with C++17. | bunnei | 2018-01-13 | 4 | -126/+7 |
| | |||||
* | configuration: Add cpu_core configuration option | MerryMage | 2018-01-12 | 3 | -4/+18 |
| | |||||
* | arm_dynarmic: Implement core | MerryMage | 2018-01-12 | 7 | -64/+165 |
| | |||||
* | core: Include <algorithm> where used. | bunnei | 2018-01-12 | 3 | -0/+6 |
| | |||||
* | nv: Fix more broken asserts. | bunnei | 2018-01-12 | 2 | -3/+3 |
| | |||||
* | nvdisp_disp0: Fix broken assert. | bunnei | 2018-01-12 | 1 | -1/+1 |
| | |||||
* | core: Fix recent GCC build breaks. | bunnei | 2018-01-12 | 2 | -2/+4 |
| | |||||
* | svc: Implement GetSystemTick. | bunnei | 2018-01-12 | 2 | -2/+21 |
| | |||||
* | nvdisp_disp0: Call SwapBuffers to render framebuffer. | bunnei | 2018-01-11 | 1 | -0/+7 |
| | |||||
* | CMakeLists: Add framebuffer_layout.cpp. | bunnei | 2018-01-11 | 1 | -0/+1 |
| | |||||
* | frontend: Update for undocked Switch screen layout. | bunnei | 2018-01-11 | 6 | -274/+39 |
| | |||||
* | NV: Move the nv device nodes to their own directory and namespace. | Subv | 2018-01-11 | 11 | -166/+430 |
| | |||||
* | VI: Use a Pulse event instead of OneShot for the vblank events. | Subv | 2018-01-11 | 1 | -1/+1 |
| | | | | This prevents missing frames if the vblank fires between the DequeueBuffer and Wait(vsync) calls | ||||
* | vi: Use new CoreTiming::EventType | bunnei | 2018-01-11 | 1 | -1/+5 |
| | |||||
* | NV: Expose the nvdisp_disp0 device and a weak reference to the nvdrv:a service. | Subv | 2018-01-11 | 6 | -172/+252 |
| | | | | | | NVFlinger will call into the nvdisp_disp0 device to perform screen flips, bypassing the ioctl interface. We now have the address of the framebuffer to draw, we just need to actually put it on the screen. | ||||
* | NV: Determine what buffer to draw for each layer of each display. | Subv | 2018-01-11 | 2 | -13/+58 |
| | | | | | | Don't try to draw buffers that the guest application is using, only queued buffers are eligible for drawing. Drawing actual pixels is still not implemented. | ||||
* | NV: Signal all display's vsync event 60 times per second. | Subv | 2018-01-11 | 2 | -1/+32 |
| | |||||
* | NV: Give each display its own vsync event. | Subv | 2018-01-11 | 2 | -12/+29 |
| | |||||
* | NV: Keep track of Displays, Layers and BufferQueues in nvflinger. | Subv | 2018-01-11 | 4 | -41/+261 |
| | |||||
* | IPC: Allow passing arguments to the Interfaces when using PushIpcInterface | Subv | 2018-01-11 | 1 | -3/+3 |
| | |||||
* | NV: Implemented (with stubs) the vi:m service and some of its subservices. | Subv | 2018-01-11 | 6 | -0/+726 |
| | | | | The homebrew display test application now properly writes graphics data to the graphics buffer but we still don't have a way to compose the display layers. | ||||
* | NV: Implemented the nvdrv:a service and the /dev/nvmap device. | Subv | 2018-01-11 | 4 | -0/+354 |
| | |||||
* | IPC: Corrected some definitions for the buffer C descriptor flags. | Subv | 2018-01-11 | 3 | -3/+10 |
| | |||||
* | svc: Stub ResetSignal and CreateTransferMemory | Subv | 2018-01-11 | 2 | -3/+28 |
| | |||||
* | svc: Stub SetMemoryAttribute | Subv | 2018-01-11 | 2 | -0/+11 |
| | |||||
* | Threads: Added enum values for the Switch's 4 cpu cores and implemented svcGetInfo(AllowedCpuIdBitmask) | Subv | 2018-01-10 | 4 | -10/+25 |
| | |||||
* | Services: Allow lm to log single-character messages. | Subv | 2018-01-10 | 1 | -7/+3 |
| | |||||
* | SVC: Fixed WaitSynchronization with multiple handles when none is immediately ready. | Subv | 2018-01-09 | 1 | -7/+18 |
| | |||||
* | SVC: Implemented CancelSynchronization. | Subv | 2018-01-09 | 2 | -1/+19 |
| | |||||
* | ErrorCodes: Updated the InvalidHandle and Timeout kernel error codes. | Subv | 2018-01-09 | 1 | -2/+7 |
| | |||||
* | SVC: Fixed WaitSynchronization with multiple handles when at least one of them is ready. | Subv | 2018-01-09 | 2 | -3/+29 |
| | |||||
* | kernel: Rename Semaphore to ConditionVariable. | bunnei | 2018-01-09 | 9 | -161/+169 |
| | |||||
* | mutex: Remove unused call to VerifyGuestState. | bunnei | 2018-01-09 | 1 | -3/+0 |
| | |||||
* | Kernel: Actually wake up the requested number of threads in Semaphore::Release. | Subv | 2018-01-09 | 3 | -18/+16 |
| | | | | | | Also properly keep track of data in guest memory, this fixes managing the semaphore from userland. It was found that Semaphores are actually Condition Variables, with Release(1) and Release(-1) being equivalent to notify_one and notify_all. We should change the name of the class to reflect this. | ||||
* | Kernel: Properly keep track of mutex lock data in the guest memory. This fixes userland locking/unlocking. | Subv | 2018-01-09 | 3 | -63/+60 |
| | |||||
* | Kernel: Allow chaining WaitSynchronization calls inside a wakeup callback. | Subv | 2018-01-09 | 4 | -30/+78 |
| | |||||
* | fix macos build | MerryMage | 2018-01-09 | 1 | -4/+4 |
| | |||||
* | core_timing: Use 1.020GHz for core clock rate. | bunnei | 2018-01-09 | 1 | -5/+3 |
| | |||||
* | CoreTiming: Reworked CoreTiming (cherry-picked from Citra #3119) | B3n30 | 2018-01-09 | 7 | -556/+276 |
| | | | | * CoreTiming: New CoreTiming; Add Test for CoreTiming | ||||
* | IPC: Make DuplicateSession return the Domain instead of the Session if the request was made on a Domain interface. | Subv | 2018-01-07 | 2 | -2/+7 |
| | |||||
* | AppletOE: Fixed command buffer structure for ReceiveMessage. | Subv | 2018-01-07 | 1 | -2/+1 |
| | |||||
* | IPC: Corrected some command headers in the IPC Controller interface. | Subv | 2018-01-07 | 1 | -4/+2 |
| | |||||
* | IPC: Corrected some command header sizes in appletOE. | Subv | 2018-01-07 | 1 | -12/+21 |
| | |||||
* | IPC: Take the number of domain objects as a parameter in MakeBuilder. | Subv | 2018-01-07 | 2 | -4/+6 |
| | |||||
* | SM: Fixed connecting to services with an 8-byte name, like appletOE. | Subv | 2018-01-07 | 1 | -12/+4 |
| | |||||
* | IPC: Fixed pushing ResultCodes into the command buffer. | Subv | 2018-01-07 | 2 | -7/+9 |
| | | | | They should have 32 bits of padding after the error code now. | ||||
* | IPC: Add functions to read the input move/copy objects from an IPC request. | Subv | 2018-01-07 | 3 | -2/+42 |
| | |||||
* | IPC: Don't attempt to read the command buffer if it holds a Close request. | Subv | 2018-01-07 | 1 | -0/+5 |
| | |||||
* | IPC Cleanup: Remove 3DS-specific code and translate copy, move and domain objects in IPC requests. | Subv | 2018-01-07 | 8 | -405/+118 |
| | | | | Popping objects from the buffer is still not implemented. | ||||
* | IPC: Skip the entire u64 of the command id when receiving an IPC request. | Subv | 2018-01-07 | 2 | -15/+5 |
| | | | | Service code now doesn't have to deal with this. | ||||
* | IPC: Use the correct size when pushing raw data to the command buffer and fixed pushing domain objects. | Subv | 2018-01-07 | 4 | -10/+29 |
| | | | | Domain object ids are always stored immediately after the raw data. | ||||
* | svc: Implement svcSignalProcessWideKey. | bunnei | 2018-01-07 | 2 | -4/+23 |
| | |||||
* | semaphore: More changes for Switch. | bunnei | 2018-01-07 | 2 | -11/+17 |
| | |||||
* | wait_object: Refactor to allow waking up a single thread. | bunnei | 2018-01-07 | 2 | -15/+28 |
| | |||||
* | nso: Always load the filepath specified by the user. | bunnei | 2018-01-07 | 1 | -1/+3 |
| | |||||
* | core_timing: Increase clock speed for Switch docked. | bunnei | 2018-01-07 | 3 | -3/+3 |
| | |||||
* | svc: Implement svcWaitProcessWideKeyAtomic. | bunnei | 2018-01-06 | 2 | -1/+54 |
| | |||||
* | semaphore: Updates for Switch. | bunnei | 2018-01-06 | 2 | -21/+31 |
| | |||||
* | lm: Assert on unsupported multi-message. | bunnei | 2018-01-06 | 1 | -0/+9 |
| | |||||
* | svc: Implement WaitSynchronization for a single handle. | bunnei | 2018-01-06 | 1 | -4/+24 |
| | |||||
* | svc: Refactor LockMutex code to use WaitSynchronization1. | bunnei | 2018-01-06 | 1 | -13/+45 |
| | |||||
* | lm: Improve Log() to format a useful string. | bunnei | 2018-01-05 | 1 | -10/+75 |
| | |||||
* | svc: Add missing string_util include. | bunnei | 2018-01-05 | 1 | -0/+1 |
| | |||||
* | cmake: Don't compile Dynarmic as it's unused. | bunnei | 2018-01-04 | 1 | -1/+1 |
| | |||||
* | core: Increase tight_loop 100x for speed. | bunnei | 2018-01-04 | 1 | -1/+1 |
| | |||||
* | arm_unicorn: Load/release unicorn DLL. | bunnei | 2018-01-04 | 1 | -0/+16 |
| | |||||
* | unicorn: Use for arm interface on Windows. | bunnei | 2018-01-04 | 4 | -9/+242 |
| | |||||
* | arm_dynarmic: More cleanup. | bunnei | 2018-01-04 | 1 | -6/+0 |
| | |||||
* | core: Remove unicorn_dynload. | bunnei | 2018-01-04 | 1 | -2/+0 |
| | |||||
* | arm_dynarmic: Gut interface until dynarmic is ready for general use. | bunnei | 2018-01-04 | 2 | -142/+44 |
| | |||||
* | arm: Remove SkyEye/Dyncom code that is ARMv6-only. | bunnei | 2018-01-03 | 33 | -14549/+22 |
| | |||||
* | vm_manager: Use a more reasonable MAX_ADDRESS size. | bunnei | 2018-01-03 | 1 | -5/+4 |
| | |||||
* | svc: Remove unnecessary "svc" prefix to naming scheme. | bunnei | 2018-01-03 | 1 | -106/+106 |
| | |||||
* | pctl: Remove duplicate InstallInterfaces function. | bunnei | 2018-01-03 | 1 | -4/+0 |
| | |||||
* | hle: Move SVC code to kernel namespace. | bunnei | 2018-01-03 | 4 | -134/+121 |
| | |||||
* | svc: Improve svcGetInfo. | bunnei | 2018-01-01 | 2 | -35/+41 |
| | |||||
* | vm_manager: Stub out a bunch of interfaces used by svcGetInfo. | bunnei | 2018-01-01 | 2 | -1/+51 |
| | |||||
* | svc: Fix string formatting for CreateThread. | bunnei | 2018-01-01 | 1 | -1/+1 |
| | |||||
* | cmake: Add missing object_address_table. | bunnei | 2018-01-01 | 1 | -0/+2 |
| | |||||
* | core/video_core: Fix a bunch of u64 -> u32 warnings. | bunnei | 2018-01-01 | 4 | -18/+18 |
| | |||||
* | svc: Stub out svcWaitSynchronization. | bunnei | 2018-01-01 | 1 | -1/+9 |
| | | | | - This does not matter until we implement other kernel objects, mutexes use svcLockMutex for waiting. | ||||
* | svc: Implement svcExitProcess. | bunnei | 2018-01-01 | 3 | -11/+77 |
| | |||||
* | svc: Implement svcUnlockMutex. | bunnei | 2018-01-01 | 1 | -1/+11 |
| | |||||
* | svc: Implement svcLockMutex. | bunnei | 2018-01-01 | 3 | -24/+134 |
| | |||||
* | kernel: Add ObjectAddressTable class. | bunnei | 2018-01-01 | 3 | -2/+101 |
| | |||||
* | thread: Keep track of the initially created handle. | bunnei | 2017-12-31 | 3 | -2/+7 |
| | | | | This is kinda crufty, but we need it for now to update guest state variables. | ||||
* | svc: Implement svcExitThread. | bunnei | 2017-12-31 | 1 | -1/+9 |
| | |||||
* | svc: Implement svcCreateThread. | bunnei | 2017-12-31 | 1 | -2/+57 |
| | |||||
* | svc: Cleanup svcGetThreadPriority. | bunnei | 2017-12-31 | 1 | -3/+5 |
| | |||||
* | svc: Stub out svcGetCurrentProcessorNumber. | bunnei | 2017-12-31 | 1 | -1/+7 |
| | |||||
* | errors: Define missing kernel error codes. | bunnei | 2017-12-31 | 1 | -0/+3 |
| | |||||
* | svc: Implement svcSetThreadPriority. | bunnei | 2017-12-31 | 1 | -1/+30 |
| | |||||
* | svc: Change SignalProcessWideKey to a stub. | bunnei | 2017-12-31 | 1 | -2/+2 |
| | |||||
* | function_wrappers: Cleanup, fix warnings, remove unused code. | bunnei | 2017-12-31 | 1 | -187/+35 |
| | |||||
* | svc: Implement svcUnmapMemory. | bunnei | 2017-12-31 | 3 | -1/+15 |
| | |||||
* | svc: Minor cleanups. | bunnei | 2017-12-30 | 1 | -8/+9 |
| | |||||
* | svc: Implement svcStartThread. | bunnei | 2017-12-30 | 1 | -0/+16 |
| | |||||
* | thread: Main thread should set thread handle to reg 1. | bunnei | 2017-12-30 | 1 | -1/+4 |
| | |||||
* | thread: Remove THUMB mode flag. | bunnei | 2017-12-30 | 1 | -1/+1 |
| | |||||
* | thread: Main thread should be ready by default, all others dormant. | bunnei | 2017-12-30 | 1 | -4/+3 |
| | |||||
* | kernel: Various 64-bit fixes in memory/process/thread | bunnei | 2017-12-29 | 5 | -14/+14 |
| | |||||
* | applet_oe: Stub out a bunch of interfaces necessary for boot. | bunnei | 2017-12-29 | 2 | -1/+159 |
| | |||||
* | controller: Implement DuplicateSession. | bunnei | 2017-12-29 | 2 | -9/+11 |
| | |||||
* | kernel: Fix implementation of ConvertSessionToDomain. | bunnei | 2017-12-29 | 10 | -54/+90 |
| | |||||
* | ap, aoc_u: Minor cleanup. | bunnei | 2017-12-29 | 3 | -4/+1 |
| | |||||
* | service: Add empty interface for pctl:a. | bunnei | 2017-12-29 | 6 | -0/+90 |
| | |||||
* | kernel: Add basic support for Domain object. | bunnei | 2017-12-29 | 5 | -4/+112 |
| | |||||
* | kernel: Add SyncObject primitive, use it for ClientSession. | bunnei | 2017-12-29 | 4 | -10/+41 |
| | |||||
* | svc: Implement MapMemory. | bunnei | 2017-12-29 | 3 | -4/+17 |
| | |||||
* | process: Add method to mirror a memory region. | bunnei | 2017-12-29 | 2 | -0/+27 |
| | |||||
* | svc: Implement SetHeapSize. | bunnei | 2017-12-28 | 2 | -3/+19 |
| | |||||
* | service: Clean up apm/lm/applet_oe/controller/sm ctor/dtor. | bunnei | 2017-12-28 | 10 | -20/+10 |
| | |||||
* | service: Halt on ReportUnimplementedFunction and improve output log. | bunnei | 2017-12-28 | 1 | -4/+2 |
| | |||||
* | service: Add empty interface for aoc:u. | bunnei | 2017-12-28 | 4 | -0/+44 |
| | |||||
* | service: Return proper result code for IPC::CommandType::Close. | bunnei | 2017-11-01 | 4 | -9/+12 |
| | |||||
* | hle: Use Switch formatted result codes. | bunnei | 2017-11-01 | 8 | -346/+110 |
| | |||||
* | svc: Implement GetThreadId and GetProcessId. | bunnei | 2017-10-23 | 2 | -2/+37 |
| | |||||
* | logging: Rename category "Core_ARM11" to "Core_ARM". | bunnei | 2017-10-23 | 8 | -87/+87 |
| | |||||
* | nso: Load more common submodules. | bunnei | 2017-10-23 | 1 | -15/+11 |
| | |||||
* | memory: Support 32-bit paging, move heap address space up. | bunnei | 2017-10-23 | 2 | -3/+3 |
| | |||||
* | hle: Fix QueryMemory response for MemoryInfo. | bunnei | 2017-10-20 | 7 | -149/+31 |
| | |||||
* | lm: Implement lm::Initialize and Logger::log. | bunnei | 2017-10-19 | 2 | -3/+67 |
| | |||||
* | hle_ipc: Only copy necessary fields for outgoing command buffer. | bunnei | 2017-10-19 | 1 | -1/+1 |
| | |||||
* | hle_ipc: Parse out buffer X/A/B/B descriptors from incoming command buffer. | bunnei | 2017-10-19 | 2 | -14/+19 |
| | |||||
* | service: Add CreatePort function (that does not register/install). | bunnei | 2017-10-19 | 2 | -0/+12 |
| | |||||
* | memory: Print addresses as 64-bit. | bunnei | 2017-10-19 | 1 | -2/+2 |
| | |||||
* | ipc_helpers: Fix alignment (was wrong as a result of a dynarmic bug). | bunnei | 2017-10-18 | 1 | -3/+4 |
| | |||||
* | service: Print correct command ID on unimplemented function. | bunnei | 2017-10-18 | 1 | -1/+1 |
| | |||||
* | hle: Implement ConvertSessionToDomain, various cleanups. | bunnei | 2017-10-15 | 10 | -33/+82 |
| | |||||
* | core: Refactor MakeMagic usage and remove dead code. | bunnei | 2017-10-15 | 9 | -843/+10 |
| | |||||
* | hle: Add service stubs for apm and appletOE. | bunnei | 2017-10-15 | 10 | -2/+136 |
| | |||||
* | hle: Initial implementation of NX service framework and IPC. | bunnei | 2017-10-15 | 16 | -639/+571 |
| | |||||
* | nso: Add a log for loading submodules. | bunnei | 2017-10-14 | 1 | -0/+1 |
| | |||||
* | svc: Some logging cleanup. | bunnei | 2017-10-14 | 1 | -7/+5 |
| | |||||
* | svc: Update MemoryInfo flags for 64-bit. | bunnei | 2017-10-14 | 1 | -5/+5 |
| | |||||
* | svc: Initial nx impl. for QueryMemory, ConnectToPort, SendSyncRequest, etc. | bunnei | 2017-10-14 | 1 | -1185/+185 |
| | |||||
* | Remove more 3DS-specific code. | bunnei | 2017-10-13 | 5 | -48/+3 |
| | |||||
* | Remove more 3DS-specific code. | bunnei | 2017-10-13 | 6 | -1413/+1 |
| | |||||
* | Remove more 3DS-specific code. | bunnei | 2017-10-13 | 3 | -55/+0 |
| | |||||
* | Remove lots more 3DS-specific code. | bunnei | 2017-10-13 | 48 | -6870/+6 |
| | |||||
* | hle: Remove a large amount of 3ds-specific service code. | bunnei | 2017-10-10 | 195 | -22288/+2 |
| | |||||
* | Merge remote-tracking branch 'upstream/master' into nx | bunnei | 2017-10-10 | 116 | -1713/+3915 |
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Conflicts: # src/core/CMakeLists.txt # src/core/arm/dynarmic/arm_dynarmic.cpp # src/core/arm/dyncom/arm_dyncom.cpp # src/core/hle/kernel/process.cpp # src/core/hle/kernel/thread.cpp # src/core/hle/kernel/thread.h # src/core/hle/kernel/vm_manager.cpp # src/core/loader/3dsx.cpp # src/core/loader/elf.cpp # src/core/loader/ncch.cpp # src/core/memory.cpp # src/core/memory.h # src/core/memory_setup.h | ||||
| * | Change command header in nwm::UDS Initialize function | Dragios | 2017-10-09 | 1 | -1/+1 |
| | | |||||
| * | Merge pull request #2991 from Subv/getpointer | Sebastian Valle | 2017-10-08 | 3 | -63/+61 |
| |\ | | | | | | | Remove more usages of GetPointer. | ||||
| | * | SVC: Removed GetPointer usage in the GetResourceLimit functions. | Subv | 2017-10-04 | 1 | -10/+16 |
| | | | |||||
| | * | SVC: Remove GetPointer usage in CreatePort. | Subv | 2017-10-04 | 2 | -6/+4 |
| | | | |||||
| | * | SVC: Replace GetPointer usage with ReadCString in ConnectToPort. | Subv | 2017-10-04 | 2 | -20/+9 |
| | | | |||||
| | * | SVC: Replace GetPointer usage with ReadBlock in OutputDebugString. | Subv | 2017-10-04 | 2 | -4/+6 |
| | | | |||||
| | * | SVC: Replace GetPointer usage with Read32 in ReplyAndReceive. | Subv | 2017-10-04 | 2 | -7/+6 |
| | | | |||||
| | * | SVC: Replace GetPointer usage with Read32 in WaitSynchronizationN. | Subv | 2017-10-04 | 2 | -8/+8 |
| | | | |||||
| | * | Memory: Remove all GetPointer usages from the GDB stub. | Subv | 2017-10-04 | 1 | -8/+12 |
| | | | |||||
| * | | Merge pull request #2975 from shinyquagsire23/archive-ncch-container-and-override | Sebastian Valle | 2017-10-06 | 7 | -78/+581 |
| |\ \ | | | | | | | | | file_sys/archive_ncch: use NCCHs/.apps instead of .romfs files, NCCH section override | ||||
| | * | | file_sys, loader: add support for reading TMDs to determine app paths | shinyquagsire23 | 2017-10-01 | 2 | -5/+27 |
| | | | | |||||
| | * | | file_sys: add class for Title Metadata (TMD) | shinyquagsire23 | 2017-10-01 | 3 | -0/+338 |
| | | | | |||||
| | * | | file_sys/ncch_container: add RomFS, ExeFS override to allow for backward compatibility with existing .romfs system archive dumps | shinyquagsire23 | 2017-10-01 | 2 | -69/+206 |
| | | | | |||||
| | * | | file_sys/archive_ncch: use NCCHContainer instead of loading .romfs files | shinyquagsire23 | 2017-10-01 | 1 | -6/+12 |
| | | | | |||||
| * | | | Merge pull request #2953 from Subv/applet_launch | Sebastian Valle | 2017-10-04 | 2 | -30/+47 |
| |\ \ \ | | | | | | | | | | | HLE/APT: Always set up the APT parameter when starting a library applet. | ||||
| | * | | | HLE/APT: Always set up the APT parameter when starting a library applet. | Subv | 2017-09-26 | 2 | -30/+47 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Only use the HLE interface if an HLE applet with the desired id was started. This commit reorganizes the APT code surrounding parameter creation and delivery to make it easier to support LLE applets in the future. As future work, the HLE applet interface can be reworked to utilize the same facilities as the LLE interface. | ||||
| * | | | | Merge pull request #2977 from Subv/shmem_create | bunnei | 2017-10-03 | 1 | -15/+12 |
| |\ \ \ \ | | |_|_|/ | |/| | | | SharedMemory: Don't take over and unmap the source memory block when creating a shared memory, just reference it | ||||
| | * | | | Kernel/SharedMemory: Don't take over and unmap the source memory block when creating a shared memory, just reference it. | Subv | 2017-10-02 | 1 | -15/+12 |
| | | |/ | | |/| | | | | | | | | | Also reference the right offset into the backing block for the requested address. | ||||
| * | | | Merge pull request #2971 from Subv/per_process_memops | Sebastian Valle | 2017-10-01 | 4 | -22/+61 |
| |\ \ \ | | | | | | | | | | | Memory: Add overloads for ReadBlock and WriteBlock that operate on a specific process. | ||||
| | * | | | Memory: Make WriteBlock take a Process parameter on which to operate | Subv | 2017-10-01 | 2 | -10/+19 |
| | | | | | |||||
| | * | | | Memory: Make ReadBlock take a Process parameter on which to operate | Subv | 2017-10-01 | 2 | -12/+30 |
| | | | | | |||||
| | * | | | Kernel/Thread: Added a helper function to get a thread's command buffer VAddr. | Subv | 2017-10-01 | 2 | -0/+12 |
| | | | | | |||||
| * | | | | Merge pull request #2974 from Subv/nim_event | Sebastian Valle | 2017-10-01 | 3 | -2/+29 |
| |\ \ \ \ | | |_|/ / | |/| | | | Services/NIM: Implement CheckForSysUpdateEvent. | ||||
| | * | | | Services/NIM: Implement CheckForSysUpdateEvent. | Subv | 2017-09-30 | 3 | -2/+29 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Implementation verified by reverse engineering. This lets the Home Menu boot without crashing on startup. | ||||
| * | | | | Moved down_count to CoreTiming | Huw Pascoe | 2017-09-30 | 8 | -42/+32 |
| |/ / / | |||||
| * | | | Services/UDS: Handle the rest of the connection sequence. (#2963) | B3n30 | 2017-09-30 | 3 | -19/+250 |
| | | | | | | | | | | | | Services/UDS: Handle the rest of the connection sequence. | ||||
| * | | | Merge pull request #2946 from Subv/home_menu_apt | Sebastian Valle | 2017-09-30 | 3 | -8/+45 |
| |\ \ \ | | | | | | | | | | | Implement PrepareToStartNewestHomeMenu and fixed an APT regression. | ||||
| | * | | | HLE/APT: Always return an error from PrepareToStartNewestHomeMenu so that the Home Menu doesn't try to reboot the system. | Subv | 2017-09-24 | 3 | -2/+26 |
| | | | | | | | | | | | | | | | | | | | | | | | | | As per 3dbrew: "During Home Menu start-up it uses APT:PrepareToStartNewestHomeMenu. If that doesn't return an error(normally NS returns 0xC8A0CFFC for that), Home Menu starts a hardware reboot with APT:StartNewestHomeMenu etc. " | ||||
| | * | | | HLE/APT: Prepare the APT Wakeup parameter when the game calls Initialize | Subv | 2017-09-24 | 1 | -6/+19 |
| | | |/ | | |/| | | | | | | | | | | | | | We need to know what is being run so we can set the APT parameter destination AppId correctly. Delaying the preparation of the parameter until we know which AppId is running lets us support booting both the Home Menu and normal game Applications. | ||||
| * | | | Merge pull request #2967 from Subv/thread_wakeup_callbacks | Sebastian Valle | 2017-09-30 | 4 | -17/+91 |
| |\ \ \ | | |_|/ | |/| | | Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken | ||||
| | * | | Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken. | Subv | 2017-09-28 | 4 | -17/+91 |
| | | | | | | | | | | | | | | | | | | | | | | | | This change makes for a clearer (less confusing) path of execution in the scheduler, now the code to execute when a thread awakes is closer to the code that puts the thread to sleep (WaitSynch1, WaitSynchN). It also allows us to implement the special wake up behavior of ReplyAndReceive without hacking up WaitObject::WakeupAllWaitingThreads. If savestates are desired in the future, we can change this implementation to one similar to the CoreTiming event system, where we first register the callback functions at startup and assign their identifiers to the Thread callback variable instead of directly assigning a lambda to the wake up callback variable. | ||||
| * | | | Fixed type conversion ambiguity | Huw Pascoe | 2017-09-30 | 23 | -72/+83 |
| | | | | |||||
| * | | | Merge pull request #2961 from Subv/load_titles | bunnei | 2017-09-29 | 14 | -61/+87 |
| |\ \ \ | | |/ / | |/| | | Loaders: Don't automatically set the current process every time we load an application. | ||||
| | * | | Loaders: Don't automatically set the current process every time we load an application. | Subv | 2017-09-27 | 8 | -37/+40 |
| | | | | | | | | | | | | | | | | The loaders will now just create a Kernel::Process, construct it and return it to the caller, which is responsible for setting it as the current process and configuring the global page table. | ||||
| | * | | Kernel/Thread: Allow specifying which process a thread belongs to when creating it. | Subv | 2017-09-27 | 4 | -17/+22 |
| | | | | | | | | | | | | | | | | Don't automatically assume that Thread::Create will only be called when the parent process is currently scheduled. This assumption will be broken when applets or system modules are loaded. | ||||
| | * | | Memory: Allow IsValidVirtualAddress to be called with a specific process parameter. | Subv | 2017-09-27 | 2 | -7/+25 |
| | | | | | | | | | | | | | | | | There is still an overload of IsValidVirtualAddress that only takes the VAddr and will default to the current process. | ||||
| * | | | Merge pull request #2954 from Subv/cache_unmapped_mem | James Rowe | 2017-09-27 | 1 | -1/+16 |
| |\ \ \ | | |/ / | |/| | | Memory/RasterizerCache: Ignore unmapped memory regions when caching physical regions | ||||
| | * | | Memory/RasterizerCache: Ignore unmapped memory regions when caching physical regions. | Subv | 2017-09-26 | 1 | -1/+16 |
| | |/ | | | | | | | | | | | | | | | | Not all physical regions need to be mapped into the address space of every process, for example, system modules do not have a VRAM mapping. This fixes a crash when loading applets and system modules. | ||||
| * | | HLE/Archives: Allow multiple loaded applications to access their SelfNCCH archive independently. | Subv | 2017-09-25 | 6 | -18/+65 |
| | | | | | | | | | | | | | | | | | | | | | | | | The loaders now register each loaded ROM with the SelfNCCH factory, which keeps the data around for the duration of the emulation session. When opening the SelfNCCH archive, the factory queries the current program's programid and uses that as a key to the map that contains the NCCHData structure (RomFS, Icon, Banner, etc). 3dsx files do not have a programid and will use a default of 0 for this value, thus, only 1 3dsx file with RomFS is loadable at the same time. | ||||
| * | | Merge pull request #2952 from MerryMage/page-tables | B3n30 | 2017-09-25 | 11 | -26/+55 |
| |\ \ | | | | | | | | | Switchable Page Tables | ||||
| | * | | ARM_Interface: Implement PageTableChanged | MerryMage | 2017-09-25 | 6 | -6/+39 |
| | | | | |||||
| | * | | memory: Remove GetCurrentPageTablePointers | MerryMage | 2017-09-24 | 2 | -10/+0 |
| | | | | |||||
| | * | | memory: Add GetCurrentPageTable/SetCurrentPageTable | MerryMage | 2017-09-24 | 6 | -12/+18 |
| | |/ | | | | | | | | | | Don't expose Memory::current_page_table as a global. | ||||
| * | | Merge pull request #2948 from Subv/register_service | B3n30 | 2017-09-25 | 4 | -1/+33 |
| |\ \ | | | | | | | | | HLE/SRV: Implemented RegisterService. | ||||
| | * | | HLE/SRV: Implemented RegisterService. | Subv | 2017-09-24 | 4 | -1/+33 |
| | |/ | | | | | | | | | | Now system modules can do more than just crash immediately on startup. | ||||
| * | | Loader/NCCH: Add support for loading application updates (#2927) | Max Thomas | 2017-09-25 | 8 | -439/+670 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * loader/ncch: split NCCH parsing into its own file * loader/ncch: add support for loading update NCCHs from the SD card * loader/ncch: fix formatting * file_sys/ncch_container: Return a value for OpenFile * loader/ncch: cleanup, always instantiate overlay_ncch to base_ncch * file_sys/ncch_container: better encryption checks, allow non-app NCCHs to load properly and for the existence of NCCH structures to be checked * file_sys/ncch_container: pass filepath as a const reference | ||||
| * | | Services/UDS: Added a function to send EAPoL-Start packets (#2920) | B3n30 | 2017-09-25 | 5 | -88/+250 |
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | | * Services/UDS: Added a function to generate the EAPoL-Start packet body. * Services/UDS: Added filter for beacons. * Services/UDS: Lock a mutex when accessing connection_status from both the emulation and network thread. * Services/UDS: Handle the Association Response frame and respond with the EAPoL-Start frame. * fixup: make use of current_node, changed received_beacons into a list, mutex and assert corrections * fixup: fix damn clang-format | ||||
| * | WebService: Verify username and token (#2930) | B3n30 | 2017-09-19 | 3 | -0/+23 |
| | | | | | | | | | | | | | | | | | | | | * WebService: Verify username and token; Log errors in PostJson * Fixup: added docstrings to the functions * Webservice: Added Icons to the verification, imrpved error detection in cpr, fixup nits * fixup: fmt warning | ||||
| * | Merge pull request #2906 from Subv/ns_new_framework | Yuri Kunde Schlesner | 2017-09-16 | 7 | -42/+77 |
| |\ | | | | | | | Services/NS: Port ns:s to the new service framework. | ||||
| | * | Services/NS: Port ns:s to the new service framework. | Subv | 2017-09-16 | 7 | -42/+77 |
| | | | |||||
| * | | Merge pull request #2842 from Subv/switchable_page_table | B3n30 | 2017-09-15 | 13 | -119/+177 |
| |\ \ | | | | | | | | | Kernel/Memory: Give each process its own page table and allow switching the current page table upon reschedule | ||||
| | * | | CPU/Dynarmic: Disable the fast page-table access in dynarmic until it supports switching page tables at runtime. | Subv | 2017-09-15 | 1 | -1/+3 |
| | | | | |||||
| | * | | Kernel/Memory: Make IsValidPhysicalAddress not go through the current process' virtual memory mapping. | Subv | 2017-09-15 | 1 | -2/+1 |
| | | | | |||||
| | * | | Kernel/Threads: Don't clear the CPU instruction cache when performing a context switch from an idle thread into a thread in the same process. | Subv | 2017-09-15 | 1 | -1/+3 |
| | | | | | | | | | | | | | | | | We were unnecessarily clearing the cache when going from Process A -> Idle -> Process A, this caused extreme performance regressions. | ||||
| | * | | Kernel/Memory: Changed GetPhysicalPointer so that it doesn't go through the current process' page table to obtain a pointer. | Subv | 2017-09-15 | 4 | -30/+69 |
| | | | | |||||
| | * | | Kernel/Memory: Switch the current page table when a new process is scheduled. | Subv | 2017-09-10 | 1 | -0/+10 |
| | | | | |||||
| | * | | Kernel/Memory: Give each Process its own page table. | Subv | 2017-09-10 | 9 | -87/+93 |
| | | | | | | | | | | | | | | | | The loader is in charge of setting the newly created process's page table as the main one during the loading process. | ||||
| * | | | Merge pull request #2915 from wwylele/font-archive-2 | bunnei | 2017-09-12 | 3 | -135/+155 |
| |\ \ \ | | | | | | | | | | | APT: load different shared font depending on the region | ||||
| | * | | | APT: load different shared font depending on the region | wwylele | 2017-09-03 | 3 | -135/+155 |
| | | | | | |||||
| * | | | | Merge pull request #2831 from Subv/uds_auth | Weiyi Wang | 2017-09-05 | 7 | -53/+289 |
| |\ \ \ \ | | | | | | | | | | | | | Services/UDS: Handle beacon frames and the basic AP connection sequence frames. | ||||
| | * | | | | Services/UDS: Remove an old duplicated declaration of WifiPacket. | Subv | 2017-08-27 | 2 | -22/+0 |
| | | | | | | |||||
| | * | | | | Services/UDS: Handle the connection sequence packets. | Subv | 2017-08-27 | 1 | -17/+83 |
| | | | | | | | | | | | | | | | | | | | | | | | | There is currently no stage tracking, a client is considered "Connected" when it receives the EAPoL Logoff packet from the server, this is not yet implemented. | ||||
| | * | | | | Services/UDS: Store the received beacon frames until RecvBeaconBroadcastData is called, up to 15 beacons at the same time, removing any older beacon frames when the limit is exceeded. | Subv | 2017-08-27 | 1 | -3/+62 |
| | | | | | | |||||
| | * | | | | Services/UDS: Add functions to generate 802.11 auth and assoc response frames. | Subv | 2017-08-27 | 5 | -11/+144 |
| | | | | | | |||||
| * | | | | | Remove _flag in var names | mailwl | 2017-09-04 | 1 | -6/+6 |
| | | | | | | |||||
| * | | | | | Mii Selector Applet: update Mii structures | mailwl | 2017-09-04 | 2 | -34/+29 |
| | |/ / / | |/| | | | |||||
| * | | | | Merge pull request #2899 from wwylele/touch-refactor | bunnei | 2017-08-29 | 5 | -43/+78 |
| |\ \ \ \ | | | | | | | | | | | | | Refactor touch input into a TouchDevice | ||||
| | * | | | | EmuWindow: refactor touch input into a TouchDevice | wwylele | 2017-08-24 | 2 | -39/+63 |
| | | | | | | |||||
| | * | | | | HID: use TouchDevice for touch pad | wwylele | 2017-08-24 | 3 | -4/+15 |
| | | | | | | |||||
| * | | | | | Merge pull request #2905 from danzel/fix-2902 | Sebastian Valle | 2017-08-29 | 4 | -5/+5 |
| |\ \ \ \ \ | | |_|_|_|/ | |/| | | | | Use recursive_mutex instead of mutex to fix #2902 | ||||
| | * | | | | Use recursive_mutex instead of mutex to fix #2902 | danzel | 2017-08-29 | 4 | -5/+5 |
| | |/ / / | |||||
| * | | | | web_services: Refactor to remove dependency on Core. | bunnei | 2017-08-26 | 1 | -1/+7 |
| | | | | | |||||
| * | | | | qt: Add an option to view/regenerate telemetry ID. | bunnei | 2017-08-26 | 2 | -3/+28 |
| | | | | | |||||
| * | | | | settings: Add enable_telemetry, citra_username, and citra_token. | bunnei | 2017-08-26 | 1 | -0/+3 |
| | | | | | |||||
| * | | | | telemetry_session: Log telemetry ID. | bunnei | 2017-08-26 | 1 | -0/+36 |
| | | | | | |||||
| * | | | | SidebySide Layout (#2859) | ThaMighty90 | 2017-08-25 | 5 | -4/+53 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * added a SidebySide Layout * Reworked, so both screen have the same height and cleaned up screen translates. * added the option in the UI, hope this is the right way to do it. formated framebuffer_layout.cpp * delete the x64 files * deleted ui_configure_graphics.h * added Option for the Layout in the xml * got rid of SIDE_BY_SIDE_ASPECT_RATIO because it was useless. pulled translate into variables * changed shift variables to u32 and moved them in their respective branch. remove notr="true" for the Screen layout drop down * reworked intends :). changed function description for SideFrameLayout * some description reworking | ||||
| * | | | Merge pull request #2839 from Subv/global_kernel_lock | James Rowe | 2017-08-24 | 6 | -4/+46 |
| |\ \ \ | | | | | | | | | | | Kernel/HLE: Use a mutex to synchronize access to the HLE kernel state between the cpu thread and any other possible threads that might touch the kernel (network thread, etc). | ||||
| | * | | | Kernel/Memory: Acquire the global HLE lock when a memory read/write operation falls outside of the fast path, for it might perform an MMIO operation. | Subv | 2017-08-22 | 1 | -1/+8 |
| | | | | | |||||
| | * | | | Kernel/HLE: Use a mutex to synchronize access to the HLE kernel state between the cpu thread and any other possible threads that might touch the kernel (network thread, etc). | Subv | 2017-08-22 | 5 | -3/+38 |
| | | | | | | | | | | | | | | | | | | | | This mutex is acquired in SVC::CallSVC, ie, as soon as the guest application enters the HLE kernel, and should be acquired by the aforementioned threads before modifying kernel structures. | ||||
| * | | | | Merge pull request #2893 from Subv/not_schedule_main_thread | bunnei | 2017-08-22 | 1 | -5/+1 |
| |\ \ \ \ | | | | | | | | | | | | | Kernel/Threads: Don't immediately switch to the new main thread when loading a new process. | ||||
| | * | | | | Kernel/Threads: Don't immediately switch to the new main thread when loading a new process. | Subv | 2017-08-22 | 1 | -5/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is necessary for loading multiple processes at the same time. The main thread will be automatically scheduled when necessary once the scheduler runs. | ||||
| * | | | | | GPU/Warnings: Explicitly cast the screen refresh ticks to u64. | Subv | 2017-08-21 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | Warnings: Add UNREACHABLE macros to switches that contemplate all possible values. | Subv | 2017-08-21 | 3 | -2/+7 |
| | | | | | | |||||
| * | | | | | HLE/Applets: Fixed some conversion warnings when creating the framebuffer shared memory objects. | Subv | 2017-08-21 | 4 | -8/+8 |
| | | | | | | |||||
| * | | | | | CPU/Dynarmic: Fixed a warning when incrementing the number of ticks in ExecuteInstructions. | Subv | 2017-08-21 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | Dyncom: Use size_t instead of int to store the instruction offsets in the instruction cache. | Subv | 2017-08-21 | 2 | -4/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | Fixes a few warnings. | ||||
| * | | | | | Dyncom: Fixed a conversion warning when decoding thumb instructions. | Subv | 2017-08-21 | 1 | -1/+1 |
| |/ / / / | |||||
| * | | | | Merge pull request #2861 from wwylele/motion-refactor | James Rowe | 2017-08-20 | 8 | -254/+47 |
| |\ \ \ \ | | |_|_|/ | |/| | | | Refactor MotionEmu into a InputDevice | ||||
| | * | | | HID: fix a comment and a warning | wwylele | 2017-08-20 | 1 | -2/+2 |
| | | | | | |||||
| | * | | | move MotionEmu from core/frontend to input_common as a InputDevice | wwylele | 2017-08-11 | 6 | -254/+4 |
| | | | | | |||||
| | * | | | HID: use MotionDevice for Accelerometer and Gyroscope | wwylele | 2017-08-11 | 3 | -5/+48 |
| | | | | | |||||
| * | | | | Added missing parts in libnetwork (#2838) | B3n30 | 2017-08-19 | 3 | -1/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | | * Network: Set and send the game information over enet Added Callbacks for RoomMember and GetMemberList to Room in preparation for web_services. | ||||
| * | | | | Merge pull request #2881 from MerryMage/dsp-firm-check | Yuri Kunde Schlesner | 2017-08-16 | 1 | -3/+4 |
| |\ \ \ \ | | | | | | | | | | | | | dsp_dsp: Remove size assertion in LoadComponent | ||||
| | * | | | | dsp_dsp: Remove size assertion in LoadComponent | MerryMage | 2017-08-15 | 1 | -3/+4 |
| | | | | | | |||||
| * | | | | | Merge pull request #2843 from Subv/applet_slots | Sebastian Valle | 2017-08-12 | 2 | -35/+200 |
| |\ \ \ \ \ | | |_|/ / / | |/| | | | | Services/APT: Use an array to hold data about the 4 possible concurrent applet types (Application, Library, HomeMenu, System) | ||||
| | * | | | | Services/APT: Use the AppletAttributes union directly when dealing with applet attrs. | Subv | 2017-08-07 | 1 | -19/+15 |
| | | | | | | |||||
| | * | | | | Services/APT: Use an array to hold data about the 4 possible concurrent applet types (Application, Library, HomeMenu, System). | Subv | 2017-08-07 | 2 | -35/+204 |
| | |/ / / | | | | | | | | | | | | | | | | This gives each applet type its own set of events as per the real NS module. | ||||
| * | | | | Merge pull request #2863 from wwylele/pad-state-zero | Weiyi Wang | 2017-08-10 | 2 | -2/+2 |
| |\ \ \ \ | | | | | | | | | | | | | HID: zero unused PadState bits | ||||
| | * | | | | HID: zero unused PadState bits | wwylele | 2017-08-10 | 2 | -2/+2 |
| | |/ / / | |||||
| * | | | | Merge pull request #2862 from j-selby/update-cryptopp | bunnei | 2017-08-09 | 1 | -1/+1 |
| |\ \ \ \ | | | | | | | | | | | | | Update CryptoPP (byte ambiguity) | ||||
| | * | | | | Update cryptopp | James | 2017-08-08 | 1 | -1/+1 |
| | |/ / / | |||||
| * / / / | Service/dlp: Update function tables according 3dbrew | mailwl | 2017-08-09 | 3 | -4/+44 |
| |/ / / | |||||
| * | | | telemetry: Add field for OsPlatform. | bunnei | 2017-08-04 | 1 | -0/+9 |
| | | | | |||||
| * | | | telemetry: Add field for BuildName. | bunnei | 2017-08-04 | 1 | -0/+1 |
| | | | | |||||
| * | | | telemetry: Add field for RequiresSharedFont. | bunnei | 2017-08-04 | 1 | -0/+4 |
| | | | | |||||
| * | | | telemetry_session: Log BuildDate and ProgramName fields. | bunnei | 2017-08-04 | 1 | -0/+7 |
| | | | | |||||
| * | | | core: Expose AppLoader as a public interface. | bunnei | 2017-08-04 | 1 | -4/+5 |
| | | | | |||||
| * | | | loader: Expose program title. | bunnei | 2017-08-04 | 3 | -12/+31 |
| | | | | |||||
| * | | | Handle invalid filenames when renaming files/directories | James | 2017-07-31 | 2 | -4/+78 |
| | | | | |||||
| * | | | Merge pull request #2840 from Subv/apt_parameter | bunnei | 2017-07-27 | 2 | -33/+105 |
| |\ \ \ | | | | | | | | | | | Services/APT: Corrected the behavior of the Receive/Send/Glance/CancelParameter functions | ||||
| | * | | | Service/APT: Log Send/Cancel/Receive/GlanceParameter calls even if they return an error. | Subv | 2017-07-21 | 1 | -7/+9 |
| | | | | | |||||
| | * | | | Services/APT: Return the proper error code when calling SendParameter with an outstanding parameter already in memory. | Subv | 2017-07-21 | 2 | -4/+17 |
| | | | | | |||||
| | * | | | Services/APT: Reset the APT parameter inside CancelParameter if the conditions are met. | Subv | 2017-07-21 | 1 | -6/+23 |
| | | | | | |||||
| | * | | | Services/APT: Properly clear the apt parameter after a successful ReceiveParameter call. | Subv | 2017-07-21 | 1 | -2/+8 |
| | | | | | |||||
| | * | | | Services/APT: Use the right error codes in ReceiveParameter and GlanceParameter when the parameter doesn't exist. | Subv | 2017-07-21 | 1 | -0/+28 |
| | | | | | |||||
| | * | | | Services/APT: Use boost::optional for the APT parameter structure. | Subv | 2017-07-21 | 1 | -20/+26 |
| | |/ / | |||||
* | | | | loader: Various improvements for NSO/NRO loaders. | bunnei | 2017-10-10 | 8 | -58/+40 |
| | | | | |||||
* | | | | loader: Add support for NRO, as well as various fixes and shared linker. | bunnei | 2017-10-06 | 9 | -146/+434 |
| | | | | |||||
* | | | | nso: Fixes to support homebrew NSOs without a MOD header. | bunnei | 2017-10-04 | 2 | -17/+23 |
| | | | | |||||
* | | | | arm_interface: Set TLS address for dynarmic core. | bunnei | 2017-09-30 | 5 | -0/+32 |
| | | | | |||||
* | | | | nso: Refactor and allocate .bss section. | bunnei | 2017-09-30 | 8 | -130/+160 |
| | | | | |||||
* | | | | process: Support loading multiple codesets. | bunnei | 2017-09-30 | 2 | -20/+27 |
| | | | | |||||
* | | | | loader: Add support for loading an NSO. | bunnei | 2017-09-30 | 5 | -0/+342 |
| | | | | |||||
* | | | | externals: Add lz4. | bunnei | 2017-09-30 | 1 | -1/+1 |
| | | | | |||||
* | | | | memory: Log with 64-bit values. | bunnei | 2017-09-30 | 1 | -8/+8 |
| | | | | |||||
* | | | | kernel: Various threading fixes to support 64-bit addressing. | bunnei | 2017-09-30 | 2 | -8/+8 |
| | | | | |||||
* | | | | core: Various changes to support 64-bit addressing. | bunnei | 2017-09-30 | 5 | -54/+54 |
| | | | | |||||
* | | | | arm: Use 64-bit addressing in a bunch of places. | bunnei | 2017-09-30 | 8 | -78/+111 |
| | | | | |||||
* | | | | elf: Check if machine is ARM. | bunnei | 2017-09-30 | 1 | -2/+9 |
|/ / / | |||||
* | | | Merge pull request #2799 from yuriks/virtual-cached-range-flush | Weiyi Wang | 2017-07-22 | 6 | -68/+113 |
|\ \ \ | |/ / |/| | | Add address conversion functions returning optional, Add function to flush virtual region from rasterizer cache | ||||
| * | | Memory: Add function to flush a virtual range from the rasterizer cache | Yuri Kunde Schlesner | 2017-06-22 | 4 | -47/+72 |
| | | | | | | | | | | | | | | | | | | This is slightly more ergonomic to use, correctly handles virtual regions which are disjoint in physical addressing space, and checks only regions which can be cached by the rasterizer. | ||||
| * | | Memory: Add TryVirtualToPhysicalAddress, returning a boost::optional | Yuri Kunde Schlesner | 2017-06-22 | 2 | -7/+23 |
| | | | |||||
| * | | Memory: Make PhysicalToVirtualAddress return a boost::optional | Yuri Kunde Schlesner | 2017-06-22 | 4 | -14/+18 |
| | | | | | | | | | | | | And fix a few places in the code to take advantage of that. | ||||
* | | | telemetry: Log performance, configuration, and system data. | bunnei | 2017-07-18 | 3 | -12/+80 |
| | | | |||||
* | | | stubbed frd::UnscrambleLocalFriendCode (#2827) | B3n30 | 2017-07-17 | 3 | -1/+57 |
| | | | |||||
* | | | Merge pull request #2784 from wwylele/font-archive | Weiyi Wang | 2017-07-16 | 5 | -22/+264 |
|\ \ \ | | | | | | | | | load shared font from system archive | ||||
| * | | | apt: load shared font from system archive | wwylele | 2017-06-26 | 4 | -20/+260 |
| | | | | |||||
| * | | | apt/shared_font: don't relocate zero offset | wwylele | 2017-06-25 | 1 | -2/+4 |
| |/ / | |||||
* | | | web_service: Add CMake flag to enable. | bunnei | 2017-07-12 | 2 | -3/+12 |
| | | | |||||
* | | | telemetry_session: Use TelemetryJson to submit real telemetry. | bunnei | 2017-07-12 | 1 | -2/+2 |
| | | | |||||
* | | | web_service: Add skeleton project. | bunnei | 2017-07-10 | 1 | -1/+1 |
| | | | |||||
* | | | settings: Add telemetry endpoint URL. | bunnei | 2017-07-10 | 1 | -0/+3 |
| | | | |||||
* | | | Merge pull request #2815 from mailwl/bossp | Sebastian Valle | 2017-07-08 | 1 | -0/+3 |
|\ \ \ | | | | | | | | | Service/boss:P: Add some functions to FunctionTable | ||||
| * | | | Service/boss:P: Add some functions to FunctionTable | mailwl | 2017-07-01 | 1 | -0/+3 |
| | |/ | |/| | |||||
* | | | Merge pull request #2797 from yuriks/cached-vma-free-crash | bunnei | 2017-07-08 | 1 | -5/+20 |
|\ \ \ | |/ / |/| | | Memory: Fix crash when unmapping a VMA covering cached surfaces | ||||
| * | | Memory: Fix crash when unmapping a VMA covering cached surfaces | Yuri Kunde Schlesner | 2017-06-22 | 1 | -5/+20 |
| |/ | | | | | | | | | | | | | | | | | | | Unmapping pages tries to flush any cached GPU surfaces touching that region. When a cached page is invalidated, GetPointerFromVMA() is used to restore the original pagetable pointer. However, since that VMA has already been deleted, this hits an UNREACHABLE case in that function. Now when this happens, just set the page type to Unmapped and continue, which arrives at the correct end result. | ||||
* | | Merge pull request #2793 from Subv/replyandreceive | Sebastian Valle | 2017-06-30 | 6 | -23/+161 |
|\ \ | | | | | | | Kernel/SVC: Partially implemented svcReplyAndReceive | ||||
| * | | Kernel/SVC: Pass the current thread as a parameter to ClientSession::SendSyncRequest. | Subv | 2017-06-29 | 3 | -4/+7 |
| | | | |||||
| * | | Kernel/Sessions: Clean up the list of pending request threads of a session when the client endpoint is closed. | Subv | 2017-06-26 | 1 | -0/+5 |
| | | | |||||
| * | | Kernel/SVC: Partially implemented svcReplyAndReceive. | Subv | 2017-06-26 | 2 | -11/+121 |
| | | | | | | | | | | | | | | | | | | | | | | | | It behaves mostly as WaitSynchronizationN with wait_all = false, except for IPC buffer translation. The target thread of an IPC response will now wake up when responding. IPC buffer translation is currently not implemented. Error passing back to svcSendSyncRequest is currently not implemented. | ||||
| * | | Kernel/ServerSession: Keep track of which threads have issued sync requests. | Subv | 2017-06-25 | 3 | -9/+29 |
| | | | |||||
* | | | gpu: add comments for TextureCopy | wwylele | 2017-06-29 | 2 | -8/+8 |
| | | | |||||
* | | | gpu: fix edge cases for TextureCopy | wwylele | 2017-06-27 | 1 | -18/+23 |
| | | | |||||
* | | | Merge pull request #2778 from Subv/uds_more | Sebastian Valle | 2017-06-27 | 5 | -1/+436 |
|\ \ \ | | | | | | | | | Services/UDS: Stub SendTo to generate the unencrypted data frames with the right headers | ||||
| * | | | UDS: Use the ToDS and FromDS fields to properly calculate the AAD used during encryption. | Subv | 2017-06-26 | 1 | -15/+32 |
| | | | | |||||
| * | | | UDS: Move the UDS keyslot used to generate the CCMP key to the AES::KeySlotID enum. | Subv | 2017-06-26 | 2 | -4/+3 |
| | | | | |||||
| * | | | UDS: Run clang-format. | Subv | 2017-06-26 | 3 | -51/+55 |
| | | | | |||||
| * | | | UDS: Added functions to encrypt and decrypt the data frames. | Subv | 2017-06-26 | 3 | -12/+156 |
| | | | | | | | | | | | | | | | | The responsibility of encryption and encapsulation into an 802.11 MAC frame will fall into the callers of GenerateDataPayload. | ||||
| * | | | UDS: Clarify comment about the first 4 bytes of the SecureData header. | Subv | 2017-06-15 | 2 | -1/+5 |
| | | | | | | | | | | | | | | | | It is likely that these 4 bytes are actually a different header, part of some protocol that encapsulates the SecureData protocol. | ||||
| * | | | UDS: Return the correct error messages in SendTo when not connected to a network or trying to send to itself. | Subv | 2017-06-15 | 1 | -6/+13 |
| | | | | |||||
| * | | | UDS: Stub SendTo to generate the unencrypted data frame with the right headers. | Subv | 2017-06-15 | 4 | -1/+261 |
| |/ / | |||||
* | | | Kernel: Implement AcceptSession SVC | Yuri Kunde Schlesner | 2017-06-23 | 4 | -3/+38 |
| | | | |||||
* | | | Kernel: Fix SVC wrapper for CreatePort | Yuri Kunde Schlesner | 2017-06-23 | 1 | -3/+2 |
| | | | | | | | | | | | | The return parameters were flipped. | ||||
* | | | Kernel: Implement CreateSessionToPort SVC | Yuri Kunde Schlesner | 2017-06-23 | 1 | -1/+12 |
| | | | |||||
* | | | Merge pull request #2798 from yuriks/svc-create-session | Yuri Kunde Schlesner | 2017-06-23 | 2 | -3/+26 |
|\ \ \ | | | | | | | | | Kernel: Implement CreateSession SVC | ||||
| * | | | Kernel: Implement CreateSession SVC | Yuri Kunde Schlesner | 2017-06-22 | 2 | -3/+26 |
| | |/ | |/| | |||||
* / | | Kernel/IPC: Support translation of null handles | Yuri Kunde Schlesner | 2017-06-21 | 1 | -7/+12 |
|/ / | | | | | | | | | Missed this in my first implementation. Thanks to @wwylele for pointing out that this was missing. | ||||
* | | Merge pull request #2789 from yuriks/misc-kernel | Weiyi Wang | 2017-06-21 | 2 | -1/+5 |
|\ \ | | | | | | | Trivial no-op additions | ||||
| * | | Memory: Add enum definitions for the n3DS FCRAM size | Yuri Kunde Schlesner | 2017-06-21 | 1 | -1/+3 |
| | | | |||||
| * | | Kernel: Add comment about the extended linear heap area | Yuri Kunde Schlesner | 2017-06-19 | 1 | -0/+2 |
| |/ | |||||
* | | Merge pull request #2790 from yuriks/remove-movefrom | Yuri Kunde Schlesner | 2017-06-21 | 24 | -56/+57 |
|\ \ | | | | | | | Remove ResultVal::MoveFrom | ||||
| * | | ResultVal: Remove MoveFrom() | Yuri Kunde Schlesner | 2017-06-19 | 24 | -57/+53 |
| | | | | | | | | | | | | | | | Replace it with std::move(result_val).Unwrap(), or Foo().Unwrap() in case you already have an rvalue. | ||||
| * | | ResultVal: Add an rvalue overload of Unwrap() | Yuri Kunde Schlesner | 2017-06-19 | 1 | -1/+6 |
| |/ | |||||
* | | Merge pull request #2779 from Subv/uds_more2 | Sebastian Valle | 2017-06-21 | 1 | -0/+36 |
|\ \ | | | | | | | UDS: Added a hook for updating the connection status when a client connects to the network. | ||||
| * | | UDS: Added a hook for updating the connection status when a client connects to the network. | Subv | 2017-06-15 | 1 | -0/+36 |
| |/ | |||||
* / | Kernel/IPC: Make HLERequestContext usable from outside kernel | Yuri Kunde Schlesner | 2017-06-19 | 3 | -5/+10 |
|/ | |||||
* | Services/UDS: Set the proper bit in the ConnectionStatus structure when creating a network. (#2738) | Sebastian Valle | 2017-06-13 | 3 | -5/+15 |
| | | | | | | | | | | * Services/UDS: Set the proper bit in the ConnectionStatus structure when creating a network. This lets the application know that the host was successfully added to the session. * Services/UDS: Reset the connection status when destroying the network * Services/UDS: Reset the connection status's bitmask of changed nodes after reporting it to the game. | ||||
* | Kernel/IPC: Use boost::small_vector for HLE context objects | Yuri Kunde Schlesner | 2017-06-12 | 1 | -1/+3 |
| | |||||
* | Kernel: Allow clearing request_objects to re-use buffer space | Yuri Kunde Schlesner | 2017-06-11 | 3 | -0/+14 |
| | | | | | Reduces the necessary allocation to max(in_handles, out_handles) rather than (in_handles + out_handles). | ||||
* | Kernel: Basic support for IPC translation for HLE services | Yuri Kunde Schlesner | 2017-06-11 | 3 | -18/+130 |
| | |||||
* | Service/sm: Convert srv: to use IPC helpers | Yuri Kunde Schlesner | 2017-06-11 | 1 | -49/+56 |
| | |||||
* | IPC: Add Pop/PushObjects methods to RequestParser/Builder | Yuri Kunde Schlesner | 2017-06-11 | 1 | -10/+103 |
| | | | | | These use the context functions to create and look-up handles for the user. | ||||
* | IPC: Add basic HLERequestContext support to RequestParser/Builder | Yuri Kunde Schlesner | 2017-06-11 | 1 | -1/+32 |
| | |||||
* | Kernel: Add methods in HLERequestContext abstracting handle creation | Yuri Kunde Schlesner | 2017-06-11 | 2 | -0/+12 |
| | |||||
* | ServiceFramework: Use separate copy of command buffer | Yuri Kunde Schlesner | 2017-06-11 | 3 | -9/+29 |
| | | | | | | Copy the IPC command buffer to/from the request context before/after the handler is invoked. This is part of a move away from using global data for handling IPC requests. | ||||
* | Merge pull request #2756 from yuriks/service-framework | Yuri Kunde Schlesner | 2017-06-09 | 9 | -64/+355 |
|\ | | | | | New service framework | ||||
| * | Service/sm: Convert 'srv:' to ServiceFramework | Yuri Kunde Schlesner | 2017-06-09 | 5 | -51/+75 |
| | | |||||
| * | Service: Remove a few redundant namespace qualifiers | Yuri Kunde Schlesner | 2017-06-08 | 1 | -5/+5 |
| | | |||||
| * | Service: Add new ServiceFramework framework for writing HLE services | Yuri Kunde Schlesner | 2017-06-08 | 5 | -4/+269 |
| | | | | | | | | | | | | | | | | | | | | | | | | The old "Interface" class had a few problems such as using free functions (Which didn't allow you to write the service handler as if it were a regular class.) which weren't very extensible. (Only received one parameter with a pointer to the Interface object.) The new ServiceFramework aims to solve these problems by working with member functions and passing a generic context struct as parameter. This struct can be extended in the future without having to update all existing service implementations. | ||||
| * | Kernel: Remove some unnecessary namespace qualifications | Yuri Kunde Schlesner | 2017-06-06 | 1 | -4/+6 |
| | | |||||
* | | Session: Remove/add some forward declarations | Yuri Kunde Schlesner | 2017-06-08 | 2 | -1/+2 |
| | | |||||
* | | Kernel: Ensure objects are kept alive during ClientSession disconnection | Yuri Kunde Schlesner | 2017-06-08 | 1 | -7/+13 |
| | | | | | | | | Fixes #2760 | ||||
* | | Merge pull request #2737 from Subv/decryptbeacondata | James Rowe | 2017-06-07 | 1 | -1/+97 |
|\ \ | |/ |/| | Services/UDS: Implement DecryptBeaconData. | ||||
| * | Services/UDS: Implement DecryptBeaconData. | Subv | 2017-06-06 | 1 | -1/+97 |
| | | | | | | | | This function decrypts the encrypted data tags contained in the 802.11 beacon frames. | ||||
* | | Service: Remove unnecessary includes from service.h | Yuri Kunde Schlesner | 2017-06-06 | 31 | -12/+79 |
| | | | | | | | | | | This has a huge fallout in terms of needing to fix other files because all service implementations included that file. | ||||
* | | Service: Make service registration part of the sm implementation | Yuri Kunde Schlesner | 2017-06-06 | 6 | -24/+147 |
| | | | | | | | | Also enhances the GetServiceHandle implementation to be more accurate. | ||||
* | | Service/sm: Use an actual semaphore for the notification semaphore | Yuri Kunde Schlesner | 2017-06-06 | 1 | -8/+9 |
| | | | | | | | | | | An Event was used way back then when we didn't have proper working semaphores. Our Semaphore implementation is good enough now. | ||||
* | | Service: Move SRV interface to a new sm/ subdirectory | Yuri Kunde Schlesner | 2017-06-06 | 4 | -9/+10 |
| | | | | | | | | | | This will contain the implementation of the sm (Service Manager) system module. | ||||
* | | Kernel: Add a dedicated SetHleHandler method to ServerPort/ServerSession | Yuri Kunde Schlesner | 2017-06-06 | 11 | -62/+73 |
| | | | | | | | | | | | | This allows attaching a HLE handle to a ServerPort at any point after it is created, allowing port/session creation to be generic between HLE and regular services. | ||||
* | | ResultVal: Add more convenience utils for creating and cascading results | Yuri Kunde Schlesner | 2017-06-06 | 1 | -0/+19 |
| | | |||||
* | | HLE: Move SessionRequestHandler from Service:: to Kernel:: | Yuri Kunde Schlesner | 2017-06-06 | 14 | -73/+100 |
| | | | | | | | | | | Most of the code that works with this is or will be in the kernel, so it's a more appropriate place for it to be. | ||||
* | | Addressed Bunnei's review comments, and made some other tweaks: | TheKoopaKingdom | 2017-06-03 | 6 | -24/+22 |
| | | | | | | | | | | - Deleted GetStatus() because it wasn't used anywhere outside of Core::System. - Fixed design flaw where the message bar status could be set despite the game being stopped. | ||||
* | | Switched to the ERROR_NOT_FOUND constant from errors.h. | TheKoopaKingdom | 2017-06-03 | 2 | -4/+3 |
| | | |||||
* | | Moved whitelist checks from FS_User to the Archive_NCCH handler. | TheKoopaKingdom | 2017-06-03 | 2 | -53/+37 |
| | | |||||
* | | Created a whitelist of system archives to prevent false positives creating dialogs. | TheKoopaKingdom | 2017-06-03 | 6 | -24/+60 |
| | | |||||
* | | Optimized messages that were repetitive and added ability for core errors to specify more details optionally. | TheKoopaKingdom | 2017-06-03 | 1 | -2/+15 |
| | | |||||
* | | Made some changes from review comments: | TheKoopaKingdom | 2017-06-03 | 8 | -35/+33 |
| | | | | | | | | | | | | | | | | - Made LoadKernelSystemMode return a pair consisting of a system mode and a result code (Could use review). - Deleted ErrorOpenGL error code in favor of just having ErrorVideoCore. - Made dialog messages more clear. - Compared archive ID in fs_user.cpp to ArchiveIdCode::NCCH as opposed to hex magic. - Cleaned up some other stuff. | ||||
* | | Added system for handling core errors in citra-qt. | TheKoopaKingdom | 2017-06-03 | 5 | -8/+43 |
| | | |||||
* | | Fixed encrypted ROM error messages. | TheKoopaKingdom | 2017-06-03 | 3 | -9/+19 |
| | | |||||
* | | Merge pull request #2722 from wwylele/cam-ipc-helper | bunnei | 2017-06-01 | 2 | -293/+265 |
|\ \ | | | | | | | CAM: use IPCHelper | ||||
| * | | fixup!cam: use IPCHelper | wwylele | 2017-05-27 | 2 | -30/+43 |
| | | | |||||
| * | | cam: move u32->u8 trancation to IPCHelper | wwylele | 2017-05-24 | 1 | -34/+33 |
| | | | |||||
| * | | cam: use IPCHelper | wwylele | 2017-05-24 | 1 | -278/+238 |
| | | | |||||
* | | | Merge pull request #2739 from yuriks/kernel-reorg | bunnei | 2017-06-01 | 25 | -341/+428 |
|\ \ \ | | | | | | | | | Split-up kernel.h | ||||
| * | | | Kernel: Move HandleTable to a separate file | Yuri Kunde Schlesner | 2017-05-30 | 18 | -203/+242 |
| | | | | |||||
| * | | | Kernel: Move WaitObject to a separate file | Yuri Kunde Schlesner | 2017-05-30 | 13 | -132/+176 |
| | | | | | | | | | | | | | | | | | | | | Now that HandleTable doesn't directly depend on WaitObject anymore, this can be separated from the main kernel.h header. | ||||
| * | | | Kernel: Removed HandleTable::GetWaitObject | Yuri Kunde Schlesner | 2017-05-30 | 2 | -11/+2 |
| | | | | | | | | | | | | | | | | | | | | This isn't necessary anymore since plain Get works correctly for WaitObjects. | ||||
| * | | | Kernel: Extract dynamic Object pointer cast into its own function | Yuri Kunde Schlesner | 2017-05-29 | 1 | -11/+24 |
| | |/ | |/| | |||||
* | | | CMake: Remove unnecessary include_directories for dynarmic | Yuri Kunde Schlesner | 2017-05-28 | 1 | -3/+0 |
| | | | | | | | | | | | | Dynarmic already adds the correct include paths to the library target. | ||||
* | | | CMake: Add cryptopp include path to target property | Yuri Kunde Schlesner | 2017-05-28 | 1 | -1/+0 |
| | | | |||||
* | | | CMake: Use IMPORTED target for Boost | Yuri Kunde Schlesner | 2017-05-28 | 1 | -1/+1 |
|/ / | |||||
* | | CMake: Correct inter-module dependencies and library visibility | Yuri Kunde Schlesner | 2017-05-28 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | Modules didn't correctly define their dependencies before, which relied on the frontends implicitly including every module for linking to succeed. Also changed every target_link_libraries call to specify visibility of dependencies to avoid leaking definitions to dependents when not necessary. | ||||
* | | Remove some unnecessary inclusions of video_core.h | Yuri Kunde Schlesner | 2017-05-28 | 2 | -2/+0 |
| | | |||||
* | | Move screen size constants from video_core to core | Yuri Kunde Schlesner | 2017-05-28 | 5 | -13/+46 |
| | | | | | | | | | | video_core didn't even properly use them, and they were the source of many otherwise-unnecessary dependencies from core to video_core. | ||||
* | | Core: Fix some out-of-style includes | Yuri Kunde Schlesner | 2017-05-28 | 4 | -4/+4 |
| | | |||||
* | | Move framebuffer_layout from Common to Core | Yuri Kunde Schlesner | 2017-05-28 | 4 | -1/+215 |
| | | | | | | | | | | | | This removes a dependency inversion between core and common. It's also the proper place for the file since it makes screen layout decisions specific to the 3DS. | ||||
* | | Merge pull request #2716 from yuriks/decentralized-result | bunnei | 2017-05-26 | 32 | -277/+343 |
|\ \ | | | | | | | Decentralize ResultCode | ||||
| * | | FS: Remove unused result definition | Yuri Kunde Schlesner | 2017-05-25 | 1 | -5/+0 |
| | | | |||||
| * | | Kernel: Centralize error definitions in errors.h | Yuri Kunde Schlesner | 2017-05-25 | 23 | -132/+178 |
| | | | |||||
| * | | GSP_GPU: Move error codes from result.h to local file | Yuri Kunde Schlesner | 2017-05-25 | 2 | -17/+23 |
| | | | |||||
| * | | FileSys: Move all result description to errors.h | Yuri Kunde Schlesner | 2017-05-25 | 10 | -105/+115 |
| | | | |||||
| * | | result: Make error description a generic integer | Yuri Kunde Schlesner | 2017-05-25 | 3 | -6/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | It is now known that result code description vary depending on the module, and so they're best defined on a per-module basis. To support this, allow passing in an arbitrary integer instead of limiting to the ones in the ErrorDescription enum. These will be gradually migrated to their individual users, but a few will be kept as "common" codes shared by all modules. | ||||
| * | | Make BitField and ResultCode constexpr-initializable | Yuri Kunde Schlesner | 2017-05-25 | 1 | -18/+15 |
| | | | |||||
* | | | telemetry: Log a few simple data fields throughout core. | bunnei | 2017-05-25 | 3 | -1/+22 |
| | | | |||||
* | | | core: Keep track of telemetry for the current emulation session. | bunnei | 2017-05-25 | 5 | -0/+83 |
| |/ |/| | |||||
* | | Merge pull request #2692 from Subv/vfp_ftz | Sebastian Valle | 2017-05-22 | 2 | -0/+26 |
|\ \ | |/ |/| | Dyncom/VFP: Convert denormal outputs into 0 when the FTZ flag is enabled. | ||||
| * | fixup! Dyncom/VFP: Convert denormal outputs into 0 when the FTZ flag is enabled. | Subv | 2017-05-22 | 2 | -4/+0 |
| | | |||||
| * | Dyncom/VFP: Convert denormal outputs into 0 when the FTZ flag is enabled. | Subv | 2017-05-08 | 2 | -0/+30 |
| | | | | | | | | Inputs are still not flushed to 0 if they are denormals. | ||||
* | | Merge pull request #2406 from Subv/session_disconnect | Yuri Kunde Schlesner | 2017-05-22 | 8 | -51/+84 |
|\ \ | | | | | | | Kernel: Properly update port counters on session disconnection. | ||||
| * | | Kernel/Sessions: Remove the ClientSession::Create function. | Subv | 2017-05-22 | 3 | -16/+3 |
| | | | | | | | | | | | | It is not meant to be used by anything other than CreateSessionPair. | ||||
| * | | Kernel: Remove a now unused enum and variable regarding a session's status. | Subv | 2017-05-15 | 2 | -8/+0 |
| | | | |||||
| * | | Kernel: Use a Session object to keep track of the status of a Client/Server session pair. | Subv | 2017-05-15 | 8 | -32/+86 |
| | | | | | | | | | | | | Reduce the associated port's connection count when a ServerSession is destroyed. | ||||
* | | | Merge pull request #2694 from Subv/vfp_vsub_ftz | Merry | 2017-05-22 | 1 | -2/+12 |
|\ \ \ | | | | | | | | | Dyncom/VFP: Perform flush-to-zero on the second operand of vsub before sending it to vadd. | ||||
| * | | | Dyncom/VFP: Perform flush-to-zero on the second operand of vsub before sending it to vadd. | Subv | 2017-05-14 | 1 | -2/+12 |
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | Previously we were letting vadd flush the value to positive 0, but there are cases where this behavior is wrong, for example, vsub: -0 - +0 = -0 vadd: -0 + +0 = +0 Now we'll flush the value to +0 inside vsub, and then negate it. | ||||
* | | | Merge pull request #2661 from Subv/uds5 | bunnei | 2017-05-19 | 5 | -33/+602 |
|\ \ \ | | | | | | | | | Services/UDS: Generate 802.11 beacon frames when a network is open. | ||||
| * | | | Services/UDS: Use the new IPC helper functions. | Subv | 2017-05-15 | 1 | -21/+10 |
| | | | | |||||
| * | | | Services/UDS: Implement RecvBeaconBroadcastData. | Subv | 2017-05-15 | 1 | -19/+69 |
| | | | | | | | | | | | | | | | | | | | | This allows the applications to retrieve 802.11 beacon frames from nearby UDS networks. Note that the networks are still not announced anywhere. | ||||
| * | | | Services/UDS: Generate the UDS beacons when the beacon callback fires. | Subv | 2017-05-15 | 5 | -7/+537 |
| | | | | |||||
* | | | | use IPCHelper for PTM services | emmaus | 2017-05-19 | 3 | -31/+45 |
| | | | | |||||
* | | | | Merge pull request #2687 from yuriks/address-mappings | Yuri Kunde Schlesner | 2017-05-14 | 7 | -49/+121 |
|\ \ \ \ | | | | | | | | | | | Kernel: Map special regions according to ExHeader | ||||
| * | | | | Kernel: Map special regions according to ExHeader | Yuri Kunde Schlesner | 2017-05-10 | 5 | -52/+105 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This replaces the hardcoded VRAM/DSP mappings with ones made based on the ExHeader ARM11 Kernel caps list. While this has no visible effect for most applications (since they use a standard set of mappings) it does improve support for system modules and n3DS exclusives. | ||||
| * | | | | DSP: Create backing memory for entire DSP RAM | Yuri Kunde Schlesner | 2017-05-10 | 1 | -1/+6 |
| | | | | | | | | | | | | | | | | | | | | Also move address space mapping out of video_core. | ||||
| * | | | | Memory: Add constants for the n3DS additional RAM | Yuri Kunde Schlesner | 2017-05-10 | 2 | -2/+16 |
| | | | | | | | | | | | | | | | | | | | | This is 4MB of extra, separate memory that was added on the New 3DS. | ||||
* | | | | | Merge pull request #2676 from wwylele/irrst | bunnei | 2017-05-10 | 9 | -24/+208 |
|\ \ \ \ \ | |/ / / / |/| | | | | ir: implement new 3ds HID via ir:rst | ||||
| * | | | | fixup!ir: implement new 3ds HID via ir:rst | wwylele | 2017-05-07 | 1 | -31/+32 |
| | | | | | |||||
| * | | | | ir: implement new 3ds HID via ir:rst | wwylele | 2017-05-04 | 9 | -24/+207 |
| | | | | | |||||
* | | | | | Merge pull request #2696 from Subv/vfp_revert | Yuri Kunde Schlesner | 2017-05-09 | 3 | -59/+30 |
|\ \ \ \ \ | | | | | | | | | | | | | Dyncom/VFP: Revert edf30d8 and fix the FPSCR getting invalid values. | ||||
| * | | | | | Dyncom/VFP: Strip the VFP_NAN_FLAG sentinel value when setting vfp exceptions. | Subv | 2017-05-09 | 2 | -2/+2 |
| | | | | | | |||||
| * | | | | | Revert "Remove `exceptions` parameter from `normaliseround` VFP functions" | Subv | 2017-05-09 | 3 | -57/+28 |
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This reverts commit edf30d84cc0e8299d61c98f5bb40a6428d1576bc. Conflicts: src/core/arm/skyeye_common/vfp/vfp_helper.h src/core/arm/skyeye_common/vfp/vfpdouble.cpp src/core/arm/skyeye_common/vfp/vfpsingle.cpp | ||||
* | | | | | Dyncom: Remove disassembler code | Yuri Kunde Schlesner | 2017-05-08 | 4 | -1589/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Had licensing issue around it, in addition to several bugs. Closes #1632, #1280 | ||||
* | | | | | Dyncom: Tweak types and log formatting | Yuri Kunde Schlesner | 2017-05-08 | 3 | -8/+10 |
| | | | | | |||||
* | | | | | Remove unused symbols code | Yuri Kunde Schlesner | 2017-05-08 | 3 | -46/+0 |
| | | | | | |||||
* | | | | | Remove ability to load symbol maps | Yuri Kunde Schlesner | 2017-05-08 | 2 | -40/+2 |
|/ / / / | | | | | | | | | | | | | | | | | This was now mostly unused except by thread creation, which used a symbol of the entrypoint, if available, to name the thread. | ||||
* / / / | Create a random console_unique_id (#2668) | B3n30 | 2017-05-06 | 2 | -5/+71 |
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Create a random console_id when config save_file is created Added button in system config to refresh the console unique id * Moved the connect for the button from .ui file to constructor of ConfigureSystem * Added warning and info dialog Fixup: Make use of qt5 style connects, renamed the refresh button, removed some duplicate code, changed random device and moved all to the generate function * Changed the random generator to reflect what a real 3DS stores as console unique id Fixup: Changed the warning message * Fixup: Set and Create * Fixup: Added console id label, therfore removed second message box * Fixup: fixed the endianess * Fixup: more endianness fixes * Fixup: Endianness the 3rd | ||||
* | | | Merge pull request #2606 from wwylele/ir | bunnei | 2017-05-04 | 6 | -44/+761 |
|\ \ \ | | | | | | | | | ir: implement circle pad pro | ||||
| * | | | ir: implement circle pad pro | wwylele | 2017-05-03 | 6 | -44/+761 |
| | | | | |||||
* | | | | Merge pull request #2532 from wwylele/ldrro-ipc | Yuri Kunde Schlesner | 2017-04-18 | 1 | -193/+138 |
|\ \ \ \ | |_|_|/ |/| | | | ldr_ro: use IPC helper | ||||
| * | | | ldr_ro: use IPC helper | wwylele | 2017-04-17 | 1 | -193/+138 |
| |/ / | |||||
* | | | Merge pull request #2659 from MerryMage/dsp_dsp-correction | bunnei | 2017-04-13 | 1 | -0/+18 |
|\ \ \ | |_|/ |/| | | dsp_dsp: Messages are modified by service before being sent to DSP | ||||
| * | | dsp_dsp: Messages are modified by service before being sent to DSP | MerryMage | 2017-04-12 | 1 | -0/+18 |
| | | | |||||
* | | | Merge pull request #2628 from Subv/uds | Sebastian Valle | 2017-04-12 | 2 | -45/+388 |
|\ \ \ | |_|/ |/| | | Services/UDS: Initial support for hosting local-wlan networks. | ||||
| * | | Services/UDS: Fixed a style mistake in GetChannel. | Sebastian Valle | 2017-03-27 | 1 | -2/+1 |
| | | | |||||
| * | | Services/UDS: Use consistent spelling for WiFi and simplify the GetChannel function. | Subv | 2017-03-26 | 1 | -4/+4 |
| | | | |||||
| * | | Services/UDS: Signal the connection event when closing down the network. | Subv | 2017-03-26 | 1 | -0/+1 |
| | | | |||||
| * | | Services/UDS: Do not allow trying to start up a network that only the host can connect to. | Subv | 2017-03-26 | 1 | -0/+3 |
| | | | |||||
| * | | Service/UDS: Schedule an event to broadcast the beacon frames every 102.4ms. | Subv | 2017-03-26 | 2 | -2/+58 |
| | | | |||||
| * | | Services/UDS: Store the entire NetworkInfo structure that was used to create the network. | Subv | 2017-03-26 | 1 | -13/+5 |
| | | | | | | | | | | | | It will be needed when generating the beacon frames. | ||||
| * | | Services/UDS: Initial support for hosting local-wlan networks. | Subv | 2017-03-26 | 2 | -44/+336 |
| | | | | | | | | | | | | Currently it will let games create a network as hosts, but will not broadcast it anywhere and will not allow clients to connect. | ||||
* | | | Merge pull request #2533 from Lectem/apt_ipchelper | bunnei | 2017-04-06 | 6 | -257/+386 |
|\ \ \ | | | | | | | | | IpcHelper enhancement and APT refactor | ||||
| * | | | hopefully fix clang-format issues with old version | Lectem | 2017-03-20 | 1 | -3/+2 |
| | | | | |||||
| * | | | address more comments | Lectem | 2017-03-19 | 1 | -20/+20 |
| | | | | |||||
| * | | | Cast size_t to u32 for PushStaticBuffer usages | Lectem | 2017-03-18 | 1 | -2/+2 |
| | | | | |||||
| * | | | IPCHelper Skip method + address comments for apt | Lectem | 2017-03-18 | 3 | -38/+46 |
| | | | | |||||
| * | | | fix #2560 and other comments | Lectem | 2017-03-18 | 3 | -22/+22 |
| | | | | |||||
| * | | | move push out of class body and add u8 u16 bool specializations | Lectem | 2017-03-18 | 4 | -55/+114 |
| | | | | |||||
| * | | | refactor APT service to use the new IPC helpers | Lectem | 2017-03-18 | 4 | -195/+258 |
| | | | | |||||
* | | | | Merge pull request #2634 from wwylele/battery | bunnei | 2017-04-06 | 2 | -1/+16 |
|\ \ \ \ | | | | | | | | | | | shared_page: stub battery state | ||||
| * | | | | shared_page: stub battery state | wwylele | 2017-03-21 | 2 | -1/+16 |
| | | | | | |||||
* | | | | | error conversion fixes for soc_u | noah the goodra | 2017-04-03 | 1 | -39/+32 |
| | | | | | |||||
* | | | | | Fix OutputDebugString syscall | Michael Theall | 2017-04-01 | 2 | -4/+4 |
| | | | | | |||||
* | | | | | ptm: create SharedExtSave file before openning it | wwylele | 2017-03-25 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | Merge pull request #2512 from SonofUgly/custom-layout | bunnei | 2017-03-22 | 2 | -12/+24 |
|\ \ \ \ \ | |/ / / / |/| | | | | Add custom layout settings. | ||||
| * | | | | Add custom layout settings. | SonofUgly | 2017-02-23 | 2 | -12/+24 |
| | | | | | |||||
* | | | | | apt: fix RequestBuilder parameters for Unwrap | wwylele | 2017-03-18 | 1 | -1/+1 |
| |/ / / |/| | | | |||||
* | | | | Merge pull request #2497 from wwylele/input-2 | bunnei | 2017-03-17 | 10 | -401/+213 |
|\ \ \ \ | | | | | | | | | | | Refactor input emulation & add SDL gamepad support | ||||
| * | | | | Input: remove unused stuff & clean up | wwylele | 2017-03-01 | 7 | -412/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 1. removed zl, zr and c-stick from HID::PadState. They are handled by IR, not HID 2. removed button handling in EmuWindow 3. removed key_map 4. cleanup #include | ||||
| * | | | | InputCommon: add Keyboard | wwylele | 2017-03-01 | 1 | -2/+0 |
| | | | | | |||||
| * | | | | HID: use AnalogDevice | wwylele | 2017-03-01 | 3 | -2/+30 |
| | | | | | |||||
| * | | | | HID: use ButtonDevice | wwylele | 2017-03-01 | 5 | -1/+100 |
| | | | | | |||||
| * | | | | Input: add device and factory template | wwylele | 2017-03-01 | 2 | -0/+98 |
| | |/ / | |/| | | |||||
* | | | | Merge pull request #2618 from wwylele/log-less-filename | bunnei | 2017-03-17 | 6 | -8/+11 |
|\ \ \ \ | | | | | | | | | | | Reduce host file name and path logging | ||||
| * | | | | file_sys: lower log level for setting host path | wwylele | 2017-03-08 | 4 | -4/+4 |
| | | | | | |||||
| * | | | | loader/ncch: less verbose log for loading game list. only log program ID when booting | wwylele | 2017-03-08 | 1 | -3/+6 |
| | | | | | |||||
| * | | | | loader: lower file name logging level | wwylele | 2017-03-08 | 1 | -1/+1 |
| |/ / / | |||||
* | | | | Merge pull request #2620 from FernandoS27/syscore_error | bunnei | 2017-03-16 | 1 | -5/+15 |
|\ \ \ \ | | | | | | | | | | | Refined thread launch on syscore error messages | ||||
| * | | | | Refined thread launch on syscore error messages | Fernando Sahmkow | 2017-03-09 | 1 | -5/+15 |
| |/ / / | |||||
* / / / | cfg: implement GenHashConsoleUnique | wwylele | 2017-03-12 | 1 | -7/+24 |
|/ / / | |||||
* | | | Timer: restore missing signaled=true from #2421 | wwylele | 2017-02-27 | 1 | -0/+2 |
| | | | |||||
* | | | Merge pull request #2594 from wwylele/ir-separate | bunnei | 2017-02-27 | 6 | -147/+159 |
|\ \ \ | | | | | | | | | IR: separate functions of each port to their own files | ||||
| * | | | IR: separate functions of each port to their own files | wwylele | 2017-02-26 | 6 | -147/+159 |
| | | | | |||||
* | | | | Fix log entry in timer::signal (#2600) | B3n30 | 2017-02-27 | 1 | -1/+1 |
| | | | | |||||
* | | | | Doxygen: Amend minor issues (#2593) | Mat M | 2017-02-27 | 9 | -13/+15 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Corrects a few issues with regards to Doxygen documentation, for example: - Incorrect parameter referencing. - Missing @param tags. - Typos in @param tags. and a few minor other issues. | ||||
* | | | | Merge pull request #2587 from yuriks/status-bar | Yuri Kunde Schlesner | 2017-02-27 | 12 | -45/+213 |
|\ \ \ \ | |/ / / |/| | | | Replace built-in Profiler with indicators in status bar | ||||
| * | | | PerfStats: Re-order and document members better | Yuri Kunde Schlesner | 2017-02-27 | 2 | -5/+14 |
| | | | | |||||
| * | | | Core: Re-write frame limiter | Yuri Kunde Schlesner | 2017-02-27 | 4 | -39/+50 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now based on std::chrono, and also works in terms of emulated time instead of frames, so we can in the future frame-limit even when the display is disabled, etc. The frame limiter can also be enabled along with v-sync now, which should be useful for those with displays running at more than 60 Hz. | ||||
| * | | | Core: Make PerfStats internally locked | Yuri Kunde Schlesner | 2017-02-27 | 6 | -8/+23 |
| | | | | | | | | | | | | | | | | More ergonomic to use and will be required for upcoming changes. | ||||
| * | | | PerfStats: Add method to get the instantaneous time ratio | Yuri Kunde Schlesner | 2017-02-27 | 3 | -7/+22 |
| | | | | |||||
| * | | | Add performance statistics to status bar | Yuri Kunde Schlesner | 2017-02-27 | 8 | -3/+120 |
| | | | | |||||
| * | | | Core: Remove unnecessary include in thread.h | Yuri Kunde Schlesner | 2017-02-27 | 3 | -1/+2 |
| | | | | |||||
* | | | | Merge pull request #2569 from wwylele/wrap-unwrap | bunnei | 2017-02-25 | 13 | -6/+564 |
|\ \ \ \ | | | | | | | | | | | APT: implemented Wrap and Unwrap | ||||
| * | | | | APT: implement Wrap and Unwrap | wwylele | 2017-02-21 | 5 | -6/+149 |
| | | | | | |||||
| * | | | | HW: add AES engine & implement AES-CCM | wwylele | 2017-02-21 | 8 | -0/+415 |
| | | | | | |||||
* | | | | | Merge pull request #2421 from Subv/timers | Yuri Kunde Schlesner | 2017-02-25 | 3 | -16/+36 |
|\ \ \ \ \ | | | | | | | | | | | | | Timers: Immediately signal the timer if it was started with an initial value of 0 | ||||
| * | | | | | Timers: Return an error when calling SetTimer with negative timeouts. | Subv | 2017-02-22 | 1 | -0/+5 |
| | | | | | | |||||
| * | | | | | Timers: Immediately signal the timer if it was started with an initial value of 0. | Subv | 2017-02-22 | 2 | -16/+31 |
| | |/ / / | |/| | | | |||||
* | | | | | Merge pull request #2585 from MerryMage/sxtb16-sxtab16 | bunnei | 2017-02-20 | 1 | -4/+4 |
|\ \ \ \ \ | |/ / / / |/| | | | | dyncom: Correct SXTAB16 and SXTB16 | ||||
| * | | | | dyncom: Correct SXTAB16 and SXTB16 | MerryMage | 2017-02-18 | 1 | -4/+4 |
| | | | | | |||||
* | | | | | HID: move enable_accelerometer/gyroscope_count initialization into Init() (#2574) | Weiyi Wang | 2017-02-17 | 1 | -2/+5 |
| | | | | | | | | | | | | | | | Fixes #2556 | ||||
* | | | | | core: add missing errors.h in CMakeLists.txt | wwylele | 2017-02-15 | 1 | -0/+1 |
| | | | | | |||||
* | | | | | HLE/IPC: Fix uninitialized variables in helpers (#2568) | Yuri Kunde Schlesner | 2017-02-14 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | Fixes #2567 | ||||
* | | | | | NWM changed to NIM | noah the goodra | 2017-02-14 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | turned clang format back on | noah the goodra | 2017-02-14 | 1 | -1/+1 |
| |/ / / |/| | | | |||||
* | | | | Core: add cryptopp library (#2412) | Weiyi Wang | 2017-02-13 | 1 | -1/+2 |
| | | | | |||||
* | | | | Merge pull request #2561 from wwylele/fs-rom | Yuri Kunde Schlesner | 2017-02-13 | 9 | -60/+295 |
|\ \ \ \ | | | | | | | | | | | file_sys: change RomFS archive to Self NCCH archive | ||||
| * | | | | loader: use self NCCH archive | wwylele | 2017-02-13 | 6 | -90/+7 |
| | | | | | |||||
| * | | | | file_sys: add Self NCCH archive | wwylele | 2017-02-13 | 5 | -0/+318 |
| |/ / / | |||||
* | | | | core: Free AppLoader on shutdown to release file (#2558) | Yuri Kunde Schlesner | 2017-02-11 | 1 | -9/+2 |
| | | | | | | | | | | | | Fixes #2455 | ||||
* | | | | hid: remove the touch field from PadState (#2557) | Weiyi Wang | 2017-02-11 | 2 | -6/+0 |
|/ / / | |||||
* | | | Merge pull request #2027 from Lectem/ipcrefactor | Weiyi Wang | 2017-02-05 | 6 | -68/+364 |
|\ \ \ | | | | | | | | | IPC helper | ||||
| * | | | fix wwylele's comment and use typename in templates | Lectem | 2017-02-05 | 1 | -4/+4 |
| | | | | |||||
| * | | | fix comments alignment | Lectem | 2016-12-30 | 1 | -22/+22 |
| | | | | |||||
| * | | | move Pop methods out of class body | Lectem | 2016-12-26 | 1 | -72/+88 |
| | | | | |||||
| * | | | IPC helpers example | Lectem | 2016-12-26 | 3 | -35/+40 |
| | | | | |||||
| * | | | IPC helpers | Lectem | 2016-12-26 | 3 | -48/+323 |
| | | | | |||||
* | | | | Merge pull request #2496 from mailwl/cfg-mem | Yuri Kunde Schlesner | 2017-02-04 | 1 | -5/+8 |
|\ \ \ \ | | | | | | | | | | | Core: update Kernel Config Memory to latest version (11.2) | ||||
| * | | | | Core: update Kernel Config Memory to latest version (11.2) | mailwl | 2017-01-30 | 1 | -5/+8 |
| | |_|/ | |/| | | |||||
* | | | | Merge pull request #2518 from MerryMage/coproc | Yuri Kunde Schlesner | 2017-02-04 | 5 | -15/+140 |
|\ \ \ \ | | | | | | | | | | | arm_dynarmic: Coprocessor support | ||||
| * | | | | arm_dynarmic: Update memory interface | MerryMage | 2017-02-03 | 1 | -10/+10 |
| | | | | | |||||
| * | | | | arm_dynarmic: CP15 support | MerryMage | 2017-02-03 | 5 | -5/+130 |
| |/ / / | |||||
* | | | | Merge pull request #2509 from jfmherokiller/settingscastpatch | bunnei | 2017-02-03 | 1 | -1/+1 |
|\ \ \ \ | | | | | | | | | | | removed the possibly uneeded cast on values.gdbstub_port | ||||
| * | | | | removed the possibly uneeded cast on values.gdbstub_port | noah the goodra | 2017-01-31 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | as far as i could tell this cast is unneeded because [GDBStub::SetServerPort](https://github.com/citra-emu/citra/blob/master/src/core/gdbstub/gdbstub.cpp#L897) takes a u16 and [values.gdbstub_port](https://github.com/citra-emu/citra/blob/master/src/core/settings.h#L116) is already a u16 | ||||
* | | | | | GSP_GPU::StoreDataCache stubbed (#2428) | mailwl | 2017-02-03 | 1 | -1/+28 |
|/ / / / | |||||
* / / / | HLE/Applets: Stub Mint (eShop) Applet (#2463) | mailwl | 2017-01-31 | 4 | -0/+108 |
|/ / / | | | | | | | | | | This allows Phoenix Wright - Dual Destinies to boot. | ||||
* | | | Merge pull request #2368 from wwylele/camera-2 | Yuri Kunde Schlesner | 2017-01-30 | 11 | -172/+1457 |
|\ \ \ | | | | | | | | | CAM: build the service framework with a dummy implementation | ||||
| * | | | CAM: implement basic camera functions with a blank camera | wwylele | 2017-01-11 | 11 | -172/+1457 |
| |/ / | |||||
* | | | Merge pull request #2429 from wwylele/auto-language-fix | Yuri Kunde Schlesner | 2017-01-30 | 1 | -36/+38 |
|\ \ \ | | | | | | | | | CFG: move language override to the boot process | ||||
| * | | | CFG: override language setting on boot | wwylele | 2017-01-19 | 1 | -36/+38 |
| | | | | |||||
* | | | | Merge pull request #2494 from Kloen/killing-warnings-2-final-mix | Yuri Kunde Schlesner | 2017-01-30 | 1 | -1/+1 |
|\ \ \ \ | | | | | | | | | | | core: inline CPU, 132 warnings fixed on GCC | ||||
| * | | | | core: inline CPU, 132 warnings fixed on GCC | Kloen | 2017-01-30 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | Merge pull request #2492 from Kloen/killing-warnings-HD1.5ReMIX | Yuri Kunde Schlesner | 2017-01-30 | 4 | -0/+28 |
|\ \ \ \ \ | |/ / / / |/| | | | | Fix OSX build warnings about unhandled enumeration values. | ||||
| * | | | | core: fix err_f.cpp warning about unhandled enumeration value on OSX | Kloen | 2017-01-29 | 1 | -0/+2 |
| | | | | | |||||
| * | | | | core: fix savedata_archive.cpp warnings about unhandled enumeration values on OSX | Kloen | 2017-01-29 | 1 | -0/+12 |
| | | | | | |||||
| * | | | | core: fix archive_sdmc.cpp warnings about unhandled enumeration value on OSX | Kloen | 2017-01-29 | 1 | -0/+12 |
| | | | | | |||||
| * | | | | core: fix archive_extsavedata.cpp warning on OSX | Kloen | 2017-01-29 | 1 | -0/+2 |
| | |_|/ | |/| | | |||||
* / | | | core: emu_window.cpp, fix conversion warnings from float to s16 on MSVC | Kloen | 2017-01-29 | 1 | -6/+6 |
|/ / / | |||||
* | | | SDL: Select audio device (#2403) | Kloen Lansfiel | 2017-01-26 | 1 | -0/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Initial Commit Added Device logic to Sinks Started on UI for selecting devices Removed redundant import * Audio Core: Complete Device Switching Complete the device switching implementation by allowing the output device to be loaded, changed and saved through the configurations menu. Worked with the Sink abstraction and tuned the "Device Selection" configuration so that the Device List is automatically populated when the Sink is changed. This hopefully addresses the concerns and recommendations mentioned in the comments of the PR. * Clean original implementation. * Refactor GetSinkDetails | ||||
* | | | Merge pull request #2434 from mailwl/nfc-amiibo | Yuri Kunde Schlesner | 2017-01-26 | 4 | -20/+249 |
|\ \ \ | | | | | | | | | Service/NFC: stub some functions | ||||
| * | | | Service/NFC: stub some functions | mailwl | 2017-01-14 | 4 | -20/+249 |
| | | | | | | | | | | | | | | | | Tested on: Mini-Mario & Friends - amiibo Challenge | ||||
* | | | | core: fix mic_u warnings on MSVC | Kloen | 2017-01-23 | 1 | -4/+4 |
| | | | | |||||
* | | | | HID: reset acceleroeter and gyroscope index in Init | wwylele | 2017-01-20 | 1 | -0/+2 |
| | | | | |||||
* | | | | loader: Add support for 3DSX special relocation types, fixes citra-emu/citra#2449 | Thomas Farr | 2017-01-18 | 1 | -9/+25 |
| | | | | | | | | | | | | | | | | As per devkitPro/3dstools@47bea18 | ||||
* | | | | CoreTiming: use named constant for ARM11 clock rate | wwylele | 2017-01-16 | 4 | -5/+6 |
| | | | | |||||
* | | | | HID: manages updating itself using correct ticks | wwylele | 2017-01-16 | 3 | -62/+93 |
|/ / / | |||||
* / / | GSP::WriteHWRegsWithMask: fix register mask | mailwl | 2017-01-14 | 1 | -1/+1 |
|/ / | |||||
* | | Merge pull request #2425 from Subv/cleanup_todos | bunnei | 2017-01-12 | 4 | -32/+30 |
|\ \ | | | | | | | Implement some TODOs in the code. | ||||
| * | | Threads: Check the process' resource limit for the max allowed priority when creating a thread and remove the priority clamping code. | Subv | 2017-01-11 | 2 | -13/+9 |
| | | | |||||
| * | | Thread: Added priority range checking to svcSetThreadPriority and removed priority clamping code from Thread::SetPriority. | Subv | 2017-01-11 | 3 | -18/+18 |
| | | | |||||
| * | | Y2R: Use the proper error code when GetStandardCoefficient receives an invalid value. | Subv | 2017-01-11 | 1 | -1/+3 |
| | | | |||||
* | | | Merge pull request #2308 from mailwl/ac-i | bunnei | 2017-01-12 | 9 | -297/+424 |
|\ \ \ | |/ / |/| | | Service/AC: add ac:i service | ||||
| * | | Service/AC: add ac:i service | mailwl | 2016-12-30 | 9 | -297/+424 |
| | | | |||||
* | | | Merge pull request #2397 from Subv/pulse | bunnei | 2017-01-10 | 5 | -13/+20 |
|\ \ \ | | | | | | | | | Kernel: Implemented Pulse event and timers. | ||||
| * | | | Kernel: Implemented Pulse event and timers. | Subv | 2017-01-05 | 5 | -13/+20 |
| |/ / | | | | | | | | | | Closes #1904 | ||||
* | | | Merge pull request #2384 from bunnei/internal-res-option | bunnei | 2017-01-08 | 2 | -2/+1 |
|\ \ \ | | | | | | | | | config: Add option for specifying screen resolution scale factor. | ||||
| * | | | config: Add option for specifying screen resolution scale factor. | bunnei | 2017-01-07 | 2 | -2/+1 |
| | | | | |||||
* | | | | Merge pull request #1951 from wwylele/motion-sensor | bunnei | 2017-01-07 | 5 | -8/+212 |
|\ \ \ \ | |/ / / |/| | | | Emulate motion sensor in frontend | ||||
| * | | | Frontend: make motion sensor interfaced thread-safe | wwylele | 2016-12-29 | 2 | -2/+8 |
| | | | | |||||
| * | | | Frontend: emulate motion sensor | wwylele | 2016-12-26 | 5 | -8/+206 |
| | |/ | |/| | |||||
* | | | Merge pull request #2410 from Subv/sleepthread | bunnei | 2017-01-07 | 3 | -0/+14 |
|\ \ \ | | | | | | | | | Don't yield execution in SleepThread(0) if there are no available threads to run | ||||
| * | | | Kernel: Don't attempt to yield execution in SleepThread(0) if there are no available threads to run. | Subv | 2017-01-06 | 3 | -0/+14 |
| | | | | | | | | | | | | | | | | With this we avoid an useless temporary deschedule of the current thread. | ||||
* | | | | Merge pull request #2396 from Subv/sema_acquire | bunnei | 2017-01-07 | 1 | -1/+2 |
|\ \ \ \ | | | | | | | | | | | Kernel/Semaphore: Fixed a regression in semaphore waits. | ||||
| * | | | | Kernel/Semaphore: Fixed a regression in semaphore waits. | Subv | 2017-01-05 | 1 | -1/+2 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | The regression was caused by a missing check in #2260. The new behavior is consistent with the real kernel. | ||||
* | | | | Kernel: Fix SharedMemory objects always returning error when addr = 0 (#2404) | Hyper | 2017-01-06 | 1 | -1/+5 |
| | | | | | | | | | | | | Closes #2400 | ||||
* | | | | Merge pull request #2408 from Subv/priority_boosting | bunnei | 2017-01-06 | 1 | -27/+0 |
|\ \ \ \ | | | | | | | | | | | Kernel: Removed the priority boost code for starved threads. | ||||
| * | | | | Kernel: Removed the priority boost code for starved threads. | Subv | 2017-01-05 | 1 | -27/+0 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | After hwtesting and reverse engineering the kernel, it was found that the CTROS scheduler performs no priority boosting for threads like this, although some other forms of scheduling priority-starved threads might take place. For example, it was found that hardware interrupts might cause low-priority threads to run if the CPU is preempted in the middle of an SVC handler that deschedules the current (high priority) thread before scheduling it again. | ||||
* / / / | Kernel: Remove some unused functions. | Subv | 2017-01-05 | 2 | -32/+0 |
|/ / / | |||||
* | | | Merge pull request #2393 from Subv/synch | Sebastian Valle | 2017-01-05 | 17 | -159/+221 |
|\ \ \ | | | | | | | | | Kernel: Mutex priority inheritance and synchronization improvements. | ||||
| * | | | Kernel: Add some asserts to enforce the invariants in the scheduler. | Subv | 2017-01-05 | 2 | -2/+13 |
| | | | | |||||
| * | | | Kernel: Remove a thread from all of its waiting objects' waiting_threads list when it is awoken. | Subv | 2017-01-05 | 1 | -18/+4 |
| | | | | | | | | | | | | | | | | This fixes a potential bug where threads would not get removed from said list if they awoke after waiting with WaitSynchronizationN with wait_all = false | ||||
| * | | | Kernel: Remove Thread::wait_objects_index and use wait_objects to hold all the objects that a thread is waiting on. | Subv | 2017-01-05 | 4 | -21/+22 |
| | | | | |||||
| * | | | Kernel: Use different thread statuses when a thread calls WaitSynchronization1 and WaitSynchronizationN with wait_all = true. | Subv | 2017-01-04 | 3 | -16/+20 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit removes the overly general THREADSTATUS_WAIT_SYNCH and replaces it with two more granular statuses: THREADSTATUS_WAIT_SYNCH_ANY when a thread waits on objects via WaitSynchronization1 or WaitSynchronizationN with wait_all = false. THREADSTATUS_WAIT_SYNCH_ALL when a thread waits on objects via WaitSynchronizationN with wait_all = true. | ||||
| * | | | Kernel/Mutex: Propagate thread priority changes to other threads inheriting the priority via mutexes | Subv | 2017-01-04 | 5 | -42/+60 |
| | | | | |||||
| * | | | Kernel/Mutex: Update a mutex priority when a thread stops waiting on it. | Subv | 2017-01-04 | 5 | -24/+42 |
| | | | | |||||
| * | | | Kernel/Mutex: Implemented priority inheritance. | Subv | 2017-01-04 | 5 | -31/+51 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | The implementation is based on reverse engineering of the 3DS's kernel. A mutex holder's priority will be temporarily boosted to the best priority among any threads that want to acquire any of its held mutexes. When the holder releases the mutex, it's priority will be boosted to the best priority among the threads that want to acquire any of its remaining held mutexes. | ||||
| * | | | Kernel: Object ShouldWait and Acquire calls now take a thread as a parameter. | Subv | 2017-01-04 | 17 | -68/+56 |
| | | | | | | | | | | | | | | | | This will be useful when implementing mutex priority inheritance. | ||||
| * | | | Kernel/Synch: Do not attempt a reschedule on every syscall. | Subv | 2017-01-04 | 2 | -2/+18 |
| | |/ | |/| | | | | | | | Not all syscalls should cause reschedules, this commit attempts to remedy that, however, it still does not cover all cases. | ||||
* | | | Fix some warnings (#2399) | Jonathan Hao | 2017-01-04 | 7 | -15/+8 |
| | | | |||||
* | | | Service/NFC: stub GetTagInRangeEvent | mailwl | 2016-12-30 | 5 | -0/+42 |
|/ / | | | | | | | Fix Fatal Error in Mini-Mario & Friends - amiibo Challenge | ||||
* | | Merge pull request #2240 from wwylele/auto-region | bunnei | 2016-12-30 | 5 | -2/+91 |
|\ \ | | | | | | | Config: auto-select region and language | ||||
| * | | Config: auto-select region and language | wwylele | 2016-12-07 | 5 | -2/+91 |
| | | | |||||
* | | | Core: remove unused hle.cpp | wwylele | 2016-12-27 | 1 | -58/+0 |
| | | | |||||
* | | | Core: reset cpu_core in Shutdown to make IsPoweredOn work properly | wwylele | 2016-12-24 | 1 | -0/+1 |
| |/ |/| | |||||
* | | core: Move emu_window and key_map into core | MerryMage | 2016-12-23 | 7 | -2/+648 |
| | | | | | | | | * Removes circular dependences (common should not depend on core) | ||||
* | | Service/NWM: add nwm services | mailwl | 2016-12-22 | 18 | -10/+317 |
| | | |||||
* | | Merge pull request #2366 from MerryMage/MemoryReadCode | bunnei | 2016-12-22 | 1 | -0/+1 |
|\ \ | | | | | | | arm_dynarmic: Provide MemoryReadCode callback | ||||
| * | | arm_dynarmic: Provide MemoryReadCode callback | MerryMage | 2016-12-22 | 1 | -0/+1 |
| | | | | | | | | | | | | Change of interface in dynarmic 36082087ded632079b16d24137fdd0c450ce82ea | ||||
* | | | Merge pull request #2343 from bunnei/core-cleanup | bunnei | 2016-12-22 | 32 | -407/+377 |
|\ \ \ | |/ / |/| | | Core: Top-level consolidate & misc cleanup | ||||
| * | | ThreadContext: Move from "core" to "arm_interface". | bunnei | 2016-12-22 | 8 | -37/+26 |
| | | | |||||
| * | | core: Replace "AppCore" nomenclature with just "CPU". | bunnei | 2016-12-22 | 8 | -93/+91 |
| | | | |||||
| * | | Address clang-format issues. | bunnei | 2016-12-22 | 6 | -32/+33 |
| | | | |||||
| * | | core: Remove HLE module, consolidate code & various cleanups. | bunnei | 2016-12-22 | 19 | -107/+94 |
| | | | |||||
| * | | core: Consolidate core and system state, remove system module & cleanups. | bunnei | 2016-12-22 | 12 | -311/+264 |
| | | | |||||
| * | | core: Consolidate top-level system state into a singleton. | bunnei | 2016-12-22 | 2 | -23/+120 |
| | | | |||||
| * | | loader: Remove duplicate docstrings. | bunnei | 2016-12-22 | 3 | -56/+0 |
| | | | |||||
* | | | Merge pull request #2285 from mailwl/csnd-format | bunnei | 2016-12-22 | 2 | -49/+92 |
|\ \ \ | |/ / |/| | | csnd:SND: Reformat source code | ||||
| * | | csnd:SND reformat source code | mailwl | 2016-12-12 | 2 | -49/+92 |
| | | | |||||
* | | | Revert "Memory: Always flush whole pages from surface cache" | bunnei | 2016-12-18 | 1 | -10/+0 |
| | | | |||||
* | | | Thread: remove the thread from the thread list when exiting | wwylele | 2016-12-17 | 3 | -3/+15 |
| | | | |||||
* | | | Merge pull request #2337 from lioncash/gdb | bunnei | 2016-12-16 | 1 | -9/+8 |
|\ \ \ | | | | | | | | | gdbstub: const correctness changes | ||||
| * | | | gdbstub: const correctness changes | Lioncash | 2016-12-16 | 1 | -9/+8 |
| | | | | | | | | | | | | | | | | Also uses size_t as the length indicator type, as is common with buffers. | ||||
* | | | | Merge pull request #2322 from MerryMage/ctx-mnu | Merry | 2016-12-16 | 5 | -0/+35 |
|\ \ \ \ | | | | | | | | | | | game_list: Add a context menu with "Open Save Location" option | ||||
| * | | | | loader: Implement ReadProgramId | MerryMage | 2016-12-15 | 3 | -0/+28 |
| | | | | | |||||
| * | | | | archive_source_sd_savedata: Add static method to get a specific save data path | MerryMage | 2016-12-15 | 2 | -0/+7 |
| | | | | | |||||
* | | | | | Kernel: remove object's waiting thread if it is dead | wwylele | 2016-12-16 | 1 | -1/+2 |
| |/ / / |/| | | | |||||
* | | | | Merge pull request #2260 from Subv/scheduling | bunnei | 2016-12-16 | 7 | -195/+209 |
|\ \ \ \ | | | | | | | | | | | Threading: Reworked the way our scheduler works. | ||||
| * | | | | Fixed the codestyle to match our clang-format rules. | Subv | 2016-12-14 | 3 | -27/+39 |
| | | | | | |||||
| * | | | | Properly remove a thread from its wait_objects' waitlist when it is awoken by a timeout. | Subv | 2016-12-10 | 3 | -2/+11 |
| | | | | | |||||
| * | | | | WaitSynch: Removed unused variables and reduced SharedPtr copies. | Subv | 2016-12-09 | 4 | -73/+56 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Define a variable with the value of the sync timeout error code. Use a boost::flat_map instead of an unordered_map to hold the equivalence of objects and wait indices in a WaitSynchN call. | ||||
| * | | | | Use boost remove_erase_if instead of the erase-remove idiom | Subv | 2016-12-07 | 1 | -2/+3 |
| | | | | | |||||
| * | | | | Improved the algorithm for GetHighestPriorityReadyThread. | Subv | 2016-12-07 | 1 | -14/+13 |
| | | | | | |||||
| * | | | | Threading: Added some utility functions and const correctness. | Subv | 2016-12-04 | 3 | -15/+35 |
| | | | | | |||||
| * | | | | Threading: Reworked the way our scheduler works. | Subv | 2016-12-04 | 7 | -189/+179 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Threads will now be awakened when the objects they're waiting on are signaled, instead of repeating the WaitSynchronization call every now and then. The scheduler is now called once after every SVC call, and once after a thread is awakened from sleep by its timeout callback. This new implementation is based off reverse-engineering of the real kernel. See https://gist.github.com/Subv/02f29bd9f1e5deb7aceea1e8f019c8f4 for a more detailed description of how the real kernel handles rescheduling. | ||||
* | | | | | Merge pull request #2328 from wwylele/fix-trace | Yuri Kunde Schlesner | 2016-12-16 | 1 | -11/+9 |
|\ \ \ \ \ | | | | | | | | | | | | | Fix debug build from #2249 | ||||
| * | | | | | FS: fix debug build from #2249 | wwylele | 2016-12-15 | 1 | -11/+9 |
| | | | | | | |||||
* | | | | | | Merge pull request #2332 from lioncash/gdb | Yuri Kunde Schlesner | 2016-12-16 | 5 | -16/+23 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | gdbstub: Remove global variable from public interface | ||||
| * | | | | | | gdbstub: Remove global variable from public interface | Lioncash | 2016-12-15 | 5 | -16/+23 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Currently, this is only ever queried, so adding a function to check if the server is enabled is more sensible. If directly modifying this externally is ever desirable, it should be done by adding a function to the interface, rather than exposing implementation details directly. | ||||
* | | | | | | | Merge pull request #2320 from mailwl/cecd-update | Yuri Kunde Schlesner | 2016-12-16 | 8 | -13/+81 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Service/CECD: Add cecd:ndm service | ||||
| * | | | | | | | Service/CECD: Add cecd:ndm service | mailwl | 2016-12-15 | 8 | -13/+81 |
| | | | | | | | | |||||
* | | | | | | | | Merge pull request #2331 from lioncash/trunc | bunnei | 2016-12-15 | 1 | -1/+2 |
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | | hid: Get rid of a double -> float truncation warning | ||||
| * | | | | | | | hid: Get rid of a double -> float truncation warning | Lioncash | 2016-12-15 | 1 | -1/+2 |
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | float literals need to have the 'f' prefix. | ||||
* | | | | | | | Merge pull request #2330 from lioncash/pragma | Sebastian Valle | 2016-12-15 | 3 | -0/+6 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | core: Add missing #pragma once directives where applicable | ||||
| * | | | | | | | core: Add missing #pragma once directives where applicable | Lioncash | 2016-12-15 | 3 | -0/+6 |
| |/ / / / / / | |||||
* / / / / / / | act: Fix docstring typo | Lioncash | 2016-12-15 | 1 | -1/+1 |
|/ / / / / / | | | | | | | | | | | | | | | | | | | These aren't the AM services. | ||||
* | | | | | | Merge pull request #2314 from mailwl/account | bunnei | 2016-12-15 | 8 | -10/+44 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Service/ACT: move ACT services to folder | ||||
| * | | | | | | Service/ACT: move ACT services to folder | mailwl | 2016-12-14 | 8 | -10/+44 |
| | |_|/ / / | |/| | | | | |||||
* | | | | | | Memory: Always flush whole pages from surface cache | Yuri Kunde Schlesner | 2016-12-15 | 1 | -0/+10 |
| |/ / / / |/| | | | | | | | | | | | | | | | | | | | This prevents individual writes touching a cached page, but which don't overlap the surface, from constantly hitting the surface cache lookup. | ||||
* | | | | | Merge pull request #2249 from Subv/sessions_v3 | Yuri Kunde Schlesner | 2016-12-15 | 24 | -170/+591 |
|\ \ \ \ \ | |/ / / / |/| | | | | Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication. | ||||
| * | | | | Fixed the codestyle to match our clang-format rules. | Subv | 2016-12-14 | 16 | -68/+108 |
| | | | | | |||||
| * | | | | Moved the HLE command buffer translation task to ServerSession instead of the HLE handler superclass. | Subv | 2016-12-09 | 6 | -47/+38 |
| | | | | | |||||
| * | | | | Kernel/IPC: Small codestyle cleanup | Subv | 2016-12-09 | 2 | -3/+1 |
| | | | | | |||||
| * | | | | Added a framework for partially handling Session disconnections. | Subv | 2016-12-08 | 8 | -9/+67 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Further implementation will happen in a future commit. Fixes a regression. | ||||
| * | | | | Use std::move where appropriate. | Subv | 2016-12-08 | 12 | -177/+187 |
| | | | | | |||||
| * | | | | Return an error code when connecting to a saturated port. | Subv | 2016-12-05 | 5 | -7/+20 |
| | | | | | | | | | | | | | | | | | | | | The error code was taken from the 3DS kernel. | ||||
| * | | | | HLE: Use a member variable instead of a virtual function to retrieve the max number of sessions that can be connected to an HLE service at the same time. | Subv | 2016-12-05 | 5 | -8/+18 |
| | | | | | |||||
| * | | | | Split SessionRequestHandler::HandleSyncRequest into HandleSyncRequest, TranslateRequest and HandleSyncRequestImpl. | Subv | 2016-12-05 | 6 | -22/+59 |
| | | | | | | | | | | | | | | | | | | | | HandleSyncRequest now takes care of calling the command buffer translate function before actually invoking the command handler for HLE services. | ||||
| * | | | | Kernel: Remove the Redirection handle type. | Subv | 2016-12-05 | 1 | -2/+0 |
| | | | | | |||||
| * | | | | KServerPorts now have an HLE handler "template", which is inherited by all ServerSessions created from it. | Subv | 2016-12-05 | 12 | -69/+86 |
| | | | | | |||||
| * | | | | Declare empty ServerSession and ClientSession constructors as default. | Subv | 2016-12-03 | 2 | -4/+4 |
| | | | | | |||||
| * | | | | Threads do not wait for the server endpoint to call AcceptSession before returning from a ConnectToPort or GetServiceHandle call. | Subv | 2016-12-01 | 2 | -3/+5 |
| | | | | | |||||
| * | | | | Fixed the rebase mistakes. | Subv | 2016-12-01 | 10 | -82/+76 |
| | | | | | |||||
| * | | | | A bit of a redesign. | Subv | 2016-12-01 | 13 | -263/+266 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Sessions and Ports are now detached from each other. HLE services are handled by means of a SessionRequestHandler class, Interface now inherits from this class. The File and Directory classes are no longer kernel objects, but SessionRequestHandlers instead, bound to a ServerSession when requested. File::OpenLinkFile now creates a new session pair and binds the File instance to it. | ||||
| * | | | | IPC/HLE: Associate the ClientSessions with their parent port's HLE interface if it exists. | Subv | 2016-12-01 | 6 | -26/+21 |
| | | | | | | | | | | | | | | | | | | | | Pass the triggering ServerSession to the HLE command handler to differentiate which session caused the request. | ||||
| * | | | | Kernel/HLE: Service::Interface no longer inherits from any Kernel object, and is now its own standalone class. | Subv | 2016-12-01 | 4 | -24/+52 |
| | | | | | | | | | | | | | | | | | | | | Interface is now used by aggregation in ClientPort, to forward service commands to their HLE implementation if needed. | ||||
| * | | | | fixup! Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication. | Subv | 2016-12-01 | 4 | -5/+6 |
| | | | | | |||||
| * | | | | Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication. | Subv | 2016-12-01 | 16 | -88/+314 |
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | All handles obtained via srv::GetServiceHandle or svcConnectToPort are references to ClientSessions. Service modules will wait on the counterpart of those ClientSessions (Called ServerSessions) using svcReplyAndReceive or svcWaitSynchronization[1|N], and will be awoken when a SyncRequest is performed. HLE Interfaces are now ClientPorts which override the HandleSyncRequest virtual member function to perform command handling immediately. | ||||
* | / / | Minor amendment of GSP_GPU::ImportDisplayCaptureInfo code | JamePeng | 2016-12-13 | 1 | -3/+5 |
| |/ / |/| | | |||||
* | | | Merge pull request #2267 from JayFoxRox/fix-mingw-cc | Sebastian Valle | 2016-12-11 | 1 | -2/+2 |
|\ \ \ | | | | | | | | | Support mingw cross-compilation | ||||
| * | | | gdbstub: Remove unused include | Jannik Vogel | 2016-12-05 | 1 | -1/+0 |
| | | | | |||||
| * | | | Support mingw cross-compile | Jannik Vogel | 2016-12-05 | 1 | -1/+2 |
| | | | | |||||
* | | | | APT::GetStartupArgument: force clear startup argument | mailwl | 2016-12-11 | 2 | -5/+11 |
| | | | | |||||
* | | | | Core: Add a forgotten #include <cstring> for memcpy. | Emmanuel Gil Peyrot | 2016-12-11 | 1 | -0/+1 |
| | | | | |||||
* | | | | Add all services to the Service namespace | Lioncash | 2016-12-11 | 45 | -482/+390 |
| | | | | | | | | | | | | | | | | | | | | Previously there was a split where some of the services were in the Service namespace and others were not. | ||||
* | | | | Merge pull request #2291 from lioncash/svc | bunnei | 2016-12-09 | 10 | -12/+61 |
|\ \ \ \ | | | | | | | | | | | service: Add the cfg:nor service | ||||
| * | | | | service: Add cfg:nor service | Lioncash | 2016-12-09 | 4 | -0/+49 |
| | | | | | |||||
| * | | | | service: Drop '_Interface' from cfg service names | Lioncash | 2016-12-09 | 7 | -12/+12 |
| | | | | | |||||
* | | | | | Merge pull request #2292 from lioncash/bool | Yuri Kunde Schlesner | 2016-12-09 | 1 | -1/+1 |
|\ \ \ \ \ | |/ / / / |/| | | | | ptm: Use boolean instead of integral value | ||||
| * | | | | ptm: Use boolean instead of integral value | Lioncash | 2016-12-09 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | The third parameter of Write is actually a bool type, not an int. | ||||
* | | | | | Merge pull request #2287 from lioncash/svc | Yuri Kunde Schlesner | 2016-12-09 | 12 | -12/+170 |
|\ \ \ \ \ | | | | | | | | | | | | | service: Minor PTM changes | ||||
| * | | | | | service: Add the ptm:s service | Lioncash | 2016-12-08 | 3 | -0/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | 3dbrew documents this as being the exact same as ptm:sysm | ||||
| * | | | | | service: Add common ptm:u commands to other ptm services | Lioncash | 2016-12-08 | 4 | -0/+54 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 3dbrew indicates that all services have access to these commands except for ptm:sets. | ||||
| * | | | | | service: Drop '_Interface' in ptm service class names | Lioncash | 2016-12-08 | 7 | -14/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | Inheriting from Service::Interface makes this obvious. | ||||
| * | | | | | service: Add ptm::gets and ptm::sets services | Lioncash | 2016-12-08 | 6 | -0/+90 |
| | | | | | | |||||
* | | | | | | Merge pull request #2280 from Subv/citrace_size | Sebastian Valle | 2016-12-08 | 1 | -2/+2 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Fixed the gpu command list size when creating CiTraces. | ||||
| * | | | | | Fixed the gpu command list size when creating CiTraces. | Subv | 2016-12-08 | 1 | -2/+2 |
| | |/ / / | |/| | | | |||||
* | | | | | service: Add mvd and qtm services | Lioncash | 2016-12-08 | 14 | -0/+271 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Adds the two New3DS-only modules. 3dbrew was used for command information. | ||||
* | | | | | Merge pull request #2284 from lioncash/svc | Yuri Kunde Schlesner | 2016-12-08 | 8 | -30/+199 |
|\ \ \ \ \ | | | | | | | | | | | | | service: Add nfc services | ||||
| * | | | | | service: Add nfc services | Lioncash | 2016-12-08 | 8 | -30/+199 |
| | | | | | | | | | | | | | | | | | | | | | | | | 3dbrew was used for the command information. | ||||
* | | | | | | Merge pull request #2277 from lioncash/explicit | Yuri Kunde Schlesner | 2016-12-08 | 8 | -10/+10 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | file_sys: Make a few single-argument constructors explicit | ||||
| * | | | | | file_sys: Make a few single-argument constructors explicit | Lioncash | 2016-12-07 | 8 | -10/+10 |
| | |_|_|/ | |/| | | | | | | | | | | | | | Prevents implicit conversions. | ||||
* | | | | | Merge pull request #2283 from lioncash/svc | Yuri Kunde Schlesner | 2016-12-08 | 21 | -28/+212 |
|\ \ \ \ \ | | | | | | | | | | | | | service: Update function tables | ||||
| * | | | | | ssl_c: Update function table | Lioncash | 2016-12-08 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew | ||||
| * | | | | | ptm: Update ptm_sysm function table | Lioncash | 2016-12-08 | 3 | -6/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | pm_app: Update function table | Lioncash | 2016-12-08 | 1 | -6/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | nwm_uds: Update function table | Lioncash | 2016-12-08 | 1 | -5/+7 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | nim: Update function tables | Lioncash | 2016-12-08 | 2 | -0/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | http_c: Update function table | Lioncash | 2016-12-08 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | gsp_lcd: Update function table | Lioncash | 2016-12-08 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | fs_user: Update function table | Lioncash | 2016-12-08 | 1 | -0/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | dlp_srvr: Update function table | Lioncash | 2016-12-08 | 1 | -0/+7 |
| | | | | | | |||||
| * | | | | | cfg: Update function tables | Lioncash | 2016-12-08 | 3 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew | ||||
| * | | | | | cecd_u: Update function table | Lioncash | 2016-12-08 | 1 | -1/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | boss_p: Update function table | Lioncash | 2016-12-08 | 1 | -3/+68 |
| | | | | | | |||||
| * | | | | | act: Update function tables | Lioncash | 2016-12-08 | 2 | -0/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
| * | | | | | apt: Update apt function tables | Lioncash | 2016-12-08 | 2 | -7/+73 |
| | |_|/ / | |/| | | | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
* | | | | | Merge pull request #2281 from lioncash/applet | Yuri Kunde Schlesner | 2016-12-08 | 8 | -30/+22 |
|\ \ \ \ \ | |/ / / / |/| | | | | applet: minor interface changes | ||||
| * | | | | applet: Move common IsRunning underlying variable to the Applet class | Lioncash | 2016-12-07 | 8 | -28/+19 |
| | | | | | | | | | | | | | | | | | | | | Gets rid of basic duplication. | ||||
| * | | | | applet: Make virtual destructor defaulted | Lioncash | 2016-12-07 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | applet: Make constructor protected | Lioncash | 2016-12-07 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | Considering the class is abstract, there's no need to make the constructor public. | ||||
* | | | | | Update AM service function tables | Lioncash | 2016-12-08 | 6 | -113/+246 |
| |/ / / |/| | | | | | | | | | | | Updated based off information from 3dbrew. | ||||
* | | | | Merge pull request #2232 from wwylele/other-save | bunnei | 2016-12-07 | 11 | -80/+351 |
|\ \ \ \ | |/ / / |/| | | | FS: implement archives for other game save data | ||||
| * | | | FileSys: Implement OtherSaveData | wwylele | 2016-11-29 | 7 | -0/+214 |
| | | | | |||||
| * | | | FS: add missing MediaType | wwylele | 2016-11-29 | 1 | -1/+1 |
| | | | | |||||
| * | | | FileSys: abstract SD save data archive source | wwylele | 2016-11-29 | 6 | -79/+136 |
| | | | | |||||
* | | | | Implement Frame rate limiter (#2223) | emmauss | 2016-12-06 | 3 | -0/+35 |
| |/ / |/| | | | | | | | | | | | | | | * implement frame limiter * fixes | ||||
* | | | GSP: Downgrade log severity of SetAxiConfigQoSMode | Yuri Kunde Schlesner | 2016-12-04 | 1 | -1/+1 |
| |/ |/| | | | | | | | This function doesn't need to do anything for HLE and some games call it quite often, spamming up the logs. | ||||
* | | Set client SDK version to Service APIs | mailwl | 2016-11-30 | 7 | -13/+86 |
|/ | |||||
* | Merge pull request #2196 from Subv/system_mode | Yuri Kunde Schlesner | 2016-11-28 | 7 | -9/+35 |
|\ | | | | | Kernel/Loader: Grab the system mode from the NCCH ExHeader. | ||||
| * | Kernel/Loader: Grab the system mode from the NCCH ExHeader. | Subv | 2016-11-28 | 3 | -16/+17 |
| | | | | | | | | | | | | | | 3dsx and elf files default to system mode 2 (96MB allocated to the application). This allows Home Menu to boot without modifications. Closes #1849 | ||||
| * | Kernel/Loader: Grab the system mode from the NCCH ExHeader. | Subv | 2016-11-20 | 7 | -9/+34 |
| | | | | | | | | | | | | | | 3dsx and elf files default to system mode 2 (96MB allocated to the application). This allows Home Menu to boot without modifications. Closes #1849 | ||||
* | | Merge pull request #2222 from linkmauve/die-frameskip-die | Yuri Kunde Schlesner | 2016-11-28 | 3 | -22/+1 |
|\ \ | | | | | | | Remove the broken frame_skip option | ||||
| * | | GPU: Remove the broken frame_skip option. | Emmanuel Gil Peyrot | 2016-11-27 | 3 | -22/+1 |
| | | | | | | | | | | | | Fixes #1960. | ||||
* | | | Merge pull request #2132 from wwylele/fix-fs-err | Sebastian Valle | 2016-11-28 | 27 | -304/+1180 |
|\ \ \ | |/ / |/| | | Correct FS error codes & add path boundary checks | ||||
| * | | FileSys: rename SaveDataCheck archive to NCCH archive | wwylele | 2016-11-19 | 5 | -23/+22 |
| | | | | | | | | | | | | According to the observation from game and 3dbrew "Used for accessing general NCCH data" | ||||
| * | | FileSys: remove unused DiskArchive | wwylele | 2016-11-19 | 2 | -179/+0 |
| | | | | | | | | | | | | All "subclasses" of DiskArchive are splitted out. This class is useless | ||||
| * | | PTM & CFG: use the correct path and error code according to the new FileSys policy | wwylele | 2016-11-19 | 2 | -5/+6 |
| | | | |||||
| * | | FileSys: w->rw permission lift only happens in SDMC archive | wwylele | 2016-11-19 | 4 | -2/+14 |
| | | | |||||
| * | | FileSys: add SDMCWriteOnlyArchive | wwylele | 2016-11-19 | 6 | -0/+140 |
| | | | |||||
| * | | FileSys: add SDMCArchive | wwylele | 2016-11-19 | 3 | -1/+301 |
| | | | | | | | | | | | | Now DiskArchive only serves for SDMC, then it should be just a "SDMCArchive" | ||||
| * | | FileSys: add ExtSaveDataArchive | wwylele | 2016-11-19 | 2 | -1/+115 |
| | | | | | | | | | | | | ExtSaveData is more similar to SaveData, so let it be a subclass of SaveData | ||||
| * | | FileSys: add SaveDataArchive | wwylele | 2016-11-19 | 7 | -4/+368 |
| | | | | | | | | | | | | The error checking of SaveDataArchive is completely different from DiskArchive, so it has to be a new class instead of a subclass of DiskArchive. | ||||
| * | | FileSys: remove Open from FileBackend | wwylele | 2016-11-19 | 4 | -64/+44 |
| | | | | | | | | | | | | Same as directory, file shouldn't expose Open either. | ||||
| * | | FileSys: remove Open from DirectoryBackend | wwylele | 2016-11-19 | 4 | -25/+5 |
| | | | | | | | | | | | | Open should not be an interface exposed by Directory because it is the Archive thats implement the methed to open the directory. The service API of 3DS also implies this - Open is not a function of directory service, but is of FS main service | ||||
| * | | FileSys: add PathParser | wwylele | 2016-11-19 | 3 | -0/+161 |
| | | | |||||
| * | | FileSys: make Archive interfaces return error code | wwylele | 2016-11-01 | 6 | -87/+91 |
| | | | | | | | | | | | | and make the mode parameter a reference since it is a BitField union | ||||
* | | | Merge pull request #2168 from mailwl/mic | Sebastian Valle | 2016-11-27 | 2 | -16/+307 |
|\ \ \ | | | | | | | | | MIC_U: Stub service funcions | ||||
| * | | | Output parameters to log | mailwl | 2016-11-25 | 1 | -4/+6 |
| | | | | |||||
| * | | | MIC_U: Stub service funcions | mailwl | 2016-11-25 | 2 | -16/+305 |
| | | | | |||||
* | | | | dynarmic: Add ticks based on ticks executed, not ticks requested | MerryMage | 2016-11-26 | 1 | -2/+2 |
|/ / / | |||||
* | | | Expose page table to dynarmic for optimized reads and writes to the JIT | James Rowe | 2016-11-25 | 3 | -6/+18 |
| | | | |||||
* | | | Bravely Default/Second stuck #1822 (#2188) | pippo2931 | 2016-11-24 | 4 | -2/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Bravely Default/Second stuck #1822 CancelLibraryApplet stub * Log parameter. * Taking care of comments * Sync with 3DBrew * White space ? * lower case | ||||
* | | | Merge pull request #2186 from wwylele/config9 | Yuri Kunde Schlesner | 2016-11-24 | 1 | -2/+8 |
|\ \ \ | | | | | | | | | cfg: add config block 0x00090000 | ||||
| * | | | cfg: add config block 0x00090000 | wwylele | 2016-11-17 | 1 | -2/+8 |
| | | | | |||||
* | | | | Merge pull request #1654 from JamePeng/errdisp | Yuri Kunde Schlesner | 2016-11-24 | 1 | -118/+198 |
|\ \ \ \ | | | | | | | | | | | Rework the code of err:f service! | ||||
| * | | | | Rework the code of err:f service | JamePeng | 2016-10-06 | 1 | -118/+198 |
| | | | | | |||||
* | | | | | Merge pull request #2193 from Subv/pulse_events | bunnei | 2016-11-20 | 2 | -0/+10 |
|\ \ \ \ \ | | | | | | | | | | | | | Kernel/Events: Log an error when trying to create Pulse events and timers | ||||
| * | | | | | Kernel/Events: Log an error when trying to create Pulse events and timers. | Subv | 2016-11-19 | 2 | -0/+10 |
| | |_|_|/ | |/| | | | | | | | | | | | | | Related to #1904 | ||||
* / | | | | APT/Applets: Renamed the members of the SignalType enum. | Subv | 2016-11-19 | 5 | -16/+27 |
|/ / / / | | | | | | | | | | | | | Names now make sense and match 3dbrew. | ||||
* | | | | Merge pull request #2172 from jroweboy/fix-mingw | bunnei | 2016-11-16 | 1 | -1/+1 |
|\ \ \ \ | | | | | | | | | | | Fix mingw compilation support | ||||
| * | | | | Add mingw compile support | James Rowe | 2016-11-14 | 1 | -1/+1 |
| | |/ / | |/| | | |||||
* / | | | Support additional screen layouts. | James Rowe | 2016-11-05 | 2 | -0/+18 |
|/ / / | | | | | | | | | | | | | Allows users to choose a single screen layout or a large screen layout. Adds a configuration option to change the prominent screen. | ||||
* | | | Style fix | mailwl | 2016-11-02 | 1 | -2/+2 |
| | | | |||||
* | | | Rename AcConfig, change types u8 to u32 | mailwl | 2016-11-02 | 1 | -21/+25 |
| | | | |||||
* | | | AC_U: Stub functions, used if EULA agreed | mailwl | 2016-11-02 | 2 | -14/+190 |
| |/ |/| | |||||
* | | Merge pull request #2126 from wwylele/stub-nwm | bunnei | 2016-10-31 | 1 | -0/+11 |
|\ \ | | | | | | | NWM: stub Initialize with an error | ||||
| * | | NWM: stub Initialize with an error | wwylele | 2016-10-12 | 1 | -0/+11 |
| |/ | |||||
* | | Merge pull request #2123 from jbeich/freebsd | bunnei | 2016-10-31 | 1 | -0/+8 |
|\ \ | | | | | | | Fix build on DragonFly and FreeBSD | ||||
| * | | core: some errno values are uncommon on Unix | Jan Beich | 2016-10-28 | 1 | -0/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | src/core/hle/service/soc_u.cpp:107:6: error: 'ENODATA' was not declared in this scope {ENODATA, 43}, ^ src/core/hle/service/soc_u.cpp:117:6: error: 'ENOSR' was not declared in this scope {ENOSR, 53}, ^ src/core/hle/service/soc_u.cpp:118:6: error: 'ENOSTR' was not declared in this scope {ENOSTR, 54}, ^ src/core/hle/service/soc_u.cpp:139:6: error: 'ETIME' was not declared in this scope {ETIME, 75}, ^ | ||||
* | | | Small fix to let IDA see target.xml | mailwl | 2016-10-28 | 1 | -1/+1 |
|/ / | |||||
* | | FRD: fix GetMyFriendKey | mailwl | 2016-10-25 | 1 | -1/+1 |
| | | |||||
* | | Fix typos | Ricardo de Almeida Gonzaga | 2016-10-20 | 5 | -5/+5 |
| | | |||||
* | | Merge pull request #2024 from JamePeng/update-boss-code | bunnei | 2016-10-08 | 3 | -4/+1808 |
|\ \ | |/ |/| | Update the stub code of BOSS | ||||
| * | Update the stub code of BOSS | JamePeng | 2016-10-02 | 3 | -4/+1808 |
| | | |||||
* | | Merge pull request #1652 from wwylele/kernal-tool | bunnei | 2016-10-05 | 7 | -7/+26 |
|\ \ | | | | | | | Debugger: implement wait tree widget | ||||
| * | | move ResetType to kernel.h | wwylele | 2016-09-22 | 3 | -7/+6 |
| | | | |||||
| * | | name objects | wwylele | 2016-09-22 | 1 | -0/+4 |
| | | | |||||
| * | | implement wait tree widget | wwylele | 2016-09-22 | 4 | -0/+16 |
| |/ | |||||
* | | Merge pull request #2106 from wwylele/delete-recursive | bunnei | 2016-10-04 | 8 | -22/+93 |
|\ \ | | | | | | | FS: implement DeleteDirectoryRecursively | ||||
| * | | fs: clean up log format | wwylele | 2016-10-02 | 1 | -22/+24 |
| | | | |||||
| * | | fs: implement DeleteDirectoryRecursively | wwylele | 2016-10-02 | 8 | -1/+70 |
| |/ | |||||
* | | gpu: DisplayTransfer: a less amazing algorithm for flip | wwylele | 2016-09-29 | 1 | -8/+11 |
| | | | | | | | | the old implementation modifies the loop variable in the loop. Though it actually works, it is really confusing. Makes it morereadable now. | ||||
* | | gpu: keep the old signal strategy for null pointer | wwylele | 2016-09-29 | 1 | -4/+8 |
| | | | | | | | | | | previous commits changes the behaviour of interrupt when meeting invalid params. Regresses to the same behaviour as before needs more hwtest | ||||
* | | gpu: add validity check for TextureCopy, DisplayTransfer and FillMemory | wwylele | 2016-09-29 | 1 | -6/+88 |
| | | | | | | | | | | prevent further operation with invalid values which may cause assertion failure or divided by zero. needs more hwtest | ||||
* | | memory: fix IsValidVirtualAddress for RasterizerCachedMemory | wwylele | 2016-09-29 | 1 | -0/+3 |
| | | | | | | | | RasterizerCachedMemory doesn't has pointer but should be considered as valid | ||||
* | | gpu: move MemoryFill, TextureCopy and DisplayTransfer into functions | wwylele | 2016-09-29 | 1 | -247/+249 |
|/ | | | | The old code indented too much to read. Split into functions and do general cleanup. | ||||
* | Remove special rules for Windows.h and library includes | Yuri Kunde Schlesner | 2016-09-21 | 1 | -1/+1 |
| | |||||
* | Use negative priorities to avoid special-casing the self-include | Yuri Kunde Schlesner | 2016-09-21 | 106 | -106/+106 |
| | |||||
* | Remove empty newlines in #include blocks. | Emmanuel Gil Peyrot | 2016-09-21 | 146 | -369/+117 |
| | | | | | | | This makes clang-format useful on those. Also add a bunch of forgotten transitive includes, which otherwise prevented compilation. | ||||
* | Manually tweak source formatting and then re-run clang-format | Yuri Kunde Schlesner | 2016-09-19 | 95 | -451/+467 |
| | |||||
* | Sources: Run clang-format on everything. | Emmanuel Gil Peyrot | 2016-09-18 | 208 | -10514/+10705 |
| | |||||
* | Dyncom: Disable clang-format on the decoding table. | Emmanuel Gil Peyrot | 2016-09-18 | 1 | -0/+3 |
| | |||||
* | arm_dynarmic: Implement GetVFPSystemReg/SetVFPSystemReg. | bunnei | 2016-09-15 | 1 | -5/+12 |
| | |||||
* | arm: ResetContext shouldn't be part of ARM_Interface. | bunnei | 2016-09-15 | 6 | -30/+17 |
| | |||||
* | arm_dynarmic/arm_dyncom: Remove unnecessary "virtual" keyword. | bunnei | 2016-09-15 | 2 | -2/+2 |
| | |||||
* | dyncom: Use VFP_FPSCR/VFP_FPEXC. | bunnei | 2016-09-15 | 1 | -4/+4 |
| | |||||
* | core: Add configuration option for CPU JIT. | bunnei | 2016-09-15 | 2 | -7/+13 |
| | |||||
* | dynarmic: Implement ARM CPU interface. | bunnei | 2016-09-15 | 3 | -0/+233 |
| | |||||
* | Merge pull request #2032 from bunnei/qt-graphics | bunnei | 2016-09-01 | 3 | -0/+12 |
|\ | | | | | Qt graphics configure & V-Sync option | ||||
| * | system: Add a function to see if the emulator is running. | bunnei | 2016-08-30 | 2 | -0/+11 |
| | | |||||
| * | config: Add a setting for graphics V-Sync. | bunnei | 2016-08-30 | 1 | -0/+1 |
| | | |||||
* | | configure_audio: User-configuratble option to enable/disable audio stretching | MerryMage | 2016-08-31 | 2 | -0/+2 |
| | | |||||
* | | Merge pull request #2023 from yuriks/autobase-bcfnt | bunnei | 2016-08-30 | 3 | -30/+68 |
|\ \ | |/ |/| | Auto-detect original shared_font.bin memory base | ||||
| * | Auto-detect original shared_font.bin memory base | Yuri Kunde Schlesner | 2016-08-27 | 3 | -30/+68 |
| | | | | | | | | | | This allows a file dumped from either an o3DS or a n3DS (and potentially even an original unrebased file) to be used. | ||||
* | | Merge pull request #1948 from wwylele/cro++ | Yuri Kunde Schlesner | 2016-08-29 | 14 | -99/+3041 |
|\ \ | | | | | | | Implemented CRO | ||||
| * | | LDR: Implement CRO | wwylele | 2016-08-27 | 9 | -99/+3013 |
| | | | |||||
| * | | ARM: add ClearInstructionCache function | wwylele | 2016-08-27 | 3 | -0/+11 |
| | | | |||||
| * | | Memory: add ReadCString function | wwylele | 2016-08-27 | 2 | -0/+17 |
| |/ | |||||
* | | Merge pull request #1987 from Lectem/ipcdescriptors | Yuri Kunde Schlesner | 2016-08-27 | 5 | -22/+110 |
|\ \ | |/ |/| | fix #1942 and add a few IPC functions for descriptors | ||||
| * | fix #1942 and adds a few IPC functions for descriptors | Lectem | 2016-08-02 | 5 | -22/+110 |
| | | |||||
* | | dyncom: Read-after-write in SMLA | MerryMage | 2016-08-22 | 1 | -2/+4 |
| | | | | | | | | | | In the case when RD === RN, RD was updated before AddOverflow was called to check for an overflow, resulting in an incorrect state of the Q flag. | ||||
* | | Dyncom: Correct implementation of STM for R15 | MerryMage | 2016-08-14 | 1 | -3/+4 |
|/ | |||||
* | Merge pull request #1950 from JamePeng/fix-apt-0x0055004-and-0x00560000 | bunnei | 2016-07-29 | 5 | -22/+31 |
|\ | | | | | Correct APT::0x00550040 and APT::0x00560000 function | ||||
| * | Correct APT::0x00550040 and APT::0x00560000 function | JamePeng | 2016-07-15 | 5 | -22/+31 |
| | | |||||
* | | Instead of segfaulting, log an error to remind the user to dump the shared font file | Henrik Rydgard | 2016-07-28 | 1 | -0/+7 |
| | | |||||
* | | Merge pull request #1959 from MerryMage/revsh-upstream | bunnei | 2016-07-28 | 1 | -4/+13 |
|\ \ | | | | | | | dyncom: Fix translation of thumb REVSH | ||||
| * | | dyncom: Fix translation of thumb REVSH | MerryMage | 2016-07-28 | 1 | -4/+13 |
| | | | |||||
* | | | CoreTiming: avoid overflow | wwylele | 2016-07-23 | 1 | -1/+1 |
| | | | |||||
* | | | HLE: implement system time | wwylele | 2016-07-23 | 2 | -2/+60 |
| |/ |/| | |||||
* | | Merge pull request #1894 from wwylele/set-config-block | Yuri Kunde Schlesner | 2016-07-10 | 6 | -37/+253 |
|\ \ | | | | | | | Implement config savegame editing & clean up | ||||
| * | | Service::CFG/FS: add and refactor out utilities for front-end | wwylele | 2016-07-03 | 4 | -15/+146 |
| | | | |||||
| * | | Service::CFG: move known block ID to an enum | wwylele | 2016-07-03 | 1 | -11/+25 |
| | | | |||||
| * | | Service::CFG: add SetConfigInfoBlk4 | wwylele | 2016-07-03 | 4 | -8/+73 |
| | | | |||||
| * | | Service::CFG: add missing language | wwylele | 2016-07-02 | 1 | -1/+2 |
| | | | |||||
| * | | Service::CFG: name sound output modes | wwylele | 2016-07-02 | 2 | -2/+7 |
| |/ | |||||
* | | Merge pull request #1940 from JamePeng/fix-archive-error-code | bunnei | 2016-07-07 | 2 | -10/+15 |
|\ \ | | | | | | | Fix the errorcode of archive handle | ||||
| * | | Fix the errorcode of archive handle | JamePeng | 2016-07-04 | 2 | -10/+15 |
| | | | |||||
* | | | Merge pull request #1921 from Subv/fs_funcs | Sebastian Valle | 2016-07-05 | 1 | -11/+42 |
|\ \ \ | | | | | | | | | HLE/FS: Document some command parameters and implemented command 0x08560240 | ||||
| * | | | HLE/FS: Document some command parameters and implemented command 0x08560240 (CreateLegacySystemSaveData) | Subv | 2016-07-03 | 1 | -11/+42 |
| | | | | |||||
* | | | | HLE/Applets: Implement ErrEula applet | mailwl | 2016-07-04 | 5 | -0/+118 |
| |/ / |/| | | |||||
* | | | Result: fix and update ErrorModule | wwylele | 2016-06-30 | 1 | -6/+19 |
| |/ |/| | |||||
* | | Merge pull request #1869 from wwylele/dont-be-lazy | Yuri Kunde Schlesner | 2016-06-29 | 1 | -2/+6 |
|\ \ | | | | | | | Switch context to the same thread if necessary | ||||
| * | | Switch context on the same thread if necessary | wwylele | 2016-05-30 | 1 | -2/+6 |
| | | | |||||
* | | | Merge pull request #1867 from mailwl/srv-update | bunnei | 2016-06-29 | 2 | -15/+125 |
|\ \ \ | | | | | | | | | srv: Update according 3dbrew | ||||
| * | | | Fix parameter name in EnableNotification | mailwl | 2016-05-31 | 2 | -2/+6 |
| | | | | |||||
| * | | | Fix mistakes, add output header codes | mailwl | 2016-05-31 | 1 | -8/+24 |
| | | | | |||||
| * | | | remove ugly function | mailwl | 2016-05-31 | 1 | -35/+3 |
| | | | | |||||
| * | | | srv: Update according 3dbrew | mailwl | 2016-05-31 | 1 | -15/+137 |
| |/ / | |||||
* | | | Merge pull request #1877 from wwylele/wait-fix-timeout | bunnei | 2016-06-18 | 1 | -0/+49 |
|\ \ \ | | | | | | | | | Thread: update timeout when reruning WaitSynch | ||||
| * | | | Thread: update timeout when rerunning WaitSynch | wwylele | 2016-06-04 | 1 | -0/+49 |
| |/ / | |||||
* | | | Merge pull request #1898 from archshift/interpreter-split-take2 | bunnei | 2016-06-16 | 5 | -2727/+2729 |
|\ \ \ | |_|/ |/| | | Refactor arm_dyncom_interpreter into several files (take 2) | ||||
| * | | Make arm_dyncom_trans* into a fully fledged compilation unit | archshift | 2016-06-12 | 4 | -53/+73 |
| | | | |||||
| * | | arm_dyncom_interpreter: slightly change AllocBuffer to be intuitive | archshift | 2016-06-12 | 1 | -15/+15 |
| | | | |||||
| * | | arm_dyncom_interpreter: Add specialized GetAddressingOpLoadStoreT func | archshift | 2016-06-11 | 2 | -39/+19 |
| | | | | | | | | | | | | | | | | | | This allows us to get the addressing operation for STRT, LDRT, STRBT, and LDRBT. We do this so that translation functions don't need to see the addressing ops directly. | ||||
| * | | arm_dyncom_interpreter: rename operation functions to fit style guide | archshift | 2016-06-11 | 2 | -34/+34 |
| | | | |||||
| * | | arm_dyncom_interpreter: Rename anonymous enum to TransExtData | archshift | 2016-06-11 | 4 | -166/+164 |
| | | | |||||
| * | | arm_dyncom_interpreter.cpp: #include translation info from inc files | archshift | 2016-06-11 | 3 | -2648/+2652 |
| | | | |||||
* | | | Merge pull request #1842 from Subv/ports | bunnei | 2016-06-12 | 8 | -3/+178 |
|\ \ \ | | | | | | | | | Kernel: Added ClientPort and ServerPort classes, along with svcCreatePort. | ||||
| * | | | Kernel/SVC: Implemented svcCreatePort. | Subv | 2016-06-11 | 6 | -3/+41 |
| | | | | |||||
| * | | | Kernel: Added ClientPort and ServerPort classes. | Subv | 2016-06-05 | 6 | -2/+139 |
| | | | | | | | | | | | | | | | | This is part of an ongoing effort to implement support for multiple processes. | ||||
* | | | | hid: add missing header | wwylele | 2016-06-11 | 1 | -0/+2 |
| | | | | |||||
* | | | | Merge pull request #1789 from wwylele/input-refactor | bunnei | 2016-06-11 | 3 | -40/+53 |
|\ \ \ \ | | | | | | | | | | | Refactor input mapping & implement circle pad modifier | ||||
| * | | | | fixup! fixup! Refactor input system | wwylele | 2016-05-15 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | implement circle pad modifier | wwylele | 2016-05-15 | 1 | -1/+5 |
| | | | | | |||||
| * | | | | Refactor input subsystem | wwylele | 2016-05-15 | 3 | -40/+49 |
| | | | | | |||||
* | | | | | Revert "Split huge interpreter source file into translation info and interpreter (+ some tiny misc style fixes)" | archshift | 2016-06-11 | 5 | -2731/+2727 |
| | | | | | |||||
* | | | | | arm_dyncom_interpreter: rename operation functions to fit style guide | archshift | 2016-06-09 | 2 | -42/+42 |
| | | | | | |||||
* | | | | | arm_dyncom_interpreter.cpp: Split by translation and interpreter logic | archshift | 2016-06-09 | 5 | -2727/+2731 |
| |_|/ / |/| | | | | | | | | | | | | | | | To facilitate the split, some small changes were made to names of various structures and functions. | ||||
* | | | | gdbstub: E0 should be E00 | shinyquagsire23 | 2016-06-08 | 1 | -1/+1 |
| | | | | |||||
* | | | | service: Add other DLP services | Lioncash | 2016-06-05 | 10 | -23/+150 |
| |/ / |/| | | | | | | | | | | | | | | Specifically, dlp::CLNT and dlp::FKCL Moves them to their own folder like with other services. | ||||
* | | | gsp::gpu: Reset g_thread_id in UnregisterInterruptRelayQueue | mailwl | 2016-06-01 | 2 | -15/+22 |
| |/ |/| | |||||
* | | Merge pull request #1692 from Subv/rm_getpointer2 | bunnei | 2016-05-30 | 17 | -138/+454 |
|\ \ | | | | | | | Memory: Remove most usages of GetPointer | ||||
| * | | Memory: Handle RasterizerCachedMemory and RasterizerCachedSpecial page types in the memory block manipulation functions. | Subv | 2016-05-28 | 2 | -2/+60 |
| | | | |||||
| * | | Memory: Make ReadBlock and WriteBlock accept void pointers. | Subv | 2016-05-28 | 5 | -21/+19 |
| | | | |||||
| * | | SOC_U: Remove usage of GetPointer | Subv | 2016-05-28 | 1 | -27/+73 |
| | | | |||||
| * | | SSL_C: Remove use of Memory::GetPointer | MerryMage | 2016-05-28 | 1 | -4/+3 |
| | | | |||||
| * | | GSP_GPU: Remove use of Memory::GetPointer | MerryMage | 2016-05-28 | 1 | -33/+50 |
| | | | |||||
| * | | Memory: CopyBlock | MerryMage | 2016-05-28 | 2 | -2/+43 |
| | | | |||||
| * | | DSP_DSP: Remove use of Memory::GetPointer | MerryMage | 2016-05-28 | 1 | -7/+10 |
| | | | |||||
| * | | FS/Archive: Remove use of Memory::GetPointer | MerryMage | 2016-05-28 | 1 | -7/+14 |
| | | | |||||
| * | | CFG: Remove use of Memory::GetPointer | MerryMage | 2016-05-21 | 1 | -6/+10 |
| | | | |||||
| * | | APT: Remove use of Memory::GetPointer | MerryMage | 2016-05-21 | 5 | -35/+36 |
| | | | |||||
| * | | Kernel/Thread: Remove use of Memory::GetPointer | MerryMage | 2016-05-21 | 1 | -1/+1 |
| | | | |||||
| * | | Applets/swkdb: Remove use of Memory::GetPointer | MerryMage | 2016-05-21 | 1 | -1/+1 |
| | | | |||||
| * | | Memory: ZeroBlock | MerryMage | 2016-05-21 | 2 | -0/+39 |
| | | | |||||
| * | | FileSys/Path: Replace Memory::GetPointer with Memory::ReadBlock | MerryMage | 2016-05-21 | 1 | -6/+6 |
| | | | |||||
| * | | Memory: ReadBlock/WriteBlock | MerryMage | 2016-05-21 | 3 | -4/+81 |
| | | | |||||
| * | | Memory: IsValidVirtualAddress/IsValidPhysicalAddress | MerryMage | 2016-05-21 | 3 | -0/+26 |
| | | | |||||
* | | | Merge pull request #1756 from wwylele/config-cleanup | bunnei | 2016-05-29 | 1 | -29/+13 |
|\ \ \ | | | | | | | | | Config block: clean up | ||||
| * | | | clean up config block | wwylele | 2016-05-03 | 1 | -29/+13 |
| | | | | |||||
* | | | | Merge pull request #1568 from JayFoxRox/fix-printf | Mat M | 2016-05-27 | 3 | -26/+61 |
|\ \ \ \ | | | | | | | | | | | Fix ftoi and disable VFPv3 | ||||
| * | | | | Fix ftoi behaviour | Jannik Vogel | 2016-05-16 | 2 | -22/+53 |
| | | | | | |||||
| * | | | | Respect fpscr in ftoiz | Jannik Vogel | 2016-05-16 | 2 | -4/+4 |
| | | | | | |||||
| * | | | | Disable VFP3 instructions | Jannik Vogel | 2016-05-16 | 1 | -0/+4 |
| | | | | | |||||
* | | | | | Merge pull request #1810 from JayFoxRox/fix-float-exceptions | bunnei | 2016-05-27 | 3 | -91/+130 |
|\ \ \ \ \ | | | | | | | | | | | | | Fix float exceptions | ||||
| * | | | | | Remove `exceptions` parameter from `normaliseround` VFP functions | Jannik Vogel | 2016-05-18 | 3 | -28/+57 |
| | | | | | | |||||
| * | | | | | Fix exception propagation for VFP single precision | Jannik Vogel | 2016-05-18 | 2 | -33/+38 |
| | | | | | | |||||
| * | | | | | Fix exception propagation for VFP double precision | Jannik Vogel | 2016-05-18 | 2 | -34/+39 |
| | |_|/ / | |/| | | | |||||
* | | | | | Merge pull request #1855 from MerryMage/memory-headers-20160526 | Mat M | 2016-05-26 | 2 | -1/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | Memory: Added necessary headers and removed unnecessary header | ||||
| * | | | | | Memory: Added necessary headers and removed unnecessary header | MerryMage | 2016-05-26 | 2 | -1/+2 |
| |/ / / / | |||||
* | | | | | Merge pull request #1817 from linkmauve/smdh-stuff | bunnei | 2016-05-25 | 10 | -105/+198 |
|\ \ \ \ \ | | | | | | | | | | | | | Improve SMDH support in loaders and frontends | ||||
| * | | | | | Loader: Split SMDH into its own header and import helpers from QGameList | Emmanuel Gil Peyrot | 2016-05-21 | 4 | -47/+138 |
| | | | | | | | | | | | | | | | | | | | | | | | | Also rewrite Qt wrappers to use those. | ||||
| * | | | | | CitraQt: Simplify the game list loader code | Emmanuel Gil Peyrot | 2016-05-21 | 2 | -14/+12 |
| | | | | | | |||||
| * | | | | | Loader: Add a GetFileType method to get the type of a loaded file | Emmanuel Gil Peyrot | 2016-05-21 | 4 | -0/+30 |
| | | | | | | |||||
| * | | | | | Loader, Frontends: Refactor loader creation and game loading | Emmanuel Gil Peyrot | 2016-05-21 | 4 | -47/+21 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | This allows frontends to keep a single loader and use it multiple times e.g. for code loading and SMDH parsing. | ||||
* | | | | | New3DS: Minor style cleanup to #1520. | bunnei | 2016-05-24 | 2 | -3/+3 |
| | | | | | |||||
* | | | | | Merge pull request #1520 from JamePeng/checknew3ds | bunnei | 2016-05-24 | 9 | -10/+138 |
|\ \ \ \ \ | | | | | | | | | | | | | Implement CheckNew3DS and CheckNew3DSApp | ||||
| * | | | | | Implement CheckNew3DS and CheckNew3DSApp | JamePeng | 2016-04-20 | 9 | -10/+138 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Append an item[is_new3ds] to config file[System] group Implement APT::SetNSStateField,it will update the unknown NS_state_field | ||||
* | | | | | | SVC::WaitSynchronizationN: Reschedule at the end | wwylele | 2016-05-21 | 1 | -2/+3 |
| |/ / / / |/| | | | | |||||
* | | | | | Fix read-after-write in SMUAD, SMLAD, SMUSD, SMLSD | Jannik Vogel | 2016-05-18 | 1 | -4/+8 |
| | | | | | |||||
* | | | | | Update ACT:U and create ACT:A (#1809) | András Domonkos | 2016-05-18 | 5 | -0/+56 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Update ACT_U * Create act_a.h * Create act_a.cpp * Add service ACT:A * Add ACT:A source and header * Fix wrong header | ||||
* | | | | | Merge pull request #1800 from JayFoxRox/set-fpscr | bunnei | 2016-05-18 | 3 | -0/+6 |
|\ \ \ \ \ | |_|/ / / |/| | | | | Set fpscr for new threads | ||||
| * | | | | Set fpscr for new threads | Jannik Vogel | 2016-05-17 | 3 | -0/+6 |
| | | | | | |||||
* | | | | | DSP_DSP: Remove GetHeadphoneStatus logspam (#1799) | Maribel | 2016-05-16 | 1 | -2/+2 |
| |_|_|/ |/| | | | |||||
* | | | | Memory: Fixed a regression caused by #1695 and #1689. | Subv | 2016-05-14 | 1 | -0/+3 |
|/ / / | | | | | | | | | | | | | | | | Reserve enough space in the vector that holds the linear heap memory to prevent relocations of the backing memory when growing too much. Closes #1790 | ||||
* | | | Merge pull request #1689 from Subv/shmem | bunnei | 2016-05-13 | 18 | -128/+417 |
|\ \ \ | | | | | | | | | Kernel: Implemented shared memory. | ||||
| * | | | HLE/Applets: Give each applet its own block of heap memory, and use that when creating the framebuffer shared memory block. | Subv | 2016-05-13 | 5 | -5/+44 |
| | | | | |||||
| * | | | Kernel: Account for automatically-allocated shared memories in the amount of used linear heap memory. | Subv | 2016-05-13 | 1 | -0/+5 |
| | | | | |||||
| * | | | APT: Move the shared font loading and relocation functions to their own subdirectory services/apt/bcfnt. | Subv | 2016-05-13 | 4 | -66/+167 |
| | | | | |||||
| * | | | Kernel/SharedMemory: Log an error when Map fails. | Subv | 2016-05-13 | 1 | -1/+10 |
| | | | | |||||
| * | | | Kernel: Implemented shared memory permissions. | Subv | 2016-05-13 | 4 | -9/+50 |
| | | | | |||||
| * | | | APT: Implement relocating the shared font to its true address. | Subv | 2016-05-13 | 1 | -9/+74 |
| | | | | |||||
| * | | | Kernel/Memory: Remove the Shared Memory region from the legacy memory map. | Subv | 2016-05-13 | 1 | -1/+0 |
| | | | | |||||
| * | | | Kernel/SharedMemory: Properly implemented shared memory support. | Subv | 2016-05-13 | 10 | -118/+147 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Applications can request the kernel to allocate a piece of the linear heap for them when creating a shared memory object. Shared memory areas are now properly mapped into the target processes when calling svcMapMemoryBlock. Removed the APT Shared Font hack as it is no longer needed. | ||||
| * | | | Kernel/SVC: Fixed the register order for svcCreateMemoryBlock. | Subv | 2016-05-13 | 2 | -2/+3 |
| | | | | | | | | | | | | | | | | R0 is used as the last parameter instead of R4. | ||||
* | | | | Merge pull request #1695 from Subv/tls_alloc | bunnei | 2016-05-13 | 5 | -28/+74 |
|\ \ \ \ | | | | | | | | | | | Kernel/Threads: Dynamically allocate the TLS region for threads. | ||||
| * | | | | Kernel/Threads: Dynamically allocate the TLS region for threads in the BASE region of the linear heap. | Subv | 2016-05-07 | 5 | -28/+74 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Each thread gets a 0x200-byte area from the 0x1000-sized page, when all 8 thread slots in a single page are used up, the kernel allocates a new page to hold another 8 entries. This is consistent with what the real kernel does. | ||||
* | | | | | gdbstub: Silence missing prototype warnings | Lioncash | 2016-05-10 | 1 | -3/+3 |
| | | | | | |||||
* | | | | | dyncom: Reset the context into user mode correctly | Lioncash | 2016-05-09 | 1 | -1/+1 |
| |/ / / |/| | | | | | | | | | | | The other mode was system mode. | ||||
* | | | | Merge pull request #1766 from Subv/log_cpu | bunnei | 2016-05-08 | 3 | -0/+10 |
|\ \ \ \ | | | | | | | | | | | Kernel/Threading: Warn when a thread can be scheduled in the Syscore (Core 1) | ||||
| * | | | | Kernel/Threading: Warn when a thread can be scheduled in the Syscore (Core 1). | Subv | 2016-05-07 | 3 | -0/+10 |
| |/ / / | | | | | | | | | | | | | We do not currently implement any cores other than the AppCore (Core 0). | ||||
* | | | | Merge pull request #1718 from alex-laties/fixup-type-conversions | bunnei | 2016-05-07 | 5 | -29/+29 |
|\ \ \ \ | | | | | | | | | | | fixup simple type conversions where possible | ||||
| * | | | | fixup simple type conversions where possible | Alexander Laties | 2016-05-07 | 5 | -29/+29 |
| | | | | | |||||
* | | | | | Merge pull request #1761 from Subv/applets_fb | bunnei | 2016-05-07 | 5 | -23/+44 |
|\ \ \ \ \ | |/ / / / |/| | | | | HLE/Applets: Use the correct size for the framebuffer SharedMemory | ||||
| * | | | | HLE/Applets: Use the correct size for the framebuffer SharedMemory in the swkbd and MiiSelector applets. | Subv | 2016-05-07 | 5 | -23/+44 |
| | |_|/ | |/| | | |||||
* | | | | fix:return proper error | wwylele | 2016-05-06 | 1 | -2/+3 |
| | | | | |||||
* | | | | Merge pull request #1762 from bunnei/global | bunnei | 2016-05-06 | 4 | -8/+21 |
|\ \ \ \ | | | | | | | | | | | hle: Get rid of direct global access to g_reschedule | ||||
| * | | | | HLE: Rename RescheduleIsPending to IsReschedulePending. | bunnei | 2016-05-06 | 3 | -3/+3 |
| | | | | | |||||
| * | | | | hle: Get rid of global access to g_reschedule | Lioncash | 2016-03-21 | 4 | -8/+21 |
| | | | | | | | | | | | | | | | | | | | | | | | | | This shouldn't be directly exposed if there's already a partial API that operates on it. We can just provide the rest of that API. | ||||
* | | | | | Merge pull request #1700 from wwylele/gamelist-icon | bunnei | 2016-05-06 | 6 | -23/+149 |
|\ \ \ \ \ | | | | | | | | | | | | | Qt: display game icon and title in the game list | ||||
| * | | | | | add icon & title to game list | wwylele | 2016-05-04 | 6 | -23/+149 |
| | | | | | | |||||
* | | | | | | Layout Mii parameters input/output, and return success as result of applet work | mailwl | 2016-05-05 | 2 | -0/+49 |
| |_|/ / / |/| | | | | |||||
* | | | | | Merge pull request #1732 from wwylele/config00170000 | bunnei | 2016-05-03 | 2 | -13/+4 |
|\ \ \ \ \ | | | | | | | | | | | | | add config block 0x00170000; remove duplicated content | ||||
| * | | | | | remove duplicated function declaration | wwylele | 2016-05-01 | 1 | -13/+0 |
| | | | | | | |||||
| * | | | | | add config block 0x00170000 | wwylele | 2016-04-29 | 1 | -0/+4 |
| |/ / / / | |||||
* | | | | | VideoCore: Run include-what-you-use and fix most includes. | Emmanuel Gil Peyrot | 2016-04-30 | 4 | -2/+4 |
| | | | | | |||||
* | | | | | LCD: Remove unneeded #undef with no matching #define. | Emmanuel Gil Peyrot | 2016-04-30 | 1 | -2/+0 |
| | | | | | |||||
* | | | | | Merge pull request #1729 from MerryMage/null-sink | bunnei | 2016-04-30 | 2 | -0/+8 |
|\ \ \ \ \ | | | | | | | | | | | | | Audio Config: Implement null sink and implement sink configuration | ||||
| * | | | | | Audio: Add sink selection to configuration files | MerryMage | 2016-04-30 | 2 | -0/+8 |
| |/ / / / | |||||
* | | | | | Merge pull request #1650 from JamePeng/update-the-ndm-code | bunnei | 2016-04-30 | 3 | -27/+420 |
|\ \ \ \ \ | | | | | | | | | | | | | Update the stub code of NDM service! | ||||
| * | | | | | Update the stub code of NDM service! | JamePeng | 2016-04-20 | 3 | -27/+420 |
| | | | | | | |||||
* | | | | | | Merge pull request #1647 from mailwl/acu-closeasync | bunnei | 2016-04-30 | 2 | -1/+29 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | ac:u: stub CloseAsync; align memory size in svc:GetProcessInfo(type=2) | ||||
| * | | | | | | ac:u: stub CloseAsync; check memory size aling in svc:GetProcessInfo(type=2) | mailwl | 2016-04-21 | 2 | -1/+29 |
| |/ / / / / | |||||
* | | | | | | Merge pull request #1699 from mailwl/gpu-rights | bunnei | 2016-04-30 | 1 | -2/+38 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | gsp::Gpu: implement AcquireRight, ReleaseRight functions | ||||
| * | | | | | return checks if event and memory created | mailwl | 2016-04-23 | 1 | -1/+8 |
| | | | | | | |||||
| * | | | | | gsp::Gpu: implement AcquireRight, ReleaseRight functions | mailwl | 2016-04-22 | 1 | -8/+37 |
| | | | | | | |||||
* | | | | | | Common: Remove section measurement from profiler (#1731) | Yuri Kunde Schlesner | 2016-04-29 | 3 | -12/+0 |
| | | | | | | | | | | | | | | | | | | | | | | | | This has been entirely superseded by MicroProfile. The rest of the code can go when a simpler frametime/FPS meter is added to the GUI. | ||||
* | | | | | | Merge pull request #1708 from MerryMage/dsp_dsp | bunnei | 2016-04-27 | 3 | -59/+152 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | DSP Service: Cleanup | ||||
| * | | | | | | DSP_DSP: Fix log format strings and arguments | MerryMage | 2016-04-27 | 1 | -12/+20 |
| | | | | | | | |||||
| * | | | | | | DSP_DSP: Add return IPC headers | MerryMage | 2016-04-27 | 2 | -4/+27 |
| | | | | | | | |||||
| * | | | | | | DSP_DSP: Updated interrupt implementation | MerryMage | 2016-04-27 | 2 | -42/+106 |
| | | | | | | | |||||
| * | | | | | | DSP_DSP: Remove unused variable | MerryMage | 2016-04-24 | 1 | -2/+0 |
| | | | | | | | |||||
* | | | | | | | y2r_u: Cleanup some formatting. | bunnei | 2016-04-27 | 1 | -52/+89 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #1447 from JamePeng/update-y2r-service | bunnei | 2016-04-27 | 2 | -32/+357 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Update the code of service y2r! | ||||
| * | | | | | | | Update the code of service y2r! | JamePeng | 2016-04-20 | 2 | -32/+357 |
| | |_|/ / / / | |/| | | | | | |||||
* | | | | | | | am: title_id is long long uint | Sam Spilsbury | 2016-04-24 | 1 | -1/+1 |
| |/ / / / / |/| | | | | | |||||
* | | | | | | ncch: Use correct format specifier (for long long uint) | Sam Spilsbury | 2016-04-23 | 1 | -1/+1 |
| | | | | | | |||||
* | | | | | | fs: Fix what appears to be a typo (filename_size / file_size) | Sam Spilsbury | 2016-04-23 | 1 | -1/+1 |
| | | | | | | |||||
* | | | | | | gdbstub: Don't check if unsigned int is > 0 | Sam Spilsbury | 2016-04-23 | 1 | -2/+2 |
| |/ / / / |/| | | | | |||||
* | | | | | HWRasterizer: Texture forwarding | tfarley | 2016-04-21 | 7 | -181/+348 |
| | | | | | |||||
* | | | | | Config: Add scaled resolution option | tfarley | 2016-04-21 | 2 | -1/+2 |
|/ / / / | |||||
* | | | | Merge pull request #1612 from ObsidianX/get-set-sockopt | bunnei | 2016-04-19 | 1 | -3/+97 |
|\ \ \ \ | |_|/ / |/| | | | SOC:U GetSockOpt/SetSockOpt | ||||
| * | | | Rework sockopt translation to match the error translation code already in place | Ryan Loebs | 2016-04-02 | 1 | -22/+30 |
| | | | | |||||
| * | | | Code style | Ryan Loebs | 2016-03-30 | 1 | -2/+2 |
| | | | | |||||
| * | | | Added GetSockOptName | Ryan Loebs | 2016-03-30 | 1 | -15/+58 |
| | | | | | | | | | | | | | | | | Filter out and translate invalid sockopt names. | ||||
| * | | | Derp: win32: typedef int socklen_t; | Ryan Loebs | 2016-03-29 | 1 | -4/+0 |
| | | | | |||||
| * | | | But of course, Windows uses 'int' while Linux uses 'socklen_t' | Ryan Loebs | 2016-03-29 | 1 | -0/+4 |
| | | | | |||||
| * | | | Compiling on Windows now | Ryan Loebs | 2016-03-29 | 1 | -3/+3 |
| | | | | |||||
| * | | | Formatting... | Ryan Loebs | 2016-03-29 | 1 | -1/+1 |
| | | | | |||||
| * | | | Addressing PR comments | Ryan Loebs | 2016-03-29 | 1 | -4/+4 |
| | | | | |||||
| * | | | SOC Updates | Ryan Loebs | 2016-03-29 | 1 | -3/+46 |
| | | | | | | | | | | | | | | | | | | | | | | | | -Implement GetSockOpt / SetSockOpt -Fix bug in RecvFrom where sending from localhost does not fill in src_addr/src_addr_len on Linux | ||||
* | | | | core: Clean out some unnecessary header includes | Lioncash | 2016-04-16 | 3 | -14/+1 |
| | | | | |||||
* | | | | Merge pull request #1667 from wwylele/ncch-loader-fix | bunnei | 2016-04-15 | 1 | -2/+2 |
|\ \ \ \ | | | | | | | | | | | loader: only decompress code section | ||||
| * | | | | ncch:only decompress .code section | wwylele | 2016-04-14 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | Y2R: num_tiles should be allowed when its value is 128 (#1669) | JamePeng | 2016-04-15 | 1 | -1/+1 |
|/ / / / | |||||
* | | | | Merge pull request #1613 from mailwl/anp | bunnei | 2016-04-11 | 2 | -2/+7 |
|\ \ \ \ | | | | | | | | | | | Set Kernel config "Hardware Inited" to 1 (true) | ||||
| * | | | | Set Kernel config "Unknown Value" to 0x1 | mailwl | 2016-04-11 | 2 | -2/+7 |
| | | | | | |||||
* | | | | | CitraQt: Apply config at startup | Jannik Vogel | 2016-04-11 | 2 | -0/+16 |
|/ / / / | |||||
* | | / | Fix BLX LR opcode interpretation | mailwl | 2016-04-09 | 1 | -2/+3 |
| |_|/ |/| | | |||||
* | | | Merge pull request #1644 from polaris-/gdb-fixes | bunnei | 2016-04-08 | 1 | -23/+85 |
|\ \ \ | | | | | | | | | Adopted WinterMute's gdbstub changes | ||||
| * | | | Adopted WinterMute's gdbstub changes | polaris- | 2016-04-06 | 1 | -23/+85 |
| | | | | | | | | | | | | | | | | | | | | This fixes the comments left on the PR (whitespace, SO_REUSEADDR, comment changes). | ||||
* | | | | update the code of AM service! (#1623) | JamePeng | 2016-04-08 | 6 | -51/+289 |
| | | | | |||||
* | | | | cecd:u: stub GetCecStateAbbreviated (#1648) | mailwl | 2016-04-08 | 3 | -0/+28 |
| | | | | |||||
* | | | | Update cpsr (T)humb bit while creating thread | mailwl | 2016-04-08 | 1 | -1/+1 |
| | | | | |||||
* | | | | Merge pull request #1577 from JamePeng/update-apta-func | bunnei | 2016-04-07 | 5 | -8/+47 |
|\ \ \ \ | | | | | | | | | | | Append the missing function name"GetAppletInfo", "SetAppCpuTimeLimit" and "GetAppCpuTimeLimit" to APT:A | ||||
| * | | | | append SetAppCpuTimeLimit and GetAppCpuTimeLimit to APT:A | JamePeng | 2016-04-06 | 3 | -13/+16 |
| | | | | | |||||
| * | | | | implement APT::GetStartupArgument | JamePeng | 2016-04-04 | 5 | -2/+37 |
| | | | | | |||||
| * | | | | Append the missing function name"GetAppletInfo" to APT:A | JamePeng | 2016-04-04 | 1 | -1/+2 |
| | | | | | |||||
* | | | | | Fix thumb ADR instruction alignment | mailwl | 2016-04-06 | 1 | -6/+2 |
| |/ / / |/| | | | |||||
* | | | | Merge pull request #1435 from mailwl/frd_u | bunnei | 2016-04-06 | 4 | -55/+234 |
|\ \ \ \ | | | | | | | | | | | frd:u: Initial stub some functions | ||||
| * | | | | frd:u: Initial stub some functions | mailwl | 2016-03-27 | 4 | -55/+234 |
| | |/ / | |/| | | |||||
* | | | | Merge pull request #1643 from MerryMage/make_unique | Mathew Maidment | 2016-04-06 | 14 | -37/+31 |
|\ \ \ \ | |_|/ / |/| | | | Common: Remove Common::make_unique, use std::make_unique | ||||
| * | | | Common: Remove Common::make_unique, use std::make_unique | MerryMage | 2016-04-05 | 14 | -37/+31 |
| | |/ | |/| | |||||
* | | | Merge pull request #1616 from exhalatio/dlp_dummy | bunnei | 2016-04-03 | 4 | -0/+63 |
|\ \ \ | | | | | | | | | Dummy implementation dlp:SRVR Service. | ||||
| * | | | Dummy implementation dlp:SRVR Service. | exhalatio | 2016-04-02 | 4 | -0/+63 |
| | | | | |||||
* | | | | Merge pull request #1619 from mailwl/cecd | bunnei | 2016-04-02 | 3 | -3/+54 |
|\ \ \ \ | | | | | | | | | | | cecd:u: stub GetCecInfoEventHandle, GetChangeStateEventHandle | ||||
| * | | | | cecd:u: stub GetCecInfoEventHandle, GetChangeStateEventHandle | mailwl | 2016-03-31 | 3 | -3/+54 |
| | | | | | |||||
* | | | | | Merge pull request #1390 from purpasmart96/citra_gsp_error_codes | bunnei | 2016-04-01 | 3 | -80/+97 |
|\ \ \ \ \ | | | | | | | | | | | | | GSP: Return proper error codes for register writes | ||||
| * | | | | | GSP: Return proper error codes for register writes | purpasmart96 | 2016-03-31 | 3 | -80/+97 |
| |/ / / / | |||||
* | | | | | Merge pull request #1618 from MerryMage/one-step | Mathew Maidment | 2016-03-31 | 1 | -26/+57 |
|\ \ \ \ \ | | | | | | | | | | | | | Prevent cache overflow when single stepping | ||||
| * | | | | | DynCom: Optimize single stepping | MerryMage | 2016-03-30 | 1 | -26/+57 |
| | |_|/ / | |/| | | | |||||
* | | | | | Merge pull request #1419 from mailwl/branch-gsp | bunnei | 2016-03-31 | 1 | -6/+41 |
|\ \ \ \ \ | |_|/ / / |/| | | | | Add gsp functions: SetAxiConfigQoSMode, UnregisterInterruptRelayQueue | ||||
| * | | | | Add gsp functions: SetAxiConfigQoSMode, UnregisterInterruptRelayQueue | mailwl | 2016-03-31 | 1 | -6/+41 |
| | |_|/ | |/| | | |||||
* / | | | Add common methods to all cfg:* ports | Ryan Loebs | 2016-03-29 | 3 | -0/+21 |
|/ / / | |||||
* | | | use reference instead of pointer | wwylele | 2016-03-26 | 1 | -9/+9 |
| | | | |||||
* | | | Merge pull request #1549 from wwylele/acc_gyro | bunnei | 2016-03-26 | 4 | -23/+187 |
|\ \ \ | |_|/ |/| | | hid: implement accelerometer and gyroscope back-end | ||||
| * | | implement GyroscopeCalibrateParam | wwylele | 2016-03-25 | 2 | -9/+20 |
| | | | |||||
| * | | implement accel and gyro backend | wwylele | 2016-03-22 | 4 | -23/+176 |
| | | | |||||
* | | | Merge pull request #1560 from lioncash/savedata | bunnei | 2016-03-22 | 1 | -1/+2 |
|\ \ \ | | | | | | | | | archive_extsavedata: Fix member initialization order | ||||
| * | | | archive_extsavedata: Fix member initialization order | Lioncash | 2016-03-21 | 1 | -1/+2 |
| | |/ | |/| | | | | | | | shared appears in the initializer list before mount_point | ||||
* | | | Merge pull request #1563 from lioncash/lolfiq | bunnei | 2016-03-22 | 1 | -4/+3 |
|\ \ \ | | | | | | | | | armstate: Correct FIQ register banking | ||||
| * | | | armstate: Correct FIQ register banking | Lioncash | 2016-03-21 | 1 | -4/+3 |
| |/ / | | | | | | | | | | FIQ has seven banked registers (R8 to R14), not two. | ||||
* | | | Merge pull request #1559 from lioncash/vec | bunnei | 2016-03-21 | 1 | -8/+5 |
|\ \ \ | | | | | | | | | soc_u: Get rid of explicit delete and new | ||||
| * | | | soc_u: Get rid of explicit delete and new | Lioncash | 2016-03-21 | 1 | -8/+5 |
| |/ / | |||||
* | | | session: Make helper functions constexpr | Lioncash | 2016-03-21 | 1 | -6/+6 |
| | | | |||||
* | | | loader: Make MakeMagic constexpr | Lioncash | 2016-03-21 | 1 | -1/+1 |
|/ / | |||||
* | | Merge pull request #1302 from Subv/save_fix | bunnei | 2016-03-20 | 24 | -143/+400 |
|\ \ | | | | | | | HLE/FS: Fixed many corner cases in our file handling | ||||
| * | | HLE/FS: Change the error code returned when an ExtSaveData archive is not found. | Subv | 2016-03-20 | 5 | -33/+45 |
| | | | | | | | | | | | | This allows Fire Emblem to boot again. | ||||
| * | | HLE/FS: Corrected some style concerns. | Subv | 2016-03-20 | 8 | -14/+12 |
| | | | |||||
| * | | HLE/FS: Fixed creating the config savefile when it doesn't exist. | Subv | 2016-03-20 | 1 | -1/+1 |
| | | | | | | | | | | | | This fixes a regression. | ||||
| * | | HLE/FS: Implemented GetFormatInfo | Subv | 2016-03-20 | 19 | -62/+257 |
| | | | | | | | | | | | | Format information is currently only implemented for the ExtSaveData, SharedExtSaveData and SaveData archives, the information is stored in a file alongside the root folder of the archive. | ||||
| * | | HLE/FS: Don't return an error when deleting the ExtSaveData if it does not exist. | Subv | 2016-03-20 | 1 | -1/+1 |
| | | | |||||
| * | | HLE/FS: Return the proper error codes when opening files. | Subv | 2016-03-20 | 7 | -28/+43 |
| | | | |||||
| * | | HLE/FS: Fixed the OpenDirectory error code | Subv | 2016-03-20 | 1 | -1/+1 |
| | | | |||||
| * | | HLE/FS: Return the proper error codes on file Read/Write operations. | Subv | 2016-03-20 | 7 | -18/+40 |
| | | | | | | | | | | | | These operations are limited by the open flags specified while opening the file. | ||||
| * | | HLE/FS: Corrected the error codes for DeleteFile | Subv | 2016-03-20 | 6 | -12/+22 |
| | | | |||||
| * | | HLE/FS: Corrected the error codes for CreateFile | Subv | 2016-03-20 | 2 | -2/+7 |
| | | | |||||
| * | | HLE/FS: FS::CreateFile takes an u64 for the file size. | Subv | 2016-03-20 | 8 | -10/+10 |
| |/ | |||||
* / | Fix missing header | LittleWhite | 2016-03-20 | 1 | -0/+2 |
|/ | |||||
* | Merge pull request #1505 from pippo2931/fef | bunnei | 2016-03-18 | 1 | -1/+25 |
|\ | | | | | GetArchiveResource stub | ||||
| * | Fix header | pippo2931 | 2016-03-12 | 1 | -1/+1 |
| | | |||||
| * | GetArchiveResource stub | pippo2931 | 2016-03-12 | 1 | -1/+25 |
| | | |||||
* | | core/video_core: Make NumIds functions constexpr | Lioncash | 2016-03-17 | 2 | -2/+2 |
| | | |||||
* | | core/video_core: Don't cast away const in subscript operators | Lioncash | 2016-03-17 | 2 | -6/+6 |
| | | | | | | | | Not to say these subscript operators aren't totally ugly as is. | ||||
* | | Reorganize the ndm service path for dummy implement function | JamePeng | 2016-03-14 | 6 | -26/+122 |
| | | | | | | | | | | | | SuspendDaemons , ResumeDaemons , OverrideDefaultDaemons The NDM file move to /core/hle/service/ndm/ now! | ||||
* | | hid: fix pad update | wwylele | 2016-03-13 | 1 | -1/+1 |
| | | |||||
* | | svc: Move ResetType enum to the kernel event header | Lioncash | 2016-03-13 | 10 | -16/+17 |
| | | |||||
* | | svc: Remove unused ArbitrationType enum | Lioncash | 2016-03-12 | 1 | -9/+0 |
| | | | | | | | | An equivalent enum already exists within address_arbiter.h | ||||
* | | svc: Make ResetType an enum class | Lioncash | 2016-03-12 | 11 | -24/+23 |
|/ | |||||
* | Merge pull request #1266 from Subv/miiapplet | bunnei | 2016-03-12 | 7 | -2/+156 |
|\ | | | | | HLE/Applets: Implemented a dummy Mii Selector applet. | ||||
| * | HLE/Applets: Implemented a dummy Mii Selector applet. | Subv | 2016-03-12 | 7 | -2/+156 |
| | | | | | | | | This prevents some games (like Super Mario 3D Land) from freezing when trying to launch it, however, it's not complete and won't let you go past Mii selection as the parameter structure hasn't been reverse engineered yet. | ||||
* | | Merge pull request #1500 from lioncash/nullptr | bunnei | 2016-03-12 | 1 | -1/+1 |
|\ \ | | | | | | | gsp_gpu: Change 0 literal to nullptr | ||||
| * | | gsp_gpu: Change 0 literal to nullptr | Lioncash | 2016-03-12 | 1 | -1/+1 |
| | | | |||||
* | | | hle: Update service function tables | Lioncash | 2016-03-12 | 4 | -1/+16 |
|/ / | |||||
* | | Fix missing return | LittleWhite | 2016-03-09 | 1 | -0/+2 |
| | | |||||
* | | Merge pull request #1474 from lioncash/renderer | bunnei | 2016-03-09 | 3 | -10/+10 |
|\ \ | | | | | | | renderer_base: Minor changes | ||||
| * | | renderer_base: Don't directly expose the rasterizer unique_ptr | Lioncash | 2016-03-09 | 3 | -10/+10 |
| | | | | | | | | | | | | | | | There's no reason to allow direct access to the unique_ptr instance. Only its contained pointer. | ||||
* | | | Merge pull request #1344 from LittleWhite-tb/error-output | bunnei | 2016-03-09 | 5 | -9/+17 |
|\ \ \ | |/ / |/| | | Output errors in GUI | ||||
| * | | Improve error report from Init() functions | LittleWhite | 2016-03-08 | 5 | -7/+14 |
| | | | | | | | | | | | | Add error popup when citra initialization failed | ||||
| * | | Display errors in GUI when loading ROM failed | LittleWhite | 2016-03-03 | 1 | -2/+3 |
| | | | |||||
* | | | DSP: Implement Pipe 2 | MerryMage | 2016-03-06 | 1 | -43/+151 |
| | | | | | | | | | | | | | | | | | | Pipe 2 is a DSP pipe that is used to initialize both the DSP hardware (the application signals to the DSP to initialize) and the application (the DSP provides the memory location of structures in the shared memory region). | ||||
* | | | Memory: Do correct Phys->Virt address translation for non-APP linheap | Yuri Kunde Schlesner | 2016-03-06 | 3 | -3/+6 |
| | | | |||||
* | | | Merge pull request #1455 from yuriks/ResultVal-union | Mathew Maidment | 2016-03-06 | 1 | -42/+16 |
|\ \ \ | | | | | | | | | core: Use unrestricted union to hold storage of ResultVal value | ||||
| * | | | core: Use unrestricted union to hold storage of ResultVal value | Yuri Kunde Schlesner | 2016-03-05 | 1 | -42/+16 |
| | | | | |||||
* | | | | DSP: Print hash of firmware to console | MerryMage | 2016-03-06 | 1 | -8/+21 |
| | | | | |||||
* | | | | Loader/NCCH: Log the program ID during loading | Yuri Kunde Schlesner | 2016-03-05 | 1 | -1/+2 |
|/ / / | | | | | | | | | | | | | This is useful for all sorts of things, but mainly to identify save folders more easily. | ||||
* | | | Merge pull request #1429 from mailwl/branch-acu | bunnei | 2016-03-05 | 1 | -2/+17 |
|\ \ \ | | | | | | | | | ac:u IsConnected implemented | ||||
| * | | | ac:u: Stub IsConnected | mailwl | 2016-03-04 | 1 | -2/+17 |
| |/ / | |||||
* | | | Merge pull request #1389 from yuriks/stub-cam | bunnei | 2016-03-04 | 3 | -20/+563 |
|\ \ \ | |/ / |/| | | Stub CAM:U service | ||||
| * | | Service/CAM: Add doxycomments to all service functions | Yuri Kunde Schlesner | 2016-03-01 | 1 | -0/+217 |
| | | | |||||
| * | | Service/CAM: Dummy implementation of some functions | Yuri Kunde Schlesner | 2016-02-13 | 3 | -20/+346 |
| | | | | | | | | | | | | Thanks to @mailwl for the initial version of the stubs. | ||||
* | | | Merge pull request #1434 from Kloen/legend | bunnei | 2016-03-02 | 1 | -0/+1 |
|\ \ \ | | | | | | | | | Add THREADPROCESSORID_ALL on SVC::CreateThread | ||||
| * | | | ThreadProcessorId_All on SVC::CreateThread | Kloen | 2016-03-01 | 1 | -0/+1 |
| | | | | |||||
* | | | | Merge pull request #1297 from Subv/saves | bunnei | 2016-03-01 | 1 | -2/+4 |
|\ \ \ \ | | | | | | | | | | | DiskDirectory: Initialize the directory member with valid info. | ||||
| * | | | | DiskDirectory: Initialize the directory member with valid info. | Subv | 2016-01-16 | 1 | -2/+4 |
| | | | | | |||||
* | | | | | Service/CFG: Fix potential endianess issue | Yuri Kunde Schlesner | 2016-03-01 | 1 | -2/+3 |
| | | | | | |||||
* | | | | | Service/CFG: Add block 0x000A0000 (username) to default config file | Yuri Kunde Schlesner | 2016-03-01 | 1 | -1/+14 |
| |/ / / |/| | | | |||||
* | | | | Initial implementation ir:user | mailwl | 2016-02-26 | 3 | -18/+142 |
| | | | | |||||
* | | | | AudioCore: Skeleton Implementation | MerryMage | 2016-02-21 | 5 | -66/+99 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit: * Adds a new subproject, audio_core. * Defines structures that exist in DSP shared memory. * Hooks up various other parts of the emulator into audio core. This sets the foundation for a later HLE DSP implementation. | ||||
* | | | | BitField: Make trivially copyable and remove assignment operator | MerryMage | 2016-02-12 | 8 | -28/+28 |
| |/ / |/| | | |||||
* | | | services: Get rid of unnecessary includes | Lioncash | 2016-02-02 | 69 | -132/+32 |
| | | | |||||
* | | | services: Update function tables | Lioncash | 2016-02-02 | 2 | -5/+11 |
| | | | |||||
* | | | Merge pull request #1377 from MerryMage/mmio | bunnei | 2016-01-31 | 6 | -13/+127 |
|\ \ \ | | | | | | | | | Memory: Implemented MMIO | ||||
| * | | | Memory: Implement MMIO | MerryMage | 2016-01-30 | 6 | -13/+127 |
| |/ / | |||||
* | | | elf: Don't cast away const | Lioncash | 2016-01-25 | 1 | -3/+3 |
| | | | |||||
* | | | archive_backend: Remove unnecessary const from return types | Lioncash | 2016-01-25 | 2 | -8/+8 |
| | | | | | | | | | | | | This doesn't return by reference so const isn't really necessary | ||||
* | | | ARM_Disasm::DisassembleMemHalf: actually use width in determining opcode name | rob turner | 2016-01-19 | 1 | -9/+9 |
|/ / | |||||
* | | Merge pull request #1327 from Subv/unmap_memblock | bunnei | 2016-01-15 | 5 | -5/+60 |
|\ \ | | | | | | | HLE/SVC: Implement UnmapMemoryBlock. | ||||
| * | | HLE/SVC: Implement UnmapMemoryBlock. | Subv | 2016-01-14 | 5 | -5/+60 |
| | | | | | | | | | | | | This implementation will need to be (almost completely) changed when we implement multiprocess support. | ||||
* | | | Merge pull request #1283 from Subv/soc_fixup | bunnei | 2016-01-05 | 1 | -3/+13 |
|\ \ \ | | | | | | | | | HLE/Sockets: Fixed the buffer offset in recvfrom. | ||||
| * | | | HLE/Sockets: Fixed the buffer offset in recvfrom. | Subv | 2015-12-24 | 1 | -3/+13 |
| | | | | | | | | | | | | | | | | Closes #1277 | ||||
* | | | | Merge pull request #1310 from lioncash/services | bunnei | 2015-12-31 | 25 | -113/+369 |
|\ \ \ \ | | | | | | | | | | | services: Update some function tables | ||||
| * | | | | services: Update some function tables | Lioncash | 2015-12-30 | 25 | -113/+369 |
| | |/ / | |/| | | |||||
* / | | | arm_dyncom_dec: Fix decoding of VMLS | Lioncash | 2015-12-30 | 2 | -206/+202 |
|/ / / | | | | | | | | | | | | | | | | Previously, all VMLS variants would misdecode as CDP (which isn't necessarily wrong in itself, however VMLS has it's own label of execution) | ||||
* | | | Merge pull request #1306 from Subv/sync | bunnei | 2015-12-30 | 1 | -3/+3 |
|\ \ \ | | | | | | | | | HLE/Timers: Reset OneShot timers when they are acquired instead of when they're triggered | ||||
| * | | | HLE/Timers: Reset OneShot timers when they are acquired instead of when they're triggered. | Subv | 2015-12-30 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | Closes #1139 | ||||
* | | | | core: Use unique_ptr for holding the interpreter instances | Lioncash | 2015-12-30 | 2 | -8/+12 |
|/ / / | |||||
* | | | Merge pull request #1300 from Subv/arbitrateaddress | bunnei | 2015-12-29 | 2 | -9/+18 |
|\ \ \ | | | | | | | | | SVC: Fixed ArbitrateAddress to behave as it does on hardware. | ||||
| * | | | SVC: Fixed ArbitrateAddress to behave as it does on hardware. | Subv | 2015-12-28 | 2 | -9/+18 |
| | | | | | | | | | | | | | | | | This was verified with hwtests that i plan to upload later on. | ||||
* | | | | dyncom: Handle modifying the APSR via an MRC instruction | Lioncash | 2015-12-28 | 1 | -12/+9 |
| | | | | |||||
* | | | | svc: Remove superfluous printf argument | Lioncash | 2015-12-25 | 1 | -1/+1 |
|/ / / | |||||
* | | | dyncom: Remove PC dispatch from several instructions | Lioncash | 2015-12-21 | 1 | -94/+0 |
| | | | | | | | | | | | | These instructions aren't capable of using the PC as a destination | ||||
* | | | dyncom: Handle unprivileged load/store variants correctly | Lioncash | 2015-12-20 | 1 | -7/+33 |
| | | | | | | | | | | | | | | | | | | | | | LDRT/LDRBT/STRBT/STRT should simulate the load or store as if the host CPU is in user mode. STRT is also allowed to use the PC as an operand | ||||
* | | | svc: Fix compilation with LOG_TRACE enabled | Lioncash | 2015-12-13 | 1 | -1/+1 |
|/ / | |||||
* | | Merge pull request #1272 from yuriks/merge-rasterizer | Yuri Kunde Schlesner | 2015-12-08 | 3 | -11/+11 |
|\ \ | | | | | | | VideoCore: Unify interface to OpenGL and SW rasterizers | ||||
| * | | VideoCore: Unify interface to OpenGL and SW rasterizers | Yuri Kunde Schlesner | 2015-12-08 | 3 | -11/+11 |
| | | | | | | | | | | | | | | | | | | This removes explicit checks sprinkled all over the codebase to instead just have the SW rasterizer expose an implementation with no-ops for most operations. | ||||
| * | | VideoCore: Rename HWRasterizer methods to be less confusing | Yuri Kunde Schlesner | 2015-12-07 | 3 | -10/+10 |
| | | | |||||
* | | | dyncom: Remove static keyword from header functions | Lioncash | 2015-12-06 | 3 | -19/+19 |
| | | | |||||
* | | | arm_interface: Make GetNumInstructions const | Lioncash | 2015-12-06 | 1 | -1/+1 |
| | | | |||||
* | | | arm_interface: directly initialize class members | Lioncash | 2015-12-06 | 1 | -7/+2 |
| | | | |||||
* | | | dyncom: const correctness changes | Lioncash | 2015-12-06 | 3 | -7/+7 |
|/ / | |||||
* | | Merge pull request #1252 from Subv/cam | bunnei | 2015-12-04 | 1 | -0/+156 |
|\ \ | |/ |/| | Services/Cam: Added new log type and camera enums from 3dbrew. | ||||
| * | Services/Cam: Added new log type and camera enums from 3dbrew. | Subv | 2015-11-23 | 1 | -0/+156 |
| | | | | | | | | | | Followup to #1102 Original author @mailwl | ||||
* | | Kernel: Implement svcGetSystemInfo | Yuri Kunde Schlesner | 2015-12-01 | 7 | -1/+95 |
| | | | | | | | | | | This makes smealum/ctrulib@b96dd51d3349961189d4ab1bc2a5c45deff21c09 work with Citra. | ||||
* | | armstate: Zero out the registers on creation | Lioncash | 2015-11-29 | 1 | -11/+11 |
| | | | | | | | | | | std::array isn't always guaranteed to explicitly zero out it's contents without an initializer list. | ||||
* | | Core/ARM11: Correct the size of the VFP register array in the ThreadContext structure. | Subv | 2015-11-29 | 1 | -1/+1 |
| | | | | | | | | The VFP registers are 64 bits each, and there are 32 of them. | ||||
* | | Merge pull request #1225 from lioncash/clean | bunnei | 2015-11-29 | 1 | -12/+13 |
|\ \ | | | | | | | csnd_snd: Get rid of type punning | ||||
| * | | csnd_snd: Get rid of type punning | Lioncash | 2015-10-28 | 1 | -12/+13 |
| | | | |||||
* | | | Merge pull request #1248 from polaris-/add-ssl-stubs | bunnei | 2015-11-24 | 1 | -2/+51 |
|\ \ \ | |_|/ |/| | | Add stub functions for Initialize and GenerateRandomData in ssl:C | ||||
| * | | Add stub functions for Initialize and GenerateRandomData in ssl:C | polaris- | 2015-11-22 | 1 | -2/+51 |
| | | | |||||
* | | | Merge pull request #1246 from polaris-/patch-1 | bunnei | 2015-11-22 | 1 | -26/+31 |
|\ \ \ | |/ / |/| | | Fix read and write register blocks in gdbstub | ||||
| * | | Fix read and write register blocks in gdbstub | polaris- | 2015-11-22 | 1 | -26/+31 |
| | | | | | | | | | | | | Previously, the padding wasn't correctly accounted for which caused the gdbstub to read and write everything after R15 (starting with the dummy FPA registers) incorrectly, which caused CPSR to not be handled correctly. Everything appears to be working as expected with this change. | ||||
* | | | Add Initialize and GenerateRandomData stubs | polaris- | 2015-11-22 | 1 | -0/+2 |
|/ / | |||||
* | | Merge pull request #1122 from polaris-/gdbstub | bunnei | 2015-11-12 | 9 | -9/+1145 |
|\ \ | |/ |/| | gdbstub implementation | ||||
| * | Fix bug with reading addresses and lengths | polaris- | 2015-11-04 | 1 | -45/+55 |
| | | |||||
| * | Change headers | polaris- | 2015-10-29 | 1 | -2/+2 |
| | | |||||
| * | Add some headers so TravisCI will hopefully work | polaris- | 2015-10-22 | 1 | -0/+2 |
| | | |||||
| * | Use CHAR_BIT instead of 8 | polaris- | 2015-10-22 | 1 | -11/+11 |
| | | |||||
| * | Handle changes pointed out in comments on PR | polaris- | 2015-10-22 | 1 | -61/+34 |
| | | |||||
| * | Add a register variable to loops | polaris- | 2015-10-21 | 1 | -6/+9 |
| | | |||||
| * | Update register read loops to go with last commit | polaris- | 2015-10-21 | 1 | -6/+7 |
| | | |||||
| * | Pad responses to gdb for VFP registers | polaris- | 2015-10-21 | 1 | -0/+3 |
| | | |||||
| * | Try to add support for VFP registers | polaris- | 2015-10-21 | 1 | -4/+21 |
| | | |||||
| * | Fix buffer overflow comments | polaris- | 2015-10-21 | 1 | -2/+3 |
| | | |||||
| * | Remove unnecessary new lines, changed Deinit to Shutdown | polaris- | 2015-10-12 | 4 | -10/+7 |
| | | |||||
| * | Use BreakpointAddress struct instead of passing address directly | polaris- | 2015-10-04 | 3 | -8/+18 |
| | | |||||
| * | Implement gdbstub | polaris- | 2015-10-04 | 9 | -9/+1128 |
| | | |||||
* | | Merge pull request #1165 from esoteric-programmer/master | bunnei | 2015-10-28 | 2 | -4/+66 |
|\ \ | | | | | | | Added CSND_ExecuteType0Commands stub. | ||||
| * | | Added CSND stub. | Matthias Ernst | 2015-10-28 | 2 | -4/+66 |
| | | | |||||
* | | | Merge pull request #1208 from archshift/free-bytes | bunnei | 2015-10-28 | 8 | -1/+60 |
|\ \ \ | | | | | | | | | Implement FS_User::GetFreeBytes | ||||
| * | | | Implement FS_User::GetFreeBytes | archshift | 2015-10-28 | 8 | -1/+60 |
| | | | | |||||
* | | | | Fix copy paste | Filiph Sandström | 2015-10-24 | 1 | -1/+1 |
| | | | | |||||
* | | | | Fix wrong branch | Filiph Sandström | 2015-10-23 | 1 | -0/+12 |
| | | | | |||||
* | | | | Add GetTotalStepCount Stub | Filiph Sandström | 2015-10-23 | 1 | -1/+1 |
| | | | | |||||
* | | | | Update ptm.h | Filiph Sandström | 2015-10-23 | 1 | -0/+8 |
| | | | | |||||
* | | | | Merge pull request #1199 from Gareth422/encryption-check | bunnei | 2015-10-20 | 3 | -20/+25 |
|\ \ \ \ | |/ / / |/| | | | Loader: Implement NCCH encryption check | ||||
| * | | | Loader: Change NCCH header types to be explicitly little-endian | Gareth Poole | 2015-10-11 | 2 | -18/+17 |
| | | | | |||||
| * | | | Loader: Implement encryption check | Gareth Poole | 2015-10-11 | 3 | -2/+8 |
| | | | | |||||
* | | | | Merge pull request #1194 from linkmauve/no-newline | bunnei | 2015-10-10 | 4 | -47/+47 |
|\ \ \ \ | |/ / / |/| | | | Remove newlines in LOG_* calls | ||||
| * | | | CitraQt, SkyEye, Loader, VideoCore: Remove newlines in LOG_* calls. | Emmanuel Gil Peyrot | 2015-10-09 | 4 | -47/+47 |
| | | | | | | | | | | | | | | | | The LOG_* function itself already appends one. | ||||
* | | | | Fixed spelling errors | Gareth Poole | 2015-10-09 | 1 | -2/+2 |
|/ / / | |||||
* | / | Silence -Wsign-compare warnings. | Rohit Nirmal | 2015-10-07 | 2 | -2/+2 |
| |/ |/| | |||||
* | | Merge pull request #1095 from archshift/game-list | bunnei | 2015-10-02 | 2 | -13/+41 |
|\ \ | | | | | | | Initial implementation of a game list | ||||
| * | | Expose loader helper functions for identifying files. | archshift | 2015-10-01 | 2 | -13/+41 |
| | | | |||||
* | | | Merge pull request #1177 from linkmauve/fix-msvc-todo | bunnei | 2015-09-30 | 1 | -4/+3 |
|\ \ \ | | | | | | | | | Use a constexpr function for country initialization in service/cfg | ||||
| * | | | Service/CFG: Use a constexpr function for country initialization | Emmanuel Gil Peyrot | 2015-09-30 | 1 | -4/+3 |
| | | | | | | | | | | | | | | | | This fixes a TODO left over from when we supported MSVC 2013. | ||||
* | | | | ivfc_archive: Fix a printf specifier | Lioncash | 2015-09-30 | 1 | -1/+1 |
|/ / / | |||||
* | | | fix some xcode 7.0 warnings | Martin Lindhe | 2015-09-29 | 2 | -4/+4 |
| | | | |||||
* | | | Merge pull request #1160 from lioncash/clang | bunnei | 2015-09-22 | 8 | -16/+18 |
|\ \ \ | | | | | | | | | Silence some clang warnings | ||||
| * | | | general: Silence some warnings when using clang | Lioncash | 2015-09-16 | 8 | -16/+18 |
| | |/ | |/| | |||||
* / | | Implement 3dsx RomFS | Cruel | 2015-09-21 | 3 | -3/+61 |
|/ / | |||||
* | | Service/CFG: Add default entry for block 0x000A0001 (birthday) | Yuri Kunde Schlesner | 2015-09-14 | 1 | -0/+6 |
| | | |||||
* | | Service/CFG: Correct flags in 2 default blocks | Yuri Kunde Schlesner | 2015-09-14 | 1 | -2/+2 |
| | | | | | | | | Verified against a 9.2.0-20 config save | ||||
* | | Service/CFG: Add additional blocks to default save data | Yuri Kunde Schlesner | 2015-09-14 | 1 | -0/+34 |
| | | | | | | | | These blocks are required by various games to boot. | ||||
* | | Fix narrowing conversion warning | Yuri Kunde Schlesner | 2015-09-14 | 1 | -1/+1 |
| | | |||||
* | | Service/CFG: Move several private types from the header to the cpp | Yuri Kunde Schlesner | 2015-09-14 | 2 | -63/+49 |
| | | |||||
* | | Service/CFG: Clean up default block creation | Yuri Kunde Schlesner | 2015-09-14 | 2 | -27/+17 |
|/ | |||||
* | GSP: Implement command 0x05, used for flushing caches | Yuri Kunde Schlesner | 2015-09-14 | 2 | -13/+34 |
| | | | | | | May fix additional texture caching issues. (Though mostly in homebrew, I haven't seen any commercial software use this to flush anything but command lists.) | ||||
* | general: Replace 0 literals with nullptr where applicable | Lioncash | 2015-09-12 | 1 | -1/+1 |
| | |||||
* | General: Replace NULL and '0' usages with nullptr where applicable | Lioncash | 2015-09-11 | 4 | -31/+31 |
| | |||||
* | Merge pull request #1130 from lioncash/block | Yuri Kunde Schlesner | 2015-09-10 | 1 | -14/+7 |
|\ | | | | | memory: Get rid of pointer casts | ||||
| * | memory: Get rid of pointer casts | Lioncash | 2015-09-10 | 1 | -14/+7 |
| | | |||||
* | | General: Fix up doxygen comments | Lioncash | 2015-09-10 | 7 | -11/+9 |
| | | |||||
* | | Merge pull request #1131 from lioncash/uninit | Yuri Kunde Schlesner | 2015-09-10 | 1 | -3/+6 |
|\ \ | | | | | | | y2r: Give local variables an initial value | ||||
| * | | y2r: Give local variables an initial value | Lioncash | 2015-09-10 | 1 | -3/+6 |
| |/ | | | | | | | Keeps compilers/static analyzers quiet. | ||||
* / | disk_archive: Remove unimplemented constructor declarations | Lioncash | 2015-09-10 | 1 | -2/+0 |
|/ | |||||
* | DynCom: Converted all 0xE condition code checks to ConditionCode::AL | archshift | 2015-09-06 | 2 | -132/+132 |
| | |||||
* | Merge pull request #1101 from archshift/camu-service-names | bunnei | 2015-09-03 | 1 | -3/+60 |
|\ | | | | | Add cam:u service function names to its function table | ||||
| * | Add cam:u service function names to its function table | archshift | 2015-09-03 | 1 | -3/+60 |
| | | |||||
* | | Merge pull request #1072 from yuriks/GetSystemTick-advance-time | bunnei | 2015-09-01 | 1 | -1/+4 |
|\ \ | |/ |/| | SVC: Advance time when calling GetSystemTick to escape busy-wait loops | ||||
| * | SVC: Advance time when calling GetSystemTick to escape busy-wait loops | Yuri Kunde Schlesner | 2015-08-30 | 1 | -1/+4 |
| | | | | | | | | | | | | | | | | Cubic Ninja waited for the frame to end by spinning on a loop calling GetSystemTick while doing nothing else. Since GetSystemTick doesn't cause a reschedule (which advances time), this meant that very little emulated time would pass inside that loop, causing the game to spend most of the frame burning away CPU. | ||||
* | | Merge pull request #1085 from Subv/fs_stat | bunnei | 2015-08-30 | 1 | -1/+1 |
|\ \ | | | | | | | Services/FS: Correctly tell the guest app whether a file was correctly opened or not | ||||
| * | | Services/FS: Correctly tell the guest app whether a file was correctly opened or not. | Subv | 2015-08-29 | 1 | -1/+1 |
| | | | | | | | | | | | | Closes #1067 | ||||
* | | | Kernel: Fix wrong linear heap base on titles using newer kernels | Yuri Kunde Schlesner | 2015-08-28 | 1 | -1/+1 |
| | | | | | | | | | | | | Typo which sneaked in through review on #1025 | ||||
* | | | Kernel: Fix assertion failure when ControlMemory is called with size=0 | Yuri Kunde Schlesner | 2015-08-27 | 1 | -0/+8 |
| | | | |||||
* | | | Core: Improve APT Shared Font hack | Yuri Kunde Schlesner | 2015-08-27 | 3 | -4/+29 |
| | | | | | | | | | | | | Should fix invalid read loops in some games | ||||
* | | | dyncom: Simplify some comparisons in CondPassed | Lioncash | 2015-08-26 | 1 | -4/+4 |
| | | | |||||
* | | | dyncom: Change return type of CondPassed to bool | Lioncash | 2015-08-26 | 1 | -57/+39 |
| |/ |/| | |||||
* | | Integrate the MicroProfile profiling library | Yuri Kunde Schlesner | 2015-08-25 | 4 | -0/+24 |
| | | | | | | | | | | This brings goodies such as a configurable user interface and multi-threaded timeline view. | ||||
* | | Fix broken boot introduced by last-minute change in #1025 | Yuri Kunde Schlesner | 2015-08-22 | 1 | -1/+1 |
| | | |||||
* | | Merge pull request #1025 from yuriks/heap-management | Yuri Kunde Schlesner | 2015-08-22 | 28 | -308/+722 |
|\ \ | | | | | | | Kernel: Correct(er) handling of Heap and Linear Heap allocations | ||||
| * | | Kernel: Remove unused legacy heap MapBlock_* functions | Yuri Kunde Schlesner | 2015-08-16 | 3 | -78/+0 |
| | | | |||||
| * | | APT: Adjust shared font hack so it works with the new linear heap code | Yuri Kunde Schlesner | 2015-08-16 | 1 | -10/+11 |
| | | | |||||
| * | | Kernel: Implement svcGetProcessInfo in a basic way | Yuri Kunde Schlesner | 2015-08-16 | 6 | -3/+73 |
| | | | | | | | | | | | | | | | This also adds some basic memory usage accounting. These two types are used by Super Smash Bros. during startup. | ||||
| * | | Kernel: Add more infrastructure to support different memory layouts | Yuri Kunde Schlesner | 2015-08-16 | 10 | -28/+148 |
| | | | | | | | | | | | | | | | | | | This adds some structures necessary to support multiple memory regions in the future. It also adds support for different system memory types and the new linear heap mapping at 0x30000000. | ||||
| * | | HLE: Remove empty ConfigMem and SharedPage Shutdown functions | Yuri Kunde Schlesner | 2015-08-16 | 5 | -10/+0 |
| | | | |||||
| * | | Move core/mem_map.{cpp,h} => core/hle/kernel/memory.{cpp,h} | Yuri Kunde Schlesner | 2015-08-16 | 6 | -6/+5 |
| | | | |||||
| * | | Memory: Move address type conversion routines to memory.cpp/h | Yuri Kunde Schlesner | 2015-08-16 | 9 | -53/+47 |
| | | | | | | | | | | | | | | | These helpers aren't really part of the kernel, and mem_map.cpp/h is going to be moved there next. | ||||
| * | | Process: Store kernel compatibility version during loading | Yuri Kunde Schlesner | 2015-08-16 | 2 | -3/+7 |
| | | | |||||
| * | | Kernel: Properly implement ControlMemory FREE and COMMIT | Yuri Kunde Schlesner | 2015-08-16 | 6 | -38/+338 |
| | | | |||||
| * | | Memory: Move PAGE_MASK and PAGE_BITS to memory.h | Yuri Kunde Schlesner | 2015-08-16 | 2 | -3/+2 |
| | | | |||||
| * | | VMManager: Introduce names for used ResultCodes | Yuri Kunde Schlesner | 2015-08-16 | 2 | -6/+11 |
| | | | |||||
| * | | VMManager: Make LogLayout log level configurable as a parameter | Yuri Kunde Schlesner | 2015-08-16 | 3 | -5/+15 |
| | | | |||||
| * | | VMManager: Change block offsets to size_t | Yuri Kunde Schlesner | 2015-08-16 | 2 | -3/+3 |
| | | | |||||
* | | | Merge pull request #996 from yuriks/texture-copy | Yuri Kunde Schlesner | 2015-08-19 | 4 | -36/+101 |
|\ \ \ | |_|/ |/| | | GPU: Implement TextureCopy-mode display transfers | ||||
| * | | GPU: Implement TextureCopy-mode display transfers | Yuri Kunde Schlesner | 2015-08-16 | 4 | -36/+101 |
| |/ | | | | | | | Fixes glitchy garbage in Fire Emblem 3D scenes. | ||||
* | | Merge pull request #1033 from bbarenblat/master | Yuri Kunde Schlesner | 2015-08-16 | 1 | -0/+6 |
|\ \ | | | | | | | Handle `FileType::CIA` in `switch` statements | ||||
| * | | Properly indicate that CIA support is not implemented yet | Benjamin Barenblat | 2015-08-15 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | Make `Loader::LoadFile` return an `ErrorNotImplemented` if you call it on a CIA file. | ||||
| * | | Give CIA file type a name | Benjamin Barenblat | 2015-08-15 | 1 | -0/+2 |
| | | | | | | | | | | | | | | | Make `GetFileTypeString` return ‘CIA’ for CIA (CTR Importable Archive) files. | ||||
* | | | Merge pull request #1032 from lioncash/swap | bunnei | 2015-08-16 | 2 | -12/+6 |
|\ \ \ | |_|/ |/| | | vfp: use std::swap where applicable | ||||
| * | | vfp: use std::swap where applicable | Lioncash | 2015-08-16 | 2 | -12/+6 |
| |/ | |||||
* / | Shader: Initial implementation of x86_x64 JIT compiler for Pica vertex shaders. | bunnei | 2015-08-16 | 1 | -0/+1 |
|/ | | | | | - Config: Add an option for selecting to use shader JIT or interpreter. - Qt: Add a menu option for enabling/disabling the shader JIT. | ||||
* | Merge pull request #1027 from lioncash/debugger | bunnei | 2015-08-14 | 4 | -1/+49 |
|\ | | | | | debugger: Add the ability to view VFP register contents | ||||
| * | arm_interface: Implement interface for retrieving VFP registers | Lioncash | 2015-08-07 | 4 | -1/+49 |
| | | |||||
* | | ARM Core, Video Core, CitraQt, Citrace: Use CommonTypes types instead of the standard u?int*_t types. | Emmanuel Gil Peyrot | 2015-08-11 | 5 | -340/+345 |
| | | |||||
* | | arm_disasm: ARMv6 mul/div and abs media instructions | aroulin | 2015-08-11 | 2 | -1/+119 |
| | | | | | | | | | | | | SMLAD, SMUAD, SMLSD, SMUSD, SMLALD, SMLSLD, SMMLA, SMMUL, SMMLS USAD8, USADA8 | ||||
* | | arm_disasm: ARMv6 parallel add/sub media instructions | aroulin | 2015-08-11 | 2 | -0/+167 |
| | | | | | | | | {S, U, Q, UQ, SH, UH}{ADD16, ASX, SAX, SUB16, ADD8, SUB8} | ||||
* | | arm_disasm: ARMv6 reversal media instructions | aroulin | 2015-08-09 | 2 | -0/+26 |
| | | | | | | | | | | REV, REV16, REVSH Only their ARM encoding, Thumb encoding is still missing. | ||||
* | | arm_disasm: ARMv6 saturation media instructions | aroulin | 2015-08-09 | 2 | -2/+55 |
| | | | | | | | | SSAT, SSAT16, USAT, USAT16 | ||||
* | | arm_disasm: ARMv6 packing and sign-extend media instructions | aroulin | 2015-08-09 | 2 | -1/+181 |
| | | | | | | | | | | | | PKH, SEL SXTAB, SXTAB16, SXTB, SXTB16, SXTH, SXTAH UXTAB, UXTAB16, UXTB, UXTB16, UXTH, UXTAH | ||||
* | | Merge pull request #1026 from lioncash/disasm | Lioncash | 2015-08-07 | 1 | -12/+4 |
|\ \ | |/ |/| | arm_disasm: Remove unnecessary code | ||||
| * | arm_disasm: Remove unnecessary code | Lioncash | 2015-08-07 | 1 | -12/+4 |
| | | | | | | | | This part of disassembly only determines the opcode, there's no need for offset calculation here. | ||||
* | | Disassembler: ARMv6K REX instructions | aroulin | 2015-08-06 | 2 | -6/+97 |
| | | |||||
* | | Disassembler: ARMv6K hint instructions | aroulin | 2015-08-06 | 2 | -0/+56 |
| | | |||||
* | | Merge pull request #1008 from lioncash/pc | bunnei | 2015-07-30 | 2 | -21/+40 |
|\ \ | | | | | | | dyncom: Handle the case where PC is the source register for STR/VSTM/VLDM | ||||
| * | | dyncom: Handle the case where PC is the source register for STR/VSTM/VLDM | Lioncash | 2015-07-29 | 2 | -21/+40 |
| |/ | |||||
* | | Merge pull request #1014 from lioncash/unused-warn | bunnei | 2015-07-29 | 2 | -3/+5 |
|\ \ | | | | | | | core: Eliminate some unused variable warnings | ||||
| * | | core: Eliminate some unused variable warnings | Lioncash | 2015-07-29 | 2 | -3/+5 |
| | | | |||||
* | | | Merge pull request #1013 from lioncash/unused | Yuri Kunde Schlesner | 2015-07-29 | 1 | -3/+0 |
|\ \ \ | |/ / |/| | | dyncom: Remove an unused variable | ||||
| * | | dyncom: Remove an unused variable | Lioncash | 2015-07-29 | 1 | -3/+0 |
| | | | | | | | | | | | | This was used prior to InterpreterTranslate existing. | ||||
* | | | core: Fix missing prototype warnings | Lioncash | 2015-07-29 | 2 | -0/+2 |
|/ / | |||||
* | | Merge pull request #1009 from lioncash/table | Yuri Kunde Schlesner | 2015-07-29 | 1 | -1/+2 |
|\ \ | | | | | | | am_net: Update function table data | ||||
| * | | am_net: Add missing function to the function table | Lioncash | 2015-07-29 | 1 | -0/+1 |
| | | | |||||
| * | | am_net: Add correct function name to the function table | Lioncash | 2015-07-29 | 1 | -1/+1 |
| |/ | |||||
* | | Merge pull request #982 from Subv/home | bunnei | 2015-07-29 | 7 | -18/+84 |
|\ \ | |/ |/| | Service/APT: Return proper parameters in GetLockHandle. | ||||
| * | Service/APT: Fixed a regression, PreloadLibraryApplet should also start an applet when called. | Subv | 2015-07-24 | 6 | -5/+36 |
| | | |||||
| * | Service/APT: Return proper parameters in GetLockHandle. | Subv | 2015-07-24 | 4 | -14/+49 |
| | | | | | | | | | | Documented some APT functions This allows applets to boot. | ||||
* | | dyncom: Handle left-operand PC correctly for data-processing ops | Lioncash | 2015-07-29 | 1 | -7/+33 |
| | | | | | | | | | | | | This is considered deprecated in the ARM manual (using PC as an operand), however, this is still able to be executed on the MPCore (which I'm quite sure would be rare to begin with). | ||||
* | | Merge pull request #899 from zawata/Winsock-Deprecation | bunnei | 2015-07-28 | 1 | -2/+8 |
|\ \ | | | | | | | SOC:U : Fix WinSock function deprecation | ||||
| * | | SOC:U : Update deprecated function gethostbyname() to getaddrinfo() | zawata | 2015-07-20 | 1 | -2/+8 |
| | | | |||||
* | | | Merge pull request #1003 from lioncash/armcruft | bunnei | 2015-07-28 | 6 | -124/+91 |
|\ \ \ | | | | | | | | | dyncom: Minor cleanups. | ||||
| * | | | dyncom: Remove an unnecessary typedef | Lioncash | 2015-07-28 | 2 | -7/+5 |
| | | | | |||||
| * | | | dyncom: Use enum class for instruction decoding results | Lioncash | 2015-07-28 | 5 | -41/+40 |
| | | | | |||||
| * | | | dyncom: Remove code duplication regarding thumb instructions | Lioncash | 2015-07-28 | 3 | -23/+12 |
| | | | | |||||
| * | | | dyncom: Migrate exclusive memory access control into armstate | Lioncash | 2015-07-28 | 2 | -50/+35 |
| | | | | |||||
| * | | | dyncom: Remove duplicated typedef and extern | Lioncash | 2015-07-28 | 1 | -4/+0 |
| | | | | | | | | | | | | | | | | These are already present in arm_dyncom_dec.h. | ||||
* | | | | Merge pull request #873 from jroweboy/input_array | Tony Wasserka | 2015-07-28 | 3 | -24/+45 |
|\ \ \ \ | |/ / / |/| | | | Move input values into an array. | ||||
| * | | | Move input values into an array | James Rowe | 2015-07-28 | 3 | -24/+45 |
| | | | | |||||
* | | | | dyncom: Use std::array for register arrays | Lioncash | 2015-07-26 | 2 | -28/+29 |
| | | | | |||||
* | | | | dyncom: Use ARMul_State as an object | Lioncash | 2015-07-26 | 12 | -1105/+1023 |
| | | | | | | | | | | | | | | | | Gets rid of C-like parameter passing. | ||||
* | | | | dyncom: Remove unnecessary initialization code. | Lioncash | 2015-07-26 | 4 | -59/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | Targeting ARM version variants was only a thing on armemu. The reset routine also does basically the same thing as NewState. | ||||
* | | | | dyncom: Remove unnecessary abort-related cruft | Lioncash | 2015-07-26 | 2 | -48/+1 |
| | | | | | | | | | | | | | | | | Both the MPCore and the ARM9 have the same data abort model (base restored), so differentiating isn't necessary. | ||||
* | | | | dyncom: Rename armdefs.h to armstate.h | Lioncash | 2015-07-26 | 15 | -33/+33 |
| | | | | |||||
* | | | | dyncom: Get rid of skyeye typedefs | Lioncash | 2015-07-26 | 7 | -61/+55 |
| | | | | |||||
* | | | | dyncom: Move helper functions to their own header | Lioncash | 2015-07-26 | 10 | -41/+57 |
| | | | | |||||
* | | | | dyncom: Move arminit.cpp and armsupp.cpp into skyeye_common | Lioncash | 2015-07-26 | 3 | -2/+2 |
|/ / / | |||||
* | | | Merge pull request #989 from lioncash/extern | Yuri Kunde Schlesner | 2015-07-26 | 1 | -25/+25 |
|\ \ \ | | | | | | | | | armdefs: Remove unnecessary extern keywords | ||||
| * | | | armdefs: Remove unnecessary extern keywords | Lioncash | 2015-07-26 | 1 | -25/+25 |
| | | | | |||||
* | | | | loader: Remove unnecessary else usages | Lioncash | 2015-07-26 | 1 | -9/+9 |
|/ / / | |||||
* | | | Merge pull request #888 from zawata/Warning-Fixes-2 | Yuri Kunde Schlesner | 2015-07-25 | 2 | -3/+3 |
|\ \ \ | | | | | | | | | Core\HLE : Fix Warning | ||||
| * | | | Core\HLE : Fix Warning | zawata | 2015-07-17 | 2 | -3/+3 |
| |/ / | | | | | | | | | | "signed/unsigned mismatch" | ||||
* | | | Merge pull request #892 from zawata/another-warning-fixes | Yuri Kunde Schlesner | 2015-07-25 | 2 | -2/+2 |
|\ \ \ | | | | | | | | | Yet More Warning Fixes | ||||
| * | | | Core : Change variable type | zawata | 2015-07-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | and fix various warnings | ||||
| * | | | Core : Fix Conversion Warnings | zawata | 2015-07-19 | 1 | -1/+1 |
| | | | | |||||
* | | | | Merge pull request #983 from yuriks/null-memory-fill | Yuri Kunde Schlesner | 2015-07-24 | 1 | -13/+18 |
|\ \ \ \ | | | | | | | | | | | GSP: Don't try to write memory fill registers if start address is 0 | ||||
| * | | | | GSP: Don't try to write memory fill registers if start address is 0 | Yuri Kunde Schlesner | 2015-07-24 | 1 | -13/+18 |
| | |_|/ | |/| | | | | | | | | | | | | | | Verified to be what GSP does via REing. Fixes invalid virt->phys translation error spam in some games. | ||||
* / | | | Qt/GPU Breakpoints: Added three more breakpoint types: | Subv | 2015-07-23 | 2 | -0/+11 |
|/ / / | | | | | | | | | | | | | | | | * IncomingDisplayTransfer: Triggered just before a display transfer is performed. * GSPCommandProcessed: Triggered right after a GSP command is processed. * BufferSwapped: Triggered when the frames flip | ||||
* | | | Merge pull request #962 from Subv/am_app | bunnei | 2015-07-22 | 3 | -3/+33 |
|\ \ \ | | | | | | | | | Services/AM: Stubbed am:app::GetNumContentInfos to return 0 results. | ||||
| * | | | Services/AM: Stubbed am:app::GetNumContentInfos to return 0 results. | Subv | 2015-07-21 | 3 | -3/+33 |
| | | | | | | | | | | | | | | | | | | | | | | | | Named the service functions in am:app as per 3dbrew. This fixes an illegal read loop in Steel Diver | ||||
* | | | | Merge pull request #966 from Subv/log | bunnei | 2015-07-21 | 1 | -4/+8 |
|\ \ \ \ | | | | | | | | | | | Services/Logging: Log more useful information when some operations fail. | ||||
| * | | | | Services/Logging: Log more useful information when some operations fail. | Subv | 2015-07-21 | 1 | -4/+8 |
| |/ / / | | | | | | | | | | | | | Namely OpenFileDirectly, OpenDirectory and OpenArchive | ||||
* | | | | Merge pull request #957 from Subv/hwtest_crash | bunnei | 2015-07-21 | 1 | -0/+8 |
|\ \ \ \ | | | | | | | | | | | Kernel/Scheduling: Clean up a thread's wait_objects when its scheduled. | ||||
| * | | | | Kernel/Scheduling: Clean up a thread's wait_objects when its scheduled. | Subv | 2015-07-21 | 1 | -0/+8 |
| |/ / / | | | | | | | | | | | | | They'll be reset if needed during the next svcWaitSynchronization call (if there's any pending) | ||||
* | | | | dyncom: Pass SVC immediates directly. | Lioncash | 2015-07-21 | 3 | -6/+6 |
| | | | | | | | | | | | | | | | | Previously it would just re-read the already decoded instruction and extract the immediate value. | ||||
* | | | | Services/CFG: Added some missing functions to cfg:s | Subv | 2015-07-21 | 1 | -1/+3 |
|/ / / | |||||
* | | | Merge pull request #939 from Subv/queryprocmem | bunnei | 2015-07-20 | 2 | -6/+28 |
|\ \ \ | | | | | | | | | Kernel/SVC: Implemented svcQueryProcessMemory | ||||
| * | | | Kernel/SVC: Implemented svcQueryProcessMemory | Subv | 2015-07-17 | 2 | -6/+28 |
| | | | | |||||
* | | | | Merge pull request #951 from Subv/bit5 | bunnei | 2015-07-20 | 2 | -12/+31 |
|\ \ \ \ | | | | | | | | | | | GPU/DisplayTransfer: Implemented bit 5 in the transfer flags. | ||||
| * | | | | GPU/DisplayTransfer: Implemented bit 5 in the transfer flags. | Subv | 2015-07-20 | 2 | -12/+31 |
| | | | | | | | | | | | | | | | | | | | | It tells the GPU to not swizzle/de-swizzle the input during the transfer. | ||||
* | | | | | Merge pull request #946 from archshift/update-frdu | bunnei | 2015-07-20 | 1 | -1/+12 |
|\ \ \ \ \ | | | | | | | | | | | | | Add more frd:u unknown service commands from 3dbrew | ||||
| * | | | | | Add more frd:u unknown service commands from 3dbrew | archshift | 2015-07-19 | 1 | -1/+12 |
| | |_|/ / | |/| | | | |||||
* | | | | | dyncom: Properly retrieve the PC value in BX if used. | Lioncash | 2015-07-20 | 1 | -3/+5 |
| |/ / / |/| | | | |||||
* | | | | Change trace/unimplemented service call logs to use hex | archshift | 2015-07-19 | 1 | -1/+1 |
|/ / / | | | | | | | | | | Changes the log to use hex in the parameter list instead of decimal. | ||||
* / / | Dyncom: Support for a missing ARMv6 Thumb MOV encoding | Yuri Kunde Schlesner | 2015-07-18 | 1 | -10/+4 |
|/ / | |||||
* | | Merge pull request #938 from Subv/querymem | Yuri Kunde Schlesner | 2015-07-17 | 2 | -4/+24 |
|\ \ | | | | | | | Kernel/SVC: Implemented svcQueryMemory. | ||||
| * | | Kernel/SVC: Implemented svcQueryMemory. | Subv | 2015-07-17 | 2 | -4/+24 |
| | | | |||||
* | | | Merge pull request #937 from yuriks/codeset-leak | bunnei | 2015-07-17 | 12 | -8/+45 |
|\ \ \ | |/ / |/| | | Ensure all kernel objects are released during shutdown | ||||
| * | | Ensure all kernel objects are released during shutdown | Yuri Kunde Schlesner | 2015-07-17 | 12 | -8/+45 |
| | | | | | | | | | | | | | | | | | | | | | | | | This commit fixes several kernel object leaks. The most severe of them was threads not being removed from the private handle table used for CoreTiming events. This resulted in Threads never being released, which in turn held references to Process, causing CodeSets to never be freed when loading other applications. | ||||
* | | | arm_dyncom_interpreter: Simplify assignment in SMLAW | Lioncash | 2015-07-17 | 1 | -1/+1 |
|/ / | | | | | | | Also a side-benefit of not having implementation-defined behavior. | ||||
* | | Merge pull request #918 from yuriks/romfs | bunnei | 2015-07-17 | 17 | -97/+111 |
|\ \ | | | | | | | Do not load entire RomFS to memory, read from the file as needed instead (rebased) | ||||
| * | | Loader: Fix variable type and remove unused variable | Yuri Kunde Schlesner | 2015-07-14 | 1 | -2/+1 |
| | | | |||||
| * | | Archive: Correct a few incorrect types in function signatures | Yuri Kunde Schlesner | 2015-07-14 | 6 | -22/+22 |
| | | | | | | | | | | | | Buffer lengths should be size_t, and file offsets should be u64. | ||||
| * | | Loader: Remove unnecessary pointer indirection to IOFile | Yuri Kunde Schlesner | 2015-07-14 | 10 | -50/+50 |
| | | | |||||
| * | | FS: Stream RomFS from file instead of loading all of it to memory | condut | 2015-07-14 | 9 | -32/+47 |
| | | | |||||
* | | | Merge pull request #904 from aroulin/y2r-narrowing-warning | archshift | 2015-07-14 | 1 | -1/+1 |
|\ \ \ | |/ / |/| | | Y2R: Fix narrowing warning | ||||
| * | | Y2R: Fix narrowing warning | aroulin | 2015-07-12 | 1 | -1/+1 |
| | | | |||||
* | | | CiTrace: Clean up initialization method. | Tony Wasserka | 2015-07-13 | 2 | -70/+46 |
| | | | |||||
* | | | CiTrace: Record default vertex attributes. | Tony Wasserka | 2015-07-13 | 4 | -43/+57 |
| | | | |||||
* | | | Add CiTrace recording support. | Tony Wasserka | 2015-07-13 | 7 | -1/+419 |
| | | | | | | | | | | | | | | | | | | This is exposed in the GUI as a new "CiTrace Recording" widget. Playback is implemented by a standalone 3DS homebrew application (which only runs reliably within Citra currently; on an actual 3DS it will often crash still). | ||||
* | | | GPU: Be robust against nullptr addresses; properly reset busy bits in the trigger registers. | Tony Wasserka | 2015-07-13 | 1 | -27/+34 |
| | | | |||||
* | | | HW: Fix a stupid issue which led to unknown register reads/writes. | Tony Wasserka | 2015-07-13 | 1 | -0/+30 |
| | | | |||||
* | | | Merge pull request #921 from linkmauve/fix-applet | bunnei | 2015-07-12 | 7 | -7/+32 |
|\ \ \ | | | | | | | | | Fix applet includes using iwyu | ||||
| * | | | Core: Fix applet includes using iwyu. | Emmanuel Gil Peyrot | 2015-07-12 | 7 | -7/+32 |
| |/ / | |||||
* / / | Kernel: Add CodeSet case to Object::IsWaitable | Yuri Kunde Schlesner | 2015-07-12 | 1 | -0/+1 |
|/ / | |||||
* | | Merge pull request #823 from Subv/applets_drawing | bunnei | 2015-07-12 | 11 | -58/+567 |
|\ \ | | | | | | | Library applet support (swkbd for now) | ||||
| * | | Applets: Reworked how the Applet update event is handled. | Subv | 2015-07-12 | 7 | -35/+61 |
| | | | | | | | | | | | | Applets are now cleaned up in AppletUpdateEvent after calling their respective Update method. | ||||
| * | | Applets: Add infrastructure to allow custom drawing and input handling in Applets. | Subv | 2015-07-12 | 7 | -39/+162 |
| | | | |||||
| * | | HLE/APT: Initial HLE support for applets. | Subv | 2015-07-12 | 9 | -50/+410 |
| | | | | | | | | | | | | Currently only the SWKBD is emulated, and there's currently no way to ask the user for input, so it always returns "Subv" as the text. | ||||
* | | | Core: Properly configure address space when loading a binary | Yuri Kunde Schlesner | 2015-07-12 | 11 | -52/+223 |
| | | | | | | | | | | | | | | | | | | The code now properly configures the process image to match the loaded binary segments (code, rodata, data) instead of just blindly allocating a large chunk of dummy memory. | ||||
* | | | Memory: Fix unmapping of pages | Yuri Kunde Schlesner | 2015-07-12 | 1 | -4/+2 |
| | | | |||||
* | | | Loader: Clean up 3dsx loader a bit, fixing a potential buffer overrun | Yuri Kunde Schlesner | 2015-07-12 | 1 | -13/+16 |
| | | | |||||
* | | | Loader: Make 3dsx loader logs a bit less confusing | Yuri Kunde Schlesner | 2015-07-12 | 1 | -6/+3 |
| | | | |||||
* | | | Kernel: Remove unused member from Event | Yuri Kunde Schlesner | 2015-07-12 | 2 | -2/+1 |
|/ / | |||||
* | | Merge pull request #876 from linkmauve/include-cleanups | Yuri Kunde Schlesner | 2015-07-11 | 59 | -120/+203 |
|\ \ | | | | | | | Cleanup includes, mostly in common | ||||
| * | | Core: Cleanup hw includes. | Emmanuel Gil Peyrot | 2015-06-28 | 8 | -7/+18 |
| | | | |||||
| * | | Core: Cleanup soc:U includes. | Emmanuel Gil Peyrot | 2015-06-28 | 2 | -26/+36 |
| | | | |||||
| * | | Core, VideoCore: Replace or fix exit() calls. | Emmanuel Gil Peyrot | 2015-06-28 | 2 | -4/+6 |
| | | | |||||
| * | | Core: Cleanup file_sys includes. | Emmanuel Gil Peyrot | 2015-06-28 | 21 | -38/+72 |
| | | | |||||
| * | | Core: Cleanup core includes. | Emmanuel Gil Peyrot | 2015-06-28 | 8 | -14/+14 |
| | | | |||||
| * | | CitraQt: Cleanup includes. | Emmanuel Gil Peyrot | 2015-06-28 | 8 | -4/+17 |
| | | | |||||
| * | | Common: Cleanup key_map includes. | Emmanuel Gil Peyrot | 2015-06-28 | 10 | -16/+22 |
| | | | |||||
| * | | Common: Cleanup memory and misc includes. | Emmanuel Gil Peyrot | 2015-06-28 | 3 | -3/+4 |
| | | | |||||
| * | | Common: Fix FileUtil includes, and everything relying on those. | Emmanuel Gil Peyrot | 2015-06-28 | 7 | -0/+7 |
| | | | |||||
| * | | Services: Use the standard _WIN32 define in soc:U instead of our own EMU_PLATFORM. | Emmanuel Gil Peyrot | 2015-06-27 | 1 | -8/+7 |
| |/ | |||||
* | | Loader: Remove log line causing warning | aroulin | 2015-07-08 | 1 | -1/+0 |
| | | |||||
* | | Merge pull request #797 from linkmauve/blended-downscaling | bunnei | 2015-07-06 | 1 | -33/+46 |
|\ \ | | | | | | | Implement blended downscaling for display transfers | ||||
| * | | GPU: Implement blended downscaling for display transfers. | Emmanuel Gil Peyrot | 2015-06-28 | 1 | -27/+40 |
| | | | |||||
| * | | GPU: Use shifts instead of multiplications to calculate the actual size of the output. | Emmanuel Gil Peyrot | 2015-06-28 | 1 | -6/+6 |
| |/ | |||||
* | | Merge pull request #885 from Subv/ipc_headers | bunnei | 2015-07-06 | 1 | -5/+13 |
|\ \ | | | | | | | Services/SOC: Added command headers to some of the soc commands. | ||||
| * | | Services/SOC: Added command headers to some of the soc commands. | Subv | 2015-06-25 | 1 | -5/+13 |
| |/ | |||||
* | | vfp: Change return type of VFPInit from unsigned int to void. | Lioncash | 2015-06-29 | 2 | -4/+2 |
| | | |||||
* | | vfp: Handle accesses to FPINST/FPINST2 system registers | Lioncash | 2015-06-29 | 4 | -42/+53 |
|/ | | | | Also has a side-benefit of correcting access to the FPEXC register. | ||||
* | Add helpers to create IPC command buffer headers and descriptors | Yuri Kunde Schlesner | 2015-06-23 | 3 | -7/+43 |
| | |||||
* | Merge pull request #860 from yuriks/y2r-color | Yuri Kunde Schlesner | 2015-06-22 | 5 | -174/+734 |
|\ | | | | | Color support for Y2R | ||||
| * | Y2R: Rework conversion process, enabling support for all formats | Yuri Kunde Schlesner | 2015-06-22 | 5 | -163/+695 |
| | | |||||
| * | Y2R: Re-organize how params are stored. Support SetConversionParams | Yuri Kunde Schlesner | 2015-06-21 | 1 | -72/+100 |
| | | |||||
* | | Merge pull request #855 from purpasmart96/service_rearrangment | bunnei | 2015-06-21 | 73 | -635/+1186 |
|\ \ | |/ |/| | Services: Continue separation of services into their own folders | ||||
| * | Services: Continue separation of services into their own folders | purpasmart96 | 2015-06-12 | 73 | -635/+1186 |
| | | |||||
* | | kernel: Fix svcWaitSynch to always acquire requested wait objects. | bunnei | 2015-06-17 | 9 | -113/+68 |
| | | |||||
* | | Merge pull request #866 from lioncash/typo | Lioncash | 2015-06-16 | 1 | -1/+1 |
|\ \ | | | | | | | hw: Fix mismatched Write call | ||||
| * | | hw: Fix mismatched Write call | Lioncash | 2015-06-16 | 1 | -1/+1 |
| |/ | |||||
* | | vfp: Handle accesses to the VFP media feature registers | Lioncash | 2015-06-13 | 3 | -4/+8 |
| | | | | | | | | These are able to be accessed in any privilege mode. | ||||
* | | vfp: Implement VMOVBCR/VMOVBRC | Lioncash | 2015-06-12 | 2 | -5/+8 |
|/ | |||||
* | arm_dyncom_thumb: Fix handling of writeback for thumb LDMIA | Lioncash | 2015-06-04 | 1 | -5/+19 |
| | |||||
* | ExtSavedata: Save the icon passed to CreateExtSaveData to the correct folder. | Subv | 2015-06-02 | 4 | -14/+38 |
| | | | | Organize the ExtSaveData folders as they are stored in the console. | ||||
* | Merge pull request #838 from lioncash/thumb | Lioncash | 2015-06-01 | 1 | -3/+40 |
|\ | | | | | arm_dyncom_thumb: Implement missing instructions. | ||||
| * | arm_dyncom_thumb: Fix encoding of BKPT's immediate | Lioncash | 2015-06-01 | 1 | -1/+4 |
| | | |||||
| * | arm_dyncom_thumb: Implement CPS and SETEND | Lioncash | 2015-06-01 | 1 | -0/+13 |
| | | |||||
| * | arm_dyncom_thumb: Implement SXTH, SXTB, UXTH, and UXTB. | Lioncash | 2015-06-01 | 1 | -0/+11 |
| | | |||||
| * | arm_dyncom_thumb: Implement REV, REV16, and REVSH. | Lioncash | 2015-06-01 | 1 | -2/+12 |
| | | |||||
* | | Merge pull request #811 from archshift/commonify | archshift | 2015-05-31 | 1 | -1/+1 |
|\ \ | | | | | | | Commonify video_core utility headers | ||||
| * | | Move video_core/color.h to common/color.h | archshift | 2015-05-30 | 1 | -1/+1 |
| |/ | |||||
* | | Merge pull request #832 from yuriks/refresh-rate-option | bunnei | 2015-05-31 | 2 | -4/+2 |
|\ \ | |/ |/| | Remove gpu_refresh_rate configuration option | ||||
| * | Remove gpu_refresh_rate configuration option | Yuri Kunde Schlesner | 2015-05-30 | 2 | -4/+2 |
| | | | | | | | | | | | | | | Changing it makes emulation inherently inaccurate. It also had a wrong default value (30, whereas the real system has a refresh rate of 60 Hz) which, even if changed, would continue to be used unless people manually removed it from their config files. | ||||
* | | Merge pull request #810 from yuriks/memmap | Yuri Kunde Schlesner | 2015-05-30 | 7 | -38/+491 |
|\ \ | | | | | | | Kernel: Add VMManager to manage process address spaces | ||||
| * | | Memmap: Remove unused global pointers to memory areas | Yuri Kunde Schlesner | 2015-05-27 | 2 | -31/+8 |
| | | | |||||
| * | | Kernel: Add VMManager to manage process address spaces | Yuri Kunde Schlesner | 2015-05-27 | 6 | -16/+492 |
| | | | | | | | | | | | | | | | | | | | | | | | | This enables more dynamic management of the process address space, compared to just directly configuring the page table for major areas. This will serve as the foundation upon which the rest of the Kernel memory management functions will be built. | ||||
* | | | Remove every trailing whitespace from the project (but externals). | Emmanuel Gil Peyrot | 2015-05-29 | 38 | -105/+105 |
| |/ |/| | |||||
* | | hid: Get rid of undefined behavior | Lioncash | 2015-05-27 | 1 | -2/+2 |
|/ | | | | Modifying a variable twice across a sequence point. | ||||
* | Merge pull request #826 from lioncash/tables | Yuri Kunde Schlesner | 2015-05-27 | 1 | -22/+11 |
|\ | | | | | arm_dyncom_thumb: Merge STR/LDR table subsets. | ||||
| * | arm_dyncom_thumb: Merge STR/LDR table subsets. | Lioncash | 2015-05-27 | 1 | -22/+11 |
| | | |||||
* | | Merge pull request #825 from lioncash/dync | Lioncash | 2015-05-27 | 1 | -6/+1 |
|\ \ | | | | | | | dyncom: Minor cleanup. | ||||
| * | | arm_dyncom_interpreter: Remove unused variable | Lioncash | 2015-05-26 | 1 | -5/+1 |
| | | | | | | | | | | | | Thum decoding directly checks if the thumb bit is set instead of using a temporary. | ||||
| * | | arm_dyncom_interpreter: Remove unused macro | Lioncash | 2015-05-25 | 1 | -1/+0 |
| |/ | |||||
* | | Merge pull request #821 from Subv/ImportDisplayCaptureInfo | bunnei | 2015-05-26 | 1 | -1/+47 |
|\ \ | | | | | | | Service/GSP: Implemented ImportDisplayCaptureInfo. | ||||
| * | | Service/GSP: Implemented ImportDisplayCaptureInfo. | Subv | 2015-05-26 | 1 | -1/+47 |
| |/ | |||||
* / | Core/SVC: Map the shared memory created in CreateMemoryBlock to the specified address. | Subv | 2015-05-25 | 1 | -0/+2 |
|/ | | | | This SharedMemory can be passed to service functions (Which should map the memory into their own address space). | ||||
* | dyncom: Get rid of armemu.h | Lioncash | 2015-05-24 | 5 | -50/+29 |
| | |||||
* | y2r_u: Remove unused variable in StartConversion | Lioncash | 2015-05-23 | 1 | -1/+0 |
| | |||||
* | dyncom: Remove unused cpu parameter from decode_thumb_instr | Lioncash | 2015-05-23 | 1 | -3/+2 |
| | |||||
* | dyncom: remove load_r15 from arm_inst | Lioncash | 2015-05-23 | 2 | -490/+331 |
| | | | | It's entirely unused. Also allows getting rid of more clunky macros. | ||||
* | dyncom: Remove unnecessary parameter for load/store operations | Lioncash | 2015-05-23 | 1 | -39/+39 |
| | |||||
* | Merge pull request #801 from purpasmart96/hid_stubs | bunnei | 2015-05-23 | 4 | -9/+47 |
|\ | | | | | HID: Stub DisableAccelerometer and DisableGyroscopeLow | ||||
| * | HID: Stub DisableAccelerometer and DisableGyroscopeLow | purpasmart96 | 2015-05-23 | 4 | -9/+47 |
| | | |||||
* | | Merge pull request #802 from bunnei/vfp-trace-log | Lioncash | 2015-05-23 | 1 | -23/+23 |
|\ \ | | | | | | | VFP: Log as trace to get rid of spamming. | ||||
| * | | VFP: Log as trace to get rid of spamming. | bunnei | 2015-05-23 | 1 | -23/+23 |
| |/ | |||||
* | | Flush for y2r (moflex) | tfarley | 2015-05-23 | 1 | -0/+11 |
| | | |||||
* | | OpenGL renderer | tfarley | 2015-05-23 | 2 | -3/+22 |
| | | |||||
* | | INI hw/sw renderer toggle | tfarley | 2015-05-22 | 1 | -0/+2 |
|/ | |||||
* | Merge pull request #798 from yuriks/y2r-bw | Yuri Kunde Schlesner | 2015-05-22 | 1 | -35/+265 |
|\ | | | | | Service::Y2R: Support for grayscale decoding of specific formats | ||||
| * | Service::Y2R: Support for grayscale decoding of specific formats | Yuri Kunde Schlesner | 2015-05-22 | 1 | -35/+265 |
| | | | | | | | | | | | | | | | | | | | | | | | | Implements unrotated planar YUV 4:2:0 -> RGB24 conversions in Y2R. Currently only the Y (luma) channel is used, so the results don't contain color. This will be added in a later PR at some point. This is enough to get all currently know Moflex videos to decode. (Some don't display on-screen due to seemingly unrelated reasons.) Thanks to @archshift for doing the initial implementation which I cleaned up and then fixed the 8x8 block mode. | ||||
* | | dyncom: Eliminate clang warnings | Lioncash | 2015-05-21 | 4 | -406/+404 |
|/ | | | | Gets rid of a whole load of missing brace initialization warnings. | ||||
* | Kernel: Fix a warning introduced with ResourceLimit, and remove the fallback code to prevent it from happening again. | Emmanuel Gil Peyrot | 2015-05-21 | 1 | -2/+1 |
| | |||||
* | y2r_u: Stub StartConversion to prevent moflex games from hanging. | bunnei | 2015-05-21 | 1 | -1/+17 |
| | |||||
* | Kernel: Move reschedules from SVCs to actual mechanisms that reschedule. | bunnei | 2015-05-21 | 7 | -20/+22 |
| | |||||
* | Merge pull request #766 from purpasmart96/cfg_service_update | bunnei | 2015-05-18 | 5 | -337/+304 |
|\ | | | | | CFG: Update the cfg service to be like other integrated services | ||||
| * | CFG: Update the cfg service to be like other integrated services | purpasmart96 | 2015-05-16 | 5 | -337/+304 |
| | | |||||
* | | Merge pull request #772 from lioncash/warn | bunnei | 2015-05-18 | 3 | -9/+9 |
|\ \ | | | | | | | core/video_core: Fix a few warnings when compiling on MSVC. | ||||
| * | | vfp: Get rid of warnings | Lioncash | 2015-05-14 | 2 | -6/+6 |
| | | | | | | | | | | | | | | | - Unary minus operator applied to unsigned type. - Unsafe use of bool. | ||||
| * | | process: Get rid of warnings | Lioncash | 2015-05-14 | 1 | -3/+3 |
| | | | | | | | | | | | | Sign mismatches and "forcing value to bool" warnings. | ||||
* | | | Implement svcBreak | archshift | 2015-05-17 | 2 | -1/+17 |
| | | | |||||
* | | | Merge pull request #781 from archshift/delete | bunnei | 2015-05-16 | 1 | -33/+0 |
|\ \ \ | | | | | | | | | Delete unused hle/coprocessor.cpp | ||||
| * | | | Delete unused hle/coprocessor.cpp | archshift | 2015-05-16 | 1 | -33/+0 |
| | | | | |||||
* | | | | APT/FS: Remove asserts that were causing false positives | purpasmart96 | 2015-05-16 | 2 | -5/+5 |
|/ / / | |||||
* | | | Merge pull request #774 from lioncash/decodings | Yuri Kunde Schlesner | 2015-05-15 | 2 | -33/+191 |
|\ \ \ | | | | | | | | | dyncom: Add ARMv6K NOP and hint instructions to the interpreter. | ||||
| * | | | dyncom: Add ARMv6K NOP and hint instructions to the decoding table | Lioncash | 2015-05-14 | 2 | -12/+152 |
| | | | | |||||
| * | | | dyncom: Handle some MSR variants individually | Lioncash | 2015-05-14 | 2 | -24/+41 |
| | | | | | | | | | | | | | | | | This is necessary, as hint instructions will be recognized as MSR, which is pretty bad. | ||||
| * | | | dyncom: Move exclusive load/stores above bbl and swi in the decoding table | Lioncash | 2015-05-14 | 2 | -14/+15 |
| |/ / | |||||
* | | | Merge pull request #770 from lioncash/dyncom_clean | bunnei | 2015-05-15 | 2 | -275/+260 |
|\ \ \ | | | | | | | | | dyncom: Minor cleanup. | ||||
| * | | | dyncom: Remove duplicate enums/prototypes | Lioncash | 2015-05-14 | 1 | -7/+1 |
| | | | | | | | | | | | | | | | | These are already defined in arm_dyncom_interpreter_dec.cpp. | ||||
| * | | | dyncom: Remove unnecessary defines | Lioncash | 2015-05-14 | 1 | -4/+4 |
| | | | | | | | | | | | | | | | | These can simply be const vars. | ||||
| * | | | dyncom: Make translation-unit functions and variables static | Lioncash | 2015-05-14 | 1 | -66/+64 |
| | | | | |||||
| * | | | dyncom: Remove unnecessary typedefs | Lioncash | 2015-05-14 | 2 | -196/+197 |
| | | | | |||||
| * | | | dyncom: Remove unused structs | Lioncash | 2015-05-14 | 1 | -8/+0 |
| |/ / | |||||
* | | | Core/ResourceLimits: Implemented the basic structure of ResourceLimits. | Subv | 2015-05-15 | 12 | -14/+341 |
| | | | | | | | | | | | | | | | | | | Implemented svcs GetResourceLimit, GetResourceLimitCurrentValues and GetResourceLimitLimitValues. Note that the resource limits do not currently keep track of used objects, since we have no way to distinguish between an object created by the application, and an object created by some HLE module once we're inside Kernel::T::Create. | ||||
* | | | Memory: Use a table based lookup scheme to read from memory regions | Yuri Kunde Schlesner | 2015-05-15 | 5 | -128/+174 |
| | | | |||||
* | | | Memory: Read SharedPage directly from Memory::Read | Yuri Kunde Schlesner | 2015-05-15 | 3 | -59/+37 |
| | | | |||||
* | | | Memory: Read ConfigMem directly from Memory::Read | Yuri Kunde Schlesner | 2015-05-15 | 3 | -50/+38 |
| | | | |||||
* | | | Memmap: Re-organize memory function in two files | Yuri Kunde Schlesner | 2015-05-15 | 26 | -257/+247 |
| | | | | | | | | | | | | | | | | | | | | | memory.cpp/h contains definitions related to acessing memory and configuring the address space mem_map.cpp/h contains higher-level definitions related to configuring the address space accoording to the kernel and allocating memory. | ||||
* | | | Memmap: Remove unused declarations | Yuri Kunde Schlesner | 2015-05-15 | 2 | -20/+3 |
| | | | |||||
* | | | thread: Fix a conditional check in Reschedule | Lioncash | 2015-05-14 | 1 | -1/+1 |
|/ / | |||||
* | | dyncom: Removed irrelevant log. | bunnei | 2015-05-14 | 1 | -2/+0 |
| | | |||||
* | | dyncom: Fix decoding of BKPT's immediate | Lioncash | 2015-05-13 | 1 | -1/+1 |
|/ | | | | A shift here is intended since the representation is imm12:imm4 | ||||
* | Merge pull request #756 from purpasmart96/ptm_service_changes | bunnei | 2015-05-13 | 5 | -125/+112 |
|\ | | | | | PTM: Changed the ptm services to be like the IR, HID, and APT services. | ||||
| * | PTM: Changed the way the ptm services are handled to be like the | purpasmart96 | 2015-05-12 | 5 | -125/+112 |
| | | | | | | | | IR, HID, and APT services. | ||||
* | | Merge pull request #748 from Subv/tls_max | bunnei | 2015-05-12 | 4 | -10/+24 |
|\ \ | | | | | | | Core/Memory: Add TLS support for creating up to 300 threads | ||||
| * | | Core/Memory: Add TLS support for creating up to 300 threads | Subv | 2015-05-12 | 4 | -10/+24 |
| | | | |||||
* | | | Merge pull request #751 from yuriks/idle-thread | bunnei | 2015-05-12 | 3 | -46/+21 |
|\ \ \ | | | | | | | | | Thread: Remove the idle thread | ||||
| * | | | Thread: Remove the idle thread | Yuri Kunde Schlesner | 2015-05-12 | 3 | -46/+21 |
| | | | | | | | | | | | | | | | | Instead just use nullptr to represent no thread is active. | ||||
* | | | | Merge pull request #757 from Subv/scheduling | bunnei | 2015-05-12 | 1 | -0/+2 |
|\ \ \ \ | | | | | | | | | | | Core/Scheduling: Prepare the new priority in the thread queue when svcSetPriority is called | ||||
| * | | | | Core/Scheduling: Prepare the new priority in the thread queue when svcSetPriority is called | Subv | 2015-05-12 | 1 | -0/+2 |
| |/ / / | |||||
* | | | | Merge pull request #752 from lioncash/flush | bunnei | 2015-05-12 | 3 | -84/+98 |
|\ \ \ \ | | | | | | | | | | | vfp: Handle flush-to-zero mode. | ||||
| * | | | | vfp: Handle flush-to-zero mode. | Lioncash | 2015-05-11 | 3 | -84/+98 |
| |/ / / | |||||
* | | | | Merge pull request #755 from lioncash/mcrr-mrrc | bunnei | 2015-05-12 | 1 | -7/+68 |
|\ \ \ \ | |_|/ / |/| | | | dyncom: Stub MCRR and MRRC | ||||
| * | | | dyncom: Stub MCRR and MRRC | Lioncash | 2015-05-12 | 1 | -7/+68 |
| |/ / | | | | | | | | | | | | | There's no other coprocessor outside the VFP (which has its own VMOV variants) in which the MPCore can send/retrieve data from. Stubbed so citra won't crash and burn on the odd chance someone actually tries to use these. | ||||
* | | | Merge pull request #750 from Subv/process_svc | Yuri Kunde Schlesner | 2015-05-12 | 6 | -4/+46 |
|\ \ \ | |_|/ |/| | | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThread | ||||
| * | | fixup! | Subv | 2015-05-12 | 3 | -16/+12 |
| | | | |||||
| * | | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThread | Subv | 2015-05-11 | 6 | -4/+50 |
| | | | |||||
* | | | NWM_UDS: Fix a typo in the nwm service port name | purpasmart96 | 2015-05-12 | 1 | -1/+1 |
| |/ |/| | |||||
* | | Thread: Correctly set main thread initial stack position | Yuri Kunde Schlesner | 2015-05-11 | 3 | -5/+4 |
|/ | |||||
* | Merge pull request #740 from yuriks/gsp-shmem | archshift | 2015-05-11 | 7 | -34/+67 |
|\ | | | | | Fix crashes due to un-initialized GSP shared memory | ||||
| * | fixup! GSP: Small tweaks to shared memory initialization | Yuri Kunde Schlesner | 2015-05-11 | 1 | -1/+1 |
| | | |||||
| * | GSP: Small tweaks to shared memory initialization | Yuri Kunde Schlesner | 2015-05-11 | 1 | -9/+11 |
| | | |||||
| * | Kernel: Zero-fill shared memory blocks when mapping | Yuri Kunde Schlesner | 2015-05-11 | 1 | -0/+8 |
| | | | | | | | | | | | | This works around crashes related to GSP/HID/etc. shared memory blocks having garbage values. The proper fix requires proper management of mapped memory blocks in the process. | ||||
| * | Kernel: Capture SharedMemory attributes at creation, not when mapping | Yuri Kunde Schlesner | 2015-05-11 | 7 | -28/+51 |
| | | |||||
* | | fixup! Set the TLS address in the scheduler | Subv | 2015-05-11 | 6 | -11/+10 |
| | | |||||
* | | Core/Memory: Give every emulated thread it's own TLS area. | Subv | 2015-05-11 | 8 | -11/+31 |
|/ | | | | | The TLS area for thread T with id Ti is located at TLS_AREA_VADDR + (Ti - 1) * 0x200. This allows some games like Mario Kart 7 to continue further. | ||||
* | Common: Remove the BIT macro | Yuri Kunde Schlesner | 2015-05-09 | 1 | -2/+2 |
| | | | | | | | When the macro was introduced in 326ec51261299e48de97592631c02523da9c8118 it wasn't noticed that it conflicted in name with a heavily used macro inside of dyncom. This causes some compiler warnings. Since it's only lightly used, it was opted to simply remove the new macro. | ||||
* | Merge pull request #734 from yuriks/memmap | Tony Wasserka | 2015-05-09 | 10 | -167/+181 |
|\ | | | | | Small memory map definitions cleanup | ||||
| * | Memory: Add GetPhysicalPointer helper function | Yuri Kunde Schlesner | 2015-05-09 | 2 | -5/+14 |
| | | |||||
| * | Memory: Support more regions in the VAddr-PAddr translation functions | Yuri Kunde Schlesner | 2015-05-09 | 2 | -28/+33 |
| | | | | | | | | | | Also adds better documentation and removes the one-off reimplementation of the function in pica.h. | ||||
| * | Memory: Sort memory region variables by VAddr | Yuri Kunde Schlesner | 2015-05-09 | 2 | -10/+10 |
| | | |||||
| * | Memory: Re-organize and rename memory area address constants | Yuri Kunde Schlesner | 2015-05-09 | 9 | -131/+131 |
| | | |||||
* | | Loader: Add missing include | Yuri Kunde Schlesner | 2015-05-09 | 1 | -0/+1 |
|/ | |||||
* | Loader: Remove .bin file support | Yuri Kunde Schlesner | 2015-05-09 | 2 | -20/+0 |
| | | | | | It is of very limited practical utility currently, and will soon be impossible to support due to more accurate memory map emulation. | ||||
* | Kernel: Remove unused g_main_thread variable | Yuri Kunde Schlesner | 2015-05-09 | 3 | -5/+1 |
| | |||||
* | Process: Rename StaticAddressMapping => AddressMapping | Yuri Kunde Schlesner | 2015-05-09 | 6 | -10/+10 |
| | |||||
* | Process: Add more documentation to the class members | Yuri Kunde Schlesner | 2015-05-09 | 1 | -2/+16 |
| | |||||
* | Process: Use BitField to store process flags | Yuri Kunde Schlesner | 2015-05-09 | 2 | -16/+24 |
| | |||||
* | Loader/NCCH: Fix formatting of braces | Yuri Kunde Schlesner | 2015-05-09 | 1 | -9/+9 |
| | |||||
* | Process: Support parsing of exheader kernel caps | Yuri Kunde Schlesner | 2015-05-09 | 6 | -4/+77 |
| | |||||
* | Kernel: Remove g_program_id | Yuri Kunde Schlesner | 2015-05-09 | 6 | -21/+3 |
| | | | | This has been obsoleted by the field in Process. | ||||
* | Kernel: Introduce skeleton Process class to hold process data | Yuri Kunde Schlesner | 2015-05-09 | 13 | -48/+191 |
| | |||||
* | Core: Fix sorting in CMakeFiles.txt | Yuri Kunde Schlesner | 2015-05-08 | 1 | -21/+21 |
| | |||||
* | Merge pull request #728 from lioncash/vars | Lioncash | 2015-05-08 | 1 | -19/+17 |
|\ | | | | | dyncom: Remove an unnecessary variable in the interpreter | ||||
| * | dyncom: Remove an unnecessary variable in the interpreter | Lioncash | 2015-05-08 | 1 | -19/+17 |
| | | | | | | | | All this was doing was needlessly aliasing a variable. | ||||
* | | Remove unnecessary dyncom header files | Lioncash | 2015-05-08 | 6 | -82/+2 |
|/ | |||||
* | Common: Remove mem_arena.cpp/h | Yuri Kunde Schlesner | 2015-05-08 | 2 | -94/+31 |
| | | | | | | It is superfluous for Citra. (It's only really necessary if you're doing JIT. We were using it but not taking any advantage from it.) This should make 32-bit builds work again. | ||||
* | Fix printf format warning | Yuri Kunde Schlesner | 2015-05-07 | 1 | -1/+1 |
| | |||||
* | Common: Remove common.h | Yuri Kunde Schlesner | 2015-05-07 | 57 | -29/+85 |
| | |||||
* | Clean-up includes | Yuri Kunde Schlesner | 2015-05-07 | 7 | -9/+13 |
| | |||||
* | FileSys: De-inline Path members | Yuri Kunde Schlesner | 2015-05-07 | 4 | -125/+139 |
| | |||||
* | FileSys: Clean-up includes, de-inline destructors | Yuri Kunde Schlesner | 2015-05-07 | 7 | -20/+35 |
| | |||||
* | Move typedefs from kernel.h to more appropriate places | Yuri Kunde Schlesner | 2015-05-07 | 2 | -10/+8 |
| | |||||
* | HLE: Clean up SVC dispatch mechanism | Yuri Kunde Schlesner | 2015-05-06 | 5 | -79/+40 |
| | |||||
* | Core: Remove some unused functions and types | Yuri Kunde Schlesner | 2015-05-04 | 2 | -32/+1 |
| | |||||
* | CoreTiming: Initialize static variables at bootup. | bunnei | 2015-05-02 | 1 | -0/+10 |
| | |||||
* | HLE: Properly initialize and shutdown remaining modules. | bunnei | 2015-05-02 | 5 | -3/+20 |
| | |||||
* | Dyncom: Move cream cache to ARMul_State. | bunnei | 2015-05-02 | 4 | -25/+18 |
| | |||||
* | Kernel: Properly initialize and shutdown all modules. | bunnei | 2015-05-02 | 4 | -9/+20 |
| | |||||
* | HW: Properly initialize and shutdown all modules. | bunnei | 2015-05-02 | 3 | -3/+8 |
| | |||||
* | Services: Initialize all state variables at bootup. | bunnei | 2015-05-02 | 8 | -22/+38 |
| | |||||
* | Memory: Properly cleanup & shutdown. | bunnei | 2015-05-02 | 3 | -38/+60 |
| | |||||
* | ConfigMem: Remove duplicate retail bit | purpasmart96 | 2015-04-29 | 1 | -1/+0 |
| | |||||
* | Merge pull request #692 from purpasmart96/log_improvements | bunnei | 2015-04-28 | 4 | -22/+59 |
|\ | | | | | Services/Loader: Use more sensible log formats for certain functions along with more info being logged. | ||||
| * | Services/Loader: Use more sensible log formats for certain functions | purpasmart96 | 2015-04-28 | 4 | -22/+59 |
| | | | | | | | | along with more info being logged. | ||||
* | | ptm_sysm: Add static specifier to IsLegacyPowerOff | Lioncash | 2015-04-25 | 1 | -1/+1 |
| | | |||||
* | | dyncom: Remove more unused/unnecessary code | Lioncash | 2015-04-20 | 5 | -95/+1 |
| | | | | | | | | Gets rid of a sizeable amount of stuff in armdefs. | ||||
* | | dyncom: Remove unused/unnecessary VFP cruft | Lioncash | 2015-04-18 | 7 | -823/+15 |
| | | |||||
* | | Merge pull request #696 from yuriks/interface-deinline | bunnei | 2015-04-15 | 3 | -50/+49 |
|\ \ | | | | | | | De-inline functions from Interface, removing them from service.h | ||||
| * | | De-inline functions from Interface, removing them from service.h | Yuri Kunde Schlesner | 2015-04-14 | 3 | -50/+49 |
| | | | | | | | | | | | | This reduces the time for a full recompile from 65.43s to 59.53s (~9%) | ||||
* | | | Core_ARM11: Replace debug prints with our own logging functions in vfpsingle. | Emmanuel Gil Peyrot | 2015-04-14 | 2 | -39/+36 |
| | | | |||||
* | | | Kernel: Use the correct format string for u64 hex. | Emmanuel Gil Peyrot | 2015-04-14 | 1 | -1/+1 |
| | | | |||||
* | | | Headers: Add some forgotten overrides, thanks clang! | Emmanuel Gil Peyrot | 2015-04-14 | 2 | -2/+2 |
|/ / | |||||
* | | SVC: Assert on unsupported CreateThread processor ID. | bunnei | 2015-04-10 | 1 | -3/+9 |
| | | |||||
* | | SVC: Update various SVCs to cause a reschedule. | bunnei | 2015-04-10 | 2 | -6/+22 |
| | | | | | | | | - CreateMutex/ReleaseMutex/ReleaseSemaphore/SetTimer/CancelTimer/ArbitrateAddress | ||||
* | | Kernel: Implemented priority inheritance for mutexes. | bunnei | 2015-04-10 | 3 | -4/+22 |
| | | |||||
* | | Thread: Implement priority boost for starved threads. | bunnei | 2015-04-10 | 4 | -28/+74 |
| | | | | | | | | | | | | SVC: Return correct error code on invalid CreateThread processor ID. SVC: Assert when creating a thread with an invalid userland priority. | ||||
* | | SVC: Reschedule on svcCreateThread. | bunnei | 2015-04-10 | 1 | -0/+2 |
| | | |||||
* | | APT: (Subv) Fix bug where start event was being incorrectly signaled. | bunnei | 2015-04-10 | 1 | -6/+7 |
| | | |||||
* | | Kernel: Fixed default thread priority. | bunnei | 2015-04-10 | 2 | -5/+4 |
| | | |||||
* | | Initialize base address to 0x0 | Gareth Higgins | 2015-04-09 | 1 | -0/+1 |
|/ | |||||
* | Merge pull request #689 from lioncash/format | Tony Wasserka | 2015-04-08 | 1 | -1/+1 |
|\ | | | | | gpu: Fix a missing format specifier | ||||
| * | gpu: Fix a missing format specifier | Lioncash | 2015-04-07 | 1 | -1/+1 |
| | | |||||
* | | Merge pull request #688 from lioncash/unused | bunnei | 2015-04-08 | 5 | -50/+30 |
|\ \ | | | | | | | dyncom: Remove unnecessary enum and typedef | ||||
| * | | dyncom: Remove unnecessary enum and typedef | Lioncash | 2015-04-07 | 5 | -50/+30 |
| |/ | | | | | | | Also fixes descriptions in the process. | ||||
* | | Merge pull request #676 from purpasmart96/ir_service_refc | bunnei | 2015-04-08 | 11 | -59/+188 |
|\ \ | |/ |/| | IR: Move The IR services to their own folder and implement "GetHandles" | ||||
| * | IR: Move The IR services to their own folder and implement "GetHandles" | purpasmart96 | 2015-04-04 | 11 | -59/+188 |
| | | |||||
* | | vfp: Make the FPSID values match the MPCore | Lioncash | 2015-04-06 | 1 | -7/+7 |
| | | |||||
* | | vfp: Get rid of the VFP_OFFSET macro | Lioncash | 2015-04-06 | 5 | -64/+69 |
| | | |||||
* | | Merge pull request #685 from lioncash/cpregs | bunnei | 2015-04-06 | 9 | -134/+217 |
|\ \ | | | | | | | dyncom: Set the MPCore CP15 register reset values on initialization. | ||||
| * | | core: Migrate 3DS-specific CP15 register setting into Init | Lioncash | 2015-04-06 | 2 | -8/+5 |
| | | | |||||
| * | | arm_interface: Support retrieval/storage to CP15 registers | Lioncash | 2015-04-06 | 3 | -0/+25 |
| | | | |||||
| * | | Move CP15 enum definitions into their own enum. | Lioncash | 2015-04-06 | 5 | -168/+163 |
| | | | | | | | | | | | | Also gets rid of preprocessor mumbo-jumbo | ||||
| * | | dyncom: Properly return the value of the user RO thread register | Lioncash | 2015-04-06 | 2 | -4/+10 |
| | | | |||||
| * | | dyncom: Set CP15 reset values on initialization | Lioncash | 2015-04-06 | 1 | -0/+60 |
| | | | |||||
* | | | dyncom: Suppress uninitialized variable warnings | Lioncash | 2015-04-06 | 1 | -4/+4 |
|/ / | | | | | | | The switch cases will always be hit, but this makes compilers stop complaining. | ||||
* | | Clean-up mem_map constants and fix framebuffer translation errors | Yuri Kunde Schlesner | 2015-04-06 | 3 | -27/+27 |
| | | |||||
* | | Merge pull request #680 from archshift/bg-color | bunnei | 2015-04-04 | 1 | -0/+5 |
|\ \ | |/ |/| | Allow the user to set the background clear color during emulation | ||||
| * | Allow the user to set the background clear color during emulation | archshift | 2015-04-04 | 1 | -0/+5 |
| | | | | | | | | The background color can be seen at the sides of the bottom screen or when the window is wider than normal. | ||||
* | | Merge pull request #641 from purpasmart96/service_stubs | bunnei | 2015-04-04 | 18 | -68/+405 |
|\ \ | |/ |/| | Services: Stubs and minor changes | ||||
| * | Services: Stubs and minor changes | purpasmart96 | 2015-04-03 | 18 | -68/+405 |
| | | |||||
* | | dyncom: Move CP15 register writing into its own function. | Lioncash | 2015-04-02 | 4 | -88/+265 |
| | | | | | | | | Also implements writing to the rest of the ARM11 MPCore CP15 register set. | ||||
* | | dyncom: Move CP15 register reading into its own function. | Lioncash | 2015-04-02 | 4 | -49/+253 |
| | | | | | | | | Keeps everything contained. Added all supported readable registers in an ARM11 MPCore. | ||||
* | | dyncom: Migrate InAPrivilegedMode to armsupp | Lioncash | 2015-03-26 | 3 | -4/+7 |
| | | | | | | | | It's a generic helper function, so it should be here anyway. | ||||
* | | Merge pull request #672 from purpasmart96/citra_moar_app_mem | bunnei | 2015-03-25 | 1 | -2/+2 |
|\ \ | | | | | | | ConfigMem: Set the app memory to be 96MB instead of the default 64MB | ||||
| * | | ConfigMem: Set the app memory to be 96MB instead of the default 64MB | purpasmart96 | 2015-03-24 | 1 | -2/+2 |
| |/ | |||||
* | | Merge pull request #674 from lioncash/sys-instrs | bunnei | 2015-03-25 | 1 | -2/+62 |
|\ \ | | | | | | | dyncom: Implement RFE and SRS. | ||||
| * | | dyncom: Implement SRS | Lioncash | 2015-03-24 | 1 | -1/+32 |
| | | | |||||
| * | | dyncom: Implement RFE | Lioncash | 2015-03-24 | 1 | -1/+30 |
| |/ | |||||
* / | dyncom: Remove unused/unnecessary macros and macro constants | Lioncash | 2015-03-24 | 2 | -39/+2 |
|/ | |||||
* | Merge pull request #656 from Subv/nz | bunnei | 2015-03-22 | 7 | -26/+265 |
|\ | | | | | Services/FS: Implemented DeleteExtSaveData, CreateSystemSaveData and Del... | ||||
| * | Service/FS: Document and log some unknown values. | Subv | 2015-03-19 | 1 | -1/+26 |
| | | | | | | | | In CreateExtSaveData, DeleteExtSaveData and CreateSystemSaveData | ||||
| * | Services/FS: Implemented DeleteExtSaveData, CreateSystemSaveData and DeleteSystemSaveData | Subv | 2015-03-14 | 7 | -26/+240 |
| | | | | | | | | Also fixed a bug with CreateExtSaveData that made it unable to create ExtSaveData archives in the SDMC directory. | ||||
* | | armmmu: Remove unnecessary enum values | Lioncash | 2015-03-21 | 1 | -30/+20 |
| | | | | | | | | We don't need to care about XScale or Intel specific ARM stuff. | ||||
* | | Merge pull request #659 from lioncash/setend | bunnei | 2015-03-20 | 7 | -83/+240 |
|\ \ | | | | | | | Implement SETEND. | ||||
| * | | dyncom: Make Load/Store instructions support big endian | Lioncash | 2015-03-17 | 7 | -82/+205 |
| | | | |||||
| * | | dyncom: Implement SETEND | Lioncash | 2015-03-15 | 1 | -1/+35 |
| | | | |||||
* | | | Merge pull request #650 from Subv/scaling | bunnei | 2015-03-18 | 2 | -5/+16 |
|\ \ \ | | | | | | | | | GPU: Fixed the bit 25 in the display transfer flags. | ||||
| * | | | GPU/DisplayTransfer: Made the scaling bits a single 2bit value | Subv | 2015-03-16 | 2 | -6/+17 |
| | | | | | | | | | | | | | | | | Rephrased some comments. | ||||
| * | | | GPU: Fixed the bit 25 in the display transfer flags. | Subv | 2015-03-10 | 2 | -5/+5 |
| | | | | | | | | | | | | | | | | It is used to downscale the input image horizontally and vertically, previously we were only downscaling it vertically so this caused a hard-to-debug memory corruption problem. | ||||
* | | | | Merge pull request #655 from purpasmart96/hid_fixes | bunnei | 2015-03-17 | 4 | -12/+72 |
|\ \ \ \ | | | | | | | | | | | HID: Proper Signal Interrupts for EnableAccelerometer & EnableGyroscopeLow along with a stub for GetSoundVolume | ||||
| * | | | | HID: Proper Signal Interrupts for EnableAccelerometer & EnableGyroscopeLow along | purpasmart96 | 2015-03-17 | 4 | -12/+72 |
| | |_|/ | |/| | | | | | | | | | | with a stub for GetSoundVolume | ||||
* | | | | Merge pull request #660 from purpasmart96/ncch_updates | bunnei | 2015-03-17 | 1 | -11/+14 |
|\ \ \ \ | | | | | | | | | | | NCCH: Minor updates to the ncch header | ||||
| * | | | | NCCH: Minor updates to the ncch header | purpasmart96 | 2015-03-15 | 1 | -11/+14 |
| |/ / / | |||||
* | | | | arm_interface: Get rid of GetTicks. | Lioncash | 2015-03-16 | 5 | -17/+6 |
| | | | | | | | | | | | | | | | | Removes a TODO. | ||||
* | | | | GPU: Implemented the flip_data (bit 0) bit in display transfers. | Subv | 2015-03-14 | 2 | -6/+15 |
|/ / / | |||||
* | | | Merge pull request #642 from bunnei/touchpad | bunnei | 2015-03-12 | 4 | -130/+140 |
|\ \ \ | |_|/ |/| | | Touchpad support | ||||
| * | | hid_user: Removed unnecessary includes. | bunnei | 2015-03-11 | 1 | -2/+0 |
| | | | |||||
| * | | HID: Removed unnecessary global variables. | bunnei | 2015-03-11 | 2 | -58/+42 |
| | | | |||||
| * | | HID: Added additional variable comments and some code cleanups. | bunnei | 2015-03-11 | 2 | -20/+29 |
| | | | |||||
| * | | HID: Complete refactor of pad/touch input to fix threading issues. | bunnei | 2015-03-11 | 3 | -111/+32 |
| | | | |||||
| * | | HID: Cleanup how `next_touch_index` is calculated for Pad and touch. | bunnei | 2015-03-10 | 1 | -2/+2 |
| | | | |||||
| * | | HID: Changed TouchDataEntry `valid` to a BitField and added some doc strings. | bunnei | 2015-03-10 | 2 | -4/+4 |
| | | | |||||
| * | | HID: Added static asserts to check register position in shared memory. | bunnei | 2015-03-10 | 1 | -2/+16 |
| | | | |||||
| * | | HID: Added functions to emulate the touchpad. | bunnei | 2015-03-10 | 2 | -0/+61 |
| | | | |||||
| * | | HID: Moved some docstrings to the header. | bunnei | 2015-03-10 | 2 | -24/+16 |
| | | | |||||
| * | | HID: Refactored shared memory decoding for touchpad support. | bunnei | 2015-03-10 | 2 | -33/+64 |
| | | | |||||
* | | | Merge pull request #629 from archshift/lcdfb | bunnei | 2015-03-10 | 8 | -41/+232 |
|\ \ \ | |/ / |/| | | Implement SetLcdForceBlack and add implementation for color filling in the GPU code | ||||
| * | | Added LCD registers, and implementation for color filling in OGL code. | archshift | 2015-03-09 | 7 | -26/+184 |
| | | | |||||
| * | | Implement SetLcdForceBlack, move register enum to hw.h | archshift | 2015-03-06 | 4 | -36/+69 |
| | | | |||||
* | | | dyncom: Minor cleanup | Lioncash | 2015-03-10 | 1 | -26/+7 |
| |/ |/| | | | | | Assemblers will exit with an error when trying to assemble instructions with disallowed registers. | ||||
* | | Merge pull request #648 from Subv/fill_bit | Tony Wasserka | 2015-03-09 | 1 | -1/+1 |
|\ \ | | | | | | | GPU: Use the correct position for the finished bit in memory fills | ||||
| * | | GPU: Use the correct position for the finished bit in memory fills | Subv | 2015-03-09 | 1 | -1/+1 |
| | | | |||||
* | | | Merge pull request #646 from Subv/24bit_fills | Tony Wasserka | 2015-03-09 | 2 | -5/+5 |
|\ \ \ | | | | | | | | | GPU: Corrected the 24 bit memory fills component order | ||||
| * | | | GPU: Corrected the 24 bit memory fills component order | Subv | 2015-03-09 | 2 | -5/+5 |
| |/ / | |||||
* | | | Merge pull request #589 from kevinhartman/config-errors | bunnei | 2015-03-09 | 1 | -5/+10 |
|\ \ \ | | | | | | | | | Fix errorcodes for bad config block request | ||||
| * | | | Fix error message for bad config block request. | Kevin Hartman | 2015-02-21 | 1 | -5/+10 |
| | | | | |||||
* | | | | dyncom: Fix an indexing bug in STM | Lioncash | 2015-03-09 | 1 | -5/+4 |
| | | | | | | | | | | | | | | | | Previously it would write the contents of register 13 for the case where the link register (r14) is supposed to be written. | ||||
* | | | | dyncom: General cleanup of STM | Lioncash | 2015-03-09 | 1 | -16/+14 |
| | | | | |||||
* | | | | dyncom: Increment addr when accessing LR in LDM | Lioncash | 2015-03-09 | 1 | -0/+2 |
| |/ / |/| | | |||||
* | | | Merge pull request #538 from yuriks/perf-stat | Tony Wasserka | 2015-03-07 | 2 | -0/+14 |
|\ \ \ | |_|/ |/| | | Add profiling infrastructure and widget | ||||
| * | | Add profiling infrastructure and widget | Yuri Kunde Schlesner | 2015-03-02 | 2 | -0/+14 |
| | | | |||||
* | | | Merge pull request #615 from Subv/services | bunnei | 2015-03-05 | 40 | -1110/+1202 |
|\ \ \ | | | | | | | | | Services: Moved the PTM and APT services to their own folder | ||||
| * | | | Services: Moved the PTM and APT services to their own folder | Subv | 2015-03-04 | 40 | -1110/+1202 |
| | | | | | | | | | | | | | | | | | | | | | | | | This coincidentally fixes an issue about the PTM service failing to create its SharedExtSaveData archive due to the FS service not being initialized by the time the creating code runs. Ideally I'd like to move each process to its own folder, and have a single file per process that registers the service classes, which would be in their own files inside that folder. Then each service class would just call functions from the process to complete the commands. | ||||
* | | | | Merge pull request #625 from lioncash/warn | bunnei | 2015-03-04 | 2 | -4/+4 |
|\ \ \ \ | | | | | | | | | | | vfp: Get rid of warnings | ||||
| * | | | | vfp: Get rid of warnings | Lioncash | 2015-03-04 | 2 | -4/+4 |
| | | | | | |||||
* | | | | | GPU: Added RGB565/RGB8 framebuffer support and various cleanups. | bunnei | 2015-03-04 | 1 | -50/+25 |
| |/ / / |/| | | | | | | | | | | | | | | | | | | | - Centralizes color format encode/decode functions. - Fixes endianness issues. - Implements remaining framebuffer formats in the debugger. | ||||
* | | | | Merge pull request #622 from Subv/titles | Yuri Kunde Schlesner | 2015-03-02 | 1 | -8/+45 |
|\ \ \ \ | | | | | | | | | | | Services/AM: Stubbed TitleIDListGetTotal and GetTitleIDList. | ||||
| * | | | | Services/AM: Stubbed TitleIDListGetTotal and GetTitleIDList. | Subv | 2015-03-02 | 1 | -8/+45 |
| | | | | | | | | | | | | | | | | | | | | | | | | | They will always return 0 titles for every media type for now. This is needed to boot Home Menu further | ||||
* | | | | | Merge pull request #623 from Subv/card | bunnei | 2015-03-02 | 1 | -1/+25 |
|\ \ \ \ \ | | | | | | | | | | | | | Services/FS: Stubbed CardSlotIsInserted to always return false | ||||
| * | | | | | Services/FS: Stubbed CardSlotIsInserted to always return false | Subv | 2015-03-01 | 1 | -1/+25 |
| |/ / / / | | | | | | | | | | | | | | | | We won't be emulating this for the foreseeable future and it is needed for Home Menu to boot further | ||||
* | | | | | Merge pull request #618 from lioncash/ref | bunnei | 2015-03-02 | 1 | -2/+2 |
|\ \ \ \ \ | |_|/ / / |/| | | | | result: Make comparison operators take references | ||||
| * | | | | result: Make comparison operators take references | Lioncash | 2015-02-28 | 1 | -2/+2 |
| |/ / / | | | | | | | | | | | | | It's unnecessary to make copies for simple comparisons like this. | ||||
* | | | | Merge pull request #621 from Subv/power | bunnei | 2015-03-02 | 1 | -1/+13 |
|\ \ \ \ | |_|/ / |/| | | | Services/PTM: Stubbed PTM_Sysm::IsLegacyPowerOff. | ||||
| * | | | Services/PTM: Stubbed PTM_Sysm::IsLegacyPowerOff. | Subv | 2015-03-01 | 1 | -1/+13 |
| |/ / | | | | | | | | | | This allows the Home Menu to boot further | ||||
* | | | Merge pull request #616 from archshift/5551 | archshift | 2015-02-28 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | Added RGBA5551 compatibility in the rasterizer | ||||
| * | | | Added RGBA5551 compatibility in the rasterizer | archshift | 2015-02-28 | 1 | -1/+1 |
| |/ / | | | | | | | | | | This allows Virtual Console games to display properly. | ||||
* | | | Merge pull request #620 from lioncash/bkpt | bunnei | 2015-02-28 | 1 | -2/+3 |
|\ \ \ | | | | | | | | | arm_disasm: Show conditional code for BKPT instructions. | ||||
| * | | | arm_disasm: Show conditional code for BKPT instructions. | Lioncash | 2015-02-28 | 1 | -2/+3 |
| |/ / | | | | | | | | | | Changed cond_to_str to take a uint32, since unsigned numbers are only ever passed to it, and this can be a source of warnings for some compilers (also indexing an array without bounds checking a signed number is kind of iffy). | ||||
* / / | arm_disasm: Remove unused variable | Lioncash | 2015-02-28 | 1 | -2/+1 |
|/ / | | | | | | | Also declared an array as static, as it's only used in this translation unit. | ||||
* | | Merge pull request #599 from Subv/morton | bunnei | 2015-02-27 | 2 | -23/+64 |
|\ \ | | | | | | | GPU: Implemented bits 3 and 1 from the display transfer flags. | ||||
| * | | GPU: Implemented bits 3 and 1 from the display transfer flags. | Subv | 2015-02-27 | 2 | -23/+64 |
| | | | | | | | | | | | | | | | Bit 3 is used to specify a raw copy, where no processing is done to the data, seems to behave exactly as a DMA. Bit 1 is used to specify whether to convert from a tiled format to a linear format or viceversa. | ||||
* | | | arm: The CP15 Main ID register is not writeable | Lioncash | 2015-02-26 | 1 | -3/+1 |
|/ / | |||||
* | | Merge pull request #604 from Subv/arc_ssd | Yuri Kunde Schlesner | 2015-02-26 | 4 | -45/+70 |
|\ \ | | | | | | | Archives: Properly implemented the SystemSaveData archive. | ||||
| * | | Archives: Properly implemented the SystemSaveData archive. | Subv | 2015-02-26 | 4 | -45/+70 |
| | | | | | | | | | | | | Ported to the new factory pattern we have for archives. | ||||
* | | | arm: Remove unnecessary booleans | Lioncash | 2015-02-25 | 2 | -22/+5 |
| | | | | | | | | | | | | We don't care about any of these. | ||||
* | | | Services: Implemented Y2R_U::GetTransferEndEvent | Subv | 2015-02-24 | 1 | -1/+18 |
|/ / | | | | | | | Aero Porter was throwing an "Invalid Handle" fatal error without this. | ||||
* | | Merge pull request #595 from linkmauve/new-3ds-input | bunnei | 2015-02-24 | 2 | -0/+25 |
|\ \ | | | | | | | Frontends, HID: Add New 3DS specific pad buttons, and stub the touch one. | ||||
| * | | Frontends, HID: Add New 3DS specific pad buttons, and stub the touch one. | Emmanuel Gil Peyrot | 2015-02-22 | 2 | -0/+25 |
| | | | |||||
* | | | Merge pull request #581 from archshift/tfe | bunnei | 2015-02-23 | 1 | -1/+164 |
|\ \ \ | | | | | | | | | Added information reporting from ThrowFatalError | ||||
| * | | | Added information reporting from ThrowFatalError | archshift | 2015-02-22 | 1 | -1/+164 |
| | | | | | | | | | | | | | | | | This was RE'd from the errdisp applet. | ||||
* | | | | GPU: Fixed RGBA8 as output format in a display transfer. | Subv | 2015-02-22 | 1 | -8/+7 |
| | | | | | | | | | | | | | | | | Verified with hwtests | ||||
* | | | | Merge pull request #471 from archshift/pp3ports3 | bunnei | 2015-02-22 | 1 | -0/+37 |
|\ \ \ \ | | | | | | | | | | | GPU: Add support for more framebuffer formats in display transfers. | ||||
| * | | | | GPU: Add support for more framebuffer formats in display transfers. | Tony Wasserka | 2015-02-22 | 1 | -0/+37 |
| | | | | | |||||
* | | | | | Merge pull request #596 from kevinhartman/unaligned-cleanup | bunnei | 2015-02-22 | 2 | -35/+2 |
|\ \ \ \ \ | | | | | | | | | | | | | Clean up unaligned 32-bit memory reads | ||||
| * | | | | | Cleaned up unaligned access. | Kevin Hartman | 2015-02-22 | 2 | -35/+2 |
| | |_|_|/ | |/| | | | |||||
* | | | | | Merge pull request #594 from Subv/display_transfer | bunnei | 2015-02-22 | 1 | -8/+6 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | GPU: Fixed the RGBA8 input format and RGB8 output format | ||||
| * | | | | GPU: Fixed the RGBA8 input format and RGB8 output format | Subv | 2015-02-22 | 1 | -8/+6 |
| |/ / / | | | | | | | | | | | | | in Display Transfers, tested with hwtests. | ||||
* | | | | Merge pull request #588 from archshift/somebranch | bunnei | 2015-02-20 | 3 | -15/+5 |
|\ \ \ \ | |/ / / |/| | | | Sweeping cleanup of Common | ||||
| * | | | Misc cleanup of common and related functions | archshift | 2015-02-20 | 1 | -2/+3 |
| | | | | |||||
| * | | | Remove duplication of INSERT_PADDING_WORDS between pica.h and gpu.h | archshift | 2015-02-20 | 1 | -11/+0 |
| | | | | |||||
| * | | | Remove the useless msg_handler compilation unit that was left over from Dolphin | archshift | 2015-02-19 | 1 | -2/+2 |
| | |/ | |/| | |||||
* / | | Convert a few C stdlib asserts to Citra's own asserts | archshift | 2015-02-19 | 1 | -6/+4 |
|/ / | |||||
* | | Merge pull request #580 from lioncash/emplace | bunnei | 2015-02-18 | 1 | -1/+1 |
|\ \ | | | | | | | core/video_core: Use in-place construction where possible | ||||
| * | | core/video_core: Use in-place construction where possible | Lioncash | 2015-02-17 | 1 | -1/+1 |
| | | | |||||
* | | | GPU: Properly implement memory fills. | Tony Wasserka | 2015-02-18 | 4 | -33/+78 |
| | | | |||||
* | | | Merge pull request #570 from purpasmart96/config_mem | bunnei | 2015-02-18 | 4 | -50/+58 |
|\ \ \ | | | | | | | | | ConfigMem: Clean up the Config memory to be more like the shared page | ||||
| * | | | ConfigMem: Clean up the Config memory to be more like the shared page and moved | purpasmart96 | 2015-02-17 | 4 | -50/+58 |
| | | | | | | | | | | | | | | | | the helper macro for padding to common_funcs.h | ||||
* | | | | Merge pull request #582 from lioncash/warnings | bunnei | 2015-02-18 | 1 | -4/+4 |
|\ \ \ \ | | | | | | | | | | | vfpinstr: Fix trivial signed/unsigned mismatch warnings | ||||
| * | | | | vfpinstr: Fix trivial signed/unsigned mismatch warnings | Lioncash | 2015-02-18 | 1 | -4/+4 |
| | | | | | |||||
* | | | | | Merge pull request #579 from lioncash/bkpt | bunnei | 2015-02-18 | 2 | -2/+28 |
|\ \ \ \ \ | |/ / / / |/| | | | | dyncom: Support conditional BKPT instructions | ||||
| * | | | | dyncom: Support conditional BKPT instructions | Lioncash | 2015-02-17 | 2 | -2/+28 |
| | | | | | |||||
* | | | | | Services: Fixed "Tried to connect to named port err:f". | Subv | 2015-02-16 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | err:f is a named port, not a service | ||||
* | | | | | Merge pull request #574 from lioncash/warn | bunnei | 2015-02-16 | 1 | -2/+2 |
|\ \ \ \ \ | |/ / / / |/| | | | | vfpdouble: Use %p for printing pointer addresses. | ||||
| * | | | | vfpdouble: Use %p for printing pointer addresses. | Lioncash | 2015-02-15 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | dyncom: Actually set the destination register for USAD8/USADA8. | Lioncash | 2015-02-16 | 1 | -0/+1 |
|/ / / / | | | | | | | | | | | | | Idiotville: Population: 1 - Inhabitant name: Lioncash | ||||
* | | | | Merge pull request #539 from linkmauve/framebuffer-formats | bunnei | 2015-02-15 | 1 | -0/+19 |
|\ \ \ \ | | | | | | | | | | | Framebuffer formats | ||||
| * | | | | video_core: Implement the remaining framebuffer formats in the OpenGL renderer. | Emmanuel Gil Peyrot | 2015-02-15 | 1 | -0/+19 |
| | |/ / | |/| | | |||||
* / | | | arm: Set the A bit on reset. | Lioncash | 2015-02-15 | 1 | -1/+1 |
|/ / / | | | | | | | | | | This enum value is ORed against in ARMul_Reset (and used to refer to all interrupt bits in the CPSR). So simply updating this is enough. | ||||
* | | | Merge pull request #529 from Subv/master | bunnei | 2015-02-14 | 8 | -46/+64 |
|\ \ \ | | | | | | | | | Build: Fixed some warnings | ||||
| * | | | Build: Fixed some warnings | Subv | 2015-02-12 | 8 | -46/+64 |
| | | | | |||||
* | | | | core: Apply static to local functions | Lioncash | 2015-02-13 | 11 | -245/+252 |
| | | | | |||||
* | | | | arm: General cleanup | Lioncash | 2015-02-13 | 13 | -227/+116 |
| |/ / |/| | | | | | | | | | | | | | | | | | - Remove several typedefs for ARMul_State. - Remove unused functions - Remove unused/unnecessary headers - Removed unused enums, etc. | ||||
* | | | dyncom: Switch the app and system cores into the correct mode at initialization | Lioncash | 2015-02-13 | 5 | -17/+21 |
| | | | |||||
* | | | dyncom: Clean up the constructor | Lioncash | 2015-02-13 | 3 | -16/+7 |
| | | | | | | | | | | | | Some function calls aren't necessary and would be handled by regular initialization routines. | ||||
* | | | dyncom: Remove warning for SXTAH | Lioncash | 2015-02-13 | 1 | -1/+0 |
| | | | | | | | | | | | | This is tested to work correctly. | ||||
* | | | arm: Remove ARMul_EmulateInit | Lioncash | 2015-02-12 | 4 | -55/+1 |
| | | | | | | | | | | | | This was only used for armemu, which has since been removed. Removed components related to this as well. | ||||
* | | | armdefs: Remove unnecessary extern C | Lioncash | 2015-02-12 | 1 | -6/+0 |
|/ / | |||||
* | | Implemented WriteHWRegsWithMask for GSP. | Kevin Hartman | 2015-02-11 | 1 | -6/+91 |
| | | |||||
* | | arm: Remove ARM26 support. | Lioncash | 2015-02-11 | 2 | -45/+4 |
| | | | | | | | | This will never be used. 32-bit is the norm. | ||||
* | | Merge pull request #559 from lioncash/clean | bunnei | 2015-02-11 | 4 | -24/+40 |
|\ \ | | | | | | | arm: Some cleanup. Also fixed the initial ARM mode that is emulated. | ||||
| * | | arm: Get rid of some magic constants. Specify proper ARM mode. | Lioncash | 2015-02-11 | 3 | -3/+10 |
| | | | | | | | | | | | | Initially, we were starting the emulator in USER26MODE, which is incorrect, this should be USER32MODE. | ||||
| * | | arm: Change some more constants into enums | Lioncash | 2015-02-11 | 2 | -21/+30 |
| | | | |||||
* | | | Asserts: break/crash program, fit to style guide; log.h->assert.h | archshift | 2015-02-11 | 59 | -77/+33 |
| | | | | | | | | | | | | | | | | | | | | | Involves making asserts use printf instead of the log functions (log functions are asynchronous and, as such, the log won't be printed in time) As such, the log type argument was removed (printf obviously can't use it, and it's made obsolete by the file and line printing) Also removed some GEKKO cruft. | ||||
* | | | GSP: Fixed typo in SignalInterrupt | bunnei | 2015-02-11 | 1 | -1/+1 |
| | | | |||||
* | | | Merge pull request #552 from bunnei/setbufferswap-fix | bunnei | 2015-02-11 | 1 | -4/+3 |
|\ \ \ | | | | | | | | | GSP SetBufferSwap fix | ||||
| * | | | GSP: Call SetBufferSwap for each screen on corresponding signal interrupt. | bunnei | 2015-02-11 | 1 | -4/+3 |
| | | | | |||||
* | | | | Merge pull request #526 from purpasmart96/citra_stubs | bunnei | 2015-02-11 | 4 | -8/+191 |
|\ \ \ \ | | | | | | | | | | | Services: Stub some functions | ||||
| * | | | | Services: Stub some functions | purpasmart96 | 2015-02-08 | 4 | -8/+191 |
| | | | | | |||||
* | | | | | Merge pull request #556 from lioncash/clean | bunnei | 2015-02-11 | 4 | -28/+19 |
|\ \ \ \ \ | | |_|/ / | |/| | | | arm: Remove TRUE/FALSE defines | ||||
| * | | | | arm: Remove TRUE/FALSE defines | Lioncash | 2015-02-10 | 4 | -28/+19 |
| | | | | | | | | | | | | | | | | | | | | | | | | | - Removed the Debug parameter from ARMul_State since it isn't used. - Changed ARMul_CoProInit to a void function. It always returned true. | ||||
* | | | | | Merge pull request #555 from lioncash/lut | bunnei | 2015-02-11 | 1 | -7/+7 |
|\ \ \ \ \ | | | | | | | | | | | | | arm_dyncom_thumb: Make lookup tables static | ||||
| * | | | | | arm_dyncom_thumb: Make lookup tables static | Lioncash | 2015-02-10 | 1 | -7/+7 |
| |/ / / / | | | | | | | | | | | | | | | | These don't need to be recreated all the time. | ||||
* | | | | | PTM: Fixed a problem with the gamecoin PTM file. | Subv | 2015-02-10 | 1 | -21/+13 |
| | | | | | |||||
* | | | | | Archives: Made the Format function more generic. | Subv | 2015-02-10 | 3 | -9/+10 |
| | | | | | |||||
* | | | | | Archives: Expose the File and Directory classes to HLE | Subv | 2015-02-10 | 3 | -58/+62 |
| | | | | | |||||
* | | | | | ResultVal: Fixed compilation when reassigning a ResultVal. | Subv | 2015-02-10 | 1 | -3/+3 |
| | | | | | |||||
* | | | | | FS: Allow multiple instances of the same archive type to be open at once | Yuri Kunde Schlesner | 2015-02-10 | 19 | -159/+199 |
| | | | | | |||||
* | | | | | FS: Get rid of completely useless Archive class | Yuri Kunde Schlesner | 2015-02-10 | 1 | -36/+26 |
|/ / / / | |||||
* | | | | Merge pull request #553 from lioncash/denorm | bunnei | 2015-02-10 | 2 | -0/+6 |
|\ \ \ \ | | | | | | | | | | | vfp: Normalize accumulator for multiply accumulate instructions | ||||
| * | | | | vfp: Normalize accumulator for multiply accumulate instructions | Lioncash | 2015-02-10 | 2 | -0/+6 |
| | | | | | |||||
* | | | | | dyncom: Add more regs to MCR/MRC | Lioncash | 2015-02-10 | 2 | -18/+35 |
|/ / / / | | | | | | | | | | | | | Adds the registers that were left out of some coprocessor ranges. | ||||
* | / / | Scheduler refactor Pt. 1 | Kevin Hartman | 2015-02-10 | 7 | -284/+287 |
| |/ / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Simplifies scheduling logic, specifically regarding thread status. It should be much clearer which statuses are valid for a thread at any given point in the system. * Removes dead code from thread.cpp. * Moves the implementation of resetting a ThreadContext to the corresponding core's implementation. Other changes: * Fixed comments in arm interfaces. * Updated comments in thread.cpp * Removed confusing, useless, functions like MakeReady() and ChangeStatus() from thread.cpp. * Removed stack_size from Thread. In the CTR kernel, the thread's stack would be allocated before thread creation. | ||||
* | | | Merge pull request #551 from bunnei/mutex-fixes | bunnei | 2015-02-10 | 3 | -20/+24 |
|\ \ \ | | | | | | | | | Mutex/synch fixes | ||||
| * | | | Mutex: Locks should be recursive. | bunnei | 2015-02-10 | 2 | -16/+20 |
| | | | | |||||
| * | | | WaitSynch: Always reschedule (verified behavior on hw). | bunnei | 2015-02-10 | 1 | -4/+4 |
| | | | | |||||
* | | | | vfpdouble: Fix the FTOUI NaN sign setting | Lioncash | 2015-02-09 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | This was fixed for vfpsingle, but not vfpdouble | ||||
* | | | | Throw more unused/unnecessary VFP code out | Lioncash | 2015-02-09 | 3 | -215/+1 |
| | | | | |||||
* | | | | vfp_helper: Convert some flags to enums. Throw out more duplicated FPSCR stuff | Lioncash | 2015-02-09 | 4 | -192/+153 |
| | | | | |||||
* | | | | vfp_helper: Normalize tabs to spaces | Lioncash | 2015-02-09 | 1 | -172/+170 |
|/ / / | |||||
* | | | vfp_helper: Remove unnecessary extern C blocks | Lioncash | 2015-02-06 | 1 | -17/+1 |
| | | | |||||
* | | | vfp: Move FPSID, FPEXC, and FPSCR values over to enums. | Lioncash | 2015-02-06 | 3 | -150/+104 |
| | | | | | | | | | | | | Also got rid of duplicate definitions of some of these values. | ||||
* | | | Merge pull request #537 from lioncash/vfp | bunnei | 2015-02-04 | 1 | -6/+6 |
|\ \ \ | | | | | | | | | vfp: Fix VCVT | ||||
| * | | | vfp: Fix VCVT | Lioncash | 2015-02-04 | 1 | -6/+6 |
| | | | | | | | | | | | | | | | | | | | | These variants exclusively read from the single precision regs and write to double-precision registers Fixes issues where converted values would be way off from what they should be due to the results being stored in the wrong registers. | ||||
* | | | | Merge pull request #536 from lioncash/dead | bunnei | 2015-02-04 | 2 | -1765/+0 |
|\ \ \ \ | |/ / / |/| | | | vfp: Throw out unused code | ||||
| * | | | vfp: Throw out unused code | Lioncash | 2015-02-04 | 2 | -1765/+0 |
| | | | | |||||
* | | | | dyncom: Remove more unnecessary code | Lioncash | 2015-02-03 | 1 | -45/+3 |
|/ / / | |||||
* | | | core: Fix some warnings on OSX | Lioncash | 2015-02-03 | 4 | -6/+5 |
| | | | |||||
* | | | Kernel: Stop creating useless Handles during object creation | Yuri Kunde Schlesner | 2015-02-02 | 18 | -57/+41 |
| | | | | | | | | | | | | | | | They're finally unnecessary, and will stop cluttering the application's handle table. | ||||
* | | | Kernel: Make WaitObjects share ownership of Threads waiting on them | Yuri Kunde Schlesner | 2015-02-02 | 6 | -12/+17 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | During normal operation, a thread waiting on an WaitObject and the object hold mutual references to each other for the duration of the wait. If a process is forcefully terminated (The CTR kernel has a SVC to do this, TerminateProcess, though no equivalent exists for threads.) its threads would also be stopped and destroyed, leaving dangling pointers in the WaitObjects. The solution is to simply have the Thread remove itself from WaitObjects when it is stopped. The vector of Threads in WaitObject has also been changed to hold SharedPtrs, just in case. (Better to have a reference cycle than a crash.) | ||||
* | | | Explicitly instantiate constructors/destructors for Kernel objects | Yuri Kunde Schlesner | 2015-02-02 | 17 | -8/+51 |
| | | | | | | | | | | | | | | | | | | This should speed up compile times a bit, as well as enable more liberal use of forward declarations. (Due to SharedPtr not trying to emit the destructor anymore.) | ||||
* | | | Mutex: Replace g_mutex_held_locks with a set inside Thread | Yuri Kunde Schlesner | 2015-02-02 | 3 | -23/+18 |
| | | | |||||
* | | | HID: Fix crash when pressing a key when the emulator is stopped | Yuri Kunde Schlesner | 2015-02-02 | 1 | -0/+2 |
| | | | |||||
* | | | SVC: Enable CloseHandle, clean up DuplicateHandle | Yuri Kunde Schlesner | 2015-02-02 | 1 | -9/+5 |
| | | | |||||
* | | | Kernel: Fix bug in HandleTable::Close | Yuri Kunde Schlesner | 2015-02-02 | 1 | -1/+1 |
| | | | |||||
* | | | Kernel: Remove Object::GetHandle (it's not used anymore :D) | Yuri Kunde Schlesner | 2015-02-02 | 2 | -9/+1 |
| | | | |||||
* | | | Kernel: Introduce unique Object ids for debugging | Yuri Kunde Schlesner | 2015-02-02 | 4 | -8/+16 |
| | | | |||||
* | | | Kernel: Use separate Handle tables for CoreTiming userdata | Yuri Kunde Schlesner | 2015-02-02 | 4 | -18/+25 |
| | | | | | | | | | | | | This is to support the removal of GetHandle soon | ||||
* | | | Kernel: Remove previous scheduled event when a Timer is re-Set | Yuri Kunde Schlesner | 2015-02-02 | 1 | -0/+3 |
| | | | |||||
* | | | FS: Remove use of GetHandle | Yuri Kunde Schlesner | 2015-02-02 | 1 | -1/+1 |
| | | | |||||
* | | | Thread: Modernize two functions that slipped through previous rebases | Yuri Kunde Schlesner | 2015-02-02 | 4 | -18/+16 |
| | | | |||||
* | | | Service: Store function names as const char* instead of std::string | Yuri Kunde Schlesner | 2015-02-02 | 1 | -6/+6 |
| | | | | | | | | | | | | | | | Uses less memory (strings and function table is stored in constant data) and speeds up start up (no need to allocate and copy strings). | ||||
* | | | Service: Clean-up Interface | Yuri Kunde Schlesner | 2015-02-02 | 46 | -67/+54 |
| | | | |||||
* | | | Make Port/Service registration and querying more HW-accurate | Yuri Kunde Schlesner | 2015-02-02 | 4 | -106/+80 |
| | | | |||||
* | | | Filesys: Move creation of Handles for File/Directory to service handlers | Yuri Kunde Schlesner | 2015-02-02 | 3 | -32/+33 |
| | | | |||||
* | | | Merge pull request #514 from rohit-n/fix-warnings | bunnei | 2015-02-01 | 1 | -2/+2 |
|\ \ \ | | | | | | | | | Silence a few warnings. | ||||
| * | | | Silence a few warnings. | Rohit Nirmal | 2015-01-30 | 1 | -2/+2 |
| | | | | |||||
* | | | | Merge pull request #525 from lioncash/armwarn | bunnei | 2015-02-01 | 2 | -6/+3 |
|\ \ \ \ | | | | | | | | | | | vfp: Get rid of some compile warnings | ||||
| * | | | | vfp: Get rid of some compile warnings | Lioncash | 2015-02-01 | 2 | -6/+3 |
| | | | | | |||||
* | | | | | arm: Clean up ARMul_State | Lioncash | 2015-02-01 | 5 | -138/+84 |
|/ / / / | | | | | | | | | | | | | Remove unnecessary/unused struct variables. | ||||
* | | | | arm: Adios armemu | Lioncash | 2015-02-01 | 16 | -8599/+166 |
| | | | | |||||
* | | | | Merge pull request #512 from lioncash/assignment | Tony Wasserka | 2015-01-31 | 2 | -4/+4 |
|\ \ \ \ | |_|/ / |/| | | | shared_memory: Fix assignments in SharedMemory::Map | ||||
| * | | | shared_memory: Fix assignments in SharedMemory::Map | Lioncash | 2015-01-30 | 2 | -4/+4 |
| |/ / | |||||
* | | | dyncom: clean up arm_dyncom_dec.h | Lioncash | 2015-01-30 | 1 | -43/+2 |
| | | | |||||
* | | | arm: Move headers over to pragma once | Lioncash | 2015-01-30 | 7 | -31/+11 |
| | | | |||||
* | | | arm: Get rid of armcpu.h and skyeye_types.h | Lioncash | 2015-01-30 | 6 | -115/+0 |
| | | | |||||
* | | | arm: Clean out armos.h and armmmu.h | Lioncash | 2015-01-30 | 2 | -181/+23 |
| | | | |||||
* | | | Merge pull request #513 from lioncash/cleanup | bunnei | 2015-01-30 | 6 | -1667/+168 |
|\ \ \ | | | | | | | | | arm: Cleanup. | ||||
| * | | | arm: Throw out a lot of unnecessary code | Lioncash | 2015-01-30 | 6 | -1536/+56 |
| | | | | |||||
| * | | | armdefs: Move some defines over to enums | Lioncash | 2015-01-30 | 1 | -131/+112 |
| |/ / | |||||
* | | | loader: Add missing printf argument | Lioncash | 2015-01-30 | 1 | -1/+1 |
| | | | |||||
* | | | archive: Fix initializer list order for the File class. | Lioncash | 2015-01-30 | 1 | -1/+1 |
| | | | |||||
* | | | apt_u: Fix missing printf specifiers | Lioncash | 2015-01-30 | 1 | -2/+2 |
|/ / | |||||
* | | Kernel: Mark all appropriate kernel objects as "final" | Yuri Kunde Schlesner | 2015-01-30 | 7 | -8/+7 |
| | | |||||
* | | SVC: Use CASCADE_RESULT in SVC handlers | Yuri Kunde Schlesner | 2015-01-30 | 2 | -77/+32 |
| | | |||||
* | | Remove result.h InvalidHandle | Yuri Kunde Schlesner | 2015-01-30 | 4 | -30/+32 |
| | | | | | | | | | | It was only being used in two places, where it was replaced by a local constant. | ||||
* | | SVC: Change return type of handlers to ResultCode | Yuri Kunde Schlesner | 2015-01-30 | 2 | -132/+127 |
| | | |||||
* | | Kernel: Convert Event to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 10 | -152/+151 |
| | | |||||
* | | Kernel: Convert Timer to (mostly) not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 3 | -111/+112 |
| | | |||||
* | | Kernel: Convert Mutex to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 5 | -114/+110 |
| | | |||||
* | | Kernel: Convert AddressArbiter to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 3 | -38/+55 |
| | | |||||
* | | Kernel: Convert Semaphore to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 3 | -67/+88 |
| | | |||||
* | | Kernel: Convert SharedMemory to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 8 | -102/+107 |
| | | |||||
* | | Additions to ResultVal to make it more convenient to use. | Yuri Kunde Schlesner | 2015-01-30 | 1 | -1/+25 |
| | | |||||
* | | Move VAddr/PAddr typedefs to kernel.h | Yuri Kunde Schlesner | 2015-01-30 | 2 | -9/+7 |
| | | |||||
* | | Kernel: Remove useless/duplicated comments; mark functions static | Yuri Kunde Schlesner | 2015-01-30 | 6 | -32/+8 |
| | | |||||
* | | Merge pull request #412 from purpasmart96/svc_table_cleanup | bunnei | 2015-01-28 | 1 | -7/+7 |
|\ \ | | | | | | | SVC: Update the SVC function table | ||||
| * | | SVC: Update the SVC function table | purpasmart96 | 2015-01-27 | 1 | -7/+7 |
| | | | |||||
* | | | dyncom: Minor cleanup | Lioncash | 2015-01-27 | 1 | -126/+137 |
| | | | | | | | | | | | | Narrow scopes for the instruction variables. Remove unnecessary parentheses. | ||||
* | | | Merge pull request #345 from purpasmart96/apt_stubs | bunnei | 2015-01-27 | 1 | -91/+276 |
|\ \ \ | | | | | | | | | APT_U: Stub some functions & misc changes | ||||
| * | | | APT_U: Stub some functions & misc changes | purpasmart96 | 2015-01-23 | 1 | -91/+276 |
| | | | | |||||
* | | | | Update vfp.cpp | bunnei | 2015-01-27 | 1 | -1/+1 |
| | | | | | | | | | | | | VFP: Changed a debug log to trace. | ||||
* | | | | Merge pull request #485 from Subv/more_servs | bunnei | 2015-01-26 | 21 | -3/+426 |
|\ \ \ \ | | | | | | | | | | | Services: Stubbed more services. | ||||
| * | | | | Services/HID: Removed some files due to a rebase error | Subv | 2015-01-24 | 3 | -267/+0 |
| | | | | | |||||
| * | | | | Services: Stubbed more services. | Subv | 2015-01-24 | 24 | -3/+693 |
| | | | | | | | | | | | | | | | | | | | | Implemented FSUser::CreateExtSaveData | ||||
* | | | | | Merge pull request #410 from chinhodado/cleanup | bunnei | 2015-01-24 | 5 | -483/+157 |
|\ \ \ \ \ | | | | | | | | | | | | | Cleanup: Logging in Core | ||||
| * | | | | | Cleanup: Logging in Core | Chin | 2015-01-19 | 5 | -483/+157 |
| | | | | | | |||||
* | | | | | | vfp: Clean up vertical alignment for instructions | Lioncash | 2015-01-23 | 1 | -131/+125 |
| | | | | | | |||||
* | | | | | | cam_u.h: fix indentation | archshift | 2015-01-22 | 1 | -2/+2 |
| |/ / / / |/| | | | | | | | | | Withholding my profanity towards Xcode. | ||||
* | | | | | Merge pull request #493 from archshift/ptmplay | bunnei | 2015-01-22 | 6 | -0/+106 |
|\ \ \ \ \ | | | | | | | | | | | | | Stubbed some services | ||||
| * | | | | | Stubbed cam:u service | archshift | 2015-01-21 | 4 | -0/+51 |
| | | | | | | |||||
| * | | | | | Stubbed ptm:play service | archshift | 2015-01-21 | 4 | -0/+55 |
| | | | | | | |||||
* | | | | | | dyncom: Minor cleanup | Lioncash | 2015-01-22 | 1 | -282/+270 |
| | | | | | | | | | | | | | | | | | | | | | | | | Removes some unused macros and cleans up indentation inconsistencies | ||||
* | | | | | | WaitSynchronization: Added a result code for invalid result, fixed bug. | bunnei | 2015-01-22 | 1 | -3/+9 |
| | | | | | | |||||
* | | | | | | Thread: Fix WaitSynchronization1 to not set register 1 on thread wakeup. | bunnei | 2015-01-22 | 3 | -25/+45 |
| | | | | | | |||||
* | | | | | | Thread: Use std::find in CheckWait_WaitObject. | bunnei | 2015-01-22 | 1 | -4/+5 |
| | | | | | | |||||
* | | | | | | Mutex: Cleanup and remove redundant code. | bunnei | 2015-01-22 | 3 | -47/+29 |
| | | | | | | |||||
* | | | | | | Kernel: Renamed some functions for clarity. | bunnei | 2015-01-22 | 7 | -10/+10 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - ReleaseNextThread->WakeupNextThread - ReleaseAllWaitingThreads->WakeupAllWaitingThreads. | ||||
* | | | | | | Kernel: Changed "ShouldWait" to return bool and "Acquire" to return void. | bunnei | 2015-01-22 | 9 | -71/+42 |
| | | | | | | |||||
* | | | | | | WaitObject: Renamed "Wait" to "ShouldWait", made "ShouldWait" and "Acquire" pure virtual. | bunnei | 2015-01-22 | 9 | -23/+22 |
| | | | | | | |||||
* | | | | | | Event: Fix implementation of "non-sticky" events. | bunnei | 2015-01-22 | 1 | -0/+4 |
| | | | | | | |||||
* | | | | | | Session: Change to a WaitObject. | bunnei | 2015-01-22 | 3 | -2/+9 |
| | | | | | | |||||
* | | | | | | Kernel: Reschedule on SignalEvent and SendSyncRequest, fix some bugs. | bunnei | 2015-01-22 | 2 | -1/+2 |
| | | | | | | |||||
* | | | | | | Mutex: Fix a bug where the thread should not wait if it already has the mutex. | bunnei | 2015-01-22 | 1 | -1/+4 |
| | | | | | | |||||
* | | | | | | Kernel: Moved Wait and Acquire to WaitObject, added way to retrieve a WaitObject safely. | bunnei | 2015-01-22 | 4 | -20/+59 |
| | | | | | | |||||
* | | | | | | SVC: Removed a Sleep that made no sense | bunnei | 2015-01-22 | 1 | -6/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Would deadlock the calling thread - Code would never get hit anyways | ||||
* | | | | | | AddressArbiter: Changed to Kernel::Object, big cleanup, removed code that made no sense. | bunnei | 2015-01-22 | 5 | -38/+45 |
| | | | | | | |||||
* | | | | | | Kernel: Get rid of WaitTypes and simplify lots of code, removing hacks. | bunnei | 2015-01-22 | 9 | -122/+63 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Improved comments | bunnei | 2015-01-22 | 1 | -7/+12 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Refactor to fix several bugs | bunnei | 2015-01-22 | 8 | -79/+76 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Separate wait checking from waiting the current thread - Resume thread when wait_all=true only if all objects are available at once - Set output to correct wait object index when there are duplicate handles | ||||
* | | | | | | Kernel: Separate WaitSynchronization into Wait and Acquire methods. | bunnei | 2015-01-22 | 8 | -18/+59 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Handle case where handles=nullptr. | bunnei | 2015-01-22 | 1 | -0/+4 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Handle case where handle_count is invalid. | bunnei | 2015-01-22 | 1 | -3/+7 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Handle case where handle_count=0. | bunnei | 2015-01-22 | 1 | -19/+29 |
| | | | | | | |||||
* | | | | | | WaitSynchronizationN: Implement return values | bunnei | 2015-01-22 | 10 | -83/+189 |
| | | | | | | |||||
* | | | | | | Event: Fixed some bugs and cleanup (Subv) | bunnei | 2015-01-22 | 4 | -57/+16 |
| | | | | | | |||||
* | | | | | | Thread: Keep track of multiple wait objects. | bunnei | 2015-01-22 | 3 | -16/+30 |
| | | | | | | |||||
* | | | | | | Event: Get rid of permanent_lock hack. | bunnei | 2015-01-22 | 2 | -36/+8 |
| | | | | | | |||||
* | | | | | | WaitObject: Added RemoveWaitingThread, fixed a bug, and cleanup. | bunnei | 2015-01-22 | 2 | -4/+17 |
| | | | | | | |||||
* | | | | | | Kernel: Added WaitObject and changed "waitable" objects inherit from it. | bunnei | 2015-01-22 | 8 | -71/+73 |
| | | | | | | |||||
* | | | | | | Added HID_SPVR service and split HID_U implementation into service/hid/hid.xxx | archshift | 2015-01-21 | 10 | -219/+333 |
|/ / / / / | |||||
* | | | | | Merge pull request #498 from lioncash/statics | bunnei | 2015-01-20 | 1 | -14/+14 |
|\ \ \ \ \ | | | | | | | | | | | | | core_timing: Mark several variables as static | ||||
| * | | | | | core_timing: Mark several variables as static | Lioncash | 2015-01-20 | 1 | -14/+14 |
| | | | | | | | | | | | | | | | | | | | | | | | | These are only used in this translation unit. | ||||
* | | | | | | core: Fix a few docstrings | Lioncash | 2015-01-20 | 4 | -4/+4 |
|/ / / / / | |||||
* | | | | | Merge pull request #492 from archshift/apt | bunnei | 2015-01-20 | 2 | -1/+4 |
|\ \ \ \ \ | | | | | | | | | | | | | Expose GetSharedFont and NotifyToWait to APT:A and APT:S respectively | ||||
| * | | | | | Expose GetSharedFont and NotifyToWait to APT:A and APT:S respectively | archshift | 2015-01-19 | 2 | -1/+4 |
| | | | | | | |||||
* | | | | | | Merge pull request #241 from linkmauve/better-loader | bunnei | 2015-01-20 | 8 | -352/+344 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Improve the loader a bit | ||||
| * | | | | | | Loader: Clean up the ELF AppLoader. | Emmanuel Gil Peyrot | 2015-01-15 | 2 | -42/+35 |
| | | | | | | | |||||
| * | | | | | | Loader: Clean up the 3DSX AppLoader. | Emmanuel Gil Peyrot | 2015-01-15 | 1 | -17/+24 |
| | | | | | | | |||||
| * | | | | | | Loader: Clean up the NCCH AppLoader. | Emmanuel Gil Peyrot | 2015-01-15 | 1 | -51/+48 |
| | | | | | | | |||||
| * | | | | | | Loader: Display the type of the file being loaded. | Emmanuel Gil Peyrot | 2015-01-15 | 1 | -3/+23 |
| | | | | | | | |||||
| * | | | | | | Loader: Guess filetype from the magic, or fallback to the extension. | Emmanuel Gil Peyrot | 2015-01-15 | 8 | -26/+112 |
| | | | | | | | |||||
| * | | | | | | Loader: Don’t assume the file hasn’t been read before. | Emmanuel Gil Peyrot | 2015-01-15 | 3 | -4/+13 |
| | | | | | | | |||||
| * | | | | | | Loader: Keep a reference to the file and pass it to the correct AppLoader, instead of loading it multiple times. | Emmanuel Gil Peyrot | 2015-01-15 | 8 | -176/+116 |
| | | | | | | | |||||
| * | | | | | | Loader: Initialize the default NCCH values in the class declaration, not in the constructor. | Emmanuel Gil Peyrot | 2015-01-15 | 2 | -8/+4 |
| | | | | | | | |||||
| * | | | | | | Loader: Remove the useless THREEDSXReader class. | Emmanuel Gil Peyrot | 2015-01-15 | 1 | -10/+4 |
| | | | | | | | |||||
| * | | | | | | Loader: Never forget to change is_loaded. | Emmanuel Gil Peyrot | 2015-01-15 | 6 | -7/+15 |
| | | | | | | | |||||
| * | | | | | | Loader: Don’t duplicate the docstring into the cpp file. | Emmanuel Gil Peyrot | 2015-01-15 | 4 | -56/+0 |
| | | | | | | | |||||
| * | | | | | | Loader: Fix indentation, whitespace, and a few other such cosmetic stuff. | Emmanuel Gil Peyrot | 2015-01-15 | 2 | -26/+24 |
| | | | | | | | |||||
* | | | | | | | dyncom: Clarify precedence for ternary statements | Lioncash | 2015-01-20 | 3 | -3/+3 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #494 from lioncash/shift | bunnei | 2015-01-19 | 1 | -7/+33 |
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | | dyncom: Implement missing shifts in ScaledRegisterPostIndexed, etc | ||||
| * | | | | | | dyncom: Implement missing shifts in ScaledRegisterPostIndexed, etc | Lioncash | 2015-01-19 | 1 | -7/+33 |
| | |/ / / / | |/| | | | | |||||
* | | | | | | Merge pull request #383 from zhuowei/shared_page | bunnei | 2015-01-19 | 5 | -0/+116 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Add some support for the shared page | ||||
| * | | | | | Add some support for the shared page (currently 3d slider is implemented) | Zhuowei Zhang | 2015-01-16 | 5 | -0/+116 |
| | | | | | | |||||
* | | | | | | dyncom: Handle the ARM A2 encoding of STRT/LDRT | Lioncash | 2015-01-17 | 1 | -10/+24 |
| | | | | | | | | | | | | | | | | | | | | | | | | These were also missing the shifted register case. | ||||
* | | | | | | dyncom: Handle the ARM A2 encoding of LDRBT/STRBT. | Lioncash | 2015-01-17 | 1 | -17/+15 |
| |_|/ / / |/| | | | | |||||
* | | | | | APT: Fix typo in setting return code for NotifyToWait | bunnei | 2015-01-16 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | DSP: Removed useless spam log for SignalInterrupt | bunnei | 2015-01-16 | 1 | -5/+2 |
| | | | | | |||||
* | | | | | Merge pull request #482 from yuriks/fix-vblank | bunnei | 2015-01-16 | 5 | -102/+91 |
|\ \ \ \ \ | |_|/ / / |/| | | | | Correctness fixes for GPU flipping and interrupts | ||||
| * | | | | GPU: Fix buffer overrun in Display Transfers | Yuri Kunde Schlesner | 2015-01-14 | 1 | -9/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Display transfers with the horizontal downscaling flag were calculating the wrong output size, causing them to write double the amount of data intended. It is likely that this was perceived as correct due to a separate bug in calculating source indices which caused the image to be padded unless the previous bug was present. This fixes both issues, correcting flickering issues in 3dscraft, blargSnes and more (caused by the transfer overwriting the back buffer which followed) as well as potentially fixing other crashes. | ||||
| * | | | | GSP: Fix appending of interrupts to the shared memory buffer | Yuri Kunde Schlesner | 2015-01-14 | 2 | -17/+12 |
| | | | | | | | | | | | | | | | | | | | | | | | | | The code was previously appending the interrupt to after the end of the buffer, instead of at the end. | ||||
| * | | | | GPU: Do periodic VBlank updates using CoreTiming | Yuri Kunde Schlesner | 2015-01-14 | 3 | -51/+44 |
| | | | | | |||||
| * | | | | GPU: Correct wrong default framebuffer address for sub-screen. | Yuri Kunde Schlesner | 2015-01-14 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | | | | | | | | | | It appears this is a mistake, since the sub-screen has no right framebuffer. | ||||
| * | | | | GSP: Update framebuffer info on all interrupts | Yuri Kunde Schlesner | 2015-01-14 | 1 | -12/+13 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Hardware testing determined that the GSP processes shared memory framebuffer update info even when no memory transfer or filling GX commands are used. They are now updated on every interrupt, which isn't confirmed correct but matches hardware behaviour more closely. This also reverts the hack introduced in #404. It made a few games behave better, but I believe it's incorrect and also breaks other games. | ||||
| * | | | | GPU: Fire GPU interrupts at the correct places. | Yuri Kunde Schlesner | 2015-01-14 | 2 | -21/+18 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PDC0 and PDC1 are both VBlank interrupts. PDC0 was being treated as a HBlank interrupt and fired many more times than it should. They now both fire together at 60 Hz. This puzzlingly *improves* apparent framerate on many applications. A few other interrupts were being fired inside the GSP command processing instead of on the actual GPU register writes, so they were moved there, which should cover direct writes tho those registers not going through the GX command queue. | ||||
* | | | | | Merge pull request #481 from Subv/hm_b | bunnei | 2015-01-15 | 1 | -7/+21 |
|\ \ \ \ \ | | | | | | | | | | | | | APTU: Stubbed NotifyToWait, taken from 3dmoo. | ||||
| * | | | | | APT: Fixed the comment style in some variables | Sebastian Valle | 2015-01-14 | 1 | -2/+2 |
| | | | | | | |||||
| * | | | | | APTU: Stubbed NotifyToWait, taken from 3dmoo. | Subv | 2015-01-14 | 1 | -7/+21 |
| |/ / / / | | | | | | | | | | | | | | | | | | | | | Also renamed some handles in the APT:U service to be more descriptive. Fixed a typo in InquireNotification | ||||
* | | | | | Merge pull request #480 from Subv/arb_2 | bunnei | 2015-01-14 | 3 | -4/+21 |
|\ \ \ \ \ | |/ / / / |/| | | | | AddrArbiter: Implement arbitration types 3 and 4. | ||||
| * | | | | AddrArbiter: Implement arbitration types 3 and 4. | Subv | 2015-01-13 | 3 | -4/+21 |
| | | | | | |||||
* | | | | | Services: Added some missing services. | Subv | 2015-01-13 | 9 | -1/+364 |
|/ / / / | | | | | | | | | | | | | | | | | cfg:s, ptm:sysm, apt:s. apt:s is almost exactly the same as apt:u as per 3dbrew | ||||
* | / / | vfp: Remove dead code | Lioncash | 2015-01-12 | 1 | -50/+14 |
| |/ / |/| | | |||||
* | | | dyncom: Fix 32-bit ASR shifts for immediates | Lioncash | 2015-01-12 | 1 | -5/+3 |
| | | | |||||
* | | | dyncom: Remove unused flag macros | Lioncash | 2015-01-12 | 1 | -15/+3 |
| | | | |||||
* | | | Merge pull request #472 from lioncash/overflow | bunnei | 2015-01-12 | 3 | -147/+175 |
|\ \ \ | |_|/ |/| | | dyncom: Fix some more V-flag setting ops. Plus some cleanup. | ||||
| * | | dyncom: Get rid of unnecessary outer-scope variables in InterpreterMainLoop | Lioncash | 2015-01-12 | 1 | -97/+108 |
| | | | |||||
| * | | dyncom: Fix overflow flag setting for ADD/RSB/RSC/SUB/SBC | Lioncash | 2015-01-12 | 1 | -38/+41 |
| | | | | | | | | | | | | Also cleans up CMN, and CMP. | ||||
| * | | dyncom: Add a helper function for addition with a carry | Lioncash | 2015-01-12 | 3 | -12/+26 |
| | | | |||||
* | | | Fix building on MinGW | darkf | 2015-01-12 | 1 | -0/+13 |
|/ / | |||||
* | | dyncom: Fix ADC overflow flag setting | Lioncash | 2015-01-12 | 1 | -8/+12 |
| | | |||||
* | | Merge pull request #456 from Subv/waitsync1 | bunnei | 2015-01-12 | 1 | -3/+2 |
|\ \ | | | | | | | SVC: Wake up the thread after the delay in WaitSync1 | ||||
| * | | SVC: Wake up the thread after the delay in WaitSync1 | Subv | 2015-01-11 | 1 | -3/+2 |
| | | | |||||
* | | | dyncom: Fix conditional execution of MSR | Lioncash | 2015-01-12 | 1 | -29/+31 |
| | | | |||||
* | | | Merge pull request #466 from Subv/wake | bunnei | 2015-01-11 | 1 | -0/+3 |
|\ \ \ | |/ / |/| | | Thread: Prevent waking a thread multiple times. | ||||
| * | | Thread: Prevent waking a thread multiple times. | Subv | 2015-01-11 | 1 | -0/+3 |
| | | | | | | | | | | | | If a thread was woken up by something, cancel the wakeup timeout. | ||||
* | | | Stubbed y2r:u IsBusyConversion | archshift | 2015-01-11 | 1 | -1/+16 |
| | | | | | | | | | | | | | | | There is no documentation available on this function, but we set the result to false as a stub. This allows Super Little Acorns to move all the way in game with pp3c. | ||||
* | | | Added Archive ID to fs:USER debug logs involving opening the archive. | archshift | 2015-01-10 | 1 | -3/+3 |
| | | | |||||
* | | | Logging: Log all called service functions (under trace). Compile out all trace logs under release for performance. | archshift | 2015-01-10 | 9 | -33/+22 |
| | | | |||||
* | | | Kernel: Start using boost::intrusive_ptr for lifetime management | Yuri Kunde Schlesner | 2015-01-09 | 12 | -90/+95 |
| | | | |||||
* | | | Kernel: Don't re-assign object's handle when duplicating one | Yuri Kunde Schlesner | 2015-01-09 | 2 | -2/+3 |
|/ / | |||||
* | | Merge pull request #444 from yuriks/handle-reform2 | bunnei | 2015-01-09 | 24 | -374/+329 |
|\ \ | | | | | | | Kernel Lifetime Reform Pt. 2 | ||||
| * | | Thread: Fix nullptr access in a logging function | Yuri Kunde Schlesner | 2015-01-09 | 1 | -1/+2 |
| | | | |||||
| * | | Thread: Rename thread_queue => thread_list | Yuri Kunde Schlesner | 2015-01-09 | 1 | -6/+6 |
| | | | |||||
| * | | Thread: Reduce use of Handles and move some funcs to inside the class. | Yuri Kunde Schlesner | 2015-01-09 | 11 | -302/+222 |
| | | | |||||
| * | | Kernel: Move Thread's definition to the header file | Yuri Kunde Schlesner | 2015-01-09 | 3 | -53/+67 |
| | | | |||||
| * | | Move ThreadContext to core/core.h and deal with the fallout | Yuri Kunde Schlesner | 2015-01-09 | 17 | -32/+52 |
| | | | |||||
* | | | Merge pull request #436 from kevinhartman/system-core | bunnei | 2015-01-09 | 1 | -0/+5 |
|\ \ \ | |/ / |/| | | Warn if a new thread is intended to be run on the system CPU core | ||||
| * | | Warn if a new thread is intended to be run on the system CPU core until we implement correct scheduling for such a thread. | Kevin Hartman | 2015-01-07 | 1 | -0/+5 |
| | | | |||||
* | | | Merge pull request #255 from Subv/cbranch_3 | bunnei | 2015-01-09 | 8 | -5/+234 |
|\ \ \ | | | | | | | | | Implemented timers | ||||
| * | | | SVC: Implemented the Timer service calls. | Subv | 2015-01-09 | 8 | -5/+234 |
| | | | | |||||
* | | | | Core: Fixed a crash and removed some unused variables. | Subv | 2015-01-09 | 2 | -8/+2 |
| | | | | | | | | | | | | | | | | ARM_Disasm only has static methods, so there's no need to have an instance of it. | ||||
* | | | | DynCom: Add a comment to GetTicks. | Subv | 2015-01-09 | 1 | -0/+1 |
| | | | | |||||
* | | | | Timing: Use CoreTiming::GetTicks to keep track of ticks. | Subv | 2015-01-09 | 2 | -6/+2 |
| | | | | | | | | | | | | | | | | This will keep track of idle ticks for us, and fixes some tickcount-related issues | ||||
* | | | | Merge pull request #443 from Subv/sleep_thread | bunnei | 2015-01-09 | 3 | -8/+43 |
|\ \ \ \ | | | | | | | | | | | SVC: Fixed SleepThread | ||||
| * | | | | SVC: Fixed SleepThread. | Subv | 2015-01-09 | 3 | -8/+43 |
| | |_|/ | |/| | | | | | | | | | | It will now properly wait the specified number of nanoseconds and then wake up the thread. | ||||
* | | | | Merge pull request #446 from lioncash/umaal | bunnei | 2015-01-08 | 1 | -4/+4 |
|\ \ \ \ | |/ / / |/| | | | dyncom: Fix UMAAL | ||||
| * | | | dyncom: Fix UMAAL | Lioncash | 2015-01-08 | 1 | -4/+4 |
| | | | | | | | | | | | | | | | | These need to be done as a 64-bit operation. | ||||
* | | | | Threads: Use a dummy idle thread when no other are ready. | Subv | 2015-01-08 | 4 | -2/+47 |
| | | | | | | | | | | | | | | | | This thread will not actually execute instructions, it will only advance the timing/events and try to yield immediately to the next ready thread, if there aren't any ready threads then it will be rescheduled and start its job again. | ||||
* | | | | Merge pull request #404 from bunnei/more-frame-synch-fixes | bunnei | 2015-01-08 | 1 | -1/+4 |
|\ \ \ \ | | | | | | | | | | | GPU: Toggle active framebuffer each frame | ||||
| * | | | | GSP: Toggle active framebuffer each frame | bunnei | 2015-01-08 | 1 | -1/+4 |
| | | | | | |||||
* | | | | | Merge pull request #431 from yuriks/thread-queue-cleanup | bunnei | 2015-01-07 | 1 | -1/+1 |
|\ \ \ \ \ | |_|/ / / |/| | | | | Common: Clean up ThreadQueueList | ||||
| * | | | | Common: Clean up ThreadQueueList | Yuri Kunde Schlesner | 2015-01-07 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Replace all the C-style complicated buffer management with a std::deque. In addition to making the code easier to understand it also adds support for non-POD IdTypes. Also clean the rest of the code to follow our code style. | ||||
* | | | | | Merge pull request #442 from lioncash/smul | bunnei | 2015-01-07 | 1 | -10/+7 |
|\ \ \ \ \ | |_|_|/ / |/| | | | | dyncom: Fix SMULWB/SMULWT | ||||
| * | | | | dyncom: Fix SMULWB/SMULWT | Lioncash | 2015-01-07 | 1 | -10/+7 |
| |/ / / | | | | | | | | | | | | | Wasn't doing proper sign-extension | ||||
* | | | | Merge pull request #425 from Subv/coretiming | bunnei | 2015-01-07 | 4 | -418/+378 |
|\ \ \ \ | | | | | | | | | | | Ported the CoreTiming namespace from PPSSPP | ||||
| * | | | | CoreTiming: Ported the CoreTiming namespace from PPSSPP | Subv | 2015-01-07 | 4 | -418/+378 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Implemented the required calls to make it work. CoreTiming: Added a new logging class Core_Timing. | ||||
* | | | | | Fix double-free in Service manager during shutdown | Yuri Kunde Schlesner | 2015-01-07 | 2 | -25/+4 |
| |/ / / |/| | | | | | | | | | | | Fixes #423. | ||||
* | | | | Merge pull request #438 from lioncash/swp | bunnei | 2015-01-07 | 1 | -0/+1 |
|\ \ \ \ | | | | | | | | | | | dyncom: Fix SWPB | ||||
| * | | | | dyncom: Fix SWPB | Lioncash | 2015-01-07 | 1 | -0/+1 |
| | |_|/ | |/| | | |||||
* | | | | Merge pull request #434 from lioncash/sm | bunnei | 2015-01-07 | 1 | -1/+56 |
|\ \ \ \ | |/ / / |/| | | | dyncom: Move over SMLALXY | ||||
| * | | | dyncom: Move over SMLALXY | Lioncash | 2015-01-07 | 1 | -1/+56 |
| | |/ | |/| | |||||
* | | | Merge pull request #376 from Subv/arc_reorder | bunnei | 2015-01-07 | 11 | -34/+73 |
|\ \ \ | |/ / |/| | | Archives: Change the folder layout of some archives. | ||||
| * | | Archives/Exdata: Don't set concrete_mount_point in the ctor | Subv | 2015-01-06 | 1 | -1/+1 |
| | | | |||||
| * | | Archives: Changed the unimplemented archives comment. | Subv | 2015-01-06 | 1 | -1/+1 |
| | | | | | | | | | | | | It now refers to me as the PoC | ||||
| * | | Archives: Addressed some comments | Subv | 2015-01-06 | 5 | -15/+15 |
| | | | |||||
| * | | SaveDataCheck: Fixed a typo | Subv | 2015-01-05 | 1 | -1/+1 |
| | | | |||||
| * | | Archives: Make SYSTEM_ID and SDCARD_ID strings | Subv | 2015-01-04 | 6 | -9/+11 |
| | | | |||||
| * | | Archives: Changed the way paths are built for the archives. | Subv | 2015-01-04 | 10 | -27/+64 |
| | | | | | | | | | | | | Each archive now takes a mount point of either NAND or SDMC, and builds its own directory structure there, trying to simulate an HLE-friendly hardware layout | ||||
| * | | SaveDataCheck: Move the files to nand/title | Subv | 2015-01-04 | 1 | -1/+2 |
| | | | | | | | | | | | | under /nand/title/high/low/content/00000000.app.romfs | ||||
| * | | Archives: Change the folder layout of some archives. | Subv | 2015-01-03 | 3 | -4/+3 |
| | | | | | | | | | | | | This is to better represent the hardware layout, they are still aren't quite accurate, but this better and will help a bit when implementing the other archives like NAND-RO and NAND-RW | ||||
* | | | Merge pull request #417 from kevinhartman/exclusive-tag-fix | bunnei | 2015-01-06 | 2 | -16/+18 |
|\ \ \ | | | | | | | | | Added exclusive reservation granule from ARMv7 spec to dyncom... | ||||
| * | | | Added exclusive reservation granule from ARMv7 spec to dyncom to protect LDR/STREX. | Kevin Hartman | 2015-01-06 | 2 | -16/+18 |
| | | | | |||||
* | | | | Merge pull request #413 from purpasmart96/serv_clean | bunnei | 2015-01-06 | 7 | -33/+36 |
|\ \ \ \ | | | | | | | | | | | Services: Clean up a few things and add a few function names | ||||
| * | | | | Services: Clean up a few things and add a few function names | purpasmart96 | 2015-01-06 | 7 | -33/+36 |
| | | | | | |||||
* | | | | | Merge pull request #272 from rohit-n/sign-compare | bunnei | 2015-01-06 | 1 | -4/+4 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | Silence some -Wsign-compare warnings. | ||||
| * | | | | Silence some -Wsign-compare warnings. | Rohit Nirmal | 2015-01-01 | 1 | -4/+4 |
| |/ / / | |||||
* | | | | Merge pull request #422 from lioncash/bxj | bunnei | 2015-01-05 | 1 | -8/+25 |
|\ \ \ \ | | | | | | | | | | | dyncom: Partially emulate BXJ | ||||
| * | | | | dyncom: Partially emulate BXJ | Lioncash | 2015-01-05 | 1 | -8/+25 |
| | | | | | | | | | | | | | | | | | | | | Just in case some game studio let the intern write inline assembly or something. | ||||
* | | | | | Merge pull request #416 from bunnei/fake-dsp-interrupt | bunnei | 2015-01-05 | 3 | -5/+28 |
|\ \ \ \ \ | |/ / / / |/| | | | | DSP: Signal (faked) interrupt on every frame. | ||||
| * | | | | DSP: Signal (faked) interrupt on every frame. | bunnei | 2015-01-05 | 3 | -5/+28 |
| | | | | | | | | | | | | | | | | | | | | - Hack to work around games checking that the DSP event has been signaled by a real DSP interrupt. | ||||
* | | | | | dyncom: Actually set the Q flag for SMLABB/SMLABT/SMLATB/SMLATT | Lioncash | 2015-01-05 | 1 | -1/+2 |
| | | | | | | | | | | | | | | | | | | | | Easy skyeye todo fix. | ||||
* | | | | | Merge pull request #418 from lioncash/qd | bunnei | 2015-01-05 | 4 | -25/+117 |
|\ \ \ \ \ | |/ / / / |/| | | | | dyncom: Implement QADD/QSUB/QDADD/QDSUB | ||||
| * | | | | dyncom: Implement QADD/QSUB/QDADD/QDSUB | Lioncash | 2015-01-05 | 4 | -25/+117 |
| | | | | | |||||
* | | | | | Merge pull request #407 from Subv/arbiter | bunnei | 2015-01-05 | 1 | -0/+11 |
|\ \ \ \ \ | | | | | | | | | | | | | AddressArbiter: Ported arbitration type 2 from 3dmoo. | ||||
| * | | | | | AddressArbiter: Ported arbitration type 2 from 3dmoo. | Subv | 2015-01-03 | 1 | -0/+11 |
| | | | | | | | | | | | | | | | | | | | | | | | | (Thanks 3dmoo!) | ||||
* | | | | | | Merge pull request #415 from Dante38490/master | bunnei | 2015-01-05 | 1 | -0/+2 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Loader: Add support for loading NCCH ROMs with the .3DS extension | ||||
| * | | | | | | Fix correct espace | Dante38490 | 2015-01-05 | 1 | -2/+2 |
| | | | | | | | |||||
| * | | | | | | Add support load 3DS room | Dante38490 | 2015-01-05 | 1 | -0/+2 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #408 from Subv/mutex | bunnei | 2015-01-05 | 1 | -2/+2 |
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | | Mutex: Add the calling thread to the waiting list when needed | ||||
| * | | | | | | Mutex: Add the calling thread to the waiting list when needed | Subv | 2015-01-04 | 1 | -2/+2 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | This will happen when the mutex is already owned by another thread. Should fix some issues with games being stuck due to waiting threads not being awoken. | ||||
* | | | | | | Merge pull request #386 from archshift/y2ru | bunnei | 2015-01-05 | 4 | -0/+72 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Stub the y2r:u service | ||||
| * | | | | | | Stub the y2r:u service | archshift | 2015-01-03 | 4 | -0/+72 |
| | | | | | | | |||||
* | | | | | | | skyeye: Remove duplicate typedefs | Lioncash | 2015-01-04 | 4 | -41/+17 |
| |/ / / / / |/| | | | | | | | | | | | | | | | | | citra already has its own typedefs like this. | ||||
* | | | | | | FileSys: Fix crash bug in DiskFile exposed by #400 | Yuri Kunde Schlesner | 2015-01-03 | 1 | -4/+0 |
| | | | | | | |||||
* | | | | | | FileSys: Fix a few memory leaks | Yuri Kunde Schlesner | 2015-01-03 | 2 | -6/+7 |
| | | | | | | |||||
* | | | | | | Merge pull request #396 from bunnei/default-dyncom | bunnei | 2015-01-03 | 2 | -3/+3 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Core: Change default CPU to dyncom. | ||||
| * | | | | | | Core: Change default CPU to dyncom. | bunnei | 2015-01-03 | 2 | -3/+3 |
| | |_|_|_|/ | |/| | | | | |||||
* | | | | | | Merge pull request #398 from lioncash/sm | bunnei | 2015-01-03 | 1 | -1/+43 |
|\ \ \ \ \ \ | |_|_|_|_|/ |/| | | | | | dyncom: Implement SMLAW | ||||
| * | | | | | dyncom: Implement SMLAW | Lioncash | 2015-01-03 | 1 | -1/+43 |
| | |_|/ / | |/| | | | |||||
* / | | | | VFP: Minor cleanup, functionally the same. | bunnei | 2015-01-03 | 1 | -2587/+2476 |
|/ / / / | |||||
* | | | | Merge pull request #395 from lioncash/rev | bunnei | 2015-01-03 | 1 | -45/+45 |
|\ \ \ \ | | | | | | | | | | | dyncom: Implement REVSH | ||||
| * | | | | dyncom: Implement REVSH | Lioncash | 2015-01-03 | 1 | -45/+45 |
| |/ / / | | | | | | | | | | | | | Also joins the REV ops into one common place. | ||||
* / / / | dyncom: Implement SMLALD/SMLSLD | Lioncash | 2015-01-03 | 1 | -3/+72 |
|/ / / | |||||
* | | | Merge pull request #381 from Subv/savedatacheck | bunnei | 2015-01-03 | 14 | -319/+275 |
|\ \ \ | | | | | | | | | Implemented the SaveDataCheck archive | ||||
| * | | | IVFCArchive: Use a critical log to notify of invalid operations. | Subv | 2015-01-03 | 1 | -9/+9 |
| | | | | |||||
| * | | | SaveDataCheck: Remove unneeded constructor from a class | Subv | 2015-01-03 | 1 | -2/+0 |
| | | | | |||||
| * | | | Archives: Added some documentation to IVFCArchive | Subv | 2015-01-03 | 1 | -0/+5 |
| | | | | |||||
| * | | | Archives: Reduced duplicate code in RomFS and SaveCheck. | Subv | 2015-01-03 | 14 | -341/+238 |
| | | | | | | | | | | | | | | | | Fixed a few warnings and cleaned up the code | ||||
| * | | | SaveDataCheck: Preliminary work in this archive. | Subv | 2015-01-03 | 4 | -7/+63 |
| | | | | | | | | | | | | | | | | | | | | | | | | This allows Steel Diver to boot further, some files are needed. This is still not ready and needs a big cleanup, this will possibly be delayed until the way we handle archives is fixed (with factory classes instead of ahead-of-time creation of archives) | ||||
* | | | | Merge pull request #392 from lioncash/sm | bunnei | 2015-01-03 | 1 | -3/+64 |
|\ \ \ \ | |/ / / |/| | | | dyncom: Implement SMMLA/SMMUL/SMMLS | ||||
| * | | | dyncom: Implement SMMLA/SMMUL/SMMLS | Lioncash | 2015-01-03 | 1 | -3/+64 |
| | | | | |||||
* | | | | Merge pull request #391 from lioncash/pedantic | bunnei | 2015-01-03 | 2 | -4/+4 |
|\ \ \ \ | | | | | | | | | | | archive/elf: Minor misc changes. | ||||
| * | | | | elf: Make DidRelocate const | Lioncash | 2015-01-03 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | archive: Fix initializer list order | Lioncash | 2015-01-03 | 1 | -3/+3 |
| | |/ / | |/| | | |||||
* | | | | dyncom: Implemented LDREXD/STREXD/LDREXH/STREXH | bunnei | 2015-01-03 | 3 | -227/+282 |
| |/ / |/| | | |||||
* | | | Merge pull request #390 from lioncash/wut | bunnei | 2015-01-03 | 1 | -27/+0 |
|\ \ \ | | | | | | | | | dyncom: Remove dead function InterpreterInitInstLength | ||||
| * | | | dyncom: Remove dead function InterpreterInitInstLength | Lioncash | 2015-01-03 | 1 | -27/+0 |
| |/ / | | | | | | | | | | Technically eliminates two memory leaks as well. | ||||
* | | | Merge pull request #388 from lioncash/sm | bunnei | 2015-01-03 | 5 | -52/+90 |
|\ \ \ | | | | | | | | | dyncom: Implement SMLAD/SMUAD/SMLSD/SMUSD | ||||
| * | | | armemu: Fix missing Q flag check for SMLSD. | Lioncash | 2015-01-03 | 1 | -2/+6 |
| | | | | |||||
| * | | | dyncom: Implement SMLAD/SMUAD/SMLSD/SMUSD | Lioncash | 2015-01-03 | 5 | -50/+84 |
| |/ / | |||||
* / / | soc_u: Fix a missing formatting argument | Lioncash | 2015-01-03 | 1 | -1/+1 |
|/ / | |||||
* | | dyncom: Implement SXTAB16 and SXTB16 | Lioncash | 2015-01-02 | 1 | -3/+58 |
| | | |||||
* | | Merge pull request #358 from neobrain/pica_progress2 | bunnei | 2015-01-02 | 2 | -1/+8 |
|\ \ | | | | | | | pica_progress followups | ||||
| * | | GPU: Pseudo-implement horizontal scaling. | Tony Wasserka | 2014-12-31 | 2 | -1/+8 |
| | | | | | | | | | | | | | | | It's not really known how this actually works. Some testing has shown that this probably performs no filtering, and common usage in games suggests it's not actually resizing the image at all. However, this patch does seem to fix some homebrew showing quasi-duplicated images while still keeping other applications in a working state. | ||||
* | | | Merge pull request #379 from lioncash/sh | bunnei | 2015-01-02 | 1 | -8/+110 |
|\ \ \ | | | | | | | | | dyncom: Implement SHADD8/SHADD16/SHSUB8/SHSUB16/SHASX/SHSAX | ||||
| * | | | dyncom: Implement SHADD8/SHADD16/SHSUB8/SHSUB16/SHASX/SHSAX | Lioncash | 2015-01-01 | 1 | -8/+110 |
| | |/ | |/| | |||||
* | | | Fix SADD8/SSUB8 in the armemu | Lioncash | 2015-01-01 | 1 | -50/+28 |
| | | | |||||
* | | | dyncom: Implement SADD8/SSUB8 | Lioncash | 2015-01-01 | 1 | -55/+108 |
|/ / | |||||
* | | SOC_U: Preliminary implementation of sockets. | Subv | 2014-12-31 | 4 | -22/+721 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | Stubbed CreateMemoryBlock Using Berkeley sockets, and Winsock2.2 on Windows. So far ftpony creates the socket and accepts incoming connections SOC_U: Renamed functions to maintain consistency Also prevents possible scope errors / conflicts with the actual Berkeley socket functions SOCU: Close all the opened sockets when cleaning up SOCU | ||||
* | | Merge pull request #375 from lioncash/uops | bunnei | 2014-12-31 | 1 | -9/+208 |
|\ \ | |/ |/| | dyncom: Implement UADD8/UADD16/USUB8/USUB16/UASX/USAX | ||||
| * | dyncom: Implement UADD8/UADD16/USUB8/USUB16/UASX/USAX | Lioncash | 2014-12-31 | 1 | -9/+208 |
| | | |||||
* | | dyncom: Massive refactor | bunnei | 2014-12-31 | 2 | -654/+221 |
| | | |||||
* | | Merge pull request #369 from darkf/mingw_ | bunnei | 2014-12-31 | 1 | -0/+8 |
|\ \ | | | | | | | Fix MinGW build (2) | ||||
| * \ | Fix merge conflicts | darkf | 2014-12-30 | 167 | -12294/+13495 |
| |\ \ | |||||
| * | | | Add comment regarding __WIN32__ in SkyEye code | darkf | 2014-11-29 | 1 | -0/+4 |
| | | | | |||||
| * | | | Fix MinGW build | darkf | 2014-11-29 | 1 | -0/+4 |
| | | | | |||||
* | | | | vfp: Get rid of a few warnings | Lioncash | 2014-12-30 | 2 | -2/+2 |
| |_|/ |/| | | |||||
* | | | vfp: Implement VMOVBRRSS | Lioncash | 2014-12-30 | 3 | -12/+44 |
| | | | |||||
* | | | dyncom: Implement USAT16/SSAT16 | Lioncash | 2014-12-30 | 1 | -2/+61 |
| | | | |||||
* | | | Merge pull request #368 from purpasmart96/dsp_mem | bunnei | 2014-12-30 | 3 | -2/+12 |
|\ \ \ | | | | | | | | | MemMap: Add support for DSP Read & Writes in the memory map | ||||
| * | | | MemMap: Add support for DSP Read & Writes in the memory map | purpasmart96 | 2014-12-30 | 3 | -2/+12 |
| | | | | |||||
* | | | | APT:A: Some style changes | Subv | 2014-12-30 | 1 | -12/+12 |
| | | | | |||||
* | | | | Archives: Implemented ExtSaveData and SharedExtSaveData | Subv | 2014-12-30 | 14 | -60/+264 |
| |_|/ |/| | | | | | | | | | | | | | | | | | | | | They will be stored in /extsavedata/SDMC and /extsavedata/NAND respectively. Also redirect some APT_A functions to their APT_U equivalents. Implemented the gamecoin.dat file in SharedExtSaveData in the PTM module. Implemented formatting the savegame. Retake a previous savegame if it exists instead of reporting them as not formatted every time a game is loaded. | ||||
* | | | dyncom: Implement USAT/SSAT | bunnei | 2014-12-30 | 3 | -2/+131 |
|/ / | |||||
* | | Merge pull request #253 from purpasmart96/mem_map | bunnei | 2014-12-30 | 2 | -69/+76 |
|\ \ | | | | | | | MemMap: Removed I/O address's and added more stuff | ||||
| * | | MemMap: Added AXI_WRAM & SHARED_PAGE along with other stuff | purpasmart96 | 2014-12-14 | 2 | -69/+76 |
| | | | | | | | | | | | | | | | | | | Got rid of I/O address's since the I/O addresses range's overlap with other address's types such as vram, these I/O addresses need to be done in an different way. | ||||
* | | | dyncom: Various cleanups to match coding style, no functional changes. | bunnei | 2014-12-30 | 5 | -7087/+5962 |
| | | | |||||
* | | | Merge pull request #361 from lioncash/moreqops | bunnei | 2014-12-29 | 4 | -65/+142 |
|\ \ \ | | | | | | | | | dyncom/armemu: Implement QADD8/QSUB8. | ||||
| * | | | dyncom: Implement QADD8/QSUB8 | Lioncash | 2014-12-29 | 1 | -32/+42 |
| | | | | |||||
| * | | | armemu: Implement QADD8/QSUB8 | Lioncash | 2014-12-29 | 3 | -33/+100 |
| | | | | |||||
* | | | | dyncom: Fix SMLALXY's instruction labels | Lioncash | 2014-12-29 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | They were erroneously labeled as SMLAL. | ||||
* | | | | Merge pull request #303 from linkmauve/fs-cleanup | Tony Wasserka | 2014-12-29 | 9 | -169/+97 |
|\ \ \ \ | |/ / / |/| | | | FileSys cleanup | ||||
| * | | | FileSys: Clean up according to the coding style, and remove redundant namespaced names. | Emmanuel Gil Peyrot | 2014-12-24 | 9 | -169/+97 |
| | | | | |||||
* | | | | Merge pull request #360 from lioncash/dynuxt | bunnei | 2014-12-29 | 1 | -2/+55 |
|\ \ \ \ | | | | | | | | | | | dyncom: Implement UXTB16/UXTAB16 | ||||
| * | | | | dyncom: Implement UXTB16/UXTAB16 | Lioncash | 2014-12-29 | 1 | -2/+55 |
| | | | | | |||||
* | | | | | Merge pull request #347 from bunnei/frameskip | bunnei | 2014-12-29 | 3 | -27/+38 |
|\ \ \ \ \ | |/ / / / |/| | | | | Frameskip | ||||
| * | | | | GPU: Implement frameskip and remove forced framebuffer swap hack. | bunnei | 2014-12-29 | 3 | -27/+38 |
| | | | | | |||||
* | | | | | Merge pull request #355 from lioncash/simp | bunnei | 2014-12-29 | 1 | -225/+142 |
|\ \ \ \ \ | | | | | | | | | | | | | armemu: Simplify some instructions. | ||||
| * | | | | | armemu: Simplify SSAT/SSAT16/SXTB/SXTAB | Lioncash | 2014-12-28 | 1 | -71/+48 |
| | | | | | | |||||
| * | | | | | armemu: Simplify REV/REV16/SXTH/SXTAH | Lioncash | 2014-12-28 | 1 | -38/+26 |
| | | | | | | |||||
| * | | | | | armemu: Simplify USAT16/UXTB/UXTAB | Lioncash | 2014-12-28 | 1 | -65/+42 |
| | | | | | | |||||
| * | | | | | armemu: Simplify REVSH/UXTH/UXTAH | Lioncash | 2014-12-28 | 1 | -48/+23 |
| | | | | | | |||||
* | | | | | | Merge pull request #359 from lioncash/vfp | bunnei | 2014-12-29 | 5 | -1664/+1053 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | vfp: Actually make the code somewhat readable | ||||
| * | | | | | | vfp: Actually make the code somewhat readable | Lioncash | 2014-12-29 | 5 | -1664/+1053 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #331 from yuriks/handle-reform | bunnei | 2014-12-29 | 14 | -208/+249 |
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | | New Handle manager | ||||
| * | | | | | | Kernel: New handle manager | Yuri Kunde Schlesner | 2014-12-28 | 13 | -168/+209 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This handle manager more closely mirrors the behaviour of the CTR-OS one. In addition object ref-counts and support for DuplicateHandle have been added. Note that support for DuplicateHandle is still experimental, since parts of the kernel still use Handles internally, which will likely cause troubles if two different handles to the same object are used to e.g. wait on a synchronization primitive. | ||||
| * | | | | | | Kernel: Replace GetStaticHandleType by HANDLE_TYPE constants | Yuri Kunde Schlesner | 2014-12-28 | 8 | -15/+15 |
| | | | | | | | |||||
| * | | | | | | Rename ObjectPool to HandleTable | Yuri Kunde Schlesner | 2014-12-28 | 12 | -54/+54 |
| | | | | | | | |||||
* | | | | | | | dyncom: Implement PKHBT and PKHTB. | bunnei | 2014-12-28 | 1 | -2/+57 |
| | | | | | | | |||||
* | | | | | | | armemu: Fix PKHTB to do an arithmetic shift and correctly decode immediate field. | bunnei | 2014-12-28 | 1 | -13/+5 |
| | | | | | | | |||||
* | | | | | | | dyncom: Implement USAD8/USADA8 | Lioncash | 2014-12-28 | 3 | -3/+53 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #354 from lioncash/usaduflow | bunnei | 2014-12-28 | 3 | -4/+14 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | armemu: Fix underflows in USAD8/USADA8 | ||||
| * | | | | | | armemu: Fix underflows in USAD8/USADA8 | Lioncash | 2014-12-28 | 3 | -4/+14 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | Initially reported by xdec. | ||||
* | | | | | | dyncom: Implement UQADD8, UQADD16, UQSUB8, UQSUB16, UQASX, and UQSAX. | Lioncash | 2014-12-27 | 3 | -12/+102 |
| | | | | | | |||||
* | | | | | | armemu: Implement UQADD8, UQADD16, UQSUB16, UQASX, and UQSAX | Lioncash | 2014-12-27 | 3 | -19/+93 |
|/ / / / / | |||||
* | | | | | dyncom: Implement UHADD8, UHADD16, UHSUB8, UHSUB16, UHASX, and UHSAX | Lioncash | 2014-12-27 | 1 | -11/+123 |
| | | | | | |||||
* | | | | | armemu: Implement UHADD8, UHADD16, UHSUB8, UHSUB16, UHASX, and UHSAX | Lioncash | 2014-12-27 | 1 | -2/+73 |
|/ / / / | |||||
* | | | | Merge pull request #339 from bunnei/fixup-gsp-synch | bunnei | 2014-12-26 | 7 | -117/+59 |
|\ \ \ \ | | | | | | | | | | | Fixup gsp synch | ||||
| * | | | | GPU: Further improve synchronization. | bunnei | 2014-12-26 | 1 | -22/+20 |
| | | | | | |||||
| * | | | | ARM: Add a mechanism for faking CPU time elapsed during HLE. | bunnei | 2014-12-26 | 6 | -95/+39 |
| | | | | | | | | | | | | | | | | | | | | - Also a few cleanups. | ||||
* | | | | | Merge pull request #330 from purpasmart96/new_srv | bunnei | 2014-12-26 | 61 | -309/+367 |
|\ \ \ \ \ | | | | | | | | | | | | | More services & small clean ups | ||||
| * | | | | | More services & small clean ups | purpasmart96 | 2014-12-26 | 61 | -309/+367 |
| | | | | | | |||||
* | | | | | | Merge pull request #343 from lioncash/smmla | bunnei | 2014-12-26 | 1 | -2/+30 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | armemu: Implement SMMUL, SMMLA, and SMMLS. | ||||
| * | | | | | | armemu: Implement SMMUL, SMMLA, and SMMLS. | Lioncash | 2014-12-25 | 1 | -2/+30 |
| | |_|/ / / | |/| | | | | |||||
* | | | | | | Merge pull request #341 from lioncash/moresmops | bunnei | 2014-12-26 | 1 | -2/+33 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | armemu: Implement SMLALD/SMLSLD | ||||
| * | | | | | | armemu: Implement SMLALD/SMLSLD | Lioncash | 2014-12-24 | 1 | -2/+33 |
| |/ / / / / | |||||
* / / / / / | armemu: Fix GE/Q flag setting semantics | Lioncash | 2014-12-24 | 1 | -62/+56 |
|/ / / / / | |||||
* | | | | | Merge pull request #328 from archshift/writeable | bunnei | 2014-12-24 | 1 | -1/+18 |
|\ \ \ \ \ | |_|/ / / |/| | | | | Stubbed IsSdmcWriteable to always return writeable. | ||||
| * | | | | Stubbed IsSdmcWriteable to always return writeable. | archshift | 2014-12-24 | 1 | -1/+18 |
| | | | | | |||||
* | | | | | armemu: Set the Q flag correctly for much of the other ops | Lioncash | 2014-12-23 | 1 | -8/+8 |
| | | | | | | | | | | | | | | | | | | | | They were setting the old S flag. | ||||
* | | | | | armemu: Set the Q flag properly for SMLAD/SMUAD | Lioncash | 2014-12-23 | 3 | -13/+28 |
| | | | | | |||||
* | | | | | Merge pull request #334 from lioncash/cpsr | bunnei | 2014-12-23 | 1 | -1/+1 |
|\ \ \ \ \ | | | | | | | | | | | | | armemu: Fix retrieval of the CPSR in MRS instructions. | ||||
| * | | | | | armemu: Fix retrieval of the CPSR in MRS instructions. | Lioncash | 2014-12-23 | 1 | -1/+1 |
| | | | | | | |||||
* | | | | | | Merge pull request #335 from lioncash/cpsrcreate | bunnei | 2014-12-23 | 4 | -25/+78 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | armemu: Emulate the GE and Q flags. | ||||
| * | | | | | armemu: Properly set the Q flag for SSAT16/USAT16 upon saturation. | Lioncash | 2014-12-23 | 1 | -9/+23 |
| | | | | | | |||||
| * | | | | | armemu: Fix SEL | Lioncash | 2014-12-23 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | Needs to use the updated state of the CPSR. | ||||
| * | | | | | armemu: Fix construction of the CPSR | Lioncash | 2014-12-23 | 4 | -15/+54 |
| |/ / / / | |||||
* / / / / | dyncom: Move over QADD16/QASX/QSAX/QSUB16 | Lioncash | 2014-12-22 | 1 | -7/+87 |
|/ / / / | |||||
* | | | | Merge pull request #322 from chinhodado/master | bunnei | 2014-12-22 | 4 | -11/+8 |
|\ \ \ \ | |/ / / |/| | | | More warning cleanups | ||||
| * | | | More warning cleanups | Chin | 2014-12-21 | 4 | -11/+8 |
| | | | | |||||
* | | | | Merge pull request #332 from lioncash/sel | bunnei | 2014-12-22 | 1 | -1/+58 |
|\ \ \ \ | | | | | | | | | | | dyncom: Move SEL over | ||||
| * | | | | dyncom: Move SEL over | Lioncash | 2014-12-22 | 1 | -1/+58 |
| | | | | | |||||
* | | | | | Merge pull request #312 from Subv/still_more_savedata_stuff | bunnei | 2014-12-22 | 14 | -30/+508 |
|\ \ \ \ \ | |/ / / / |/| | | | | CFG: Implemented the GetConfigInfoBlk2 function. | ||||
| * | | | | CFG: Fixed some warnings and errors in Clang | Subv | 2014-12-22 | 2 | -4/+4 |
| | | | | | |||||
| * | | | | CFG: More style changes | Subv | 2014-12-22 | 1 | -5/+5 |
| | | | | | |||||
| * | | | | CFGU: Indentation | Subv | 2014-12-21 | 1 | -4/+3 |
| | | | | | |||||
| * | | | | CFG: Some indentation | Subv | 2014-12-21 | 1 | -11/+13 |
| | | | | | |||||
| * | | | | CFG: Changed the CreateConfigInfoBlk search loop | Subv | 2014-12-21 | 1 | -7/+4 |
| | | | | | |||||
| * | | | | CFG: Corrected the licenses in cfg_i.cpp and cfg_u.cpp | Subv | 2014-12-21 | 2 | -2/+2 |
| | | | | | |||||
| * | | | | CFG: Create a new subfolder cfg inside service to handle cfg | Subv | 2014-12-21 | 11 | -489/+617 |
| | | | | | | | | | | | | | | | | | | | | Moved most of the shared CFG code there, implemented a few CFG:I functions | ||||
| * | | | | CFGU: Some changes | Subv | 2014-12-21 | 1 | -12/+33 |
| | | | | | |||||
| * | | | | CFGU: Addressed some issues. | Subv | 2014-12-21 | 1 | -43/+55 |
| | | | | | |||||
| * | | | | CFGU: Addressed some comments. | Subv | 2014-12-21 | 1 | -11/+13 |
| | | | | | |||||
| * | | | | Style: Addressed some comments | Subv | 2014-12-21 | 2 | -6/+12 |
| | | | | | |||||
| * | | | | CFG_U: Use Common::make_unique instead of the std version | Subv | 2014-12-21 | 1 | -1/+2 |
| | | | | | |||||
| * | | | | CFG:U: Implemented some more blocks | Subv | 2014-12-21 | 1 | -4/+30 |
| | | | | | |||||
| * | | | | CFG: Implemented block 0x00070001 in the config savefile | Subv | 2014-12-21 | 1 | -0/+5 |
| | | | | | |||||
| * | | | | CFGU: Use an absolute offset in the config savefile blocks | Subv | 2014-12-21 | 1 | -1/+3 |
| | | | | | |||||
| * | | | | CFG: Load the Config savedata file if it already exists. | Subv | 2014-12-21 | 1 | -3/+4 |
| | | | | | |||||
| * | | | | CFGU: Added block 0x000A0002 to the default savegame file | Subv | 2014-12-21 | 1 | -0/+18 |
| | | | | | | | | | | | | | | | | | | | | That's the language id block, we're using LANGUAGE_EN for now. This block allows some games to boot further | ||||
| * | | | | CFG: Refactored how the config file works. | Subv | 2014-12-21 | 2 | -56/+127 |
| | | | | | | | | | | | | | | | | | | | | It is now kept in memory as per 3dbrew, all updates happen on memory, then they can be saved using UpdateConfigNANDSavegame. | ||||
| * | | | | CFG:U: Add some data to the 0x00050005 config block. | Subv | 2014-12-21 | 1 | -6/+11 |
| | | | | | | | | | | | | | | | | | | | | Seems to allow some games to boot further, thanks @Normmatt for sharing this information | ||||
| * | | | | CFG: Implemented the GetConfigInfoBlk2 function. | Subv | 2014-12-21 | 5 | -15/+197 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Added a "config" file to the CFG process service (CFG:U), and added a few default blocks to it. Implemented GetSystemModel and GetModelNintendo2DS | ||||
* | | | | | Merge pull request #324 from lioncash/dync | bunnei | 2014-12-22 | 1 | -7/+102 |
|\ \ \ \ \ | |/ / / / |/| | | | | dyncom: Move over SASX/SSAX/SADD16/SSUB16 | ||||
| * | | | | dyncom: Move over SASX/SSAX/SADD16/SSUB16 | Lioncash | 2014-12-22 | 1 | -7/+102 |
| | | | | | |||||
* | | | | | Merge pull request #291 from purpasmart96/license | bunnei | 2014-12-21 | 130 | -137/+137 |
|\ \ \ \ \ | | | | | | | | | | | | | License change | ||||
| * | | | | | License change | purpasmart96 | 2014-12-21 | 130 | -137/+137 |
| | | | | | | |||||
* | | | | | | Merge pull request #271 from archshift/createf | bunnei | 2014-12-21 | 8 | -1/+91 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | Added CreateFile to the FS_USER service | ||||
| * | | | | | Added CreateFile to the FS_USER service | archshift | 2014-12-21 | 8 | -1/+91 |
| | | | | | | | | | | | | | | | | | | | | | | | | Tested with hwtests. | ||||
* | | | | | | Merge pull request #323 from lioncash/saddsub | bunnei | 2014-12-21 | 1 | -14/+87 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | armemu: Implement SADD8/SSUB8 | ||||
| * | | | | | | armemu: Implement SADD8/SSUB8 | Lioncash | 2014-12-21 | 1 | -14/+87 |
| | | | | | | | |||||
* | | | | | | | Thread: Wait current thread on svc_SleepThread | bunnei | 2014-12-21 | 3 | -22/+35 |
| |_|_|/ / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Removed unused VBLANK sleep mode - Added error log for bad context switch - Renamed VerifyWait to CheckWaitType to be more clear | ||||
* | | | | | | Merge pull request #316 from yuriks/thread-handle | bunnei | 2014-12-20 | 3 | -2/+16 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Kernel: Implement support for current thread pseudo-handle | ||||
| * | | | | | Kernel: Implement support for current thread pseudo-handle | Yuri Kunde Schlesner | 2014-12-20 | 3 | -2/+16 |
| | | | | | | | | | | | | | | | | | | | | | | | | This boots a few (mostly Nintendo 1st party) games further. | ||||
* | | | | | | Merge pull request #296 from lioncash/dyn | bunnei | 2014-12-20 | 1 | -1/+47 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | dyncom: Implement UMAAL | ||||
| * | | | | | | dyncom: Implement UMAAL | Lioncash | 2014-12-19 | 1 | -1/+47 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #310 from lioncash/ssat16 | bunnei | 2014-12-20 | 1 | -14/+20 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | armemu: Fix SSAT16. | ||||
| * | | | | | | | armemu: Fix SSAT16 | Lioncash | 2014-12-19 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The lower-bound would never be negative like it should | ||||
| * | | | | | | | armemu: Clean up naming and formatting for SSAT16 | Lioncash | 2014-12-19 | 1 | -14/+20 |
| | |_|_|/ / / | |/| | | | | | |||||
* | | | | | | | armemu: Should be using labs for USAD8/USADA8 | Lioncash | 2014-12-20 | 1 | -4/+4 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #311 from lioncash/usada | bunnei | 2014-12-20 | 1 | -1/+24 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | armemu: Implement USAD8 and USADA8 | ||||
| * | | | | | | | armemu: Implement USAD8 and USADA8 | Lioncash | 2014-12-19 | 1 | -1/+24 |
| | | | | | | | | |||||
* | | | | | | | | Merge pull request #313 from lioncash/smlsd | bunnei | 2014-12-20 | 1 | -6/+10 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | armemu: Implement SMLSD | ||||
| * | | | | | | | | armemu: Implement SMLSD | Lioncash | 2014-12-19 | 1 | -6/+10 |
| | |_|/ / / / / | |/| | | | | | | |||||
* | | | | | | | | Merge pull request #314 from lioncash/qsax-qasx | bunnei | 2014-12-20 | 1 | -7/+20 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | armemu: Implement QASX and QSAX | ||||
| * | | | | | | | | armemu: Implement QASX and QSAX | Lioncash | 2014-12-19 | 1 | -7/+20 |
| |/ / / / / / / | |||||
* | | | | | | | | Merge pull request #315 from chinhodado/master | bunnei | 2014-12-20 | 4 | -9/+16 |
|\ \ \ \ \ \ \ \ | |_|_|_|_|/ / / |/| | | | | | | | Clean up some warnings | ||||
| * | | | | | | | Clean up some warnings | Chin | 2014-12-20 | 4 | -9/+16 |
| | | | | | | | | |||||
* | | | | | | | | Common: Add a clone of std::make_unique | Yuri Kunde Schlesner | 2014-12-20 | 3 | -10/+14 |
| | | | | | | | | |||||
* | | | | | | | | Merge pull request #306 from Subv/even_more_savedata | bunnei | 2014-12-20 | 1 | -2/+31 |
|\ \ \ \ \ \ \ \ | |/ / / / / / / |/| | | | | | | | SaveData: Added some documentation to FormatSaveData | ||||
| * | | | | | | | FS_U: Added the command to the docs of SaveData functions | Subv | 2014-12-20 | 1 | -0/+2 |
| | | | | | | | | |||||
| * | | | | | | | SaveData: Added some documentation to FormatSaveData | Subv | 2014-12-18 | 1 | -2/+29 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We still don't know what the other parameters do, but they appear to be very similar to those of FormatThisUserSaveData. Most likely FormatThisUserSaveData is just an alias for FormatSaveData with LowPathType Empty | ||||
* | | | | | | | | Merge pull request #294 from lioncash/var | bunnei | 2014-12-19 | 1 | -12/+9 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | armemu: Narrow the scope of some variables in handle_v6_insn | ||||
| * | | | | | | | | armemu: Narrow the scope of some variables in handle_v6_insn | Lioncash | 2014-12-17 | 1 | -12/+9 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no reason to have these in the outer-most scope. | ||||
* | | | | | | | | | Merge pull request #305 from lioncash/paren | bunnei | 2014-12-19 | 1 | -4/+4 |
|\ \ \ \ \ \ \ \ \ | |_|_|/ / / / / / |/| | | | | | | | | armemu: Get rid of bitwise parenthesis warnings | ||||
| * | | | | | | | | armemu: Get rid of bitwise parenthesis warnings | Lioncash | 2014-12-18 | 1 | -4/+4 |
| | |_|/ / / / / | |/| | | | | | | |||||
* | | | | | | | | Merge pull request #302 from purpasmart96/flushshutup | bunnei | 2014-12-19 | 1 | -1/+25 |
|\ \ \ \ \ \ \ \ | |_|_|_|/ / / / |/| | | | | | | | GSP_GPU: Shut up FlushDataCache | ||||
| * | | | | | | | GSP_GPU: Shut up FlushDataCache | purpasmart96 | 2014-12-19 | 1 | -1/+25 |
| | | | | | | | | |||||
* | | | | | | | | Merge pull request #308 from Subv/more_savedata | bunnei | 2014-12-19 | 1 | -1/+1 |
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | SystemSaveData: Fixed a typo that was segfaulting | ||||
| * | | | | | | | | SystemSaveData: Fixed a typo that was segfaulting | Subv | 2014-12-19 | 1 | -1/+1 |
| | | | | | | | | | |||||
* | | | | | | | | | Merge pull request #304 from lioncash/sflags | bunnei | 2014-12-18 | 1 | -4/+29 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | armemu: Set GE flags properly for SSUB16, SADD16, SSAX, and SASX. | ||||
| * | | | | | | | | | armemu: Set GE flags correctly for SSUB16, SADD16, SSAX, and SASX. | Lioncash | 2014-12-18 | 1 | -4/+29 |
| | |_|/ / / / / / | |/| | | | | | | | |||||
* | | | | | | | | | Merge pull request #307 from lioncash/usat16 | bunnei | 2014-12-18 | 1 | -11/+20 |
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | armemu: Fix USAT16. | ||||
| * | | | | | | | | | armemu: Fix lower-bounds clamping for USAT16 | Lioncash | 2014-12-18 | 1 | -1/+6 |
| | | | | | | | | | | |||||
| * | | | | | | | | | armemu: More concise names for USAT16-related variables | Lioncash | 2014-12-18 | 1 | -11/+15 |
| |/ / / / / / / / | |||||
* | | | | | | | | | Merge pull request #301 from Subv/more_savedata | bunnei | 2014-12-18 | 5 | -2/+78 |
|\ \ \ \ \ \ \ \ \ | |/ / / / / / / / |/| / / / / / / / | |/ / / / / / / | SaveData: Implemented the SystemSaveData archive. | ||||
| * | | | | | | | SystemSaveData: Added a TODO to move it to the NAND. | Subv | 2014-12-18 | 1 | -1/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Maybe sometime when we actually implement that | ||||
| * | | | | | | | SaveData: Implemented the SystemSaveData archive. | Subv | 2014-12-18 | 5 | -2/+76 |
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | It will be stored in the /syssavedata folder. This archive is user by various Services and possibly games via the FS:U service. | ||||
* | | | | | | | Merge pull request #299 from lioncash/join | bunnei | 2014-12-18 | 1 | -34/+23 |
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | | Combine SSUB16, SADD16, SASX, and SSAX. | ||||
| * | | | | | | armemu: Combine SSUB16, SADD16, SASX, and SSAX. | Lioncash | 2014-12-18 | 1 | -34/+23 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #298 from lioncash/flags | bunnei | 2014-12-18 | 1 | -4/+22 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | armemu: Unset GE flags for UADD8 if results are < 0x100 | ||||
| * | | | | | | | armemu: Unset GE flags for UADD8 if results are < 0x100 | Lioncash | 2014-12-17 | 1 | -4/+22 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reference manual states these must be set to zero if this case is true. | ||||
* | | | | | | | | Merge pull request #295 from lioncash/umaal | bunnei | 2014-12-18 | 1 | -3/+25 |
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | | armemu: Implement UMAAL | ||||
| * | | | | | | | armemu: Implement UMAAL | Lioncash | 2014-12-17 | 1 | -3/+25 |
| | |_|/ / / / | |/| | | | | | |||||
* | | | | | | | Merge pull request #292 from lioncash/backports | bunnei | 2014-12-18 | 1 | -19/+30 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Backport more skyeye fixes from 3dmoo | ||||
| * | | | | | | | armemu: Fix PKHTB | Normmatt | 2014-12-17 | 1 | -6/+12 |
| | | | | | | | | |||||
| * | | | | | | | armemu: Implement REVSH | Normmatt | 2014-12-17 | 1 | -5/+9 |
| | | | | | | | | |||||
| * | | | | | | | armemu: Fix UXTAB/UXTAH | Normmatt | 2014-12-17 | 1 | -4/+4 |
| | | | | | | | | |||||
| * | | | | | | | armemu: Fix SXTAB | Normmatt | 2014-12-17 | 1 | -2/+2 |
| | | | | | | | | |||||
| * | | | | | | | armemu: Fix SXTAH | Normmatt | 2014-12-17 | 1 | -2/+3 |
| |/ / / / / / | |||||
* | | | | | | | Merge pull request #297 from lioncash/ssub16 | bunnei | 2014-12-18 | 1 | -8/+8 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | armemu: Fix SSUB16 | ||||
| * | | | | | | | armemu: Fix SSUB16 | Lioncash | 2014-12-17 | 1 | -8/+8 |
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Broken from the same reason SADD16 was. The lo part of the result should only be constructed from the lo halfwords of rm and rn. The hi part of the result should only be constructed from the hi halfwords of rm and rn. | ||||
* | | | | | | | Merge pull request #185 from purpasmart96/mem_perm | bunnei | 2014-12-18 | 2 | -5/+13 |
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | | Kernel: Add missing permissions | ||||
| * | | | | | | Kernel:Add missing permissions in shared memory & svc | purpasmart96 | 2014-11-19 | 2 | -5/+13 |
| | | | | | | | |||||
* | | | | | | | Filesystem/Archives: Implemented the SaveData archive | Subv | 2014-12-18 | 22 | -490/+454 |
| |/ / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The savedata for each game is stored in /savedata/<ProgramID> for NCCH files. ELF files and 3DSX files use the folder 0 because they have no ID information Got rid of the code duplication in File and Directory Files that deal with the host machine's file system now live in DiskFile, similarly for directories and DiskDirectory and archives with DiskArchive. FS_U: Use the correct error code when a file wasn't found | ||||
* | | | | | | Merge pull request #293 from lioncash/sops | bunnei | 2014-12-17 | 1 | -8/+9 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | armemu: Fix SADD16 | ||||
| * | | | | | | armemu: Fix SADD16 | Lioncash | 2014-12-17 | 1 | -8/+9 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | The lo and hi parts of the result were being constructed as a result of hi and lo halfword intermixing from the rm and rn regs. However the lo part of the result should be constructed only from the lo halfwords of rm and rn, and the hi part of the result should only be constructed from the hi halfwords of rm and rn. | ||||
* | | | | | | Merge pull request #287 from lioncash/qaddsub16 | bunnei | 2014-12-17 | 1 | -33/+37 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | armemu: Join QADD16/QSUB16 and fix saturation clamping. | ||||
| * | | | | | armemu: Fix lower-bound signed saturation clamping for QADD16/QSUB16. | Lioncash | 2014-12-16 | 1 | -2/+2 |
| | | | | | | |||||
| * | | | | | armemu: Join QADD16 and QSUB16 together. | Lioncash | 2014-12-16 | 1 | -33/+37 |
| | | | | | | | | | | | | | | | | | | | | | | | | The only difference between these ops is one adds and one subtracts. Everything is literally the same. | ||||
* | | | | | | Merge pull request #289 from lioncash/smops | bunnei | 2014-12-17 | 1 | -38/+35 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Join SMUAD, SMUSD, and SMLAD ops. Also fix them as well. | ||||
| * | | | | | | armemu: Fix SMUAD, SMUSD, and SMLAD | Lioncash | 2014-12-16 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Wrong values were being multiplied together. | ||||
| * | | | | | | armemu: Join SMUAD, SMUSD, and SMLAD | Lioncash | 2014-12-16 | 1 | -38/+35 |
| |/ / / / / | |||||
* | | | | | | Merge pull request #290 from lioncash/vsub | bunnei | 2014-12-17 | 1 | -2/+5 |
|\ \ \ \ \ \ | |_|_|/ / / |/| | | | | | armemu: Backport some VFP fixes from 3dmoo. | ||||
| * | | | | | armemu: Fix FTOUI NaN sign. | Normmatt | 2014-12-16 | 1 | -1/+1 |
| | | | | | | |||||
| * | | | | | armemu: Fix FSUBS bug where NaN shouldn't be negated | Normmatt | 2014-12-16 | 1 | -1/+4 |
| |/ / / / | |||||
* | | | | | Merge pull request #286 from yuriks/msvc-fix | bunnei | 2014-12-16 | 2 | -6/+8 |
|\ \ \ \ \ | | | | | | | | | | | | | Comment out empty arrays causing compile errors in MSVC | ||||
| * | | | | | Comment out empty arrays causing compile errors in MSVC | Yuri Kunde Schlesner | 2014-12-16 | 2 | -6/+8 |
| | | | | | | |||||
* | | | | | | Merge pull request #285 from lioncash/uxtab16 | bunnei | 2014-12-16 | 1 | -10/+25 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | armemu: Implement UXTAB16 | ||||
| * | | | | | armemu: Implement UXTAB16 | Lioncash | 2014-12-16 | 1 | -10/+25 |
| |/ / / / | |||||
* | | | | | Merge pull request #283 from yuriks/archive-refactor | bunnei | 2014-12-16 | 23 | -506/+320 |
|\ \ \ \ \ | | | | | | | | | | | | | Archive refactor | ||||
| * | | | | | Work around libstdc++'s lack of support for std::hash on enums | Yuri Kunde Schlesner | 2014-12-16 | 1 | -0/+15 |
| | | | | | | |||||
| * | | | | | FS.Archive: Clean up treatment of archives and their handles | Yuri Kunde Schlesner | 2014-12-16 | 11 | -387/+197 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Refactor FS::Archive internals to make Archive creation and lifetime management clearer. - Remove the "Archive as a File" hack. - Implement 64-bit Archive handles. | ||||
| * | | | | | Service.FS: Rename FileSys::File to FileBackend | Yuri Kunde Schlesner | 2014-12-16 | 10 | -17/+17 |
| | | | | | | |||||
| * | | | | | Service.FS: Rename FileSys::Directory to DirectoryBackend | Yuri Kunde Schlesner | 2014-12-16 | 10 | -18/+18 |
| | | | | | | |||||
| * | | | | | Service.FS: Rename FileSys::Archive to ArchiveBackend | Yuri Kunde Schlesner | 2014-12-16 | 6 | -12/+12 |
| | | | | | | |||||
| * | | | | | Service.FS: Do archive registration using IdCode instead of name | Yuri Kunde Schlesner | 2014-12-16 | 7 | -42/+32 |
| | | | | | | |||||
| * | | | | | HLE: Rename namespaces to match move & fix initialization order | Yuri Kunde Schlesner | 2014-12-16 | 9 | -43/+43 |
| | | | | | | |||||
| * | | | | | HLE: Move kernel/archive.* to service/fs/ | Yuri Kunde Schlesner | 2014-12-16 | 9 | -12/+11 |
| | | | | | | |||||
* | | | | | | Merge pull request #282 from archshift/services | bunnei | 2014-12-16 | 10 | -0/+229 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | Added stubs for ldr:ro, cecd:u, nim:aoc, and am:app services | ||||
| * | | | | | Added stub for nim:aoc service... | archshift | 2014-12-16 | 4 | -0/+62 |
| | | | | | | |||||
| * | | | | | Added stub for cecd:u service... | archshift | 2014-12-16 | 4 | -0/+54 |
| | | | | | | | | | | | | | | | | | | | | | | | | I couldn't find any information about this service... | ||||
| * | | | | | Added stub for ldr:ro service... | archshift | 2014-12-16 | 4 | -0/+59 |
| | | | | | | |||||
| * | | | | | Added am:app service stub. | archshift | 2014-12-16 | 4 | -0/+54 |
| | | | | | | | | | | | | | | | | | | | | | | | | Apparently nothing at all is known about this service... | ||||
* | | | | | | Merge pull request #281 from lioncash/uxtb16 | bunnei | 2014-12-16 | 1 | -12/+12 |
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | | armemu: Fix UXTB16 | ||||
| * | | | | | armemu: Fix UXTB16 | Lioncash | 2014-12-15 | 1 | -12/+12 |
| |/ / / / | | | | | | | | | | | | | | | | Rotation bits are 10 and 11, not 9 and 10. | ||||
* / / / / | Remove SyncRequest from K::Object and create a new K::Session type | Yuri Kunde Schlesner | 2014-12-15 | 15 | -104/+129 |
|/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | This is a first step at fixing the conceptual insanity that is our handling of service and IPC calls. For now, interfaces still directly derived from Session because we don't have the infrastructure to do it properly. (That is, Processes and scheduling them.) | ||||
* | | | | Merge pull request #276 from lioncash/decrappify | bunnei | 2014-12-15 | 1 | -306/+169 |
|\ \ \ \ | | | | | | | | | | | Clean up armdefs.h a little. | ||||
| * | | | | Clean up armdefs.h | Lioncash | 2014-12-14 | 1 | -306/+169 |
| | |/ / | |/| | | |||||
* | | | | Merge pull request #246 from Subv/cbranch_1 | bunnei | 2014-12-15 | 5 | -2/+160 |
|\ \ \ \ | | | | | | | | | | | SVC: Implemented Semaphores | ||||
| * | | | | Kernel/Semaphores: Fixed build | Subv | 2014-12-13 | 1 | -2/+2 |
| | | | | | |||||
| * | | | | Kernel/Semaphore: Small style change | Subv | 2014-12-13 | 1 | -1/+1 |
| | | | | | |||||
| * | | | | Kernel/Semaphores: Invert the available count checking. | Subv | 2014-12-13 | 1 | -11/+9 |
| | | | | | | | | | | | | | | | | | | | | Same semantics, idea by @yuriks | ||||
| * | | | | Kernel/Semaphores: Addressed some issues. | Subv | 2014-12-13 | 2 | -32/+18 |
| | | | | | |||||
| * | | | | Semaphore: Removed an unneeded function | Subv | 2014-12-13 | 1 | -5/+0 |
| | | | | | |||||
| * | | | | Semaphores: Addressed some style issues | Subv | 2014-12-13 | 1 | -6/+5 |
| | | | | | |||||
| * | | | | Semaphore: Implemented the initial_count parameter. | Subv | 2014-12-13 | 2 | -5/+7 |
| | | | | | |||||
| * | | | | SVC: Implemented ReleaseSemaphore. | Subv | 2014-12-13 | 4 | -19/+81 |
| | | | | | | | | | | | | | | | | | | | | This behavior was tested on hardware, however i'm still not sure what use the "initial_count" parameter has | ||||
| * | | | | SVC: Implemented svcCreateSemaphore | Subv | 2014-12-13 | 5 | -1/+117 |
| |/ / / | | | | | | | | | | | | | | | | | ToDo: Implement svcReleaseSemaphore * Some testing against hardware needed | ||||
* | | | | Merge pull request #273 from bunnei/more-skyeye-fixes | bunnei | 2014-12-15 | 3 | -419/+485 |
|\ \ \ \ | |/ / / |/| | | | ARM: Pull some SkyEye fixes from 3dmoo. | ||||
| * | | | ARM: Pull some SkyEye fixes from 3dmoo. | bunnei | 2014-12-15 | 3 | -419/+485 |
| | | | | |||||
* | | | | kernel: Remove unused log arguments | Lioncash | 2014-12-13 | 1 | -3/+3 |
|/ / / | |||||
* | | | Add configurable per-class log filtering | Yuri Kunde Schlesner | 2014-12-13 | 1 | -1/+3 |
| | | | |||||
* | | | Convert old logging calls to new logging macros | Yuri Kunde Schlesner | 2014-12-13 | 40 | -385/+336 |
| | | | |||||
* | | | New logging system | Yuri Kunde Schlesner | 2014-12-13 | 1 | -0/+1 |
| | | | |||||
* | | | Merge pull request #267 from bunnei/apt-shared-font | bunnei | 2014-12-13 | 5 | -66/+132 |
|\ \ \ | | | | | | | | | APT shared font loading | ||||
| * | | | APT_U: Added GetSharedFont service function. | bunnei | 2014-12-13 | 1 | -34/+100 |
| | | | | |||||
| * | | | MemMap: Renamed "GSP" heap to "linear", as this is not specific to GSP. | bunnei | 2014-12-12 | 4 | -32/+32 |
| | | | | | | | | | | | | | | | | - Linear simply indicates that the mapped physical address is always MappedVAddr+0x0C000000, thus this memory can be used for hardware devices' DMA (such as the GPU). | ||||
* | | | | DSP: Added stub for ReadPipeIfPossible. | bunnei | 2014-12-12 | 1 | -1/+45 |
|/ / / | |||||
* | | | Merge pull request #256 from Subv/mutex | bunnei | 2014-12-11 | 3 | -37/+67 |
|\ \ \ | | | | | | | | | Kernel/Mutex: Properly lock the mutex when a thread enters it | ||||
| * | | | Mutex: Remove some forward declarations | Subv | 2014-12-07 | 1 | -16/+15 |
| | | | | | | | | | | | | | | | | Moved Mutex::WaitSynchronization to the end of the file. | ||||
| * | | | Mutex: Release all held mutexes when a thread exits. | Subv | 2014-12-07 | 3 | -22/+56 |
| | | | | |||||
| * | | | Mutex: Properly lock the mutex when a thread enters it | Subv | 2014-12-06 | 1 | -12/+9 |
| | | | | | | | | | | | | | | | | Also resume only the next immediate thread waiting for the mutex when it is released, instead of resuming them all. | ||||
* | | | | CFG:U: Store country codes as u16 instead of char pointers, and return the correct error in GetCountryCodeID. | Emmanuel Gil Peyrot | 2014-12-10 | 1 | -44/+48 |
| | | | | |||||
* | | | | GSP: Trigger GPU interrupts at more accurate locations. | bunnei | 2014-12-10 | 1 | -7/+6 |
| | | | | |||||
* | | | | GSP: Updated TriggerCmdReqQueue to return success code. | bunnei | 2014-12-10 | 1 | -0/+3 |
| | | | | |||||
* | | | | GSP: Updated RegisterInterruptRelayQueue to return expected magic number. | bunnei | 2014-12-10 | 1 | -1/+4 |
| | | | | |||||
* | | | | GPU: Fixed bug in command list size decoding. | bunnei | 2014-12-10 | 3 | -4/+3 |
| | | | | |||||
* | | | | Remove unused NDMA module | Yuri Kunde Schlesner | 2014-12-09 | 4 | -88/+0 |
| | | | | |||||
* | | | | Merge pull request #217 from archshift/cmd_buff | bunnei | 2014-12-09 | 1 | -12/+12 |
|\ \ \ \ | | | | | | | | | | | Log the cmd_buff arguments when citra comes across an unimplemented function | ||||
| * | | | | Log the cmd_buff arguments when citra comes across an unimplemented function | archshift | 2014-11-25 | 1 | -12/+12 |
| | | | | | |||||
* | | | | | Thread: Fixed to wait on address when in arbitration. | bunnei | 2014-12-09 | 3 | -11/+31 |
| | | | | | |||||
* | | | | | Merge pull request #244 from bunnei/cleanup-memmap | bunnei | 2014-12-09 | 2 | -31/+21 |
|\ \ \ \ \ | | | | | | | | | | | | | MemMap: Updated memory map to subtract base address instead of mask. | ||||
| * | | | | | MemMap: Updated memory map to subtract base address instead of mask. | bunnei | 2014-12-03 | 2 | -31/+21 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - More readable, a little less error prone. Conflicts: src/core/mem_map.h src/core/mem_map_funcs.cpp | ||||
* | | | | | | Merge pull request #263 from lioncash/sasx | bunnei | 2014-12-09 | 1 | -4/+4 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Fix emulation of SASX and SSAX instructions. | ||||
| * | | | | | | armemu: Fix SSAX | Lioncash | 2014-12-08 | 1 | -1/+1 |
| | | | | | | | |||||
| * | | | | | | armemu: Fix SASX | Lioncash | 2014-12-08 | 1 | -1/+1 |
| | | | | | | | |||||
| * | | | | | | armemu: Fix parenthesis warnings regarding bitwise ops | Lioncash | 2014-12-08 | 1 | -4/+4 |
| | | | | | | | |||||
* | | | | | | | Merge pull request #259 from ichfly/master | bunnei | 2014-12-09 | 5 | -0/+278 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Loader: Add 3DSX support | ||||
| * | | | | | | | Loader: Add 3DSX support | ichfly | 2014-12-08 | 5 | -0/+278 |
| |/ / / / / / | |||||
* | | | | | | | Merge pull request #264 from Subv/files | bunnei | 2014-12-09 | 1 | -3/+6 |
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | Kernel/File: Fixed file read/write hwtests | ||||
| * | | | | | | | Kernel/File: Fixed file read/write hwtests | Subv | 2014-12-08 | 1 | -3/+6 |
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The 3DS allows the user to read from files opened with the Write access modifier, even if he did not specify the Read access modifier. Open the files in binary mode so that we can prevent CR/LF problems in Windows, where a line-end is replaced by these two bytes instead of just 0xA, this was causing problems with the GetSize test | ||||
* | | | | | | | Merge pull request #260 from archshift/opendir | bunnei | 2014-12-09 | 7 | -3/+40 |
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | | Make OpenDirectory fail if the directory doesn't exist | ||||
| * | | | | | | Make OpenDirectory fail if the directory doesn't exist | archshift | 2014-12-07 | 7 | -3/+40 |
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is in line with what the hardware itself does. It does this by splitting the initial directory opening into Directory.Open(), which will return false if a stat fails. Then, Archive::OpenDirectory will return nullptr, and archive.cpp will return an error code . | ||||
* | | | | | | Merge pull request #245 from rohit-n/null-nullptr | bunnei | 2014-12-07 | 1 | -6/+6 |
|\ \ \ \ \ \ | |/ / / / / |/| | | | | | Change NULLs to nullptrs. | ||||
| * | | | | | Change NULLs to nullptrs. | Rohit Nirmal | 2014-12-03 | 1 | -6/+6 |
| | | | | | | |||||
* | | | | | | Merge pull request #250 from Subv/cbranch_2 | bunnei | 2014-12-05 | 3 | -4/+31 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | SVC: Implemented GetThreadId. | ||||
| * | | | | | | Threads: Remove a redundant function. | Subv | 2014-12-04 | 1 | -9/+1 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Use the next_thread_id variable directly. | ||||
| * | | | | | | Threads: Implemented a sequential thread id | Subv | 2014-12-04 | 2 | -4/+19 |
| | | | | | | | |||||
| * | | | | | | SVC: Implemented GetThreadId. | Subv | 2014-12-04 | 3 | -4/+24 |
| |/ / / / / | | | | | | | | | | | | | | | | | | | For now threads are using their Handle value as their Id, it should not really cause any problems because Handle values are unique in Citra, but it should be changed. I left a ToDo there because this is not correct behavior as per hardware. | ||||
* | | | | | | Merge pull request #222 from archshift/renamexyz | bunnei | 2014-12-05 | 8 | -38/+229 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Implemented RenameFile and RenameDirectory in FS:USER | ||||
| * | | | | | | Updated archive.cpp functions for proper error handling | archshift | 2014-12-04 | 5 | -94/+41 |
| | | | | | | | |||||
| * | | | | | | Implemented RenameDirectory in FS:USER | archshift | 2014-11-25 | 8 | -1/+123 |
| | | | | | | | |||||
| * | | | | | | Implemented RenameFile in FS:USER | archshift | 2014-11-25 | 8 | -1/+123 |
| | |_|/ / / | |/| | | | | |||||
* | | | | | | Merge pull request #248 from lioncash/kernel | bunnei | 2014-12-05 | 2 | -10/+7 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Misc minor kernel-related changes. | ||||
| * | | | | | | kernel: Shorten GetCount | Lioncash | 2014-12-04 | 1 | -6/+3 |
| | | | | | | | |||||
| * | | | | | | kernel: Make some functions const | Lioncash | 2014-12-04 | 2 | -4/+4 |
| | |_|/ / / | |/| | | | | |||||
* | | | | | | Merge pull request #249 from lioncash/enum | bunnei | 2014-12-04 | 1 | -1/+1 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | mem_map: Make enum for addresses use u32 as the underlying type | ||||
| * | | | | | | mem_map: Make enum for addresses use u32 as the underlying type | Lioncash | 2014-12-04 | 1 | -1/+1 |
| |/ / / / / | |||||
* | | | | | | Merge pull request #247 from lioncash/const | bunnei | 2014-12-04 | 2 | -4/+4 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | hid_user: Pass by reference with PadButtonPress/PadButtonRelease | ||||
| * | | | | | | hid_user: Pass by reference with PadButtonPress/PadButtonRelease | Lioncash | 2014-12-04 | 2 | -4/+4 |
| | |_|/ / / | |/| | | | | |||||
* | | | | | | Merge pull request #238 from archshift/dsp | bunnei | 2014-12-04 | 2 | -26/+47 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Add stub for ConvertProcessFromDspDram | ||||
| * | | | | | | Add stub for ConvertProcessFromDspDram | archshift | 2014-12-04 | 2 | -26/+47 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | Should theoretically push retail stuff further along | ||||
* | | | | | | PTM_U: Added a stub for GetBatteryLevel & GetBatteryChargeState & GetAdapterState | purpasmart96 | 2014-12-04 | 1 | -3/+72 |
| |/ / / / |/| | | | | |||||
* | | | | | Merge pull request #231 from purpasmart96/serv_ac_wifi_status | bunnei | 2014-12-03 | 1 | -1/+19 |
|\ \ \ \ \ | | | | | | | | | | | | | AC_U: Added a stub for GetWifiStatus | ||||
| * | | | | | AC_U: Added a stub for GetWifiStatus | purpasmart96 | 2014-12-03 | 1 | -1/+19 |
| | |_|_|/ | |/| | | | |||||
* | | | | | Merge pull request #219 from Subv/ptm | bunnei | 2014-12-03 | 1 | -1/+18 |
|\ \ \ \ \ | |_|/ / / |/| | | | | PTM_U: Implemented the GetShellState function. | ||||
| * | | | | PTM_U: Implemented the GetShellState function. | Subv | 2014-12-01 | 1 | -1/+18 |
| | | | | | |||||
* | | | | | Merge pull request #224 from bunnei/dsp-service-improvements | bunnei | 2014-12-01 | 2 | -26/+107 |
|\ \ \ \ \ | | | | | | | | | | | | | Dsp service improvements | ||||
| * | | | | | DSP: Added stubs for several commonly used DSP service functions. | bunnei | 2014-12-01 | 1 | -25/+106 |
| | | | | | | |||||
| * | | | | | DSP: Fixed typo in port name. | bunnei | 2014-12-01 | 1 | -1/+1 |
| | |_|/ / | |/| | | | |||||
* | | | | | Merge pull request #214 from Subv/master | bunnei | 2014-12-01 | 1 | -2/+86 |
|\ \ \ \ \ | | | | | | | | | | | | | CFG:U: Implemented the GetCountryCodeID and GetCountryCodeString | ||||
| * | | | | | CFG:U: Implemented the GetCountryCodeID and GetCountryCodeString. | Subv | 2014-11-30 | 1 | -2/+86 |
| | | | | | | |||||
* | | | | | | Merge pull request #225 from bunnei/fix-release-mutex | bunnei | 2014-11-30 | 1 | -8/+7 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Mutex: Changed behavior to always release mutex for all threads. | ||||
| * | | | | | | Mutex: Changed behavior to always release mutex for all threads. | bunnei | 2014-11-26 | 1 | -8/+7 |
| | |/ / / / | |/| | | | | |||||
* | | | | | | Merge pull request #226 from bunnei/svc-and-thread-fixes | bunnei | 2014-11-30 | 2 | -1/+6 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | Svc and thread fixes | ||||
| * | | | | | | Thread: Check that thread is actually in "wait state" when verifying wait. | bunnei | 2014-11-26 | 1 | -1/+1 |
| | | | | | | | |||||
| * | | | | | | SVC: Add debug log to ArbitrateAddress. | bunnei | 2014-11-26 | 1 | -0/+2 |
| | | | | | | | |||||
| * | | | | | | SVC: SleepThread should yield to the next ready thread. | bunnei | 2014-11-26 | 1 | -0/+3 |
| |/ / / / / | |||||
* | | | | | | Merge pull request #235 from yuriks/dyncom-map | bunnei | 2014-11-30 | 1 | -33/+15 |
|\ \ \ \ \ \ | | | | | | | | | | | | | | | dyncom: Use unordered_map rather than the terrible 2-level bb_map | ||||
| * | | | | | | dyncom: Use unordered_map rather than the terrible 2-level bb_map | Yuri Kunde Schlesner | 2014-11-29 | 1 | -33/+15 |
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | Seems (probably just placebo/wishful thinking) to make it slightly faster. Also reduces memory usage and makes shutdown when debugging from MSVC fast. | ||||
* / | | | | | arm_dyncom_interpreter: Get rid of unused var warnings | Lioncash | 2014-11-29 | 1 | -4/+2 |
|/ / / / / | |||||
* | | / / | Fixed formatting and switch statement warnings | vaguilar | 2014-11-27 | 7 | -11/+13 |
| |_|/ / |/| | | | |||||
* | | | | Remove unused includes to common/thread.h | Emmanuel Gil Peyrot | 2014-11-25 | 1 | -2/+0 |
|/ / / | |||||
* | | | Use pointers instead of passing handles around in some functions. | Yuri Kunde Schlesner | 2014-11-24 | 1 | -19/+15 |
| | | | |||||
* | | | Remove duplicated docs/update them for changed parameters. | Yuri Kunde Schlesner | 2014-11-24 | 10 | -88/+0 |
| | | | |||||
* | | | HLE: Revamp error handling throrough the HLE code | Yuri Kunde Schlesner | 2014-11-24 | 23 | -310/+689 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All service calls in the CTR OS return result codes indicating the success or failure of the call. Previous to this commit, Citra's HLE emulation of services and the kernel universally either ignored errors or returned dummy -1 error codes. This commit makes an initial effort to provide an infrastructure for error reporting and propagation which can be use going forward to make HLE calls accurately return errors as the original system. A few parts of the code have been updated to use the new system where applicable. One part of this effort is the definition of the `ResultCode` type, which provides facilities for constructing and parsing error codes in the structured format used by the CTR. The `ResultVal` type builds on `ResultCode` by providing a container for values returned by function that can report errors. It enforces that correct error checking will be done on function returns by preventing the use of the return value if the function returned an error code. Currently this change is mostly internal since errors are still suppressed on the ARM<->HLE border, as a temporary compatibility hack. As functionality is implemented and tested this hack can be eventually removed. | ||||
* | | | Change some SkyEye defines to const ints | Yuri Kunde Schlesner | 2014-11-24 | 2 | -34/+16 |
| | | | | | | | | | | | | | | | This prevents them from interfering with other constants defined in different namespaces. | ||||
* | | | Merge pull request #191 from archshift/deletexyz | bunnei | 2014-11-24 | 8 | -26/+194 |
|\ \ \ | |/ / |/| | | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives. | ||||
| * | | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives. | archshift | 2014-11-23 | 8 | -26/+194 |
| | | | |||||
* | | | Add more services and some fixes, along with more "override" | purpasmart96 | 2014-11-21 | 26 | -17/+464 |
| | | | | | | | | | | | | in the service's headers | ||||
* | | | Merge pull request #211 from linkmauve/master | bunnei | 2014-11-19 | 45 | -142/+142 |
|\ \ \ | | | | | | | | | Remove trailing spaces from the entire project | ||||
| * | | | Remove tabs in all files except in skyeye imports and in generated GL code | Emmanuel Gil Peyrot | 2014-11-19 | 2 | -32/+32 |
| | | | | |||||
| * | | | Remove trailing spaces in every file but the ones imported from SkyEye, AOSP or generated | Emmanuel Gil Peyrot | 2014-11-19 | 44 | -111/+111 |
| | | | | |||||
* | | | | Merge pull request #208 from lioncash/statics | bunnei | 2014-11-19 | 5 | -69/+69 |
|\ \ \ \ | |/ / / |/| | | | Add static to some variables | ||||
| * | | | Add static to some variables | Lioncash | 2014-11-19 | 5 | -69/+69 |
| | | | | |||||
* | | | | Merge pull request #207 from lioncash/docs | Tony Wasserka | 2014-11-18 | 3 | -3/+3 |
|\ \ \ \ | | | | | | | | | | | Fix documentation of parameters | ||||
| * | | | | Fix documentation of parameters | Lioncash | 2014-11-18 | 3 | -3/+3 |
| |/ / / | |||||
* | | | | Merge pull request #209 from lioncash/warn | Tony Wasserka | 2014-11-18 | 1 | -1/+1 |
|\ \ \ \ | | | | | | | | | | | directory_sdmc: Fix a signed/unsigned mismatch comparison | ||||
| * | | | | directory_sdmc: Fix a signed/unsigned mismatch comparison | Lioncash | 2014-11-18 | 1 | -1/+1 |
| |/ / / | |||||
* | | | | Merge pull request #210 from lioncash/typedef | Tony Wasserka | 2014-11-18 | 1 | -10/+10 |
|\ \ \ \ | | | | | | | | | | | system: Get rid of an unnecessary enum typedef | ||||
| * | | | | system: Get rid of an unnecessary enum typedef | Lioncash | 2014-11-18 | 1 | -10/+10 |
| |/ / / | |||||
* / / / | Remove extraneous semicolons | Lioncash | 2014-11-18 | 6 | -6/+6 |
|/ / / | |||||
* / / | core: Mark some hle functions as static | Lioncash | 2014-11-18 | 6 | -48/+48 |
|/ / | | | | | | | These functions are not referred to by their linkage name outside of the translation unit, so they can be marked as static. | ||||
* | | Archive: Fixed to not destroy archive handle on close. | bunnei | 2014-11-18 | 1 | -3/+3 |
| | | |||||
* | | Archive: Fixed close archive before freeing. | bunnei | 2014-11-18 | 1 | -1/+1 |
| | | |||||
* | | FS_User: Support FileSye::Path in a more generic way. | bunnei | 2014-11-18 | 2 | -42/+76 |
| | | | | | | | | added a todo to kernel archive | ||||
* | | FileSys: Updated backend code to use FileSys::Path instead of string for paths. | bunnei | 2014-11-18 | 12 | -38/+38 |
| | | |||||
* | | FileSys: Added DebugStr method to Path class. | bunnei | 2014-11-18 | 1 | -0/+29 |
| | | |||||
* | | Merge pull request #201 from archshift/boss | bunnei | 2014-11-17 | 4 | -0/+59 |
|\ \ | | | | | | | Add missing boss:U service | ||||
| * | | Add missing boss:U service, needed according to Nintendo Zone logs. | archshift | 2014-11-17 | 4 | -0/+59 |
| | | | |||||
* | | | mem_map: Add missing prototype for Write64 | Lioncash | 2014-11-17 | 1 | -0/+1 |
|/ / | |||||
* | | Merge pull request #159 from SeannyM/enable_log | Tony Wasserka | 2014-11-15 | 1 | -0/+2 |
|\ \ | | | | | | | Add support for disabling log from settings | ||||
| * | | Add support for disabling log from settings | Sean | 2014-11-03 | 1 | -0/+2 |
| | | | |||||
* | | | Merge pull request #193 from lioncash/fmt | bunnei | 2014-11-15 | 1 | -1/+1 |
|\ \ \ | | | | | | | | | Fix two format strings. | ||||
| * | | | Fix two format strings. | Lioncash | 2014-11-14 | 1 | -1/+1 |
| | | | | |||||
* | | | | Merge pull request #194 from lioncash/virt | bunnei | 2014-11-15 | 1 | -1/+1 |
|\ \ \ \ | |/ / / |/| | | | ARM_Interface: Make destructor virtual | ||||
| * | | | ARM_Interface: Make destructor virtual | Lioncash | 2014-11-14 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | Fixes some warnings on OSX. | ||||
* | | | | Merge pull request #183 from archshift/lowpath | bunnei | 2014-11-13 | 2 | -83/+180 |
|\ \ \ \ | | | | | | | | | | | Add support for UTF-16 strings for LowPaths in FS:USER | ||||
| * | | | | Use std::u16string for conversion between UTF-8 and UTF-16, FS:USER functions | archshift | 2014-11-13 | 3 | -138/+139 |
| | | | | | |||||
| * | | | | Add support for UTF-16 strings for LowPaths in FS:USER | archshift | 2014-11-10 | 2 | -86/+182 |
| | |_|/ | |/| | | |||||
* | | | | Merge pull request #188 from bunnei/apt-fixes | bunnei | 2014-11-12 | 1 | -19/+90 |
|\ \ \ \ | | | | | | | | | | | APT_U: Various improvements and bug fixes. | ||||
| * | | | | APT_U: Added stub for function AppletUtility. | bunnei | 2014-11-12 | 1 | -1/+29 |
| | | | | | |||||
| * | | | | APT_U: Set a valid parameter buffer size in GlanceParameter. | bunnei | 2014-11-12 | 1 | -17/+39 |
| | | | | | | | | | | | | | | | | | | | | - Also Clarified GlanceParameter/ReceiveParameter documentation. | ||||
| * | | | | APT_U: Release service lock on initialization. | bunnei | 2014-11-12 | 1 | -0/+4 |
| | | | | | |||||
| * | | | | APT_U: Fixes for GetLockHandle to boot system titles. | bunnei | 2014-11-12 | 1 | -1/+18 |
| |/ / / | | | | | | | | | | | | | - Also added comment to GetLockHandle function. | ||||
* | | | | ARM: Fixed dyncom to use reg15 for PC (this core doesn't use pc variable). | bunnei | 2014-11-12 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | - Fixes single stepping in debugger. | ||||
* | | | | Core: Changed RunLoop iterations to 1000 (slightly better performance). | bunnei | 2014-11-12 | 1 | -6/+6 |
| | | | | |||||
* | | | | ARM: Removed unnecessary goto with each instruction. | bunnei | 2014-11-12 | 1 | -43/+39 |
| | | | | |||||
* | | | | ARM: Fixed several dyncom bugs. | bunnei | 2014-11-12 | 3 | -17/+25 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Fixed NZCVT flags to properly save state when function returns. - Fixed counter to keep track of the actual number of instructions executed. - Fixed single-step mode to only execute one instruction at a time. - DefaultIni: Removed comment that no longer applied to dyncom. | ||||
* | | | | Add FRD:U service and functions | archshift | 2014-11-11 | 4 | -0/+66 |
|/ / / | |||||
* | | | Fix compilation errors | Sean Maas | 2014-11-03 | 1 | -2/+2 |
| | | | |||||
* | | | Merge pull request #163 from archshift/create-directory | bunnei | 2014-11-02 | 8 | -4/+103 |
|\ \ \ | | | | | | | | | Added CreateDirectory function to service/fs.cpp, and in Archive. | ||||
| * | | | Added CreateDirectory function to service/fs.cpp, and in Archive. | archshift | 2014-11-02 | 8 | -4/+103 |
| | | | | |||||
* | | | | Merge pull request #166 from bunnei/skyeye-vfp-fixes | bunnei | 2014-11-02 | 5 | -2138/+2622 |
|\ \ \ \ | | | | | | | | | | | SkyEye ARM/VFP fixes | ||||
| * | | | | ARM: Merged additional ARMv6 instructions implemented by 3dmoo. | bunnei | 2014-11-02 | 1 | -42/+234 |
| | | | | | |||||
| * | | | | ARM: Merge latest VFP fixes from 3dmoo team. | bunnei | 2014-11-02 | 4 | -2096/+2388 |
| |/ / / | |||||
* / / / | Added ReceiveNotification, PublishToSubscriber unimplemented functions to SRV | archshift | 2014-11-02 | 1 | -0/+2 |
|/ / / | |||||
* | | | Added stub err:f service. | archshift | 2014-11-02 | 4 | -0/+58 |
| | | | |||||
* | | | Merge pull request #135 from purpasmart96/master | bunnei | 2014-11-02 | 18 | -0/+597 |
|\ \ \ | | | | | | | | | Added a bunch of services | ||||
| * | | | Added a bunch of services | purpasmart96 | 2014-11-01 | 18 | -0/+597 |
| | | | | |||||
* | | | | Fix VFP compilation errors with gcc | Yuri Kunde Schlesner | 2014-10-31 | 1 | -12/+12 |
|/ / / | |||||
* | | | Merge pull request #162 from SeannyM/warning-fixes | bunnei | 2014-10-30 | 7 | -14/+14 |
|\ \ \ | | | | | | | | | Fix some warnings | ||||
| * | | | Fix some warnings | Sean | 2014-10-30 | 7 | -14/+14 |
| | | | | |||||
* | | | | FS:USER - Implemented IsSdmcDetected | archshift | 2014-10-30 | 1 | -1/+17 |
| | | | | |||||
* | | | | Renamed souce files of services to match port names | Gareth Poole | 2014-10-29 | 13 | -21/+21 |
|/ / / | |||||
* | | | Merge pull request #151 from archshift/dyncom-enabled | bunnei | 2014-10-28 | 5 | -6/+32 |
|\ \ \ | | | | | | | | | Use configuration files to enable or disable the new dyncom interpreter. | ||||
| * | | | Added `gpu_refresh_rate` config setting for the new interpreter speed hack. | archshift | 2014-10-28 | 2 | -10/+2 |
| | | | | |||||
| * | | | Use configuration files to enable or disable the new dyncom interpreter. | archshift | 2014-10-28 | 5 | -6/+40 |
| | | | | |||||
* | | | | Merge pull request #141 from archshift/crash-hunt | bunnei | 2014-10-28 | 1 | -0/+4 |
|\ \ \ \ | | | | | | | | | | | hid.cpp: Fixed crash when updating pad data while null | ||||
| * | | | | hid.cpp: Fixed crash when updating pad data while null | archshift | 2014-10-14 | 1 | -0/+4 |
| | | | | | | | | | | | | | | | | | | | | Fixes #137 | ||||
* | | | | | Merge pull request #153 from yuriks/add-override | bunnei | 2014-10-28 | 15 | -64/+64 |
|\ \ \ \ \ | |_|_|_|/ |/| | | | | Add override keyword where appropriate | ||||
| * | | | | Add `override` keyword through the code. | Yuri Kunde Schlesner | 2014-10-26 | 15 | -64/+64 |
| | |/ / | |/| | | | | | | | | | | This was automated using `clang-modernize`. | ||||
* / | | | vfp_helper: Get rid of integer type redefinitions | Lioncash | 2014-10-26 | 1 | -7/+1 |
|/ / / | |||||
* | | | ARM: Removed unnecessary and unused SkyEye MMU code. | bunnei | 2014-10-25 | 22 | -7743/+326 |
| | | | | | | | | | | | | Added license header back in. I originally removed this because I mostly rewrote the file, but meh | ||||
* | | | ARM: Removed unused armos code from SkyEye. | bunnei | 2014-10-25 | 4 | -747/+0 |
| | | | |||||
* | | | ARM: Updated dyncom core to use fast label lookup table on clang. | bunnei | 2014-10-25 | 1 | -3/+7 |
| | | | |||||
* | | | ARM: Integrate SkyEye faster "dyncom" interpreter. | bunnei | 2014-10-25 | 20 | -75/+8230 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixed typo (make protected member public) Added license header back in. I originally removed this because I mostly rewrote the file, but meh ARM: Fixed a type error in dyncom interpreter. ARM: Updated dyncom to use unique_ptr for internal ARM state. | ||||
* | | | ARM: Reorganized file structure to move shared SkyEye code to a more common area. | bunnei | 2014-10-25 | 33 | -79/+79 |
| | | | | | | | | | | | | Removed s_ prefix | ||||
* | | | Don’t fail on empty filename in OpenFileDirectly, return the archive handle instead | Emmanuel Gil Peyrot | 2014-10-25 | 1 | -8/+7 |
| | | | |||||
* | | | Use config files to store whether SDMC is enabled or not | archshift | 2014-10-23 | 2 | -2/+10 |
|/ / | | | | | | | Before, it used to use whether the directory actually existed. As a result, .citra-emu/sdmc was never auto-created (something quite confusing to me until I read through the logs). | ||||
* | | Rename GPU::Regs::FramebufferFormat to PixelFormat | Yuri Kunde Schlesner | 2014-10-12 | 2 | -14/+10 |
| | | | | | | | | | | | | This name better represents what the enum does, and is less overloaded in the context. (The whole register the enum is part of is also called 'format'.) | ||||
* | | Merge pull request #119 from lioncash/warn | bunnei | 2014-10-09 | 2 | -3/+3 |
|\ \ | | | | | | | Fix warnings in video_core | ||||
| * | | Fix warnings in video_core | Lioncash | 2014-10-08 | 2 | -3/+3 |
| | | | |||||
* | | | Merge pull request #128 from purpasmart96/master | bunnei | 2014-10-08 | 1 | -1/+31 |
|\ \ \ | | | | | | | | | APT:U Added a stub fuction for "GlanceParameter" | ||||
| * | | | APT: Added a stub for the "GlanceParameter" function. | purpasmart96 | 2014-10-08 | 1 | -1/+31 |
| | | | | |||||
* | | | | Merge pull request #108 from archshift/config | bunnei | 2014-10-08 | 3 | -0/+42 |
|\ \ \ \ | | | | | | | | | | | Configuration files | ||||
| * | | | | Added configuration file system. | archshift | 2014-10-08 | 3 | -0/+42 |
| | |/ / | |/| | | | | | | | | | | Uses QSettings on citra-qt, and inih on citra-cli. | ||||
* | | | | Common: Add a helper function to generate a 8.3 filename from a long one. | Emmanuel Gil Peyrot | 2014-10-06 | 3 | -29/+27 |
| | | | | | | | | | | | | | | | | Core: Fix the SDMC Directory implementation to make blargSnes work. | ||||
* | | | | FileSys: Add static asserts for the Directory struct, and fix its fields position. | Emmanuel Gil Peyrot | 2014-10-06 | 1 | -2/+8 |
| | | | | |||||
* | | | | FileSys: split the constructor into an Open method, in order to notify the opener something went wrong. | Emmanuel Gil Peyrot | 2014-10-06 | 7 | -14/+57 |
| | | | | | | | | | | | | | | | | Kernel: Return an invalid handle to OpenFile when it failed to open. | ||||
* | | | | FileSys/Kernel: Implement SetSize service call for File objects. | Emmanuel Gil Peyrot | 2014-10-06 | 6 | -0/+49 |
| | | | | |||||
* | | | | FileSys: Add forgotten docstrings. | Emmanuel Gil Peyrot | 2014-10-06 | 7 | -4/+35 |
| |/ / |/| | | |||||
* | | | Added some more names to the function table | purpasmart96 | 2014-10-05 | 1 | -0/+2 |
| | | | | | | | | | Added "SetApplicationCpuTimeLimit" and "GetApplicationCpuTimeLimit" to apt.cpp | ||||
* | | | added "StoreDataCache" to the function table | purpasmart96 | 2014-09-30 | 1 | -0/+1 |
| | | | | | | | | | seems simple enough | ||||
* | | | Fix warnings in core and common | Lioncash | 2014-09-28 | 2 | -2/+2 |
|/ / | |||||
* | | Use the citra user path for the sdmc directory | archshift | 2014-09-21 | 1 | -2/+1 |
| | | |||||
* | | Kernel: Implement the Close command for Archive, File and Directory. | Emmanuel Gil Peyrot | 2014-09-17 | 2 | -0/+43 |
| | | |||||
* | | FS: Implement OpenArchive, OpenDirectory, OpenFile and OpenFileDirectly calls. | Emmanuel Gil Peyrot | 2014-09-17 | 1 | -20/+177 |
| | | |||||
* | | Kernel: Add a Directory object and a getter for it from an Archive object. | Emmanuel Gil Peyrot | 2014-09-17 | 3 | -0/+91 |
| | | |||||
* | | Core: Add a method to obtain a Directory from an Archive. | Emmanuel Gil Peyrot | 2014-09-17 | 5 | -0/+44 |
| | | |||||
* | | Core: Add a Directory object, with both a stub and a passthrough implementations. | Emmanuel Gil Peyrot | 2014-09-17 | 6 | -0/+264 |
| | | |||||
* | | Kernel: Add a File object and a getter for it from an Archive object. | Emmanuel Gil Peyrot | 2014-09-17 | 2 | -0/+118 |
| | | |||||
* | | Core: Add a passthrough backend for the filesystem, exposed as SDMC. | Emmanuel Gil Peyrot | 2014-09-17 | 5 | -0/+302 |
| | | |||||
* | | Core: Add a new File class, obtainable from an Archive, and a stub implementation. | Emmanuel Gil Peyrot | 2014-09-17 | 7 | -0/+208 |
| | | |||||
* | | Common: Rename the File namespace to FileUtil, to match the filename and prevent collisions. | Emmanuel Gil Peyrot | 2014-09-17 | 3 | -5/+5 |
| | | |||||
* | | Merge pull request #107 from lioncash/sprintf | bunnei | 2014-09-16 | 1 | -5/+7 |
|\ \ | | | | | | | Core: Replace a sprintf in core_timing with StringFromFormat | ||||
| * | | Core: Replace a sprintf in core_timing with StringFromFormat | Lioncash | 2014-09-13 | 1 | -5/+7 |
| | | | |||||
* | | | Merge pull request #109 from lioncash/cruft | bunnei | 2014-09-15 | 1 | -41/+2 |
|\ \ \ | | | | | | | | | Core: Get rid of unnecessary switch statement in Kernel | ||||
| * | | | Core: Get rid of unnecessary switch statement in Kernel | Lioncash | 2014-09-15 | 1 | -41/+2 |
| |/ / | |||||
* | | | Merge pull request #110 from lioncash/warnings | bunnei | 2014-09-15 | 1 | -6/+6 |
|\ \ \ | | | | | | | | | Core: Fix warnings in gpu.cpp | ||||
| * | | | Core: Fix warnings in gpu.cpp | Lioncash | 2014-09-14 | 1 | -6/+6 |
| |/ / | |||||
* | | | Merge pull request #97 from archshift/cleanup | bunnei | 2014-09-14 | 1 | -1/+1 |
|\ \ \ | |/ / |/| | | Small, general code cleanup | ||||
| * | | Dead code removal: video_core.cpp, load_symbol_map.cpp | archshift | 2014-09-07 | 1 | -1/+1 |
| | | | |||||
* | | | Added support for multiple input device types for KeyMap and connected Qt. | Kevin Hartman | 2014-09-12 | 2 | -113/+127 |
| | | | |||||
* | | | Initial HID PAD work, with GLFW only. | Kevin Hartman | 2014-09-12 | 2 | -24/+197 |
| | | | |||||
* | | | Created structure for PAD. | Kevin Hartman | 2014-09-12 | 2 | -0/+28 |
| | | | |||||
* | | | Merge pull request #99 from archshift/ext-check | bunnei | 2014-09-11 | 3 | -55/+56 |
|\ \ \ | | | | | | | | | loader.cpp: improved file extension checking, made Upper/LowerStr useful, moved string_util into Common namespace | ||||
| * | | | Added string_util to common, small changes in loader.cpp | archshift | 2014-09-09 | 3 | -56/+55 |
| | | | | |||||
| * | | | loader.cpp: improved file extension checking, made Upper/LowerStr useful | archshift | 2014-09-09 | 1 | -6/+8 |
| | |/ | |/| | | | | | | | Instead of forcibly taking the last 4 characters, it now finds the last extension separator (the period) and takes a substr of its location. | ||||
* / | | core: Prune redundant includes | archshift | 2014-09-09 | 20 | -37/+0 |
|/ / | |||||
* | | Merge pull request #95 from lioncash/disassembler | bunnei | 2014-09-08 | 3 | -189/+143 |
|\ \ | | | | | | | core: Make the ARM disassembler use std::string internally | ||||
| * | | core: Make the ARM disassembler use std::string internally | Lioncash | 2014-09-06 | 3 | -189/+143 |
| | | | |||||
* | | | Merge pull request #87 from archshift/remove-cruft | bunnei | 2014-09-08 | 1 | -1/+1 |
|\ \ \ | |_|/ |/| | | Removed redundant headers for std implementations | ||||
| * | | Removed common/std_xyz, instead using the std header | archshift | 2014-09-07 | 1 | -1/+1 |
| |/ | |||||
* | | Merge pull request #93 from lioncash/ref | bunnei | 2014-09-06 | 2 | -4/+4 |
|\ \ | | | | | | | core: Pass string by reference in FetchFromPortName and DeleteService | ||||
| * | | core: Pass string by reference in FetchFromPortName and DeleteService | Lioncash | 2014-09-06 | 2 | -4/+4 |
| |/ | |||||
* | | ncch: Remove C-style struct typedefs | Lioncash | 2014-09-06 | 1 | -4/+4 |
| | | | | | | | | In C++ you can simply just declare it as is. | ||||
* | | ncch: inline declare some variables in LZSS_Decompress | Lioncash | 2014-09-06 | 1 | -7/+5 |
|/ | |||||
* | Removed common/atomic, instead using std::atomic | archshift | 2014-09-03 | 1 | -4/+4 |
| | |||||
* | Remove hand-crafted Visual Studio solution. | Yuri Kunde Schlesner | 2014-09-01 | 2 | -592/+0 |
| | |||||
* | CMake cleanup | Yuri Kunde Schlesner | 2014-09-01 | 1 | -47/+56 |
| | | | | | | | | Several cleanups to the buildsystem: - Do better factoring of common libs between platforms. - Add support to building on Windows. - Remove Qt4 support. - Re-sort file lists and add missing headers. | ||||
* | Merge pull request #84 from bunnei/fix-hw-synchronization | bunnei | 2014-08-31 | 3 | -33/+48 |
|\ | | | | | Fix GPU/HW synchronization | ||||
| * | GPU: Improve frame synchronization, increases compatibility with both homebrew and retail applications. | bunnei | 2014-08-31 | 1 | -13/+31 |
| | | |||||
| * | Core: Refactor core to use only one function for execution. | bunnei | 2014-08-31 | 2 | -20/+17 |
| | | | | | | | | | | | | Core: Cleaned up comment to be more readable. Citra: Changed loop to be more readable. | ||||
| * | Loader: Added support for loading raw BIN executables. | bunnei | 2014-08-31 | 2 | -0/+21 |
| | | | | | | | | | | | | - Useful for debugging homebrew Qt: Updated GUI to support loading .bin files. | ||||
| * | Threading: Fix thread starting to execute first instruction correctly. | bunnei | 2014-08-31 | 2 | -1/+6 |
| | | |||||
| * | srv::Initialize: Return "success" status code. | bunnei | 2014-08-31 | 1 | -0/+4 |
| | | |||||
* | | Merge pull request #82 from yuriks/addr-types | bunnei | 2014-08-31 | 2 | -31/+40 |
|\ \ | | | | | | | Introduce VAddr and PAddr typedefs for ARM addresses. | ||||
| * | | Introduce VAddr and PAddr typedefs for ARM addresses. | Yuri Kunde Schlesner | 2014-08-31 | 2 | -31/+40 |
| |/ | |||||
* | | Loader: Added support for loading raw BIN executables. | bunnei | 2014-08-28 | 2 | -0/+21 |
| | | | | | | | | | | | | - Useful for debugging homebrew Qt: Updated GUI to support loading .bin files. | ||||
* | | Threading: Fix thread starting to execute first instruction correctly. | bunnei | 2014-08-28 | 2 | -1/+6 |
| | | |||||
* | | srv::Initialize: Return "success" status code. | bunnei | 2014-08-28 | 1 | -0/+4 |
|/ | |||||
* | VideoCore: Fixes rendering issues on Qt and corrects framebuffer output size. | bunnei | 2014-08-26 | 1 | -9/+8 |
| | |||||
* | GPU: Fix a compiler warning about redundant semicolons. | Tony Wasserka | 2014-08-25 | 1 | -2/+2 |
| | |||||
* | Pica/citra-qt: Replace command list view and command list debugging code with something more sophisticated. | Tony Wasserka | 2014-08-25 | 1 | -5/+0 |
| | |||||
* | GSP: Update framebuffer information when necessary. | Tony Wasserka | 2014-08-25 | 2 | -2/+41 |
| | |||||
* | GSP: Implement SetBufferSwap. | Tony Wasserka | 2014-08-25 | 2 | -1/+47 |
| | |||||
* | GSP: Add a helper function for convenience. | Tony Wasserka | 2014-08-25 | 1 | -17/+22 |
| | |||||
* | Merge pull request #68 from archshift/readfile | bunnei | 2014-08-23 | 4 | -11/+88 |
|\ | | | | | Added FS functions to Archive and Archive_RomFS | ||||
| * | Added FS functions to Archive and Archive_RomFS | archshift | 2014-08-23 | 4 | -11/+88 |
| | | |||||
* | | ARM: Remove a forgotten const in vfp. | Emmanuel Gil Peyrot | 2014-08-20 | 2 | -2/+2 |
|/ | |||||
* | Core: Use std::array for managing kernel object space | Lioncash | 2014-08-19 | 2 | -5/+5 |
| | | | | These avoid relying on memset for clearing the arrays. | ||||
* | Merge pull request #55 from lioncash/string | bunnei | 2014-08-19 | 16 | -41/+38 |
|\ | | | | | Core: Alter the kernel string functions to use std::string instead of const char*. | ||||
| * | Core: Alter the kernel string functions to use std::string instead of const char*. | Lioncash | 2014-08-18 | 16 | -41/+38 |
| | | | | | | | | Most functions already operate on std::strings. This also removes the need to manually null terminate thread names. | ||||
* | | SVC: Added support for svc_GetSystemTick. | bunnei | 2014-08-19 | 2 | -19/+48 |
|/ | | | | Changed HLE function return methods to be static inline functions. | ||||
* | Merge pull request #53 from lioncash/memmap | bunnei | 2014-08-18 | 1 | -4/+8 |
|\ | | | | | Core: Fix undefined behavior in mem_map_funcs' WriteBlock function | ||||
| * | Core: Fix undefined behavior in mem_map_funcs' WriteBlock function | Lioncash | 2014-08-17 | 1 | -4/+8 |
| | | |||||
* | | Core: Fix a formatting error in svc.cpp | Lioncash | 2014-08-17 | 1 | -3/+2 |
|/ | | | | | entry_point would not be added to the string. Also used StringFromFormat so that the buffer is unnecessary. | ||||
* | Merge pull request #39 from bunnei/hid-minor-improvements | bunnei | 2014-08-13 | 2 | -6/+45 |
|\ | | | | | Hid minor improvements | ||||
| * | HID: Added new function entries from 3dbrew to FunctionTable. | bunnei | 2014-08-13 | 1 | -0/+5 |
| | | | | | | | | HID: Fix typo with DisableGyroscopeLow command. | ||||
| * | HID: Implemented HID_User::GetIPCHandles service function. | bunnei | 2014-08-08 | 1 | -5/+39 |
| | | |||||
| * | SVC: Fixed typo with MapMemoryBlock DEBUG_LOG call. | bunnei | 2014-08-08 | 1 | -1/+1 |
| | | |||||
* | | Pica: Add command processor. | Tony Wasserka | 2014-08-12 | 1 | -3/+5 |
| | | |||||
* | | Pica/GPU: Change hardware registers to use physical addresses rather than virtual ones. | Tony Wasserka | 2014-08-12 | 6 | -208/+72 |
| | | | | | | | | | | This cleans up the mess that address reading/writing had become and makes the code a *lot* more sensible. This adds a physical<->virtual address converter to mem_map.h. For further accuracy, we will want to properly extend this to support a wider range of address regions. For now, this makes simply homebrew applications work in a good manner though. | ||||
* | | GSP: Fix a major regression introduced in ffda035c, due to which no display transfers were triggered at all anymore. | Tony Wasserka | 2014-08-12 | 1 | -4/+13 |
| | | |||||
* | | Remove the fancy RegisterSet class introduced in 4c2bff61e. | Tony Wasserka | 2014-08-12 | 3 | -150/+230 |
|/ | | | | | While it was some nice and fancy template usage, it ultimately had many practical issues regarding length of involved expressions under regular usage as well as common code completion tools not being able to handle the structures. Instead, we now use a more conventional approach which is a lot more clean to use. | ||||
* | GPU: Updated g_last_ticks variable to be more descriptive (represents CPU tick count of last vertical line). | bunnei | 2014-08-07 | 1 | -5/+5 |
| | |||||
* | GPU: Updated horizontal sync line counter to use framebuffer height. | bunnei | 2014-08-07 | 1 | -2/+3 |
| | |||||
* | Thread: Added more descriptive comment to WaitCurrentThread. | bunnei | 2014-08-07 | 2 | -2/+10 |
| | |||||
* | GSP: Cleaned up command buffer decoding. | bunnei | 2014-08-07 | 2 | -61/+69 |
| | | | | | | | | GSP: Cleaned up code and added additional comments. GSP: Removed unnecessary TODO comment. GSP: Changed u32 iterators in TriggerCmdReqQueue to unsigned. | ||||
* | GSP: Added reinitialization of other state objects. | bunnei | 2014-08-06 | 1 | -0/+3 |
| | |||||
* | GSP: Removed dumb GX prefixes to functions/structs in GSP namespace. | bunnei | 2014-08-06 | 3 | -79/+80 |
| | | | | - Various other cleanups. | ||||
* | GSP: Removed unnecessary GX_FinishCommand function. | bunnei | 2014-08-06 | 1 | -13/+5 |
| | |||||
* | GSP: Implements preliminary command synchronization via GPU interrupts. | bunnei | 2014-08-06 | 4 | -29/+140 |
| | | | | Core: Added a comment to explain the logic for the RunLoop iterations. | ||||
* | MemMap: Fixed typo with GetPointer to VRAM address. | bunnei | 2014-08-06 | 1 | -1/+1 |
| | |||||
* | AddressArbiter: Removed unnecessary HLE::Reschedule. | bunnei | 2014-08-06 | 1 | -1/+0 |
| | |||||
* | AddressArbiter: Fixed bug with break statements missing from case statements. | bunnei | 2014-08-06 | 1 | -0/+2 |
| | |||||
* | SRV: Updated GetProcSemaphore to create an event instead of a mutex. | bunnei | 2014-08-06 | 1 | -8/+10 |
| | |||||
* | SVC: Removed ArbitrateAddress log message that spams to much. | bunnei | 2014-08-06 | 1 | -2/+0 |
| | |||||
* | Kernel: Updated Event and Mutex to specify handle that they are blocking for. | bunnei | 2014-08-06 | 2 | -2/+2 |
| | |||||
* | Merge pull request #36 from bunnei/fix-memory-unaligned-reads | bunnei | 2014-08-06 | 2 | -16/+28 |
|\ | | | | | Fix memory unaligned reads | ||||
| * | MemMap: Added an error for unaligned 16-bit memory reads. | bunnei | 2014-08-06 | 1 | -0/+7 |
| | | |||||
| * | MemMap: Removed Read64 function. | bunnei | 2014-08-06 | 1 | -6/+0 |
| | | | | | | | | | | - Unused code - Was not correct for unaligned memory reads | ||||
| * | FS: Fix port name (old port name was based on an unaligned memory read). | bunnei | 2014-08-06 | 1 | -1/+1 |
| | | |||||
| * | MemMap: Fix Read32 for unaligned memory reads. | bunnei | 2014-08-06 | 1 | -12/+23 |
| | | | | | | | | MemMap: Cleaned up Read32 unaligned memory access. | ||||
* | | ARM: Synchronize Citra's SkyEye core with 3dmoo's. | bunnei | 2014-07-24 | 6 | -5919/+5303 |
|/ | |||||
* | Use uniform formatting when printing hexadecimal numbers. | Tony Wasserka | 2014-07-23 | 1 | -3/+3 |
| | |||||
* | Fix a few warnings. | Tony Wasserka | 2014-07-23 | 3 | -7/+7 |
| | | | | Templates shouldn't be marked as inline if they aren't defined in the header. | ||||
* | GPU: Clarify display transfer code. | Tony Wasserka | 2014-07-23 | 1 | -12/+15 |
| | | | | Also makes the illogical component order more obvious. | ||||
* | GPU: Add documentation. | Tony Wasserka | 2014-07-23 | 1 | -2/+14 |
| | |||||
* | GSP: Add a few comments. | Tony Wasserka | 2014-07-23 | 2 | -1/+15 |
| | |||||
* | GSP: Clean up GX command processing a lot and treat command id as a u8 rather than a u32. | Tony Wasserka | 2014-07-23 | 2 | -37/+79 |
| | | | | Anonymous structs are not standard C++, hence don't use them. | ||||
* | RegisterSet: Simplify code by using structs for register definition instead of unions. | Tony Wasserka | 2014-07-23 | 2 | -133/+123 |
| | |||||
* | GPU: Make use of RegisterSet. | Tony Wasserka | 2014-07-23 | 3 | -327/+200 |
| | |||||
* | GPU: Make framebuffer code format-aware. | Tony Wasserka | 2014-07-23 | 1 | -6/+47 |
| | |||||
* | GPU: Interface cleanup. | Tony Wasserka | 2014-07-23 | 2 | -13/+20 |
| | |||||
* | GPU: Initialize GPU registers to some sensible default state. | Tony Wasserka | 2014-07-23 | 1 | -1/+16 |
| | |||||
* | GPU: Emulate memory fills. | Tony Wasserka | 2014-07-23 | 4 | -3/+89 |
| | |||||
* | GPU: Add proper framebuffer register handling. | Tony Wasserka | 2014-07-23 | 2 | -11/+105 |
| | |||||
* | GPU: Properly implement display transfers. | Tony Wasserka | 2014-07-23 | 1 | -1/+19 |
| | |||||
* | GPU: Add display transfer configuration. | Tony Wasserka | 2014-07-23 | 2 | -0/+92 |
| | |||||
* | GSP: HLE GXCommandId::SET_DISPLAY_TRANSFER and GXCommandId::SET_TEXTURE_COPY. | Tony Wasserka | 2014-07-23 | 2 | -2/+17 |
| | |||||
* | GSP: Implement ReadHWRegs and WriteHWRegs properly. | Tony Wasserka | 2014-07-23 | 1 | -27/+46 |
| | |||||
* | Use a more compatible choice of initial framebuffer addresses. | Tony Wasserka | 2014-07-22 | 1 | -10/+22 |
| | |||||
* | core: Kill off type redefenitions in armdefs.h | Lioncash | 2014-07-20 | 1 | -7/+0 |
| | |||||
* | Kernel: Added preliminary support for address arbiters. | bunnei | 2014-07-09 | 7 | -9/+144 |
| | | | | | | | | AddressArbiter: Added documentation comment, fixed whitespace issue. AddressArbiter: Fixed incorrect comment, reordered if-statement to be more clear. SVC: Removed trailing whitespace. | ||||
* | Thread: Added functions to resume threads from address arbitration. | bunnei | 2014-07-09 | 2 | -0/+44 |
| | | | | | | Thread: Cleaned up arbitrate address functions. Thread: Cleaned up ArbitrateAllThreads function. | ||||
* | function_wrappers: Fixed incorrect wrapper, added another. | bunnei | 2014-07-08 | 1 | -2/+9 |
| | |||||
* | SharedMemory: Updated MapSharedMemory to use an enum for permissions. | bunnei | 2014-07-05 | 3 | -16/+36 |
| | | | | - Also added some safety checks to MapSharedMemory. | ||||
* | Memory: Removed deprecated MapBlock_Shared function. | bunnei | 2014-07-05 | 2 | -30/+0 |
| | |||||
* | GSP: Fixed to use real shared memory object, various cleanups. | bunnei | 2014-07-05 | 2 | -30/+40 |
| | | | | | | | | - Previously, used a hard-coded shared memory handle of 0x10002000 (as used by libctru homebrew) GSP: Added name for shared memory. GSP: Cleaned up assertion message. | ||||
* | Kernel: Added support for shared memory objects. | bunnei | 2014-07-05 | 5 | -0/+142 |
| | | | | SharedMemory: Added optional name field for tracking known objects. | ||||
* | mem_map: Updated interface to expose template functions to other modules. | bunnei | 2014-07-05 | 2 | -10/+16 |
| | |||||
* | NCCH: Updated ExeFS memory allocation to be safer. | bunnei | 2014-07-05 | 2 | -1/+7 |
| | |||||
* | Archive: Added Init/Shutdown methods to reset kernel archive state. | bunnei | 2014-07-05 | 3 | -0/+19 |
| | |||||
* | Marked AppLoader_ELF, AppLoader_NCCH, and Archive_RomFS virtual functions as "override". | bunnei | 2014-07-05 | 3 | -13/+13 |
| | |||||
* | Marked AppLoader_ELF, AppLoader_NCCH, and Archive_RomFS classes as "final" | bunnei | 2014-07-05 | 3 | -3/+3 |
| | |||||
* | Loader: Updated read methods to be const | bunnei | 2014-07-05 | 5 | -68/+79 |
| | | | | - Required "file" handle to be made local and explicitly opened/closed as needed | ||||
* | FileSys: Added preliminary support for applications reading the RomFS archive. | bunnei | 2014-07-05 | 11 | -160/+311 |
| | | | | | | | | | | Archive: Fixed brace ugliness for neobrain :) FS: Commented out unused local variables to prevent warnings. ...But keeping them here for future use. archive_romfs: Removed unused #include. | ||||
* | APT: Added stubbed ReceiveParameter and various cleanups. | bunnei | 2014-07-04 | 1 | -71/+93 |
| | | | | | | APT: More cleanups. APT: Changed SignalType to be type u32. | ||||
* | Loader: Refactored interface such that data is no longer stored by loader. | bunnei | 2014-06-27 | 3 | -96/+73 |
| | | | | NCCH: Removed extra qualification ‘Loader::AppLoader_NCCH::’. | ||||
* | FS: Added stubbed code to intercept and decode file system service functions. | bunnei | 2014-06-27 | 6 | -0/+164 |
| | | | | FS: Added to CMakeLists.txt | ||||
* | Kernel: Added stubbed code to support creation of kernel Archive objects. | bunnei | 2014-06-27 | 6 | -0/+95 |
| | |||||
* | Core: Removed unused directory_file_system and meta_file_system modules. | bunnei | 2014-06-27 | 9 | -1477/+0 |
| | | | | Core: Updated CMakeLists.txt to remove directory_file_system and meta_file_system modules. | ||||
* | Loader: Refactored loading functions to only read data from binary if called. | bunnei | 2014-06-25 | 3 | -74/+141 |
| | | | | NCCH: Updated LoadExec to use Memory::WriteBlock function to load binary code. | ||||
* | MemMap: Added a WriteBlock function to write a buffer of data to memory. | bunnei | 2014-06-25 | 2 | -0/+14 |
| | |||||
* | ELF: Refactored LoadInto(..) to use memcpy, removed unnecessary code. | bunnei | 2014-06-25 | 1 | -19/+8 |
| | |||||
* | Loader: Refactored use of const. | bunnei | 2014-06-25 | 6 | -20/+19 |
| | |||||
* | NCCH: Added RomFS loading. | bunnei | 2014-06-25 | 2 | -1/+36 |
| | |||||
* | NCCH: Fixes reduce unnecessary logging and load logo/banner/etc. sections correctly. | bunnei | 2014-06-25 | 3 | -22/+29 |
| | | | | Loader: Added ErrorNotUsed ReturnStatus type to specify when something is not used. | ||||
* | Loader: Implemented AppLoader interface for abstracting application loading. | bunnei | 2014-06-25 | 6 | -523/+672 |
| | | | | | | | | | | | | | | | | | | - Various cleanups/refactorings to Loader, ELF, and NCCH modules. - Added AppLoader interface to ELF and NCCH. - Updated Qt/GLFW frontends to check AppLoader ResultStatus. NCCH: Removed extra qualification typos. Loader: Removed unnecessary #include's. NCCH: Improved readability of memcmp statements. NCCH: Added missing space. Elf: Removed unnecessary usage of unique_ptr. Loader: Removed unnecessary usage of unique_ptr. | ||||
* | NCCH: Changed decompression to load .code directly into memory rather than an intermediate buffer. | bunnei | 2014-06-17 | 1 | -9/+3 |
| | |||||
* | Elf: Removed unused macros, changed #include of "common.h" to just "common_types.h". | bunnei | 2014-06-17 | 1 | -117/+1 |
| | |||||
* | Loader: Cleaned up and removed unused code, refactored ELF namespace. | bunnei | 2014-06-17 | 4 | -209/+70 |
| | |||||
* | Elf: Renamed modules to be consistent with new loader naming, fixed tabs -> spaces. | bunnei | 2014-06-17 | 8 | -372/+342 |
| | |||||
* | Loader: Added support for booting NCCH executables. | bunnei | 2014-06-17 | 6 | -0/+384 |
| | | | | NCCH: Fixed typo in printing NCCH filename. | ||||
* | Loader: Moved elf and loader modules to a "loader" subdirectory. | bunnei | 2014-06-17 | 8 | -30/+34 |
| | |||||
* | Loader: Added stubbed detection of CXI and CCI files. | bunnei | 2014-06-16 | 1 | -0/+6 |
| | |||||
* | Loader: Removed unused CXI and DAT loading code. | bunnei | 2014-06-16 | 1 | -76/+0 |
| | |||||
* | Merge branch 'threading' of https://github.com/bunnei/citra | bunnei | 2014-06-14 | 36 | -1155/+1194 |
|\ | | | | | | | | | | | Conflicts: src/core/hle/function_wrappers.h src/core/hle/service/gsp.cpp | ||||
| * | Kernel: Removed unnecessary "#pragma once". | bunnei | 2014-06-13 | 1 | -2/+0 |
| | | |||||
| * | Kernel: Added freeing of kernel objects on emulator shutdown. | bunnei | 2014-06-13 | 3 | -0/+13 |
| | | |||||
| * | Event: Updated several log messages to be assertions. | bunnei | 2014-06-13 | 1 | -16/+8 |
| | | |||||
| * | HLE: Moved "PARAM" and "RETURN" macros to function_wrappers.h (this is only module where they are needed). | bunnei | 2014-06-13 | 2 | -5/+6 |
| | | |||||
| * | SVC: Renamed all function wrapper templates to Wrap, moved to HLE namespace. | bunnei | 2014-06-13 | 2 | -157/+145 |
| | | |||||
| * | Thread: Renamed occurrences of "t" to "thread" to improve readability. | bunnei | 2014-06-13 | 1 | -48/+45 |
| | | |||||
| * | Thread: Cleaned up VerifyWait, fixed issue where nullptr msg could unnecessarily be logged. | bunnei | 2014-06-13 | 1 | -9/+7 |
| | | |||||
| * | HLE: Removed usnused EatCycles function. | bunnei | 2014-06-13 | 3 | -15/+0 |
| | | |||||
| * | SVC: Cleaned up function wrappers to pass in correct argument types. | bunnei | 2014-06-13 | 2 | -870/+201 |
| | | |||||
| * | Thread: Moved position of * in arguments. | bunnei | 2014-06-13 | 1 | -2/+2 |
| | | |||||
| * | Thread: Updated VerifyWait to be more readable (but functionally the same). | bunnei | 2014-06-13 | 1 | -4/+3 |
| | | |||||
| * | SVC: Moved declaration of "wait" variable in SendSyncRequest for improved readability. | bunnei | 2014-06-13 | 1 | -1/+1 |
| | | |||||
| * | HLE: Updated all uses of NULL to nullptr (to be C++11 compliant) | bunnei | 2014-06-13 | 13 | -239/+239 |
| | | |||||
| * | Kernel: Updated various kernel function "name" arguments to be const references. | bunnei | 2014-06-13 | 4 | -6/+6 |
| | | |||||
| * | HLE: Updated various handle debug assertions to be more clear. | bunnei | 2014-06-13 | 4 | -10/+10 |
| | | |||||
| * | Mutex: Moved ReleaseMutex iterator declaration to be inside while loop. | bunnei | 2014-06-13 | 1 | -2/+1 |
| | | |||||
| * | Kernel: Updated several member functions to be const | bunnei | 2014-06-13 | 5 | -13/+13 |
| | | |||||
| * | Core: Cleaned up SingleStep(), updated default LCD refresh to assume each instruction is ~3 cycles | bunnei | 2014-06-13 | 2 | -12/+14 |
| | | |||||
| * | Core: Changed HW update/thread reschedule to occur more frequently (assume each instruction is ~3 cycles) | bunnei | 2014-06-13 | 1 | -2/+2 |
| | | |||||
| * | Thread: Fixed bug with ResetThread where cpu_registers[15] was being incorrectly set | bunnei | 2014-06-13 | 1 | -1/+1 |
| | | |||||
| * | Kernel: Made SyncRequest not pure virtual, with a default implementation of error (as this is not required for all kernel objects) | bunnei | 2014-06-13 | 3 | -23/+4 |
| | | |||||
| * | Kernel: Added real support for thread and event blocking | bunnei | 2014-06-13 | 6 | -76/+196 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | - SVC: Added ExitThread support - SVC: Added SignalEvent support - Thread: Added WAITTYPE_EVENT for waiting threads for event signals - Thread: Added support for blocking on other threads to finish (e.g. Thread::Join) - Thread: Added debug function for printing current threads ready for execution - Thread: Removed hack/broken thread ready state code from Kernel::Reschedule - Mutex: Moved WaitCurrentThread from SVC to Mutex::WaitSynchronization - Event: Added support for blocking threads on event signalling Kernel: Added missing algorithm #include for use of std::find on non-Windows platforms. | ||||
| * | hle: added a hokey way to force a thread reschedule during CPU single step mode (as used by the debugger) | bunnei | 2014-06-05 | 3 | -1/+7 |
| | | |||||
| * | arm: fixed a bug where ARM_Interpreter::ExecuteInstructions was actually executing one more instruction than expected | bunnei | 2014-06-05 | 1 | -1/+1 |
| | | |||||
| * | kernel: changed current default thread priority back to 0x30 - I think this is more correct | bunnei | 2014-06-05 | 1 | -1/+1 |
| | | |||||
| * | arm: fixed bug in how thread context switch occurs with SkyEye | bunnei | 2014-06-05 | 2 | -2/+9 |
| | | |||||
| * | service: added a error log messages for unimplemented WaitSynchronization | bunnei | 2014-06-05 | 1 | -0/+1 |
| | | |||||
| * | arm: reverting a change made with cb0663de - this has to have been a typo! | bunnei | 2014-06-05 | 1 | -1/+1 |
| | | |||||
| * | svc: added optional name field to Event and Mutex (used for debugging) | bunnei | 2014-06-03 | 6 | -12/+25 |
| | | |||||
| * | kernel: moved position of * for GetTypeName and GetName | bunnei | 2014-06-03 | 1 | -2/+2 |
| | | |||||
| * | coprocessor: reenabled debug log | bunnei | 2014-06-03 | 1 | -1/+1 |
| | | |||||
| * | svc: updated WaitSynchronizationN to properly use first pointer argument | bunnei | 2014-06-02 | 2 | -4/+6 |
| | | |||||
| * | svc: changed DuplicateHandle log message from "error" to "debug" | bunnei | 2014-06-02 | 1 | -1/+1 |
| | | |||||
| * | svc: added GetThreadPriority and SetThreadPriority, added (incomplete) DuplicateHandle support | bunnei | 2014-06-02 | 3 | -3/+77 |
| | | |||||
| * | kernel: changed main thread priority to default, updated Kernel::Reschedule to use PrepareReschedule | bunnei | 2014-06-02 | 6 | -9/+17 |
| | | |||||
| * | arm: added option to prepare CPU core (while mid-instruction) for thread reschedule | bunnei | 2014-06-02 | 3 | -0/+11 |
| | | |||||
| * | svc: cleaned up function_wrappers, updated various SVCs to make use of pointer arguments | bunnei | 2014-06-02 | 2 | -31/+40 |
| | | |||||
| * | svc: added missing function wrapper for SleepThread | bunnei | 2014-06-01 | 1 | -0/+4 |
| | | |||||
| * | gsp: always pass through synchronization barrier for commands | bunnei | 2014-06-01 | 1 | -1/+16 |
| | | |||||
| * | svc: updated waitSychronization to not overwrite handle on return, added stub for SleepThread (does nothing) | bunnei | 2014-06-01 | 1 | -2/+21 |
| | | |||||
| * | thread: updated Reschedule to sit at a synchronization barrier when no other threads are ready for execution | bunnei | 2014-06-01 | 1 | -0/+18 |
| | | |||||
| * | event: added a hackish ability to set an event as "locked" to its current state, cleaned up some comments | bunnei | 2014-06-01 | 2 | -4/+32 |
| | | |||||
| * | hle: added stubbed service for ndm_u | bunnei | 2014-05-30 | 5 | -0/+74 |
| | | |||||
| * | service: cleaned up log messages | bunnei | 2014-05-30 | 1 | -2/+2 |
| | | |||||
| * | service: removed PT_A from, as this was just an alias for APT_U | bunnei | 2014-05-30 | 1 | -2/+0 |
| | | |||||
| * | srv: fix to log unimplemented service (instead of crash) | bunnei | 2014-05-30 | 1 | -6/+2 |
| | | |||||
| * | mutex: fixed typo in ReleaseMutex | bunnei | 2014-05-30 | 1 | -1/+3 |
| | | |||||
| * | hle: cleaned up log messages | bunnei | 2014-05-30 | 8 | -45/+49 |
| | | |||||
| * | svc: updated OutputDebugString to use OS_LOG | bunnei | 2014-05-30 | 1 | -1/+1 |
| | | |||||
| * | arm: removed unnecessary code when calling SVC from skyeye | bunnei | 2014-05-30 | 1 | -16/+0 |
| | | |||||
| * | core: changed time delay before kernel reschedule to "approximate" a screen refresh | bunnei | 2014-05-30 | 1 | -3/+12 |
| | | |||||
| * | svc: changed unimplemented SVC log messages from "debug" messages to "error" messages | bunnei | 2014-05-30 | 1 | -8/+8 |
| | | |||||
| * | svc: added svcClearEvent, stubbed function for svcArbitrateAddress, and various fixes | bunnei | 2014-05-30 | 2 | -22/+38 |
| | | | | | | | | | | | | - force kernel reschedule after svcWaitSynchronization - fixed some bugs with passing in pointer arguments - cleaned up some comments and log messages | ||||
| * | event: added support for ClearEvent, fixed a bug with CreateEvent, fixed some comments | bunnei | 2014-05-30 | 2 | -9/+14 |
| | | |||||
| * | service: added additional hack to return success on unimplemented service calls | bunnei | 2014-05-30 | 1 | -2/+10 |
| | | |||||
| * | srv: changed a NOTICE_LOG to DEBUG_LOG | bunnei | 2014-05-30 | 1 | -1/+1 |
| | | |||||
| * | svc: added ArbitrationType enumeration | bunnei | 2014-05-30 | 1 | -0/+9 |
| | | |||||
| * | apt: added stubbed function for InquireNotification | bunnei | 2014-05-29 | 1 | -78/+86 |
| | | |||||
| * | hle: properly cast 64-bit function wrapper parameters to (u64) | bunnei | 2014-05-29 | 1 | -2/+2 |
| | | |||||
| * | hle: removed PARAM64 macro (this was incorrect), made several bug fixes accordingly for decoding U64 function parameters | bunnei | 2014-05-29 | 2 | -3/+2 |
| | | |||||
| * | lcd: moved kFrameTicks to lcd.h for use in other modules | bunnei | 2014-05-29 | 2 | -2/+2 |
| | | |||||
| * | service: changed interface to return 0 (no error) when a service method is unimplemented - hack to make apps boot further | bunnei | 2014-05-29 | 1 | -2/+2 |
| | | |||||
| * | APT_U: added stubbed function for APT_U::Enable, fixed some log messages to be more consistent | bunnei | 2014-05-28 | 1 | -3/+10 |
| | | |||||
| * | mutex: added preliminary SyncRequest/WaitSynchronization, added some comments/assertions | bunnei | 2014-05-28 | 1 | -0/+6 |
| | | |||||
| * | svc: implemented WaitSynchronization1, WaitSynchronizationN, and CreateEvent | bunnei | 2014-05-28 | 1 | -14/+54 |
| | | |||||
| * | APT_U: added event creation to Initialize method | bunnei | 2014-05-28 | 1 | -1/+11 |
| | | |||||
| * | event: fixed typos and updated CMakeLists | bunnei | 2014-05-28 | 2 | -1/+2 |
| | | |||||
| * | event: added SetEventLocked method to change status an events lock | bunnei | 2014-05-28 | 2 | -0/+18 |
| | | |||||
| * | kernel: added event module to support creation of CTR "Event" objects | bunnei | 2014-05-28 | 4 | -0/+127 |
| | | |||||
| * | mutex: removed docstring comment that is no longer relevant | bunnei | 2014-05-27 | 1 | -1/+0 |
| | | |||||
| * | mutex: added additional docstrings | bunnei | 2014-05-27 | 1 | -0/+2 |
| | | |||||
| * | kernel: added WaitSynchronization method to Kernel::Object | bunnei | 2014-05-27 | 4 | -0/+39 |
| | | |||||
| * | kernel: updated SyncRequest to take boolean thread wait result as a parameter | bunnei | 2014-05-27 | 5 | -10/+33 |
| | | |||||
| * | svc: added some assertions | bunnei | 2014-05-27 | 1 | -6/+4 |
| | | |||||
| * | service: Renamed Sync to SyncRequest | bunnei | 2014-05-27 | 1 | -1/+1 |
| | | |||||
| * | kernel: added enum for known CurrentThread and CurrentProcess handles | bunnei | 2014-05-27 | 1 | -0/+5 |
| | | |||||
| * | srv: added a real mutex for GetProcSemaphore (instead of stubbed) | bunnei | 2014-05-27 | 1 | -3/+10 |
| | | |||||
| * | svc: changed SendSyncRequest to use Kernel::Object SyncRequest (instead of just service Interface class) | bunnei | 2014-05-27 | 1 | -2/+2 |
| | | |||||
| * | kernel: add a SyncRequest method to KernelObject for use with svcSendSyncRequest | bunnei | 2014-05-27 | 4 | -6/+11 |
| | | |||||
| * | svc: added stub for DuplicateHandle SVC call | bunnei | 2014-05-27 | 1 | -1/+8 |
| | | |||||
* | | GPU debugger: Add functionality to inspect command lists. | Tony Wasserka | 2014-06-12 | 1 | -0/+4 |
| | | |||||
* | | GPU: Cleanup register definitions. | Tony Wasserka | 2014-06-12 | 3 | -31/+31 |
| | | |||||
* | | Rename LCD to GPU. | Tony Wasserka | 2014-06-12 | 8 | -36/+36 |
| | | |||||
* | | Add initial graphics debugger interface. | Tony Wasserka | 2014-06-12 | 1 | -0/+6 |
| | | |||||
* | | GSP: Define more GX commands. | Tony Wasserka | 2014-06-12 | 2 | -14/+54 |
| | | |||||
* | | Pica: Add command list registers. | Tony Wasserka | 2014-06-12 | 2 | -5/+52 |
| | | |||||
* | | Added 'this' reference to num_instructions field so it's properly updated,as before the method was affecting the local method parameter rather than the class field | Disruption | 2014-06-01 | 1 | -1/+1 |
| | | |||||
* | | service: fixed typo that MSVC did not catch as an error | bunnei | 2014-05-23 | 1 | -1/+1 |
| | | |||||
* | | core: fixed headers in CMakeLists | bunnei | 2014-05-23 | 1 | -1/+4 |
| | | |||||
* | | Merge branch 'threading' | bunnei | 2014-05-23 | 37 | -189/+1330 |
|\| | |||||
| * | core: added Kernel::Reschedule() call to check for thread changes, shortened delay time to 100 instructions | bunnei | 2014-05-23 | 1 | -1/+6 |
| | | |||||
| * | svc: added a check to ensure that a service was implemented before attempting to connect to its port | bunnei | 2014-05-23 | 1 | -1/+5 |
| | | |||||
| * | lcd: added thread wait after (faked) vblank interrupt (would have) occurred | bunnei | 2014-05-23 | 1 | -0/+4 |
| | | |||||
| * | thread: renamed "WaitCurThread" to "WaitCurrentThread", removed unused "reason" argument | bunnei | 2014-05-23 | 3 | -6/+6 |
| | | |||||
| * | thread: removed unused SwitchContext/Reschedule reason field, added missing arg parameter to SVC CreateThread | bunnei | 2014-05-23 | 3 | -12/+9 |
| | | |||||
| * | kernel: refactored function naming to remove "__" prefix | bunnei | 2014-05-23 | 6 | -65/+75 |
| | | |||||
| * | core: moved armcopro.cpp to correct filter folder (arm/interpreter) | bunnei | 2014-05-23 | 1 | -3/+3 |
| | | |||||
| * | thread: moved ThreadStatus/WaitType to header, added support for arg on CreateThread, added correct CPSR reset | bunnei | 2014-05-23 | 2 | -35/+40 |
| | | |||||
| * | APT_U: added a debug log on calling GetLockHandle | bunnei | 2014-05-23 | 1 | -0/+1 |
| | | |||||
| * | arm_interpreter: fixed load context to currently resume a thread | bunnei | 2014-05-23 | 1 | -1/+4 |
| | | |||||
| * | thread: fixed bug where result of __NextThread was not being properly checked when NULL | bunnei | 2014-05-22 | 1 | -1/+1 |
| | | |||||
| * | svc: added Kernel::Reschedule to svc WaitSynchronization1, updated log messages to include newly created handles | bunnei | 2014-05-22 | 1 | -4/+7 |
| | | |||||
| * | svc: enabled use of newly created kernel thread handle | bunnei | 2014-05-21 | 1 | -5/+5 |
| | | |||||
| * | mutex: refactored the interface to code to return a Mutex* handle | bunnei | 2014-05-21 | 4 | -5/+16 |
| | | |||||
| * | mutex: initial commit of HLE module | bunnei | 2014-05-21 | 7 | -10/+166 |
| | | |||||
| * | svc: added some comments | bunnei | 2014-05-21 | 1 | -0/+7 |
| | | |||||
| * | kernel: fixed include, in general include "common.h" not "common_types.h" | bunnei | 2014-05-21 | 1 | -1/+1 |
| | | |||||
| * | service: removed redundant include of common_types.h | bunnei | 2014-05-21 | 1 | -1/+0 |
| | | |||||
| * | arm: removed include of windows.h from armdefs.h to arminit.c (only module that uses it) | bunnei | 2014-05-21 | 2 | -4/+3 |
| | | |||||
| * | armemu: missed rename of "Syscall" to "SVC" | bunnei | 2014-05-21 | 1 | -1/+1 |
| | | |||||
| * | thread: added correct lowest thread priority, added a thread priority check, and added some comments | bunnei | 2014-05-21 | 2 | -6/+10 |
| | | |||||
| * | thread: exposed ResumeThreadFromWait function for use in other kernel modules | bunnei | 2014-05-21 | 2 | -8/+11 |
| | | |||||
| * | thread: moved threading calls to the Kernel namespace | bunnei | 2014-05-21 | 4 | -103/+117 |
| | | |||||
| * | ARM_Interpreter/ARM_Interface: Fixed member variable naming to be consistent with style guide | bunnei | 2014-05-21 | 3 | -45/+45 |
| | | |||||
| * | ARM_Interface: added SaveContext and LoadContext functions for HLE thread switching | bunnei | 2014-05-21 | 4 | -37/+65 |
| | | |||||
| * | renamed "syscall" module to "svc" (more accurate naming) | bunnei | 2014-05-21 | 9 | -26/+28 |
| | | |||||
| * | thread: whitespace change - fixed * and & placement | bunnei | 2014-05-21 | 2 | -27/+27 |
| | | |||||
| * | - created a Kernel namespace | bunnei | 2014-05-21 | 6 | -75/+87 |
| | | | | | | | | | | - cleaned up Kernel code a bit (moved stuff into namespace, fixed whitespace issues) - added handle types for all different CTROS handles | ||||
| * | apt: changed stubbed handle to be something other than 0xDEADBEEF (used as a magic value in other places) so that I can track how it propagates through the app code | bunnei | 2014-05-20 | 1 | -1/+1 |
| | | |||||
| * | thread: added declaration for __KernelReschedule to be used by syscall module | bunnei | 2014-05-20 | 1 | -0/+3 |
| | | |||||
| * | VFP: disable DBG messages because they spam the console with unimportant skyeye junk | bunnei | 2014-05-20 | 1 | -1/+1 |
| | | |||||
| * | renamed "session" to "handle" | bunnei | 2014-05-19 | 1 | -3/+3 |
| | | |||||
| * | - renamed NewHandle to CreateHandle | bunnei | 2014-05-19 | 2 | -8/+8 |
| | | | | | | | | - updated CreateHandle/DeleteHandle to use KernelObject's | ||||
| * | fix warning | bunnei | 2014-05-19 | 1 | -1/+1 |
| | | |||||
| * | - updated service(s) to be KernelObject's | bunnei | 2014-05-19 | 7 | -59/+31 |
| | | | | | | | | - various cleanups | ||||
| * | renamed "UID" to "Handle" where appropriate | bunnei | 2014-05-19 | 4 | -24/+22 |
| | | |||||
| * | - moved Handle/Result definitions to kernel.h | bunnei | 2014-05-19 | 6 | -14/+19 |
| | | | | | | | | - added ResetType enum | ||||
| * | - added stub for CreateEvent | bunnei | 2014-05-18 | 1 | -8/+22 |
| | | | | | | | | - changed some stubbed SVCs to return unique handle names for debugging purposes | ||||
| * | added stubbed function for WaitSynchronizationN | bunnei | 2014-05-18 | 2 | -4/+19 |
| | | |||||
| * | ignore thumbemu 0xDEADCODE debugging catch on MCR | bunnei | 2014-05-17 | 1 | -2/+1 |
| | | |||||
| * | changed a comment | bunnei | 2014-05-17 | 2 | -2/+2 |
| | | |||||
| * | cleanups to SVC CreateThread | bunnei | 2014-05-17 | 1 | -8/+15 |
| | | |||||
| * | Merge branch 'master' into threading | bunnei | 2014-05-17 | 6 | -23/+36 |
| |\ | |||||
| * | | - added enum ThreadProcessorId | bunnei | 2014-05-17 | 2 | -53/+107 |
| | | | | | | | | | | | | | | | - reorganized some kernel thread functions - added placeholder __KernelWaitThread_Synchronization function | ||||
| * | | - replaced KERNELOBJECT_MAX_NAME_LENGTH with KERNEL_MAX_NAME_LENGTH | bunnei | 2014-05-17 | 3 | -8/+12 |
| | | | | | | | | | | | | - added KERNEL_DEFAULT_STACK_SIZE definition (0x4000) | ||||
| * | | added stubbed GetProcSemaphore - does nothing but avoids an exception | bunnei | 2014-05-17 | 1 | -1/+7 |
| | | | |||||
| * | | add kernel.* and thread.* to VS filters | bunnei | 2014-05-17 | 1 | -0/+15 |
| | | | |||||
| * | | updated APT_U::GetLockHandle to return a valid handle | bunnei | 2014-05-17 | 1 | -1/+5 |
| | | | |||||
| * | | Merge master into threading to add support for VFP | bunnei | 2014-05-17 | 33 | -195/+14287 |
| |\ \ | |||||
| * | | | - added SVC stubs for QueryMemory and GetThreadId | bunnei | 2014-05-16 | 3 | -2/+30 |
| | | | | | | | | | | | | | | | | - added SVC structs MemoryInfo and PageInfo | ||||
| * | | | added memory mapped region for system mem - sdk demos load a segment here on ELF load | bunnei | 2014-05-16 | 3 | -1/+23 |
| | | | | |||||
| * | | | added ability to load AXF files (same as ELF) | bunnei | 2014-05-16 | 1 | -0/+3 |
| | | | | |||||
| * | | | completely gutted/refactored threading code to be simpler | bunnei | 2014-05-16 | 2 | -658/+230 |
| | | | | |||||
| * | | | changed "UID" to "Handle" to be a little more consistent with CTR naming | bunnei | 2014-05-16 | 2 | -18/+21 |
| | | | | |||||
| * | | | - added ThreadContext struct | bunnei | 2014-05-16 | 2 | -8/+26 |
| | | | | | | | | | | | | | | | | - cleaned up CreateThread svc | ||||
| * | | | - added helper function for __KernelCreateThread | bunnei | 2014-05-15 | 2 | -4/+76 |
| | | | | | | | | | | | | | | | | | | | | - added __KernelSwitchToThread for enabling a thread - added __KernelRotateThreadReadyQueue | ||||
| * | | | changed primary thread priority to 0x30 - this is typical, not 0x31 | bunnei | 2014-05-15 | 1 | -1/+2 |
| | | | | |||||
| * | | | added function stubs for EatCycles and ReSchedule | bunnei | 2014-05-15 | 2 | -0/+15 |
| | | | | |||||
| * | | | fixed thread reset to not set stack address | bunnei | 2014-05-14 | 1 | -1/+1 |
| | | | | |||||
| * | | | various cleanups / remove unused code | bunnei | 2014-05-14 | 2 | -65/+29 |
| | | | | |||||
| * | | | added a bunch of threading code, recycled from PPSSPP, with lots of hacks in for 3DS... doesn't really do much yet. Just a jumping off point | bunnei | 2014-05-14 | 2 | -70/+543 |
| | | | | |||||
| * | | | changed loader to use __KernelLoadExec | bunnei | 2014-05-14 | 1 | -8/+9 |
| | | | | |||||
| * | | | added CreateThread, CreateMutex, and ReleaseMutex SVC stubs (just parameter decoding for now) | bunnei | 2014-05-14 | 2 | -7/+38 |
| | | | | |||||
| * | | | - added __KernelLoadExec function | bunnei | 2014-05-14 | 2 | -13/+35 |
| | | | | | | | | | | | | | | | | - fixed some logging | ||||
| * | | | added option to set CPSR register to arm_interface | bunnei | 2014-05-12 | 3 | -0/+20 |
| | | | | |||||
| * | | | added initial kernel/thread modules | bunnei | 2014-05-10 | 7 | -0/+548 |
| | | | | |||||
* | | | | Merge pull request #2 from archshift/issue-7-fix | bunnei | 2014-05-20 | 6 | -26/+54 |
|\ \ \ \ | |_|_|/ |/| | | | Fixes issues with building Citra on OSX | ||||
| * | | | CMakeLists: rename HEADS, improved comments | archshift | 2014-05-20 | 1 | -2/+2 |
| | | | | | | | | | | | | | | | | Changes for clarity of comments, removed redundant compiler flags. | ||||
| * | | | Fixed vfp issues | archshift | 2014-05-17 | 4 | -10/+10 |
| | | | | |||||
| * | | | Updated cmakelists | archshift | 2014-05-17 | 1 | -6/+12 |
| | | | | |||||
| * | | | Merge remote-tracking branch 'upstream/master' into issue-7-fix | archshift | 2014-05-17 | 51 | -473/+14858 |
| |\ \ \ | | | |/ | | |/| | |||||
| * | | | Fixed indents | archshift | 2014-05-01 | 1 | -2/+2 |
| | | | | |||||
| * | | | Merge commit upstream/master into issue-7-fix | archshift | 2014-05-01 | 3 | -22/+43 |
| |\ \ \ | |||||
| * | | | | A bit of Cmake love | archshift | 2014-05-01 | 1 | -1/+38 |
| | | | | | |||||
| * | | | | Merge commit upstream/master into issue-7-fix | archshift | 2014-04-29 | 2 | -5/+11 |
| |\ \ \ \ | |||||
| * | | | | | Problematic template functions | archshift | 2014-04-28 | 1 | -15/+0 |
| | | | | | | |||||
* | | | | | | updated how we call ARM core to make things much faster | bunnei | 2014-05-17 | 6 | -23/+36 |
| |_|_|/ / |/| | | | | |||||
* | | | | | same fix as last commit - just for vfpsingle.cpp | bunnei | 2014-05-17 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | another VFP fix for GCC | bunnei | 2014-05-17 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | fixed VFP DBG log for GCC | bunnei | 2014-05-17 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | fixed typo in CMakeLists.txt | bunnei | 2014-05-17 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | - reenabled MCR and MRC functions now that VFP is attached | bunnei | 2014-05-17 | 4 | -116/+94 |
| | | | | | | | | | | | | | | | | | | | | - removed HLE::CallMCR function (was pointless) | ||||
* | | | | | - removed unused stubbed out code | bunnei | 2014-05-17 | 5 | -33/+27 |
| | | | | | | | | | | | | | | | | | | | | | | | | | - fixed some compiler issues with xscale_copro when porting code to Windows - fixed some #include's | ||||
* | | | | | added maverick.cpp to ARM core from skyeye | bunnei | 2014-05-16 | 4 | -1/+1212 |
| | | | | | |||||
* | | | | | fixed includes | bunnei | 2014-05-16 | 1 | -2/+2 |
| | | | | | |||||
* | | | | | enabled CP_ACCESS_ALLOWED | bunnei | 2014-05-16 | 1 | -6/+4 |
| | | | | | |||||
* | | | | | fixed include path | bunnei | 2014-05-16 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | removed undefined function ARMul_ConsolePrint | bunnei | 2014-05-16 | 1 | -1/+1 |
| | | | | | |||||
* | | | | | added missing armcopro from skyeye | bunnei | 2014-05-16 | 6 | -251/+1098 |
| | | | | | |||||
* | | | | | added missing skyeye mmu code | bunnei | 2014-05-16 | 12 | -44/+3333 |
| | | | | | |||||
* | | | | | fixed armmmu imports | bunnei | 2014-05-16 | 1 | -5/+5 |
| | | | | | |||||
* | | | | | - moved mmu to arm/interpreter folder | bunnei | 2014-05-16 | 16 | -1/+8791 |
| |_|_|/ |/| | | | | | | | | | | | - added initial VFP code from skyeye | ||||
* | | | | removed unknown fields from GX_CmdBufferHeader | bunnei | 2014-05-08 | 1 | -5/+0 |
| | | | | |||||
* | | | | removed unnecessary log message | bunnei | 2014-05-08 | 1 | -1/+1 |
| | | | | |||||
* | | | | - removed HLE mem "hack" and replaced with kernel mem region | bunnei | 2014-05-08 | 8 | -116/+100 |
| | | | | | | | | | | | | | | | | | | | | - added a helper function for getting command buffer for services - fixed bug where GSP DMA was incorrectly being done in DataSynchronizationBarrier (instead of gsp_TriggerCmdReqQueue) | ||||
* | | | | added kernel memory to mem_map | bunnei | 2014-05-08 | 2 | -0/+9 |
| | | | | |||||
* | | | | - added debug logging to syscall.cpp | bunnei | 2014-05-07 | 2 | -135/+173 |
| | | | | | | | | | | | | | | | | - added stubbed HLE syscall functions for svc_GetResourceLimit and svc_GetResourceLimitCurrentValues | ||||
* | | | | added mem_map read for config_mem | bunnei | 2014-05-07 | 2 | -7/+17 |
| | | | | |||||
* | | | | added config_mem module for HLE of firmware configuration memory settings | bunnei | 2014-05-07 | 5 | -0/+100 |
| | | | | |||||
* | | | | - disable strict alignment on LDRD/STRD | bunnei | 2014-05-07 | 1 | -17/+22 |
| | | | | | | | | | | | | | | | | - handle RD in STREX/STREXB | ||||
* | | | | commented out useless debug logs that just spammed console | bunnei | 2014-05-06 | 1 | -3/+3 |
| | | | | |||||
* | | | | - added CallMCR function to coprocessor HLE module | bunnei | 2014-05-02 | 3 | -29/+43 |
| | | | | | | | | | | | | | | | | - moved instruction decoding to coprocessor HLE module | ||||
* | | | | fixed include in coprocessor.cpp | bunnei | 2014-05-02 | 1 | -1/+1 |
| | | | | |||||
* | | | | renamed hle "mrc" module to "coprocessor" | bunnei | 2014-05-02 | 6 | -17/+17 |
| | | | | |||||
* | | | | - added some function wrappers for HLE | bunnei | 2014-05-02 | 2 | -10/+29 |
| | | | | | | | | | | | | | | | | | | | | - added stub for SVC CreateAddressArbiter - added OutputDebugString SVC | ||||
* | | | | - added option to load a code.bin file extracted from a CXI file | bunnei | 2014-05-01 | 2 | -14/+63 |
| | | | | | | | | | | | | | | | | - updated load launcher.dat function to use ARM11 format hack | ||||
* | | | | added a module to load symbol map files for debugging | bunnei | 2014-05-01 | 5 | -0/+55 |
| | | | | |||||
* | | | | fixed a bug where ExeFs code was being incorrectly masked | bunnei | 2014-05-01 | 1 | -1/+1 |
| |_|/ |/| | | |||||
* | | | added virtual memory map for ExeFS (where ARM11 code is supposed to be loaded) | bunnei | 2014-05-01 | 3 | -1/+17 |
| | | | |||||
* | | | reorganized memory regions enum, added regions for ExeFS code | bunnei | 2014-05-01 | 2 | -21/+26 |
| |/ |/| | |||||
* | | added virtual address conversion for firmware FW0B | bunnei | 2014-04-28 | 2 | -5/+11 |
|/ | |||||
* | removed DISALLOW_COPY_AND_ASSIGN in favor of NonCopyable class | bunnei | 2014-04-28 | 5 | -12/+1 |
| | |||||
* | fixed weird spacing | bunnei | 2014-04-28 | 1 | -1/+1 |
| | |||||
* | removed commented out line - this was for an unimplemented MRC call, no longer need to leave this here | bunnei | 2014-04-28 | 1 | -1/+0 |
| | |||||
* | hackish but working way to set the framebuffer location to VRAM (used in ARM11 demos tested thus far, e.g. yeti3DS) | bunnei | 2014-04-27 | 1 | -3/+9 |
| | |||||
* | added helper functions to mem_map to convert physical addresses to virtual addresses | bunnei | 2014-04-27 | 2 | -1/+15 |
| | |||||
* | added code to LCD modules keep track of framebuffer location in FCRAM or VRAM | bunnei | 2014-04-27 | 2 | -15/+153 |
| | |||||
* | - changed HW IO map to use virtual addresses | bunnei | 2014-04-26 | 4 | -42/+64 |
| | | | | - added hooks to catch LCD IO read/writes | ||||
* | added simple GSP GPU ReadHWRegs function to support returning the framebuffer address | bunnei | 2014-04-26 | 1 | -1/+37 |
| | |||||
* | added preliminary DataSynchronizationBarrier support with simple DMA copy | bunnei | 2014-04-26 | 1 | -7/+39 |
| | |||||
* | added (fake) physical addresses for where to put framebuffer in VRAM | bunnei | 2014-04-26 | 1 | -0/+10 |
| | |||||
* | added vram to memory_map | bunnei | 2014-04-26 | 2 | -8/+15 |
| | |||||
* | moved HLE::MRC to its own module, added support for catching data synchronization barrier command | bunnei | 2014-04-25 | 9 | -13/+66 |
| | |||||
* | added disassembly to unimplemented instruction | bunnei | 2014-04-25 | 1 | -1/+6 |
| | |||||
* | removed some cruft | bunnei | 2014-04-25 | 1 | -7/+1 |
| | |||||
* | fixed bug where svc_ControlMemory was not properly getting passed in parameters | bunnei | 2014-04-25 | 1 | -2/+2 |
| | |||||
* | - added preliminary support for svc_MapMemoryBlock | bunnei | 2014-04-25 | 4 | -14/+70 |
| | | | | | - added shared memory region - moarrrr cleanups to memory_map | ||||
* | added functions to map Heap and Shared memory space | bunnei | 2014-04-25 | 3 | -9/+76 |
| | |||||
* | added GSP::RegisterInterruptRelayQueue function | bunnei | 2014-04-25 | 1 | -31/+40 |
| | |||||
* | - refactored how service functions are called | bunnei | 2014-04-25 | 5 | -19/+39 |
| | | | | - added option to create/delete service handles | ||||
* | fixes to build on linux | bunnei | 2014-04-23 | 3 | -22/+24 |
| | |||||
* | updated CMakeLists for missing files | ShizZy | 2014-04-23 | 1 | -1/+9 |
| | |||||
* | Add a quick way to load Launcher.dat files | Mathieu Vaillancourt | 2014-04-22 | 2 | -5/+60 |
| | |||||
* | Merge branch 'hle-interface' | bunnei | 2014-04-18 | 34 | -212/+2339 |
|\ | |||||
| * | renamed hw_lcd module to just lcd | bunnei | 2014-04-18 | 6 | -12/+10 |
| | | |||||
| * | added NDMA hardware interface | bunnei | 2014-04-18 | 5 | -2/+141 |
| | | |||||
| * | added GSP heap memory allocation | bunnei | 2014-04-18 | 3 | -1/+76 |
| | | |||||
| * | fixed bug in Memory::GetPointer | bunnei | 2014-04-18 | 1 | -2/+2 |
| | | |||||
| * | moved enums into Memory:: namespace | bunnei | 2014-04-18 | 1 | -4/+2 |
| | | |||||
| * | added memory read/write to GSP heap | bunnei | 2014-04-18 | 3 | -7/+16 |
| | | |||||
| * | more various refactors to memory interface | bunnei | 2014-04-18 | 3 | -48/+58 |
| | | |||||
| * | cleaned up memory interfaces a lot, removed some hackish stuff | bunnei | 2014-04-18 | 3 | -106/+50 |
| | | |||||
| * | added a new function wrapper | bunnei | 2014-04-17 | 1 | -0/+5 |
| | | |||||
| * | fixed bug with printing std::string in log messages | bunnei | 2014-04-17 | 1 | -2/+2 |
| | | |||||
| * | changed unknown memory read/write to report the size | bunnei | 2014-04-17 | 1 | -2/+3 |
| | | |||||
| * | added class stub for HID:User service | bunnei | 2014-04-17 | 5 | -0/+80 |
| | | |||||
| * | updated service comments | bunnei | 2014-04-17 | 6 | -5/+17 |
| | | |||||
| * | - fixed tabs in function_wrappers.h | bunnei | 2014-04-17 | 4 | -395/+413 |
| | | | | | | | | | | - fixed log message wording in hle.cpp - added syscall stubs for CloseHandle and WaitSynchronization1 | ||||
| * | - added stubbed out GSP::Gpu service interface | bunnei | 2014-04-16 | 9 | -7/+111 |
| | | | | | | | | - various cleanups/refactors to HLE services | ||||
| * | removed no longer used function header | bunnei | 2014-04-16 | 1 | -2/+0 |
| | | |||||
| * | restructured hle:services completely to use function lookup tables | bunnei | 2014-04-16 | 5 | -137/+215 |
| | | |||||
| * | fixed naming for APT_U | bunnei | 2014-04-16 | 3 | -9/+9 |
| | | |||||
| * | - extracted srv: calls from service.cpp and put in its own module | bunnei | 2014-04-16 | 6 | -106/+113 |
| | | | | | | | | | | - added function tables for service calls - lots of refactoring | ||||
| * | added a stub for GetLockHandle | bunnei | 2014-04-14 | 3 | -9/+44 |
| | | |||||
| * | added framework for APT service (application and title launching service) | bunnei | 2014-04-13 | 7 | -5/+126 |
| | | |||||
| * | renamed class Interface_SRV to SRV | bunnei | 2014-04-13 | 1 | -6/+6 |
| | | |||||
| * | replace tabs with spaces | bunnei | 2014-04-13 | 1 | -3/+3 |
| | | |||||
| * | added some very initial command parsing for SRV Sync | bunnei | 2014-04-13 | 1 | -5/+31 |
| | | |||||
| * | added a GetPointer function for reading from HLE command buffer | bunnei | 2014-04-13 | 2 | -0/+14 |
| | | |||||
| * | fixed hw write declarations to not be const | bunnei | 2014-04-13 | 1 | -4/+4 |
| | | |||||
| * | added OS memory read/write for thread command buffer | bunnei | 2014-04-13 | 4 | -12/+60 |
| | | |||||
| * | cleanups to service HLE | bunnei | 2014-04-13 | 2 | -8/+8 |
| | | |||||
| * | - added HLE to connect to "srv:" service | bunnei | 2014-04-13 | 11 | -168/+386 |
| | | | | | | | | | | | | - added a manager for keeping track of services/ports - added a memory mapped region for memory accessed by HLE - added HLE for GetThreadCommandBuffer function | ||||
| * | hacked CPU interpreter to ignore branch on SVC instruction (as we are HLEing this...) | bunnei | 2014-04-12 | 1 | -2/+6 |
| | | |||||
| * | added a SETABORT method that does not update LR (for HLE'd SVC that does not jump appcore CPU to an IRQ vector) | bunnei | 2014-04-12 | 1 | -0/+11 |
| | | |||||
| * | added a memory mapped option for HLE | bunnei | 2014-04-12 | 1 | -5/+8 |
| | | |||||
| * | - renamed hle_syscall to just syscall | bunnei | 2014-04-12 | 7 | -106/+157 |
| | | | | | | | | - added service.h as an initial service interface | ||||
| * | replace tabs with spaces | bunnei | 2014-04-12 | 1 | -6/+6 |
| | | |||||
| * | moved hle.cpp into hle folder (due to mistake earlier) | bunnei | 2014-04-12 | 3 | -2/+2 |
| | | |||||
| * | added remaining known syscall functions to Syscall_Table | bunnei | 2014-04-11 | 1 | -0/+80 |
| | | |||||
| * | base code to call a syscall from ARM11 appcore | bunnei | 2014-04-11 | 5 | -9/+85 |
| | | |||||
| * | updated logging message | bunnei | 2014-04-11 | 1 | -2/+2 |
| | | |||||
| * | cleaned up some logging messages | bunnei | 2014-04-11 | 5 | -32/+19 |
| | | |||||
| * | changed some naming/misc cleanups | bunnei | 2014-04-11 | 4 | -21/+20 |
| | | |||||
| * | - removed syscall classes (will just use HLEFunction) | bunnei | 2014-04-11 | 6 | -15/+54 |
| | | | | | | | | | | - added hle.cpp and module registration - removed unused code | ||||
| * | Merge branch 'master' into hle-interface | bunnei | 2014-04-11 | 1 | -8/+21 |
| |\ | |||||
| * | | added initial modules for setting up SysCall HLE | bunnei | 2014-04-11 | 7 | -0/+862 |
| | | | |||||
| * | | missed this file with commit 95e5436f | bunnei | 2014-04-11 | 1 | -1/+10 |
| | | | |||||
| * | | added Memory::GetCharPointer to read strings from HLE functions | bunnei | 2014-04-11 | 1 | -0/+4 |
| | | | |||||
| * | | cleaned up arm_interface, added a setter to set registers for use with HLE return values | bunnei | 2014-04-11 | 2 | -6/+70 |
| | | | |||||
* | | | Implement simple LoadSymbols for ELF files | Mathieu Vaillancourt | 2014-04-13 | 1 | -63/+13 |
| |/ |/| | |||||
* | | fixed a bunch of errors in CMakeLists | bunnei | 2014-04-10 | 1 | -1/+1 |
| | | |||||
* | | updated CMakeLists | bunnei | 2014-04-10 | 1 | -8/+21 |
|/ | |||||
* | fixed licensing and updated code style naming for arm_interface/arm_interpreter frontend module | bunnei | 2014-04-09 | 3 | -94/+57 |
| | |||||
* | fixed project includes to use new directory structure | bunnei | 2014-04-09 | 34 | -251/+255 |
| | |||||
* | got rid of 'src' folders in each sub-project | bunnei | 2014-04-09 | 48 | -0/+0 |
| | |||||
* | fixed some license headers that I missed | bunnei | 2014-04-09 | 2 | -46/+6 |
| | |||||
* | fixed all license file headers in core | bunnei | 2014-04-09 | 12 | -303/+44 |
| | |||||
* | fixed licensing issue with core_timing being GPL v2+ instead of Dolphin's GPL v2 | bunnei | 2014-04-09 | 2 | -487/+455 |
| | |||||
* | Merge branch 'hardware-interface' | bunnei | 2014-04-07 | 13 | -47/+386 |
|\ | | | | | | | | | Conflicts: src/core/src/core.h | ||||
| * | removed log message from hw_lcd | bunnei | 2014-04-07 | 1 | -2/+0 |
| | | |||||
| * | added hack physical memory reads with Memory::GetPointer | bunnei | 2014-04-07 | 1 | -2/+9 |
| | | |||||
| * | calling SwapBuffers from hw_lcd.cpp | bunnei | 2014-04-06 | 1 | -0/+2 |
| | | |||||
| * | initialize VideoCore | bunnei | 2014-04-06 | 1 | -2/+3 |
| | | |||||
| * | added g_app_core->Step and HW::Update to Core::SingleStep to be consistent with other changes made | bunnei | 2014-04-05 | 1 | -1/+5 |
| | | |||||
| * | changed hw_lcd to use ARM core correct tick counter instead of [what was actually] just an instruction count. this seems to fix timing issues with the 3DS_Homebrew_Pong3Dv2 demo. | bunnei | 2014-04-05 | 3 | -8/+48 |
| | | |||||
| * | add hw_lcd.* to VS project files | bunnei | 2014-04-05 | 2 | -0/+8 |
| | | |||||
| * | added an "Update" method to update all hardware | bunnei | 2014-04-05 | 2 | -0/+10 |
| | | |||||
| * | added a module for interfacing to hardware LCD | bunnei | 2014-04-05 | 2 | -0/+129 |
| | | |||||
| * | added a tick counter | bunnei | 2014-04-05 | 1 | -4/+12 |
| | | |||||
| * | added initial support for hw.cpp module | bunnei | 2014-04-05 | 8 | -52/+69 |
| | | |||||
| * | added hw module to interface h/w register reads/writes | bunnei | 2014-04-05 | 5 | -3/+118 |
| | | |||||
| * | renamed some functions | bunnei | 2014-04-05 | 1 | -11/+11 |
| | | |||||
* | | Remove Core::GetState(). Use new ARM_Interface instead. | Mathieu Vaillancourt | 2014-04-05 | 1 | -2/+0 |
|/ | |||||
* | added entry point loading from ELF file | bunnei | 2014-04-05 | 1 | -2/+4 |
| | |||||
* | - added an interface layer for ARM cores | bunnei | 2014-04-05 | 7 | -77/+213 |
| | | | | - cleaned up core.cpp a bit | ||||
* | renamed ARM disassembler class from "Arm" to "ARM_Disasm" | bunnei | 2014-04-05 | 2 | -27/+27 |
| | |||||
* | got rid of some really poorly named macros in SkyEye core | bunnei | 2014-04-05 | 3 | -9/+9 |
| | |||||
* | moved arm core to interpreter directory | bunnei | 2014-04-05 | 17 | -65/+71 |
| | |||||
* | added some commented out ARMulator functions | bunnei | 2014-04-04 | 1 | -20/+3 |
| | |||||
* | added hack to allow physical mem read/writes | bunnei | 2014-04-04 | 1 | -2/+20 |
| | |||||
* | made memory #define's enum to make debugging easier | bunnei | 2014-04-04 | 1 | -15/+21 |
| | |||||
* | Add Core::GetState() for debugger | Mathieu Vaillancourt | 2014-04-04 | 2 | -0/+9 |
| | |||||
* | removed some useless log messages | bunnei | 2014-04-04 | 1 | -2/+0 |
| | |||||
* | added thumb mode emulation | bunnei | 2014-04-04 | 6 | -4/+522 |
| | |||||
* | convert tabs to spaces | bunnei | 2014-04-02 | 10 | -6796/+6796 |
| | |||||
* | -converted tabs to spaces | bunnei | 2014-04-02 | 2 | -149/+145 |
| | | | | -moved scratchpad memory out of MemArena | ||||
* | added very hackish ARMulator core initialization and CPU stepping | bunnei | 2014-04-01 | 1 | -6/+97 |
| | |||||
* | added ELF loading support to loader.cpp | bunnei | 2014-04-01 | 1 | -69/+113 |
| | |||||
* | commented out bswap stuff... ARM ELF files are little endian anyway | bunnei | 2014-04-01 | 1 | -9/+10 |
| | |||||
* | added support for reading/writing to stack mem | bunnei | 2014-04-01 | 3 | -17/+40 |
| | |||||
* | replaced some error logs with debug asserts | bunnei | 2014-03-30 | 1 | -4/+2 |
| | |||||
* | removed unnecessary debug assert | bunnei | 2014-03-30 | 1 | -1/+0 |
| | |||||
* | added ARM11 MMU from skyeye | bunnei | 2014-03-30 | 6 | -145/+116 |
| | |||||
* | initialize mem regions | bunnei | 2014-03-30 | 1 | -0/+2 |
| | |||||
* | added various arm modules from skyeye to make project link OK | bunnei | 2014-03-30 | 9 | -166/+2582 |
| | |||||
* | added a GetPointer function to Memory for use with ELF loading | bunnei | 2014-03-25 | 3 | -30/+33 |
| | |||||
* | updated Windows project files to include ELF files | bunnei | 2014-03-25 | 2 | -0/+7 |
| | |||||
* | added Dolphin's ELF reader to the project | bunnei | 2014-03-25 | 3 | -0/+594 |
| | |||||
* | renamed FILETYPE_CTR_DIRECTORY to FILETYPE_DIRECTORY_CXI | ShizZy | 2013-10-06 | 2 | -12/+10 |
| | |||||
* | fixed a typo in declaration of meta file system | ShizZy | 2013-10-06 | 1 | -2/+2 |
| | |||||
* | moved some core functions over to system module | ShizZy | 2013-10-03 | 4 | -13/+11 |
| | |||||
* | added core_timing and system modules to core vcproj | ShizZy | 2013-10-02 | 6 | -2/+823 |
| | |||||
* | added an early function for booting from a directory | ShizZy | 2013-10-02 | 2 | -16/+35 |
| | |||||
* | added a message option to Core::Halt function | ShizZy | 2013-10-02 | 2 | -2/+2 |
| | |||||
* | upgraded proj files to vs 2013 | ShizZy | 2013-09-27 | 1 | -1/+5 |
| | |||||
* | added system.h to project | ShizZy | 2013-09-27 | 5 | -22/+87 |
| | |||||
* | added meta_file_system to project | ShizZy | 2013-09-26 | 4 | -0/+637 |
| | |||||
* | renamed file_sys_directory.* to directory_file_system.* | ShizZy | 2013-09-26 | 4 | -5/+5 |
| | |||||
* | moved file_sys back to core | ShizZy | 2013-09-26 | 5 | -0/+982 |
| | |||||
* | removed <windows.h> include from common.h and added it only where needed | ShizZy | 2013-09-24 | 1 | -0/+4 |
| | |||||
* | moved file_sys to common | ShizZy | 2013-09-24 | 5 | -982/+0 |
| | |||||
* | removed unused commented-out code | ShizZy | 2013-09-24 | 1 | -154/+0 |
| | |||||
* | renamed PSPFileInfo to just FileInfo | ShizZy | 2013-09-24 | 3 | -21/+21 |
| | |||||
* | added PPSSPP's file system directory module for game loading | ShizZy | 2013-09-24 | 3 | -10/+138 |
| | |||||
* | ppsspp file system module - currently unused | ShizZy | 2013-09-20 | 3 | -0/+1008 |
| | |||||
* | added a module for loading bootable binaries | ShizZy | 2013-09-20 | 4 | -0/+203 |
| | |||||
* | added mem_map hardware writing | ShizZy | 2013-09-20 | 3 | -75/+76 |
| | |||||
* | added hw R/W/ memory functions | ShizZy | 2013-09-19 | 5 | -3/+161 |
| | |||||
* | refactored some mem_map stuff | ShizZy | 2013-09-19 | 2 | -19/+36 |
| | |||||
* | added log msg to core | ShizZy | 2013-09-19 | 1 | -0/+2 |
| | |||||
* | added ARMulator/skyeye ARM11 core to the project | ShizZy | 2013-09-18 | 18 | -0/+11356 |
| | |||||
* | renamed project to 'citrus' | ShizZy | 2013-09-14 | 4 | -4/+4 |
| | |||||
* | cleaned up VS project files | ShizZy | 2013-09-09 | 1 | -52/+7 |
| | |||||
* | updated common paths | ShizZy | 2013-09-08 | 1 | -0/+2 |
| | |||||
* | start of 3DS memory map | ShizZy | 2013-09-06 | 2 | -4/+77 |
| | |||||
* | added core and mem_map files to the project | ShizZy | 2013-09-06 | 6 | -2/+232 |
| | |||||
* | added an ARM disassembler from the android project | ShizZy | 2013-09-05 | 4 | -0/+1175 |
| | |||||
* | added missing files | ShizZy | 2013-09-05 | 1 | -0/+2 |
| | |||||
* | various fixes to be able to build project | ShizZy | 2013-09-05 | 1 | -16/+19 |
| | |||||
* | adding initial project layout | ShizZy | 2013-08-30 | 2 | -0/+196 |