Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Build: Fixed some MSVC warnings in various parts of the code. | Subv | 2018-06-20 | 1 | -2/+2 |
| | |||||
* | 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 |
| | | |||||
* | | 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. | ||||
* | | 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 & correct miscellaneous things (#470) | greggameplayer | 2018-05-26 | 1 | -0/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | * add some InfoType * correct OpenApplicationProxy cmd number * add IDisplayController functions * fix clang-format * add more system languages | ||||
* | | 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 |
| | | | |||||
* | | | 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. | ||||
* / / | Added RequestWithContext & ControlWithContext | David Marcec | 2018-05-17 | 1 | -1/+3 |
|/ / | |||||
* | | thread: Rename mask to affinity_masks. | bunnei | 2018-05-11 | 3 | -4/+4 |
| | | |||||
* | | 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 | 2 | -3/+3 |
| | | |||||
* | | 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: Implement multicore support. | bunnei | 2018-05-11 | 5 | -45/+65 |
| | | |||||
* | | Merge pull request #431 from lioncash/fmt | bunnei | 2018-05-02 | 6 | -49/+50 |
|\ \ | | | | | | | general: Make formatting of logged hex values more straightforward | ||||
| * | | general: Make formatting of logged hex values more straightforward | Lioncash | 2018-05-02 | 6 | -49/+50 |
| | | | | | | | | | | | | | | | | | | 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 | 2 | -0/+15 |
|/ / | | | | | | | - This can be used for domain objects as inputs to service functions. | ||||
* | | GetSharedFontInOrderOfPriority (#381) | David | 2018-05-01 | 2 | -23/+27 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * 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 | 2 | -3/+5 |
| | | | | | | | | 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 | 1 | -1/+1 |
| | | | | | | | | Given we utilize fmt, we don't need to provide our own functions for formatting anymore | ||||
* | | 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 | 4 | -9/+9 |
| | | |||||
* | | 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 #370 from Subv/sync_primitives | bunnei | 2018-04-23 | 9 | -435/+228 |
|\ \ | | | | | | | 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 | 1 | -1/+1 |
| | | | |||||
| * | | Qt: Update the WaitTree widget to show info about the current mutex of each thread. | Subv | 2018-04-21 | 1 | -4/+0 |
| | | | |||||
| * | | Kernel: Remove unused ConditionVariable class. | Subv | 2018-04-21 | 5 | -148/+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. | ||||
* | | | resource_limit: Make ResourceTypes an enum class | Lioncash | 2018-04-21 | 3 | -38/+38 |
|/ / | | | | | | | Prevents enum identifiers from leaking into the surrounding scope. | ||||
* | | 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. | ||||
* | | Various service name fixes - part 2 (rebased) (#322) | Hexagon12 | 2018-04-17 | 1 | -8/+8 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * 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 | ||||
* | | vm_manager: Increase GetTotalMemoryUsage value. | bunnei | 2018-04-15 | 1 | -1/+1 |
| | | | | | | | | - Gets Binding of Isaac running. | ||||
* | | svc: Stub out SetThreadActivity, GetThreadContext. | bunnei | 2018-04-03 | 2 | -2/+19 |
| | | |||||
* | | shared_memory: Remove incorrect 3ds-specific check. | bunnei | 2018-04-03 | 1 | -12/+0 |
| | | |||||
* | | hle_ipc, fsp_srv: Cleanup logging. | bunnei | 2018-04-01 | 1 | -1/+1 |
| | | |||||
* | | hle_ipc: Do not ensure write buffer size. | bunnei | 2018-03-31 | 1 | -2/+5 |
| | | |||||
* | | memory: Fix stack region. | bunnei | 2018-03-31 | 2 | -3/+4 |
| | | |||||
* | | svc: Stub GetThreadCoreMask. | bunnei | 2018-03-30 | 2 | -3/+26 |
| | | |||||
* | | Clang Fixes | N00byKing | 2018-03-19 | 2 | -5/+5 |
| | | |||||
* | | More Warning cleanups | N00byKing | 2018-03-19 | 2 | -2/+2 |
| | | |||||
* | | Clean Warnings (?) | N00byKing | 2018-03-19 | 5 | -8/+8 |
| | | |||||
* | | 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 | 2 | -5/+13 |
| | | |||||
* | | thread: Add THREADSTATUS_WAIT_HLE_EVENT, remove THREADSTATUS_WAIT_ARB. | bunnei | 2018-03-19 | 3 | -20/+6 |
| | | |||||
* | | 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 | 1 | -0/+3 |
| | | |||||
* | | 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 | 3 | -8/+3 |
| | | |||||
* | | 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 |
| | | |||||
* | | core: Move process creation out of global state. | bunnei | 2018-03-14 | 9 | -33/+36 |
| | | |||||
* | | Merge pull request #216 from Subv/savedata | bunnei | 2018-03-02 | 2 | -9/+8 |
|\ \ | | | | | | | Implemented the SaveData archive and MountSaveData. | ||||
| * | | Kernel: Store the program id in the Process class instead of the CodeSet class. | Subv | 2018-03-02 | 2 | -9/+8 |
| |/ | | | | | | | There may be many CodeSets per Process, so it's wasteful and overcomplicated to store the program id in each of them. | ||||
* / | 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 | 2 | -5/+10 |
|\ | | | | | 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 | 2 | -2/+2 |
| | | |||||
| * | IPC: add domain header to response if only it exists in request | mailwl | 2018-02-20 | 2 | -5/+7 |
| | | |||||
* | | 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 | ||||
* / | Stub more functions | mailwl | 2018-02-22 | 1 | -1/+11 |
|/ | |||||
* | scheduler: Cleanup based on PR feedback. | bunnei | 2018-02-19 | 2 | -4/+3 |
| | |||||
* | kernel: Use Scheduler class for threading. | bunnei | 2018-02-18 | 3 | -172/+16 |
| | |||||
* | kernel: Add Scheduler, which encapsulates the scheduling loading from Thread module. | bunnei | 2018-02-18 | 2 | -0/+208 |
| | |||||
* | kernel: Remove unused address_arbiter code. | bunnei | 2018-02-18 | 4 | -197/+0 |
| | |||||
* | 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. | ||||
* | Service/hid: stub some functions | mailwl | 2018-02-16 | 2 | -0/+53 |
| | |||||
* | shared_memory: Remove some checks. | bunnei | 2018-02-15 | 1 | -13/+0 |
| | |||||
* | Merge pull request #188 from bunnei/refactor-buffer-descriptor | bunnei | 2018-02-15 | 2 | -0/+59 |
|\ | | | | | 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 |
| | | |||||
| * | 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 | 2 | -0/+51 |
| | | |||||
* | | 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 |
|/ | |||||
* | mutex: Update hasWaiters on release. | bunnei | 2018-02-06 | 1 | -0/+1 |
| | |||||
* | 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 |
| | |||||
* | shared_memory: Only mark addresses as invalid if they are within the heap | shinyquagsire23 | 2018-01-30 | 1 | -1/+2 |
| | |||||
* | Merge pull request #148 from MerryMage/feature/special-memory | bunnei | 2018-01-27 | 2 | -6/+6 |
|\ | | | | | memory: Replace all memory hooking with Special regions | ||||
| * | memory: Replace all memory hooking with Special regions | MerryMage | 2018-01-27 | 2 | -6/+6 |
| | | |||||
* | | 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 | 1 | -1/+1 |
| | | |||||
* | | ipc_helpers: Make interface domain agnostic and add header validation. | bunnei | 2018-01-25 | 1 | -1/+12 |
| | | |||||
* | | hle: Integrate Domain handling into ServerSession. | bunnei | 2018-01-25 | 5 | -28/+66 |
| | | |||||
* | | hle: Remove Domain and SyncObject kernel objects. | bunnei | 2018-01-25 | 7 | -164/+2 |
| | | |||||
* | | handle_table: Remove ConvertSessionToDomain. | bunnei | 2018-01-25 | 2 | -17/+0 |
|/ | |||||
* | Format: Run the new clang format on everything | James Rowe | 2018-01-21 | 22 | -31/+32 |
| | |||||
* | Added CreateSharedMemory & UNIMPLEMENTED() for non existent services. (#113) | David | 2018-01-20 | 2 | -1/+22 |
| | | | | | | | | | | | | * 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 | 2 | -2/+2 |
| | | | | | | | | * Fixes some cast warnings, partially fixes citra #3064 * Converted casts to uint32_t to u32 * Ran clang-format | ||||
* | 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 |
| | |||||
* | Stub PopLaunchParameter and implement Buffer C Descriptors reading on hle_ipc (#96) | gdkchan | 2018-01-18 | 2 | -7/+33 |
| | | | | | | | | | | * Stub PopLaunchParameter and implement Buffer C Descriptors reading * Address PR feedback * Ensure we push a u64 not a size_t * Fix formatting | ||||
* | 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 | ||||
* | svc: Clang-format fix. | bunnei | 2018-01-17 | 1 | -6/+4 |
| | |||||
* | hle_ipc: Clang format. | bunnei | 2018-01-17 | 1 | -2/+3 |
| | |||||
* | ipc: Implement domain command CloseVirtualHandle. | bunnei | 2018-01-17 | 2 | -2/+28 |
| | |||||
* | 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 | 1 | -0/+8 |
| | |||||
* | Merge pull request #52 from ogniK5377/fsp | bunnei | 2018-01-17 | 4 | -3/+35 |
|\ | | | | | 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 | ||||
| * | SetThreadCoreMask stub, time to implement fsp | David Marcec | 2018-01-16 | 1 | -1/+6 |
| | | |||||
| * | Added more svcGetInfo pairs | David Marcec | 2018-01-16 | 4 | -2/+29 |
| | | |||||
* | | clang-format | MerryMage | 2018-01-16 | 6 | -18/+14 |
|/ | |||||
* | 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 |
| | |||||
* | yuzu: Update license text to be consistent across project. | bunnei | 2018-01-13 | 14 | -14/+14 |
| | |||||
* | core: Include <algorithm> where used. | bunnei | 2018-01-12 | 1 | -0/+2 |
| | |||||
* | core: Fix recent GCC build breaks. | bunnei | 2018-01-12 | 1 | -2/+2 |
| | |||||
* | svc: Implement GetSystemTick. | bunnei | 2018-01-12 | 2 | -2/+21 |
| | |||||
* | IPC: Corrected some definitions for the buffer C descriptor flags. | Subv | 2018-01-11 | 2 | -1/+8 |
| | |||||
* | 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 |
| | |||||
* | 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 | 8 | -159/+167 |
| | |||||
* | 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 |
| | |||||
* | CoreTiming: Reworked CoreTiming (cherry-picked from Citra #3119) | B3n30 | 2018-01-09 | 2 | -9/+5 |
| | | | | * CoreTiming: New CoreTiming; Add Test for CoreTiming | ||||
* | IPC: Add functions to read the input move/copy objects from an IPC request. | Subv | 2018-01-07 | 2 | -2/+26 |
| | |||||
* | 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 | 2 | -74/+72 |
| | | | | 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 | 1 | -1/+2 |
| | | | | 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 | 2 | -3/+7 |
| | | | | 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 |
| | |||||
* | svc: Implement svcWaitProcessWideKeyAtomic. | bunnei | 2018-01-06 | 2 | -1/+54 |
| | |||||
* | semaphore: Updates for Switch. | bunnei | 2018-01-06 | 2 | -21/+31 |
| | |||||
* | 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 |
| | |||||
* | svc: Add missing string_util include. | bunnei | 2018-01-05 | 1 | -0/+1 |
| | |||||
* | arm: Remove SkyEye/Dyncom code that is ARMv6-only. | bunnei | 2018-01-03 | 2 | -23/+11 |
| | |||||
* | 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 |
| | |||||
* | hle: Move SVC code to kernel namespace. | bunnei | 2018-01-03 | 3 | -0/+805 |
| | |||||
* | vm_manager: Stub out a bunch of interfaces used by svcGetInfo. | bunnei | 2018-01-01 | 2 | -1/+51 |
| | |||||
* | core/video_core: Fix a bunch of u64 -> u32 warnings. | bunnei | 2018-01-01 | 1 | -2/+2 |
| | |||||
* | svc: Implement svcExitProcess. | bunnei | 2018-01-01 | 2 | -7/+38 |
| | |||||
* | svc: Implement svcLockMutex. | bunnei | 2018-01-01 | 2 | -23/+95 |
| | |||||
* | kernel: Add ObjectAddressTable class. | bunnei | 2018-01-01 | 3 | -2/+101 |
| | |||||
* | thread: Keep track of the initially created handle. | bunnei | 2017-12-31 | 2 | -1/+5 |
| | | | | This is kinda crufty, but we need it for now to update guest state variables. | ||||
* | errors: Define missing kernel error codes. | bunnei | 2017-12-31 | 1 | -0/+3 |
| | |||||
* | svc: Implement svcUnmapMemory. | bunnei | 2017-12-31 | 2 | -0/+7 |
| | |||||
* | 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 |
| | |||||
* | kernel: Fix implementation of ConvertSessionToDomain. | bunnei | 2017-12-29 | 6 | -30/+67 |
| | |||||
* | kernel: Add basic support for Domain object. | bunnei | 2017-12-29 | 4 | -4/+110 |
| | |||||
* | kernel: Add SyncObject primitive, use it for ClientSession. | bunnei | 2017-12-29 | 2 | -8/+38 |
| | |||||
* | process: Add method to mirror a memory region. | bunnei | 2017-12-29 | 2 | -0/+27 |
| | |||||
* | service: Return proper result code for IPC::CommandType::Close. | bunnei | 2017-11-01 | 2 | -6/+7 |
| | |||||
* | hle: Use Switch formatted result codes. | bunnei | 2017-11-01 | 2 | -77/+22 |
| | |||||
* | hle: Fix QueryMemory response for MemoryInfo. | bunnei | 2017-10-20 | 4 | -115/+14 |
| | |||||
* | 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 |
| | |||||
* | hle: Implement ConvertSessionToDomain, various cleanups. | bunnei | 2017-10-15 | 3 | -5/+31 |
| | |||||
* | hle: Initial implementation of NX service framework and IPC. | bunnei | 2017-10-15 | 2 | -70/+107 |
| | |||||
* | Merge remote-tracking branch 'upstream/master' into nx | bunnei | 2017-10-10 | 18 | -103/+143 |
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # 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 | ||||
| * | 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 | 2 | -0/+12 |
| |\ \ | | |/ | |/| | Memory: Add overloads for ReadBlock and WriteBlock that operate on a specific process. | ||||
| | * | Kernel/Thread: Added a helper function to get a thread's command buffer VAddr. | Subv | 2017-10-01 | 2 | -0/+12 |
| | | | |||||
| * | | Merge pull request #2967 from Subv/thread_wakeup_callbacks | Sebastian Valle | 2017-09-30 | 3 | -13/+26 |
| |\ \ | | |/ | |/| | 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 | 3 | -13/+26 |
| | | | | | | | | | | | | | | | | | | 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 | 9 | -23/+24 |
| | | | |||||
| * | | Kernel/Thread: Allow specifying which process a thread belongs to when creating it. | Subv | 2017-09-27 | 3 | -15/+19 |
| |/ | | | | | | | 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: Add GetCurrentPageTable/SetCurrentPageTable | MerryMage | 2017-09-24 | 1 | -7/+4 |
| | | | | | | | | Don't expose Memory::current_page_table as a global. | ||||
| * | Merge pull request #2842 from Subv/switchable_page_table | B3n30 | 2017-09-15 | 5 | -30/+33 |
| |\ | | | | | | | Kernel/Memory: Give each process its own page table and allow switching the current page table upon reschedule | ||||
| | * | 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 | 2 | -25/+7 |
| | | | |||||
| | * | 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 | 2 | -5/+14 |
| | | | | | | | | | | | | 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 #2839 from Subv/global_kernel_lock | James Rowe | 2017-08-24 | 1 | -1/+1 |
| |\ \ | | | | | | | | | 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/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 | 1 | -1/+1 |
| | | | | | | | | | | | | | | | | 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. | ||||
| * / | | Warnings: Add UNREACHABLE macros to switches that contemplate all possible values. | Subv | 2017-08-21 | 1 | -0/+3 |
| |/ / | |||||
* | | | loader: Various improvements for NSO/NRO loaders. | bunnei | 2017-10-10 | 2 | -4/+4 |
| | | | |||||
* | | | nso: Refactor and allocate .bss section. | bunnei | 2017-09-30 | 2 | -8/+10 |
| | | | |||||
* | | | process: Support loading multiple codesets. | bunnei | 2017-09-30 | 2 | -20/+27 |
| | | | |||||
* | | | 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 | 2 | -21/+21 |
|/ / | |||||
* | | Merge pull request #2799 from yuriks/virtual-cached-range-flush | Weiyi Wang | 2017-07-22 | 1 | -1/+1 |
|\ \ | |/ |/| | Add address conversion functions returning optional, Add function to flush virtual region from rasterizer cache | ||||
| * | Memory: Make PhysicalToVirtualAddress return a boost::optional | Yuri Kunde Schlesner | 2017-06-22 | 1 | -1/+1 |
| | | | | | | | | And fix a few places in the code to take advantage of that. | ||||
* | | Merge pull request #2793 from Subv/replyandreceive | Sebastian Valle | 2017-06-30 | 4 | -11/+39 |
|\ \ | | | | | | | Kernel/SVC: Partially implemented svcReplyAndReceive | ||||
| * | | Kernel/SVC: Pass the current thread as a parameter to ClientSession::SendSyncRequest. | Subv | 2017-06-29 | 2 | -3/+6 |
| | | | |||||
| * | | 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/ServerSession: Keep track of which threads have issued sync requests. | Subv | 2017-06-25 | 3 | -9/+29 |
| | | | |||||
* | | | Kernel: Implement AcceptSession SVC | Yuri Kunde Schlesner | 2017-06-23 | 3 | -2/+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 | 1 | -0/+2 |
|\ \ | | | | | | | Trivial no-op additions | ||||
| * | | 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 | 4 | -7/+7 |
|\ \ | | | | | | | Remove ResultVal::MoveFrom | ||||
| * | | ResultVal: Remove MoveFrom() | Yuri Kunde Schlesner | 2017-06-19 | 4 | -7/+7 |
| |/ | | | | | | | | | Replace it with std::move(result_val).Unwrap(), or Foo().Unwrap() in case you already have an rvalue. | ||||
* / | Kernel/IPC: Make HLERequestContext usable from outside kernel | Yuri Kunde Schlesner | 2017-06-19 | 2 | -3/+9 |
|/ | |||||
* | 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 | 2 | -0/+11 |
| | | | | | 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 | 2 | -6/+125 |
| | |||||
* | 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 | 1 | -3/+6 |
| | | | | | | 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 | 2 | -6/+42 |
|\ | | | | | New service framework | ||||
| * | Service: Add new ServiceFramework framework for writing HLE services | Yuri Kunde Schlesner | 2017-06-08 | 2 | -2/+36 |
| | | | | | | | | | | | | | | | | | | | | | | | | 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 | ||||
* | Kernel: Add a dedicated SetHleHandler method to ServerPort/ServerSession | Yuri Kunde Schlesner | 2017-06-06 | 7 | -33/+36 |
| | | | | | | 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. | ||||
* | HLE: Move SessionRequestHandler from Service:: to Kernel:: | Yuri Kunde Schlesner | 2017-06-06 | 8 | -15/+90 |
| | | | | | 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. | ||||
* | Kernel: Move HandleTable to a separate file | Yuri Kunde Schlesner | 2017-05-30 | 13 | -202/+234 |
| | |||||
* | Kernel: Move WaitObject to a separate file | Yuri Kunde Schlesner | 2017-05-30 | 11 | -132/+173 |
| | | | | | 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 | 1 | -9/+0 |
| | | | | | 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 |
| | |||||
* | Kernel: Centralize error definitions in errors.h | Yuri Kunde Schlesner | 2017-05-25 | 13 | -46/+133 |
| | |||||
* | Merge pull request #2406 from Subv/session_disconnect | Yuri Kunde Schlesner | 2017-05-22 | 6 | -51/+82 |
|\ | | | | | 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 | 6 | -32/+84 |
| | | | | | | | | Reduce the associated port's connection count when a ServerSession is destroyed. | ||||
* | | Kernel: Map special regions according to ExHeader | Yuri Kunde Schlesner | 2017-05-10 | 4 | -50/+102 |
| | | | | | | | | | | | | | | 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. | ||||
* | Timer: restore missing signaled=true from #2421 | wwylele | 2017-02-27 | 1 | -0/+2 |
| | |||||
* | Fix log entry in timer::signal (#2600) | B3n30 | 2017-02-27 | 1 | -1/+1 |
| | |||||
* | Doxygen: Amend minor issues (#2593) | Mat M | 2017-02-27 | 1 | -1/+2 |
| | | | | | | | | | 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 | 2 | -1/+1 |
|\ | | | | | Replace built-in Profiler with indicators in status bar | ||||
| * | Core: Remove unnecessary include in thread.h | Yuri Kunde Schlesner | 2017-02-27 | 2 | -1/+1 |
| | | |||||
* | | Timers: Immediately signal the timer if it was started with an initial value of 0. | Subv | 2017-02-22 | 2 | -16/+31 |
|/ | |||||
* | 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 | 1 | -8/+2 |
| | |||||
* | Thread: Added priority range checking to svcSetThreadPriority and removed priority clamping code from Thread::SetPriority. | Subv | 2017-01-11 | 2 | -18/+4 |
| | |||||
* | 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 #2410 from Subv/sleepthread | bunnei | 2017-01-07 | 2 | -0/+9 |
|\ \ | | | | | | | 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 | 2 | -0/+9 |
| | | | | | | | | | | | | 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. | ||||
* | | | 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 |
|/ / | |||||
* | | 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 | 3 | -10/+19 |
| | | |||||
* | | Kernel: Use different thread statuses when a thread calls WaitSynchronization1 and WaitSynchronizationN with wait_all = true. | Subv | 2017-01-04 | 2 | -13/+17 |
| | | | | | | | | | | | | | | | | 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 | 4 | -42/+54 |
| | | |||||
* | | Kernel/Mutex: Update a mutex priority when a thread stops waiting on it. | Subv | 2017-01-04 | 4 | -22/+39 |
| | | |||||
* | | Kernel/Mutex: Implemented priority inheritance. | Subv | 2017-01-04 | 4 | -22/+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 | 16 | -62/+50 |
| | | | | | | | | This will be useful when implementing mutex priority inheritance. | ||||
* | | Kernel/Synch: Do not attempt a reschedule on every syscall. | Subv | 2017-01-04 | 1 | -0/+1 |
|/ | | | | Not all syscalls should cause reschedules, this commit attempts to remedy that, however, it still does not cover all cases. | ||||
* | ThreadContext: Move from "core" to "arm_interface". | bunnei | 2016-12-22 | 2 | -4/+5 |
| | |||||
* | core: Replace "AppCore" nomenclature with just "CPU". | bunnei | 2016-12-22 | 1 | -3/+3 |
| | |||||
* | core: Remove HLE module, consolidate code & various cleanups. | bunnei | 2016-12-22 | 4 | -7/+3 |
| | |||||
* | core: Consolidate core and system state, remove system module & cleanups. | bunnei | 2016-12-22 | 1 | -3/+3 |
| | |||||
* | Thread: remove the thread from the thread list when exiting | wwylele | 2016-12-17 | 2 | -2/+14 |
| | |||||
* | 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 | 6 | -115/+102 |
|\ | | | | | Threading: Reworked the way our scheduler works. | ||||
| * | Fixed the codestyle to match our clang-format rules. | Subv | 2016-12-14 | 2 | -8/+11 |
| | | |||||
| * | Properly remove a thread from its wait_objects' waitlist when it is awoken by a timeout. | Subv | 2016-12-10 | 2 | -1/+10 |
| | | |||||
| * | WaitSynch: Removed unused variables and reduced SharedPtr copies. | Subv | 2016-12-09 | 3 | -13/+11 |
| | | | | | | | | | | | | 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 | 2 | -10/+22 |
| | | |||||
| * | Threading: Reworked the way our scheduler works. | Subv | 2016-12-04 | 6 | -111/+76 |
| | | | | | | | | | | | | | | | | | | | | 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. | ||||
* | | Fixed the codestyle to match our clang-format rules. | Subv | 2016-12-14 | 7 | -33/+51 |
| | | |||||
* | | Moved the HLE command buffer translation task to ServerSession instead of the HLE handler superclass. | Subv | 2016-12-09 | 2 | -2/+23 |
| | | |||||
* | | Added a framework for partially handling Session disconnections. | Subv | 2016-12-08 | 4 | -9/+35 |
| | | | | | | | | | | | | Further implementation will happen in a future commit. Fixes a regression. | ||||
* | | Use std::move where appropriate. | Subv | 2016-12-08 | 5 | -7/+13 |
| | | |||||
* | | Return an error code when connecting to a saturated port. | Subv | 2016-12-05 | 2 | -4/+11 |
| | | | | | | | | The error code was taken from the 3DS kernel. | ||||
* | | Split SessionRequestHandler::HandleSyncRequest into HandleSyncRequest, TranslateRequest and HandleSyncRequestImpl. | Subv | 2016-12-05 | 2 | -0/+2 |
| | | | | | | | | 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 | 8 | -35/+60 |
| | | |||||
* | | Declare empty ServerSession and ClientSession constructors as default. | Subv | 2016-12-03 | 2 | -4/+4 |
| | | |||||
* | | Fixed the rebase mistakes. | Subv | 2016-12-01 | 7 | -51/+46 |
| | | |||||
* | | A bit of a redesign. | Subv | 2016-12-01 | 6 | -215/+24 |
| | | | | | | | | | | | | | | 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 | 4 | -22/+15 |
| | | | | | | | | 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 | 2 | -8/+44 |
| | | | | | | | | 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 | 3 | -4/+5 |
| | | |||||
* | | Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication. | Subv | 2016-12-01 | 7 | -56/+233 |
|/ | | | | | | | 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. | ||||
* | Merge pull request #2196 from Subv/system_mode | Yuri Kunde Schlesner | 2016-11-28 | 2 | -6/+4 |
|\ | | | | | Kernel/Loader: Grab the system mode from the NCCH ExHeader. | ||||
| * | Kernel/Loader: Grab the system mode from the NCCH ExHeader. | Subv | 2016-11-20 | 2 | -6/+4 |
| | | | | | | | | | | | | | | 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/Events: Log an error when trying to create Pulse events and timers. | Subv | 2016-11-19 | 2 | -0/+10 |
|/ | | | | Related to #1904 | ||||
* | Fix typos | Ricardo de Almeida Gonzaga | 2016-10-20 | 2 | -2/+2 |
| | |||||
* | move ResetType to kernel.h | wwylele | 2016-09-22 | 3 | -7/+6 |
| | |||||
* | implement wait tree widget | wwylele | 2016-09-22 | 4 | -0/+16 |
| | |||||
* | Use negative priorities to avoid special-casing the self-include | Yuri Kunde Schlesner | 2016-09-21 | 14 | -14/+14 |
| | |||||
* | Remove empty newlines in #include blocks. | Emmanuel Gil Peyrot | 2016-09-21 | 29 | -74/+16 |
| | | | | | | | 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 | 15 | -64/+36 |
| | |||||
* | Sources: Run clang-format on everything. | Emmanuel Gil Peyrot | 2016-09-18 | 30 | -419/+616 |
| | |||||
* | arm: ResetContext shouldn't be part of ARM_Interface. | bunnei | 2016-09-15 | 1 | -1/+17 |
| | |||||
* | fix #1942 and adds a few IPC functions for descriptors | Lectem | 2016-08-02 | 1 | -15/+103 |
| | |||||
* | 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 | 1 | -0/+4 |
|\ \ | | | | | | | srv: Update according 3dbrew | ||||
| * | | Fix parameter name in EnableNotification | mailwl | 2016-05-31 | 1 | -0/+4 |
| |/ | |||||
* | | 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 |
| |/ | |||||
* | | Kernel/SVC: Implemented svcCreatePort. | Subv | 2016-06-11 | 4 | -2/+11 |
| | | |||||
* | | Kernel: Added ClientPort and ServerPort classes. | Subv | 2016-06-05 | 5 | -2/+135 |
|/ | | | | This is part of an ongoing effort to implement support for multiple processes. | ||||
* | Merge pull request #1692 from Subv/rm_getpointer2 | bunnei | 2016-05-30 | 1 | -1/+1 |
|\ | | | | | Memory: Remove most usages of GetPointer | ||||
| * | Kernel/Thread: Remove use of Memory::GetPointer | MerryMage | 2016-05-21 | 1 | -1/+1 |
| | | |||||
* | | Memory: Added necessary headers and removed unnecessary header | MerryMage | 2016-05-26 | 1 | -0/+1 |
|/ | |||||
* | Merge pull request #1800 from JayFoxRox/set-fpscr | bunnei | 2016-05-18 | 1 | -0/+2 |
|\ | | | | | Set fpscr for new threads | ||||
| * | Set fpscr for new threads | Jannik Vogel | 2016-05-17 | 1 | -0/+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 | 4 | -67/+161 |
|\ | | | | | 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 | 2 | -1/+30 |
| | | |||||
| * | Kernel: Account for automatically-allocated shared memories in the amount of used linear heap memory. | Subv | 2016-05-13 | 1 | -0/+5 |
| | | |||||
| * | Kernel/SharedMemory: Log an error when Map fails. | Subv | 2016-05-13 | 1 | -1/+10 |
| | | |||||
| * | Kernel: Implemented shared memory permissions. | Subv | 2016-05-13 | 2 | -9/+47 |
| | | |||||
| * | 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 | 2 | -65/+79 |
| | | | | | | | | | | | | | | 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 | 1 | -1/+1 |
| | | | | | | | | R0 is used as the last parameter instead of R4. | ||||
* | | Merge pull request #1695 from Subv/tls_alloc | bunnei | 2016-05-13 | 4 | -22/+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 | 4 | -22/+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. | ||||
* | | Merge pull request #1766 from Subv/log_cpu | bunnei | 2016-05-08 | 1 | -0/+2 |
|\ \ | | | | | | | 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 | 1 | -0/+2 |
| |/ | | | | | | | We do not currently implement any cores other than the AppCore (Core 0). | ||||
* | | Merge pull request #1762 from bunnei/global | bunnei | 2016-05-06 | 1 | -1/+2 |
|\ \ | |/ |/| | hle: Get rid of direct global access to g_reschedule | ||||
| * | hle: Get rid of global access to g_reschedule | Lioncash | 2016-03-21 | 1 | -1/+2 |
| | | | | | | | | | | 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 #1643 from MerryMage/make_unique | Mathew Maidment | 2016-04-06 | 1 | -1/+2 |
|\ \ | | | | | | | Common: Remove Common::make_unique, use std::make_unique | ||||
| * | | Common: Remove Common::make_unique, use std::make_unique | MerryMage | 2016-04-05 | 1 | -1/+2 |
| |/ | |||||
* / | session: Make helper functions constexpr | Lioncash | 2016-03-21 | 1 | -6/+6 |
|/ | |||||
* | svc: Move ResetType enum to the kernel event header | Lioncash | 2016-03-13 | 2 | -2/+8 |
| | |||||
* | svc: Make ResetType an enum class | Lioncash | 2016-03-12 | 2 | -2/+2 |
| | |||||
* | Memory: Do correct Phys->Virt address translation for non-APP linheap | Yuri Kunde Schlesner | 2016-03-06 | 2 | -2/+5 |
| | |||||
* | AudioCore: Skeleton Implementation | MerryMage | 2016-02-21 | 1 | -1/+4 |
| | | | | | | | | | 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 | 1 | -1/+1 |
| | |||||
* | Memory: Implement MMIO | MerryMage | 2016-01-30 | 2 | -4/+8 |
| | |||||
* | HLE/SVC: Implement UnmapMemoryBlock. | Subv | 2016-01-14 | 2 | -0/+28 |
| | | | | This implementation will need to be (almost completely) changed when we implement multiprocess support. | ||||
* | HLE/Timers: Reset OneShot timers when they are acquired instead of when they're triggered. | Subv | 2015-12-30 | 1 | -3/+3 |
| | | | | Closes #1139 | ||||
* | 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. | ||||
* | Kernel: Implement svcGetSystemInfo | Yuri Kunde Schlesner | 2015-12-01 | 4 | -0/+12 |
| | | | | | This makes smealum/ctrulib@b96dd51d3349961189d4ab1bc2a5c45deff21c09 work with Citra. | ||||
* | Silence -Wsign-compare warnings. | Rohit Nirmal | 2015-10-07 | 1 | -1/+1 |
| | |||||
* | general: Silence some warnings when using clang | Lioncash | 2015-09-16 | 1 | -2/+4 |
| | |||||
* | General: Fix up doxygen comments | Lioncash | 2015-09-10 | 3 | -6/+3 |
| | |||||
* | 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 | 2 | -2/+27 |
| | | | | Should fix invalid read loops in some games | ||||
* | Kernel: Remove unused legacy heap MapBlock_* functions | Yuri Kunde Schlesner | 2015-08-16 | 2 | -77/+0 |
| | |||||
* | Kernel: Implement svcGetProcessInfo in a basic way | Yuri Kunde Schlesner | 2015-08-16 | 3 | -1/+15 |
| | | | | | 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 | 5 | -20/+138 |
| | | | | | | 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. | ||||
* | Move core/mem_map.{cpp,h} => core/hle/kernel/memory.{cpp,h} | Yuri Kunde Schlesner | 2015-08-16 | 3 | -1/+160 |
| | |||||
* | Memory: Move address type conversion routines to memory.cpp/h | Yuri Kunde Schlesner | 2015-08-16 | 1 | -1/+0 |
| | | | | | 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 | 4 | -23/+243 |
| | |||||
* | 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 |
| | |||||
* | dyncom: Rename armdefs.h to armstate.h | Lioncash | 2015-07-26 | 1 | -1/+1 |
| | |||||
* | 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) | ||||
* | Ensure all kernel objects are released during shutdown | Yuri Kunde Schlesner | 2015-07-17 | 1 | -7/+14 |
| | | | | | | | | 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. | ||||
* | Merge pull request #921 from linkmauve/fix-applet | bunnei | 2015-07-12 | 2 | -0/+4 |
|\ | | | | | Fix applet includes using iwyu | ||||
| * | Core: Fix applet includes using iwyu. | Emmanuel Gil Peyrot | 2015-07-12 | 2 | -0/+4 |
| | | |||||
* | | Kernel: Add CodeSet case to Object::IsWaitable | Yuri Kunde Schlesner | 2015-07-12 | 1 | -0/+1 |
|/ | |||||
* | Core: Properly configure address space when loading a binary | Yuri Kunde Schlesner | 2015-07-12 | 5 | -14/+88 |
| | | | | | | 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. | ||||
* | Kernel: Remove unused member from Event | Yuri Kunde Schlesner | 2015-07-12 | 2 | -2/+1 |
| | |||||
* | Core: Cleanup file_sys includes. | Emmanuel Gil Peyrot | 2015-06-28 | 1 | -1/+2 |
| | |||||
* | Core: Cleanup core includes. | Emmanuel Gil Peyrot | 2015-06-28 | 2 | -1/+2 |
| | |||||
* | Common: Cleanup key_map includes. | Emmanuel Gil Peyrot | 2015-06-28 | 4 | -6/+10 |
| | |||||
* | Add helpers to create IPC command buffer headers and descriptors | Yuri Kunde Schlesner | 2015-06-23 | 1 | -0/+34 |
| | |||||
* | kernel: Fix svcWaitSynch to always acquire requested wait objects. | bunnei | 2015-06-17 | 7 | -101/+37 |
| | |||||
* | Merge pull request #810 from yuriks/memmap | Yuri Kunde Schlesner | 2015-05-30 | 2 | -0/+445 |
|\ | | | | | Kernel: Add VMManager to manage process address spaces | ||||
| * | Kernel: Add VMManager to manage process address spaces | Yuri Kunde Schlesner | 2015-05-27 | 2 | -0/+445 |
| | | | | | | | | | | | | | | | | 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 | 5 | -11/+11 |
|/ | |||||
* | 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 |
| | |||||
* | Kernel: Move reschedules from SVCs to actual mechanisms that reschedule. | bunnei | 2015-05-21 | 6 | -0/+20 |
| | |||||
* | Merge pull request #772 from lioncash/warn | bunnei | 2015-05-18 | 1 | -3/+3 |
|\ | | | | | core/video_core: Fix a few warnings when compiling on MSVC. | ||||
| * | process: Get rid of warnings | Lioncash | 2015-05-14 | 1 | -3/+3 |
| | | | | | | | | Sign mismatches and "forcing value to bool" warnings. | ||||
* | | Core/ResourceLimits: Implemented the basic structure of ResourceLimits. | Subv | 2015-05-15 | 6 | -1/+286 |
| | | | | | | | | | | | | 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. | ||||
* | | Memmap: Re-organize memory function in two files | Yuri Kunde Schlesner | 2015-05-15 | 6 | -6/+5 |
| | | | | | | | | | | | | | | 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. | ||||
* | | thread: Fix a conditional check in Reschedule | Lioncash | 2015-05-14 | 1 | -1/+1 |
|/ | |||||
* | Merge pull request #748 from Subv/tls_max | bunnei | 2015-05-12 | 3 | -7/+19 |
|\ | | | | | 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 | 3 | -7/+19 |
| | | |||||
* | | Merge pull request #751 from yuriks/idle-thread | bunnei | 2015-05-12 | 2 | -44/+19 |
|\ \ | | | | | | | Thread: Remove the idle thread | ||||
| * | | Thread: Remove the idle thread | Yuri Kunde Schlesner | 2015-05-12 | 2 | -44/+19 |
| | | | | | | | | | | | | 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 #750 from Subv/process_svc | Yuri Kunde Schlesner | 2015-05-12 | 5 | -2/+15 |
|\ \ | |/ |/| | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThread | ||||
| * | fixup! | Subv | 2015-05-12 | 2 | -7/+3 |
| | | |||||
| * | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThread | Subv | 2015-05-11 | 5 | -2/+19 |
| | | |||||
* | | 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 | 2 | -16/+37 |
|\ | | | | | Fix crashes due to un-initialized GSP shared memory | ||||
| * | 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 | 2 | -16/+29 |
| | | |||||
* | | fixup! Set the TLS address in the scheduler | Subv | 2015-05-11 | 2 | -2/+7 |
| | | |||||
* | | Core/Memory: Give every emulated thread it's own TLS area. | Subv | 2015-05-11 | 3 | -4/+22 |
|/ | | | | | 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. | ||||
* | Memory: Re-organize and rename memory area address constants | Yuri Kunde Schlesner | 2015-05-09 | 2 | -3/+4 |
| | |||||
* | 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 | 2 | -5/+5 |
| | |||||
* | 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 |
| | |||||
* | Process: Support parsing of exheader kernel caps | Yuri Kunde Schlesner | 2015-05-09 | 2 | -4/+72 |
| | |||||
* | Kernel: Remove g_program_id | Yuri Kunde Schlesner | 2015-05-09 | 2 | -8/+0 |
| | | | | This has been obsoleted by the field in Process. | ||||
* | Kernel: Introduce skeleton Process class to hold process data | Yuri Kunde Schlesner | 2015-05-09 | 4 | -19/+101 |
| | |||||
* | Common: Remove common.h | Yuri Kunde Schlesner | 2015-05-07 | 9 | -8/+14 |
| | |||||
* | Move typedefs from kernel.h to more appropriate places | Yuri Kunde Schlesner | 2015-05-07 | 1 | -10/+1 |
| | |||||
* | Kernel: Properly initialize and shutdown all modules. | bunnei | 2015-05-02 | 4 | -9/+20 |
| | |||||
* | Kernel: Use the correct format string for u64 hex. | Emmanuel Gil Peyrot | 2015-04-14 | 1 | -1/+1 |
| | |||||
* | SVC: Update various SVCs to cause a reschedule. | bunnei | 2015-04-10 | 1 | -4/+0 |
| | | | | - 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 | 2 | -22/+51 |
| | | | | | | SVC: Return correct error code on invalid CreateThread processor ID. SVC: Assert when creating a thread with an invalid userland priority. | ||||
* | 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 |
| | |||||
* | Misc cleanup of common and related functions | archshift | 2015-02-20 | 1 | -2/+3 |
| | |||||
* | Build: Fixed some warnings | Subv | 2015-02-12 | 3 | -4/+4 |
| | |||||
* | Asserts: break/crash program, fit to style guide; log.h->assert.h | archshift | 2015-02-11 | 7 | -15/+13 |
| | | | | | | | 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. | ||||
* | Scheduler refactor Pt. 1 | Kevin Hartman | 2015-02-10 | 3 | -223/+258 |
| | | | | | | | | | | | | | * 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. | ||||
* | Mutex: Locks should be recursive. | bunnei | 2015-02-10 | 2 | -16/+20 |
| | |||||
* | core: Fix some warnings on OSX | Lioncash | 2015-02-03 | 1 | -1/+0 |
| | |||||
* | Kernel: Stop creating useless Handles during object creation | Yuri Kunde Schlesner | 2015-02-02 | 12 | -36/+17 |
| | | | | | 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 | 16 | -8/+50 |
| | | | | | | 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 |
| | |||||
* | 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 |
| | |||||
* | Thread: Modernize two functions that slipped through previous rebases | Yuri Kunde Schlesner | 2015-02-02 | 3 | -15/+13 |
| | |||||
* | arm: Clean up ARMul_State | Lioncash | 2015-02-01 | 1 | -1/+1 |
| | | | | Remove unnecessary/unused struct variables. | ||||
* | shared_memory: Fix assignments in SharedMemory::Map | Lioncash | 2015-01-30 | 2 | -4/+4 |
| | |||||
* | Kernel: Mark all appropriate kernel objects as "final" | Yuri Kunde Schlesner | 2015-01-30 | 7 | -8/+7 |
| | |||||
* | Remove result.h InvalidHandle | Yuri Kunde Schlesner | 2015-01-30 | 1 | -1/+2 |
| | | | | | It was only being used in two places, where it was replaced by a local constant. | ||||
* | Kernel: Convert Event to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -83/+51 |
| | |||||
* | Kernel: Convert Timer to (mostly) not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -104/+72 |
| | |||||
* | Kernel: Convert Mutex to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -101/+82 |
| | |||||
* | Kernel: Convert AddressArbiter to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -32/+31 |
| | |||||
* | Kernel: Convert Semaphore to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -61/+61 |
| | |||||
* | Kernel: Convert SharedMemory to not use Handles | Yuri Kunde Schlesner | 2015-01-30 | 2 | -71/+54 |
| | |||||
* | Move VAddr/PAddr typedefs to kernel.h | Yuri Kunde Schlesner | 2015-01-30 | 1 | -0/+5 |
| | |||||
* | Kernel: Remove useless/duplicated comments; mark functions static | Yuri Kunde Schlesner | 2015-01-30 | 6 | -32/+8 |
| | |||||
* | Thread: Fix WaitSynchronization1 to not set register 1 on thread wakeup. | bunnei | 2015-01-22 | 2 | -22/+42 |
| | |||||
* | 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 | 8 | -64/+39 |
| | |||||
* | WaitObject: Renamed "Wait" to "ShouldWait", made "ShouldWait" and "Acquire" pure virtual. | bunnei | 2015-01-22 | 8 | -21/+20 |
| | |||||
* | 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 | 1 | -1/+1 |
| | |||||
* | 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 | 3 | -18/+57 |
| | |||||
* | AddressArbiter: Changed to Kernel::Object, big cleanup, removed code that made no sense. | bunnei | 2015-01-22 | 4 | -35/+42 |
| | |||||
* | Kernel: Get rid of WaitTypes and simplify lots of code, removing hacks. | bunnei | 2015-01-22 | 8 | -112/+43 |
| | |||||
* | WaitSynchronizationN: Refactor to fix several bugs | bunnei | 2015-01-22 | 7 | -54/+49 |
| | | | | | | - 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 | 7 | -14/+54 |
| | |||||
* | WaitSynchronizationN: Implement return values | bunnei | 2015-01-22 | 9 | -56/+139 |
| | |||||
* | Event: Fixed some bugs and cleanup (Subv) | bunnei | 2015-01-22 | 2 | -54/+13 |
| | |||||
* | 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 |
| | |||||
* | core: Fix a few docstrings | Lioncash | 2015-01-20 | 2 | -2/+2 |
| | |||||
* | AddrArbiter: Implement arbitration types 3 and 4. | Subv | 2015-01-13 | 2 | -3/+20 |
| | |||||
* | 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. | ||||
* | | Kernel: Start using boost::intrusive_ptr for lifetime management | Yuri Kunde Schlesner | 2015-01-09 | 10 | -76/+75 |
| | | |||||
* | | Kernel: Don't re-assign object's handle when duplicating one | Yuri Kunde Schlesner | 2015-01-09 | 2 | -2/+3 |
|/ | |||||
* | 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 | 9 | -281/+190 |
| | |||||
* | 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 | 2 | -4/+6 |
| | |||||
* | Merge pull request #255 from Subv/cbranch_3 | bunnei | 2015-01-09 | 5 | -1/+194 |
|\ | | | | | Implemented timers | ||||
| * | SVC: Implemented the Timer service calls. | Subv | 2015-01-09 | 5 | -1/+194 |
| | | |||||
* | | SVC: Fixed SleepThread. | Subv | 2015-01-09 | 2 | -8/+39 |
| | | | | | | | | It will now properly wait the specified number of nanoseconds and then wake up the thread. | ||||
* | | Threads: Use a dummy idle thread when no other are ready. | Subv | 2015-01-08 | 3 | -1/+35 |
| | | | | | | | | 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. | ||||
* | | 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 #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!) | ||||
* | | 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. | ||||
* | Kernel: New handle manager | Yuri Kunde Schlesner | 2014-12-28 | 9 | -142/+189 |
| | | | | | | | | | | | 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 | 8 | -41/+41 |
| | |||||
* | Merge pull request #291 from purpasmart96/license | bunnei | 2014-12-21 | 15 | -16/+16 |
|\ | | | | | License change | ||||
| * | License change | purpasmart96 | 2014-12-21 | 15 | -16/+16 |
| | | |||||
* | | Thread: Wait current thread on svc_SleepThread | bunnei | 2014-12-21 | 2 | -21/+33 |
| | | | | | | | | | | | | - 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. | ||||
* | | | Clean up some warnings | Chin | 2014-12-20 | 2 | -5/+5 |
| |/ |/| | |||||
* | | Merge pull request #185 from purpasmart96/mem_perm | bunnei | 2014-12-18 | 1 | -5/+9 |
|\ \ | | | | | | | Kernel: Add missing permissions | ||||
| * | | Kernel:Add missing permissions in shared memory & svc | purpasmart96 | 2014-11-19 | 1 | -5/+9 |
| | | | |||||
* | | | Filesystem/Archives: Implemented the SaveData archive | Subv | 2014-12-18 | 2 | -0/+7 |
| |/ |/| | | | | | | | | | | | | | | | | | 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 | ||||
* | | HLE: Rename namespaces to match move & fix initialization order | Yuri Kunde Schlesner | 2014-12-16 | 1 | -5/+0 |
| | | |||||
* | | HLE: Move kernel/archive.* to service/fs/ | Yuri Kunde Schlesner | 2014-12-16 | 3 | -534/+1 |
| | | |||||
* | | Remove SyncRequest from K::Object and create a new K::Session type | Yuri Kunde Schlesner | 2014-12-15 | 3 | -38/+75 |
| | | | | | | | | | | | | | | 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.) | ||||
* | | 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 | 2 | -16/+64 |
| | | | | | | | | 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 | 2 | -0/+98 |
| | | | | | | | | | | ToDo: Implement svcReleaseSemaphore * Some testing against hardware needed | ||||
* | | kernel: Remove unused log arguments | Lioncash | 2014-12-13 | 1 | -3/+3 |
| | | |||||
* | | Convert old logging calls to new logging macros | Yuri Kunde Schlesner | 2014-12-13 | 6 | -72/+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. | ||||
* | | | Thread: Fixed to wait on address when in arbitration. | bunnei | 2014-12-09 | 3 | -11/+31 |
| | | | |||||
* | | | Make OpenDirectory fail if the directory doesn't exist | archshift | 2014-12-07 | 1 | -0/+5 |
|/ / | | | | | | | | | | | | | 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 #250 from Subv/cbranch_2 | bunnei | 2014-12-05 | 2 | -0/+26 |
|\ \ | | | | | | | 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 | 2 | -0/+19 |
| | | | | | | | | | | | | 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 | 2 | -33/+74 |
|\ \ \ | | | | | | | | | Implemented RenameFile and RenameDirectory in FS:USER | ||||
| * | | | Updated archive.cpp functions for proper error handling | archshift | 2014-12-04 | 2 | -65/+36 |
| | | | | |||||
| * | | | Implemented RenameDirectory in FS:USER | archshift | 2014-11-25 | 2 | -0/+35 |
| | | | | |||||
| * | | | Implemented RenameFile in FS:USER | archshift | 2014-11-25 | 2 | -0/+35 |
| | | | | |||||
* | | | | 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 #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 |
| |/ / | |||||
* / / | Thread: Check that thread is actually in "wait state" when verifying wait. | bunnei | 2014-11-26 | 1 | -1/+1 |
|/ / | |||||
* | | 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 | 9 | -78/+0 |
| | | |||||
* | | HLE: Revamp error handling throrough the HLE code | Yuri Kunde Schlesner | 2014-11-24 | 13 | -201/+187 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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. | ||||
* | | Merge pull request #191 from archshift/deletexyz | bunnei | 2014-11-24 | 2 | -1/+47 |
|\ \ | | | | | | | 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 | 2 | -1/+47 |
| | | | |||||
* | | | Merge pull request #211 from linkmauve/master | bunnei | 2014-11-19 | 12 | -42/+42 |
|\ \ \ | | | | | | | | | Remove trailing spaces from the entire project | ||||
| * | | | Remove trailing spaces in every file but the ones imported from SkyEye, AOSP or generated | Emmanuel Gil Peyrot | 2014-11-19 | 12 | -42/+42 |
| | | | | |||||
* | | | | Merge pull request #208 from lioncash/statics | bunnei | 2014-11-19 | 1 | -22/+22 |
|\ \ \ \ | |/ / / |/| | | | Add static to some variables | ||||
| * | | | Add static to some variables | Lioncash | 2014-11-19 | 1 | -22/+22 |
| |/ / | |||||
* / / | Remove extraneous semicolons | Lioncash | 2014-11-18 | 1 | -1/+1 |
|/ / | |||||
* | | 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 | 1 | -0/+11 |
| | | | | | | | | added a todo to kernel archive | ||||
* | | FileSys: Updated backend code to use FileSys::Path instead of string for paths. | bunnei | 2014-11-18 | 2 | -10/+10 |
| | | |||||
* | | Fix two format strings. | Lioncash | 2014-11-14 | 1 | -1/+1 |
|/ | |||||
* | Added CreateDirectory function to service/fs.cpp, and in Archive. | archshift | 2014-11-02 | 2 | -2/+25 |
| | |||||
* | Fix some warnings | Sean | 2014-10-30 | 1 | -3/+3 |
| | |||||
* | Add `override` keyword through the code. | Yuri Kunde Schlesner | 2014-10-26 | 6 | -35/+35 |
| | | | | This was automated using `clang-modernize`. | ||||
* | FileSys: split the constructor into an Open method, in order to notify the opener something went wrong. | Emmanuel Gil Peyrot | 2014-10-06 | 1 | -0/+3 |
| | | | | 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 | 1 | -0/+8 |
| | |||||
* | 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 |
| | |||||
* | Kernel: Add a Directory object and a getter for it from an Archive object. | Emmanuel Gil Peyrot | 2014-09-17 | 3 | -0/+91 |
| | |||||
* | Kernel: Add a File object and a getter for it from an Archive object. | Emmanuel Gil Peyrot | 2014-09-17 | 2 | -0/+118 |
| | |||||
* | Core: Get rid of unnecessary switch statement in Kernel | Lioncash | 2014-09-15 | 1 | -41/+2 |
| | |||||
* | core: Prune redundant includes | archshift | 2014-09-09 | 3 | -6/+0 |
| | |||||
* | Threading: Fix thread starting to execute first instruction correctly. | bunnei | 2014-08-28 | 1 | -0/+5 |
| | |||||
* | Added FS functions to Archive and Archive_RomFS | archshift | 2014-08-23 | 1 | -3/+31 |
| | |||||
* | 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. | ||||
* | Core: Alter the kernel string functions to use std::string instead of const char*. | Lioncash | 2014-08-18 | 8 | -25/+22 |
| | | | | Most functions already operate on std::strings. This also removes the need to manually null terminate thread names. | ||||
* | Thread: Added more descriptive comment to WaitCurrentThread. | bunnei | 2014-08-07 | 2 | -2/+10 |
| | |||||
* | 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 |
| | |||||
* | Kernel: Updated Event and Mutex to specify handle that they are blocking for. | bunnei | 2014-08-06 | 2 | -2/+2 |
| | |||||
* | Kernel: Added preliminary support for address arbiters. | bunnei | 2014-07-09 | 3 | -1/+124 |
| | | | | | | | | 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. | ||||
* | SharedMemory: Updated MapSharedMemory to use an enum for permissions. | bunnei | 2014-07-05 | 2 | -6/+27 |
| | | | | - Also added some safety checks to MapSharedMemory. | ||||
* | Kernel: Added support for shared memory objects. | bunnei | 2014-07-05 | 2 | -0/+132 |
| | | | | SharedMemory: Added optional name field for tracking known objects. | ||||
* | Archive: Added Init/Shutdown methods to reset kernel archive state. | bunnei | 2014-07-05 | 3 | -0/+19 |
| | |||||
* | FileSys: Added preliminary support for applications reading the RomFS archive. | bunnei | 2014-07-05 | 2 | -10/+105 |
| | | | | | | | | | | 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. | ||||
* | Kernel: Added stubbed code to support creation of kernel Archive objects. | bunnei | 2014-06-27 | 3 | -0/+85 |
| | |||||
* | 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 | 2 | -0/+10 |
| | |||||
* | Event: Updated several log messages to be assertions. | bunnei | 2014-06-13 | 1 | -16/+8 |
| | |||||
* | 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 | 1 | -9/+0 |
| | |||||
* | 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 |
| | |||||
* | HLE: Updated all uses of NULL to nullptr (to be C++11 compliant) | bunnei | 2014-06-13 | 3 | -9/+9 |
| | |||||
* | 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 | 2 | -3/+3 |
| | |||||
* | 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 | 4 | -11/+11 |
| | |||||
* | 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 | 5 | -48/+165 |
| | | | | | | | | | | | | | - 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. | ||||
* | kernel: changed current default thread priority back to 0x30 - I think this is more correct | bunnei | 2014-06-05 | 1 | -1/+1 |
| | |||||
* | svc: added optional name field to Event and Mutex (used for debugging) | bunnei | 2014-06-03 | 4 | -8/+21 |
| | |||||
* | kernel: moved position of * for GetTypeName and GetName | bunnei | 2014-06-03 | 1 | -2/+2 |
| | |||||
* | svc: added GetThreadPriority and SetThreadPriority, added (incomplete) DuplicateHandle support | bunnei | 2014-06-02 | 2 | -0/+51 |
| | |||||
* | kernel: changed main thread priority to default, updated Kernel::Reschedule to use PrepareReschedule | bunnei | 2014-06-02 | 3 | -4/+6 |
| | |||||
* | 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 |
| | |||||
* | mutex: fixed typo in ReleaseMutex | bunnei | 2014-05-30 | 1 | -1/+3 |
| | |||||
* | event: added support for ClearEvent, fixed a bug with CreateEvent, fixed some comments | bunnei | 2014-05-30 | 2 | -9/+14 |
| | |||||
* | mutex: added preliminary SyncRequest/WaitSynchronization, added some comments/assertions | bunnei | 2014-05-28 | 1 | -0/+6 |
| | |||||
* | event: fixed typos and updated CMakeLists | bunnei | 2014-05-28 | 1 | -1/+1 |
| | |||||
* | 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 | 2 | -0/+119 |
| | |||||
* | 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 | 3 | -0/+29 |
| | |||||
* | kernel: updated SyncRequest to take boolean thread wait result as a parameter | bunnei | 2014-05-27 | 3 | -5/+20 |
| | |||||
* | kernel: added enum for known CurrentThread and CurrentProcess handles | bunnei | 2014-05-27 | 1 | -0/+5 |
| | |||||
* | kernel: add a SyncRequest method to KernelObject for use with svcSendSyncRequest | bunnei | 2014-05-27 | 3 | -0/+11 |
| | |||||
* | thread: renamed "WaitCurThread" to "WaitCurrentThread", removed unused "reason" argument | bunnei | 2014-05-23 | 2 | -4/+4 |
| | |||||
* | thread: removed unused SwitchContext/Reschedule reason field, added missing arg parameter to SVC CreateThread | bunnei | 2014-05-23 | 2 | -4/+4 |
| | |||||
* | kernel: refactored function naming to remove "__" prefix | bunnei | 2014-05-23 | 5 | -62/+72 |
| | |||||
* | thread: moved ThreadStatus/WaitType to header, added support for arg on CreateThread, added correct CPSR reset | bunnei | 2014-05-23 | 2 | -35/+40 |
| | |||||
* | thread: fixed bug where result of __NextThread was not being properly checked when NULL | bunnei | 2014-05-22 | 1 | -1/+1 |
| | |||||
* | mutex: refactored the interface to code to return a Mutex* handle | bunnei | 2014-05-21 | 2 | -3/+13 |
| | |||||
* | mutex: initial commit of HLE module | bunnei | 2014-05-21 | 2 | -0/+148 |
| | |||||
* | kernel: fixed include, in general include "common.h" not "common_types.h" | 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 | 3 | -101/+115 |
| | |||||
* | ARM_Interface: added SaveContext and LoadContext functions for HLE thread switching | bunnei | 2014-05-21 | 1 | -36/+2 |
| | |||||
* | renamed "syscall" module to "svc" (more accurate naming) | bunnei | 2014-05-21 | 1 | -1/+1 |
| | |||||
* | thread: whitespace change - fixed * and & placement | bunnei | 2014-05-21 | 2 | -27/+27 |
| | |||||
* | - created a Kernel namespace | bunnei | 2014-05-21 | 4 | -67/+79 |
| | | | | | - cleaned up Kernel code a bit (moved stuff into namespace, fixed whitespace issues) - added handle types for all different CTROS handles | ||||
* | thread: added declaration for __KernelReschedule to be used by syscall module | bunnei | 2014-05-20 | 1 | -0/+3 |
| | |||||
* | - updated service(s) to be KernelObject's | bunnei | 2014-05-19 | 1 | -4/+5 |
| | | | | - various cleanups | ||||
* | - moved Handle/Result definitions to kernel.h | bunnei | 2014-05-19 | 2 | -3/+2 |
| | | | | - added ResetType enum | ||||
* | changed a comment | bunnei | 2014-05-17 | 2 | -2/+2 |
| | |||||
* | - 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) | ||||
* | 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 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 |
| | |||||
* | 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 |
| | |||||
* | - added __KernelLoadExec function | bunnei | 2014-05-14 | 2 | -13/+35 |
| | | | | - fixed some logging | ||||
* | added initial kernel/thread modules | bunnei | 2014-05-10 | 4 | -0/+527 |