summaryrefslogtreecommitdiffstats
path: root/src/core/hle (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Services: Allow lm to log single-character messages.Subv2018-01-101-7/+3
|
* SVC: Fixed WaitSynchronization with multiple handles when none is immediately ready.Subv2018-01-091-7/+18
|
* SVC: Implemented CancelSynchronization.Subv2018-01-092-1/+19
|
* ErrorCodes: Updated the InvalidHandle and Timeout kernel error codes.Subv2018-01-091-2/+7
|
* SVC: Fixed WaitSynchronization with multiple handles when at least one of them is ready.Subv2018-01-092-3/+29
|
* kernel: Rename Semaphore to ConditionVariable.bunnei2018-01-098-159/+167
|
* mutex: Remove unused call to VerifyGuestState.bunnei2018-01-091-3/+0
|
* Kernel: Actually wake up the requested number of threads in Semaphore::Release.Subv2018-01-093-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.Subv2018-01-093-63/+60
|
* Kernel: Allow chaining WaitSynchronization calls inside a wakeup callback.Subv2018-01-094-30/+78
|
* CoreTiming: Reworked CoreTiming (cherry-picked from Citra #3119)B3n302018-01-093-11/+7
| | | | * CoreTiming: New CoreTiming; Add Test for CoreTiming
* IPC: Make DuplicateSession return the Domain instead of the Session if the request was made on a Domain interface.Subv2018-01-072-2/+7
|
* AppletOE: Fixed command buffer structure for ReceiveMessage.Subv2018-01-071-2/+1
|
* IPC: Corrected some command headers in the IPC Controller interface.Subv2018-01-071-4/+2
|
* IPC: Corrected some command header sizes in appletOE.Subv2018-01-071-12/+21
|
* IPC: Take the number of domain objects as a parameter in MakeBuilder.Subv2018-01-072-4/+6
|
* SM: Fixed connecting to services with an 8-byte name, like appletOE.Subv2018-01-071-12/+4
|
* IPC: Fixed pushing ResultCodes into the command buffer.Subv2018-01-072-7/+9
| | | | They should have 32 bits of padding after the error code now.
* IPC: Add functions to read the input move/copy objects from an IPC request.Subv2018-01-073-2/+42
|
* IPC: Don't attempt to read the command buffer if it holds a Close request.Subv2018-01-071-0/+5
|
* IPC Cleanup: Remove 3DS-specific code and translate copy, move and domain objects in IPC requests.Subv2018-01-078-405/+118
| | | | Popping objects from the buffer is still not implemented.
* IPC: Skip the entire u64 of the command id when receiving an IPC request.Subv2018-01-072-15/+5
| | | | Service code now doesn't have to deal with this.
* IPC: Use the correct size when pushing raw data to the command buffer and fixed pushing domain objects.Subv2018-01-074-10/+29
| | | | Domain object ids are always stored immediately after the raw data.
* svc: Implement svcSignalProcessWideKey.bunnei2018-01-072-4/+23
|
* semaphore: More changes for Switch.bunnei2018-01-072-11/+17
|
* wait_object: Refactor to allow waking up a single thread.bunnei2018-01-072-15/+28
|
* svc: Implement svcWaitProcessWideKeyAtomic.bunnei2018-01-062-1/+54
|
* semaphore: Updates for Switch.bunnei2018-01-062-21/+31
|
* lm: Assert on unsupported multi-message.bunnei2018-01-061-0/+9
|
* svc: Implement WaitSynchronization for a single handle.bunnei2018-01-061-4/+24
|
* svc: Refactor LockMutex code to use WaitSynchronization1.bunnei2018-01-061-13/+45
|
* lm: Improve Log() to format a useful string.bunnei2018-01-051-10/+75
|
* svc: Add missing string_util include.bunnei2018-01-051-0/+1
|
* arm: Remove SkyEye/Dyncom code that is ARMv6-only.bunnei2018-01-032-23/+11
|
* vm_manager: Use a more reasonable MAX_ADDRESS size.bunnei2018-01-031-5/+4
|
* svc: Remove unnecessary "svc" prefix to naming scheme.bunnei2018-01-031-106/+106
|
* pctl: Remove duplicate InstallInterfaces function.bunnei2018-01-031-4/+0
|
* hle: Move SVC code to kernel namespace.bunnei2018-01-033-131/+118
|
* svc: Improve svcGetInfo.bunnei2018-01-012-35/+41
|
* vm_manager: Stub out a bunch of interfaces used by svcGetInfo.bunnei2018-01-012-1/+51
|
* svc: Fix string formatting for CreateThread.bunnei2018-01-011-1/+1
|
* core/video_core: Fix a bunch of u64 -> u32 warnings.bunnei2018-01-011-2/+2
|
* svc: Stub out svcWaitSynchronization.bunnei2018-01-011-1/+9
| | | | - This does not matter until we implement other kernel objects, mutexes use svcLockMutex for waiting.
* svc: Implement svcExitProcess.bunnei2018-01-013-11/+77
|
* svc: Implement svcUnlockMutex.bunnei2018-01-011-1/+11
|
* svc: Implement svcLockMutex.bunnei2018-01-013-24/+134
|
* kernel: Add ObjectAddressTable class.bunnei2018-01-013-2/+101
|
* thread: Keep track of the initially created handle.bunnei2017-12-313-2/+7
| | | | This is kinda crufty, but we need it for now to update guest state variables.
* svc: Implement svcExitThread.bunnei2017-12-311-1/+9
|
* svc: Implement svcCreateThread.bunnei2017-12-311-2/+57
|
* svc: Cleanup svcGetThreadPriority.bunnei2017-12-311-3/+5
|
* svc: Stub out svcGetCurrentProcessorNumber.bunnei2017-12-311-1/+7
|
* errors: Define missing kernel error codes.bunnei2017-12-311-0/+3
|
* svc: Implement svcSetThreadPriority.bunnei2017-12-311-1/+30
|
* svc: Change SignalProcessWideKey to a stub.bunnei2017-12-311-2/+2
|
* function_wrappers: Cleanup, fix warnings, remove unused code.bunnei2017-12-311-187/+35
|
* svc: Implement svcUnmapMemory.bunnei2017-12-313-1/+15
|
* svc: Minor cleanups.bunnei2017-12-301-8/+9
|
* svc: Implement svcStartThread.bunnei2017-12-301-0/+16
|
* thread: Main thread should set thread handle to reg 1.bunnei2017-12-301-1/+4
|
* thread: Remove THUMB mode flag.bunnei2017-12-301-1/+1
|
* thread: Main thread should be ready by default, all others dormant.bunnei2017-12-301-4/+3
|
* kernel: Various 64-bit fixes in memory/process/threadbunnei2017-12-295-14/+14
|
* applet_oe: Stub out a bunch of interfaces necessary for boot.bunnei2017-12-292-1/+159
|
* controller: Implement DuplicateSession.bunnei2017-12-292-9/+11
|
* kernel: Fix implementation of ConvertSessionToDomain.bunnei2017-12-2910-54/+90
|
* ap, aoc_u: Minor cleanup.bunnei2017-12-293-4/+1
|
* service: Add empty interface for pctl:a.bunnei2017-12-295-0/+86
|
* kernel: Add basic support for Domain object.bunnei2017-12-294-4/+110
|
* kernel: Add SyncObject primitive, use it for ClientSession.bunnei2017-12-293-10/+40
|
* svc: Implement MapMemory.bunnei2017-12-292-3/+16
|
* process: Add method to mirror a memory region.bunnei2017-12-292-0/+27
|
* svc: Implement SetHeapSize.bunnei2017-12-282-3/+19
|
* service: Clean up apm/lm/applet_oe/controller/sm ctor/dtor.bunnei2017-12-2810-20/+10
|
* service: Halt on ReportUnimplementedFunction and improve output log.bunnei2017-12-281-4/+2
|
* service: Add empty interface for aoc:u.bunnei2017-12-283-0/+42
|
* service: Return proper result code for IPC::CommandType::Close.bunnei2017-11-014-9/+12
|
* hle: Use Switch formatted result codes.bunnei2017-11-015-272/+86
|
* svc: Implement GetThreadId and GetProcessId.bunnei2017-10-232-2/+37
|
* hle: Fix QueryMemory response for MemoryInfo.bunnei2017-10-207-149/+31
|
* lm: Implement lm::Initialize and Logger::log.bunnei2017-10-192-3/+67
|
* hle_ipc: Only copy necessary fields for outgoing command buffer.bunnei2017-10-191-1/+1
|
* hle_ipc: Parse out buffer X/A/B/B descriptors from incoming command buffer.bunnei2017-10-192-14/+19
|
* service: Add CreatePort function (that does not register/install).bunnei2017-10-192-0/+12
|
* ipc_helpers: Fix alignment (was wrong as a result of a dynarmic bug).bunnei2017-10-181-3/+4
|
* service: Print correct command ID on unimplemented function.bunnei2017-10-181-1/+1
|
* hle: Implement ConvertSessionToDomain, various cleanups.bunnei2017-10-1510-33/+82
|
* hle: Add service stubs for apm and appletOE.bunnei2017-10-159-2/+130
|
* hle: Initial implementation of NX service framework and IPC.bunnei2017-10-1515-637/+567
|
* svc: Some logging cleanup.bunnei2017-10-141-7/+5
|
* svc: Update MemoryInfo flags for 64-bit.bunnei2017-10-141-5/+5
|
* svc: Initial nx impl. for QueryMemory, ConnectToPort, SendSyncRequest, etc.bunnei2017-10-141-1185/+185
|
* Remove more 3DS-specific code.bunnei2017-10-134-45/+0
|
* Remove more 3DS-specific code.bunnei2017-10-135-1411/+1
|
* Remove more 3DS-specific code.bunnei2017-10-131-9/+0
|
* Remove lots more 3DS-specific code.bunnei2017-10-1324-4161/+6
|
* hle: Remove a large amount of 3ds-specific service code.bunnei2017-10-10184-21488/+2
|
* Merge remote-tracking branch 'upstream/master' into nxbunnei2017-10-1066-610/+1824
|\ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # Conflicts: # src/core/CMakeLists.txt # src/core/arm/dynarmic/arm_dynarmic.cpp # src/core/arm/dyncom/arm_dyncom.cpp # src/core/hle/kernel/process.cpp # src/core/hle/kernel/thread.cpp # src/core/hle/kernel/thread.h # src/core/hle/kernel/vm_manager.cpp # src/core/loader/3dsx.cpp # src/core/loader/elf.cpp # src/core/loader/ncch.cpp # src/core/memory.cpp # src/core/memory.h # src/core/memory_setup.h
| * Change command header in nwm::UDS Initialize functionDragios2017-10-091-1/+1
| |
| * Merge pull request #2991 from Subv/getpointerSebastian Valle2017-10-082-55/+49
| |\ | | | | | | Remove more usages of GetPointer.
| | * SVC: Removed GetPointer usage in the GetResourceLimit functions.Subv2017-10-041-10/+16
| | |
| | * SVC: Remove GetPointer usage in CreatePort.Subv2017-10-042-6/+4
| | |
| | * SVC: Replace GetPointer usage with ReadCString in ConnectToPort.Subv2017-10-042-20/+9
| | |
| | * SVC: Replace GetPointer usage with ReadBlock in OutputDebugString.Subv2017-10-042-4/+6
| | |
| | * SVC: Replace GetPointer usage with Read32 in ReplyAndReceive.Subv2017-10-042-7/+6
| | |
| | * SVC: Replace GetPointer usage with Read32 in WaitSynchronizationN.Subv2017-10-042-8/+8
| | |
| * | Merge pull request #2953 from Subv/applet_launchSebastian Valle2017-10-042-30/+47
| |\ \ | | | | | | | | HLE/APT: Always set up the APT parameter when starting a library applet.
| | * | HLE/APT: Always set up the APT parameter when starting a library applet.Subv2017-09-262-30/+47
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Only use the HLE interface if an HLE applet with the desired id was started. This commit reorganizes the APT code surrounding parameter creation and delivery to make it easier to support LLE applets in the future. As future work, the HLE applet interface can be reworked to utilize the same facilities as the LLE interface.
| * | | Merge pull request #2977 from Subv/shmem_createbunnei2017-10-031-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.Subv2017-10-021-15/+12
| | | | | | | | | | | | | | | | Also reference the right offset into the backing block for the requested address.
| * | | Merge pull request #2971 from Subv/per_process_memopsSebastian Valle2017-10-012-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.Subv2017-10-012-0/+12
| | | | |
| * | | | Merge pull request #2974 from Subv/nim_eventSebastian Valle2017-10-013-2/+29
| |\ \ \ \ | | |_|/ / | |/| | | Services/NIM: Implement CheckForSysUpdateEvent.
| | * | | Services/NIM: Implement CheckForSysUpdateEvent.Subv2017-09-303-2/+29
| | | | | | | | | | | | | | | | | | | | | | | | | Implementation verified by reverse engineering. This lets the Home Menu boot without crashing on startup.
| * | | | Moved down_count to CoreTimingHuw Pascoe2017-09-301-1/+1
| |/ / /
| * | | Services/UDS: Handle the rest of the connection sequence. (#2963)B3n302017-09-303-19/+250
| | | | | | | | | | | | Services/UDS: Handle the rest of the connection sequence.
| * | | Merge pull request #2946 from Subv/home_menu_aptSebastian Valle2017-09-303-8/+45
| |\ \ \ | | | | | | | | | | Implement PrepareToStartNewestHomeMenu and fixed an APT regression.
| | * | | HLE/APT: Always return an error from PrepareToStartNewestHomeMenu so that the Home Menu doesn't try to reboot the system.Subv2017-09-243-2/+26
| | | | | | | | | | | | | | | | | | | | | | | | | As per 3dbrew: "During Home Menu start-up it uses APT:PrepareToStartNewestHomeMenu. If that doesn't return an error(normally NS returns 0xC8A0CFFC for that), Home Menu starts a hardware reboot with APT:StartNewestHomeMenu etc. "
| | * | | HLE/APT: Prepare the APT Wakeup parameter when the game calls InitializeSubv2017-09-241-6/+19
| | | |/ | | |/| | | | | | | | | | | | | We need to know what is being run so we can set the APT parameter destination AppId correctly. Delaying the preparation of the parameter until we know which AppId is running lets us support booting both the Home Menu and normal game Applications.
| * | | Merge pull request #2967 from Subv/thread_wakeup_callbacksSebastian Valle2017-09-304-17/+91
| |\ \ \ | | |_|/ | |/| | Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken
| | * | Kernel/Threads: When putting a thread to wait, specify a function to execute when it is awoken.Subv2017-09-284-17/+91
| | | | | | | | | | | | | | | | | | | | | | | | This change makes for a clearer (less confusing) path of execution in the scheduler, now the code to execute when a thread awakes is closer to the code that puts the thread to sleep (WaitSynch1, WaitSynchN). It also allows us to implement the special wake up behavior of ReplyAndReceive without hacking up WaitObject::WakeupAllWaitingThreads. If savestates are desired in the future, we can change this implementation to one similar to the CoreTiming event system, where we first register the callback functions at startup and assign their identifiers to the Thread callback variable instead of directly assigning a lambda to the wake up callback variable.
| * | | Fixed type conversion ambiguityHuw Pascoe2017-09-3021-56/+59
| | | |
| * | | Kernel/Thread: Allow specifying which process a thread belongs to when creating it.Subv2017-09-274-17/+22
| |/ / | | | | | | | | | Don't automatically assume that Thread::Create will only be called when the parent process is currently scheduled. This assumption will be broken when applets or system modules are loaded.
| * | HLE/Archives: Allow multiple loaded applications to access their SelfNCCH archive independently.Subv2017-09-252-1/+24
| | | | | | | | | | | | | | | | | | | | | | | | The loaders now register each loaded ROM with the SelfNCCH factory, which keeps the data around for the duration of the emulation session. When opening the SelfNCCH archive, the factory queries the current program's programid and uses that as a key to the map that contains the NCCHData structure (RomFS, Icon, Banner, etc). 3dsx files do not have a programid and will use a default of 0 for this value, thus, only 1 3dsx file with RomFS is loadable at the same time.
| * | Merge pull request #2952 from MerryMage/page-tablesB3n302017-09-251-7/+4
| |\ \ | | | | | | | | Switchable Page Tables
| | * | memory: Add GetCurrentPageTable/SetCurrentPageTableMerryMage2017-09-241-7/+4
| | |/ | | | | | | | | | Don't expose Memory::current_page_table as a global.
| * | Merge pull request #2948 from Subv/register_serviceB3n302017-09-254-1/+33
| |\ \ | | | | | | | | HLE/SRV: Implemented RegisterService.
| | * | HLE/SRV: Implemented RegisterService.Subv2017-09-244-1/+33
| | |/ | | | | | | | | | Now system modules can do more than just crash immediately on startup.
| * / Services/UDS: Added a function to send EAPoL-Start packets (#2920)B3n302017-09-255-88/+250
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | * Services/UDS: Added a function to generate the EAPoL-Start packet body. * Services/UDS: Added filter for beacons. * Services/UDS: Lock a mutex when accessing connection_status from both the emulation and network thread. * Services/UDS: Handle the Association Response frame and respond with the EAPoL-Start frame. * fixup: make use of current_node, changed received_beacons into a list, mutex and assert corrections * fixup: fix damn clang-format
| * Merge pull request #2906 from Subv/ns_new_frameworkYuri Kunde Schlesner2017-09-166-40/+73
| |\ | | | | | | Services/NS: Port ns:s to the new service framework.
| | * Services/NS: Port ns:s to the new service framework.Subv2017-09-166-40/+73
| | |
| * | Merge pull request #2842 from Subv/switchable_page_tableB3n302017-09-155-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.Subv2017-09-151-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.Subv2017-09-152-25/+7
| | | |
| | * | Kernel/Memory: Switch the current page table when a new process is scheduled.Subv2017-09-101-0/+10
| | | |
| | * | Kernel/Memory: Give each Process its own page table.Subv2017-09-102-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 #2915 from wwylele/font-archive-2bunnei2017-09-123-135/+155
| |\ \ \ | | | | | | | | | | APT: load different shared font depending on the region
| | * | | APT: load different shared font depending on the regionwwylele2017-09-033-135/+155
| | | | |
| * | | | Merge pull request #2831 from Subv/uds_authWeiyi Wang2017-09-056-53/+287
| |\ \ \ \ | | | | | | | | | | | | Services/UDS: Handle beacon frames and the basic AP connection sequence frames.
| | * | | | Services/UDS: Remove an old duplicated declaration of WifiPacket.Subv2017-08-272-22/+0
| | | | | |
| | * | | | Services/UDS: Handle the connection sequence packets.Subv2017-08-271-17/+83
| | | | | | | | | | | | | | | | | | | | | | | | There is currently no stage tracking, a client is considered "Connected" when it receives the EAPoL Logoff packet from the server, this is not yet implemented.
| | * | | | Services/UDS: Store the received beacon frames until RecvBeaconBroadcastData is called, up to 15 beacons at the same time, removing any older beacon frames when the limit is exceeded.Subv2017-08-271-3/+62
| | | | | |
| | * | | | Services/UDS: Add functions to generate 802.11 auth and assoc response frames.Subv2017-08-274-11/+142
| | | | | |
| * | | | | Remove _flag in var namesmailwl2017-09-041-6/+6
| | | | | |
| * | | | | Mii Selector Applet: update Mii structuresmailwl2017-09-042-34/+29
| | |/ / / | |/| | |
| * | | | Merge pull request #2899 from wwylele/touch-refactorbunnei2017-08-291-4/+8
| |\ \ \ \ | | | | | | | | | | | | Refactor touch input into a TouchDevice
| | * | | | HID: use TouchDevice for touch padwwylele2017-08-241-4/+8
| | | |_|/ | | |/| |
| * / | | Use recursive_mutex instead of mutex to fix #2902danzel2017-08-293-3/+3
| |/ / /
| * | | Merge pull request #2839 from Subv/global_kernel_lockJames Rowe2017-08-244-3/+36
| |\ \ \ | | | | | | | | | | 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).Subv2017-08-224-3/+36
| | | | | | | | | | | | | | | | | | | | 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_threadbunnei2017-08-221-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.Subv2017-08-221-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.Subv2017-08-211-0/+3
| | | | | |
| * | | | | HLE/Applets: Fixed some conversion warnings when creating the framebuffer shared memory objects.Subv2017-08-214-8/+8
| |/ / / /
| * | | | Merge pull request #2861 from wwylele/motion-refactorJames Rowe2017-08-201-5/+27
| |\ \ \ \ | | |_|_|/ | |/| | | Refactor MotionEmu into a InputDevice
| | * | | HID: fix a comment and a warningwwylele2017-08-201-2/+2
| | | | |
| | * | | HID: use MotionDevice for Accelerometer and Gyroscopewwylele2017-08-111-5/+27
| | | | |
| * | | | Merge pull request #2881 from MerryMage/dsp-firm-checkYuri Kunde Schlesner2017-08-161-3/+4
| |\ \ \ \ | | | | | | | | | | | | dsp_dsp: Remove size assertion in LoadComponent
| | * | | | dsp_dsp: Remove size assertion in LoadComponentMerryMage2017-08-151-3/+4
| | | | | |
| * | | | | Merge pull request #2843 from Subv/applet_slotsSebastian Valle2017-08-122-35/+200
| |\ \ \ \ \ | | |_|/ / / | |/| | | | Services/APT: Use an array to hold data about the 4 possible concurrent applet types (Application, Library, HomeMenu, System)
| | * | | | Services/APT: Use the AppletAttributes union directly when dealing with applet attrs.Subv2017-08-071-19/+15
| | | | | |
| | * | | | Services/APT: Use an array to hold data about the 4 possible concurrent applet types (Application, Library, HomeMenu, System).Subv2017-08-072-35/+204
| | |/ / / | | | | | | | | | | | | | | | This gives each applet type its own set of events as per the real NS module.
| * | | | Merge pull request #2863 from wwylele/pad-state-zeroWeiyi Wang2017-08-102-2/+2
| |\ \ \ \ | | | | | | | | | | | | HID: zero unused PadState bits
| | * | | | HID: zero unused PadState bitswwylele2017-08-102-2/+2
| | |/ / /
| * | | | Merge pull request #2862 from j-selby/update-cryptoppbunnei2017-08-091-1/+1
| |\ \ \ \ | | | | | | | | | | | | Update CryptoPP (byte ambiguity)
| | * | | | Update cryptoppJames2017-08-081-1/+1
| | |/ / /
| * / / / Service/dlp: Update function tables according 3dbrewmailwl2017-08-093-4/+44
| |/ / /
| * | | telemetry: Add field for RequiresSharedFont.bunnei2017-08-041-0/+4
| | | |
| * | | Merge pull request #2840 from Subv/apt_parameterbunnei2017-07-272-33/+105
| |\ \ \ | | | | | | | | | | Services/APT: Corrected the behavior of the Receive/Send/Glance/CancelParameter functions
| | * | | Service/APT: Log Send/Cancel/Receive/GlanceParameter calls even if they return an error.Subv2017-07-211-7/+9
| | | | |
| | * | | Services/APT: Return the proper error code when calling SendParameter with an outstanding parameter already in memory.Subv2017-07-212-4/+17
| | | | |
| | * | | Services/APT: Reset the APT parameter inside CancelParameter if the conditions are met.Subv2017-07-211-6/+23
| | | | |
| | * | | Services/APT: Properly clear the apt parameter after a successful ReceiveParameter call.Subv2017-07-211-2/+8
| | | | |
| | * | | Services/APT: Use the right error codes in ReceiveParameter and GlanceParameter when the parameter doesn't exist.Subv2017-07-211-0/+28
| | | | |
| | * | | Services/APT: Use boost::optional for the APT parameter structure.Subv2017-07-211-20/+26
| | |/ /
* | | | loader: Various improvements for NSO/NRO loaders.bunnei2017-10-102-4/+4
| | | |
* | | | nso: Refactor and allocate .bss section.bunnei2017-09-302-8/+10
| | | |
* | | | process: Support loading multiple codesets.bunnei2017-09-302-20/+27
| | | |
* | | | kernel: Various threading fixes to support 64-bit addressing.bunnei2017-09-302-8/+8
| | | |
* | | | core: Various changes to support 64-bit addressing.bunnei2017-09-302-21/+21
| | | |
* | | | arm: Use 64-bit addressing in a bunch of places.bunnei2017-09-302-2/+2
|/ / /
* | | Merge pull request #2799 from yuriks/virtual-cached-range-flushWeiyi Wang2017-07-224-10/+9
|\ \ \ | |/ / |/| | Add address conversion functions returning optional, Add function to flush virtual region from rasterizer cache
| * | Memory: Add function to flush a virtual range from the rasterizer cacheYuri Kunde Schlesner2017-06-222-8/+7
| | | | | | | | | | | | | | | | | | This is slightly more ergonomic to use, correctly handles virtual regions which are disjoint in physical addressing space, and checks only regions which can be cached by the rasterizer.
| * | Memory: Make PhysicalToVirtualAddress return a boost::optionalYuri Kunde Schlesner2017-06-222-2/+2
| | | | | | | | | | | | And fix a few places in the code to take advantage of that.
* | | stubbed frd::UnscrambleLocalFriendCode (#2827)B3n302017-07-173-1/+57
| | |
* | | Merge pull request #2784 from wwylele/font-archiveWeiyi Wang2017-07-164-22/+262
|\ \ \ | | | | | | | | load shared font from system archive
| * | | apt: load shared font from system archivewwylele2017-06-263-20/+258
| | | |
| * | | apt/shared_font: don't relocate zero offsetwwylele2017-06-251-2/+4
| |/ /
* | / Service/boss:P: Add some functions to FunctionTablemailwl2017-07-011-0/+3
| |/ |/|
* | Merge pull request #2793 from Subv/replyandreceiveSebastian Valle2017-06-306-23/+161
|\ \ | | | | | | Kernel/SVC: Partially implemented svcReplyAndReceive
| * | Kernel/SVC: Pass the current thread as a parameter to ClientSession::SendSyncRequest.Subv2017-06-293-4/+7
| | |
| * | Kernel/Sessions: Clean up the list of pending request threads of a session when the client endpoint is closed.Subv2017-06-261-0/+5
| | |
| * | Kernel/SVC: Partially implemented svcReplyAndReceive.Subv2017-06-262-11/+121
| | | | | | | | | | | | | | | | | | | | | | | | It behaves mostly as WaitSynchronizationN with wait_all = false, except for IPC buffer translation. The target thread of an IPC response will now wake up when responding. IPC buffer translation is currently not implemented. Error passing back to svcSendSyncRequest is currently not implemented.
| * | Kernel/ServerSession: Keep track of which threads have issued sync requests.Subv2017-06-253-9/+29
| | |
* | | Merge pull request #2778 from Subv/uds_moreSebastian Valle2017-06-273-1/+432
|\ \ \ | | | | | | | | Services/UDS: Stub SendTo to generate the unencrypted data frames with the right headers
| * | | UDS: Use the ToDS and FromDS fields to properly calculate the AAD used during encryption.Subv2017-06-261-15/+32
| | | |
| * | | UDS: Move the UDS keyslot used to generate the CCMP key to the AES::KeySlotID enum.Subv2017-06-261-4/+1
| | | |
| * | | UDS: Run clang-format.Subv2017-06-263-51/+55
| | | |
| * | | UDS: Added functions to encrypt and decrypt the data frames.Subv2017-06-263-12/+156
| | | | | | | | | | | | | | | | The responsibility of encryption and encapsulation into an 802.11 MAC frame will fall into the callers of GenerateDataPayload.
| * | | UDS: Clarify comment about the first 4 bytes of the SecureData header.Subv2017-06-152-1/+5
| | | | | | | | | | | | | | | | It is likely that these 4 bytes are actually a different header, part of some protocol that encapsulates the SecureData protocol.
| * | | UDS: Return the correct error messages in SendTo when not connected to a network or trying to send to itself.Subv2017-06-151-6/+13
| | | |
| * | | UDS: Stub SendTo to generate the unencrypted data frame with the right headers.Subv2017-06-153-1/+259
| |/ /
* | | Kernel: Implement AcceptSession SVCYuri Kunde Schlesner2017-06-234-3/+38
| | |
* | | Kernel: Fix SVC wrapper for CreatePortYuri Kunde Schlesner2017-06-231-3/+2
| | | | | | | | | | | | The return parameters were flipped.
* | | Kernel: Implement CreateSessionToPort SVCYuri Kunde Schlesner2017-06-231-1/+12
| | |
* | | Merge pull request #2798 from yuriks/svc-create-sessionYuri Kunde Schlesner2017-06-232-3/+26
|\ \ \ | | | | | | | | Kernel: Implement CreateSession SVC
| * | | Kernel: Implement CreateSession SVCYuri Kunde Schlesner2017-06-222-3/+26
| | |/ | |/|
* / | Kernel/IPC: Support translation of null handlesYuri Kunde Schlesner2017-06-211-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-kernelWeiyi Wang2017-06-211-0/+2
|\ \ | | | | | | Trivial no-op additions
| * | Kernel: Add comment about the extended linear heap areaYuri Kunde Schlesner2017-06-191-0/+2
| |/
* | Merge pull request #2790 from yuriks/remove-movefromYuri Kunde Schlesner2017-06-2124-56/+57
|\ \ | | | | | | Remove ResultVal::MoveFrom
| * | ResultVal: Remove MoveFrom()Yuri Kunde Schlesner2017-06-1924-57/+53
| | | | | | | | | | | | | | | Replace it with std::move(result_val).Unwrap(), or Foo().Unwrap() in case you already have an rvalue.
| * | ResultVal: Add an rvalue overload of Unwrap()Yuri Kunde Schlesner2017-06-191-1/+6
| |/
* | Merge pull request #2779 from Subv/uds_more2Sebastian Valle2017-06-211-0/+36
|\ \ | | | | | | UDS: Added a hook for updating the connection status when a client connects to the network.
| * | UDS: Added a hook for updating the connection status when a client connects to the network.Subv2017-06-151-0/+36
| |/
* / Kernel/IPC: Make HLERequestContext usable from outside kernelYuri Kunde Schlesner2017-06-193-5/+10
|/
* Services/UDS: Set the proper bit in the ConnectionStatus structure when creating a network. (#2738)Sebastian Valle2017-06-133-5/+15
| | | | | | | | | | * Services/UDS: Set the proper bit in the ConnectionStatus structure when creating a network. This lets the application know that the host was successfully added to the session. * Services/UDS: Reset the connection status when destroying the network * Services/UDS: Reset the connection status's bitmask of changed nodes after reporting it to the game.
* Kernel/IPC: Use boost::small_vector for HLE context objectsYuri Kunde Schlesner2017-06-121-1/+3
|
* Kernel: Allow clearing request_objects to re-use buffer spaceYuri Kunde Schlesner2017-06-113-0/+14
| | | | | Reduces the necessary allocation to max(in_handles, out_handles) rather than (in_handles + out_handles).
* Kernel: Basic support for IPC translation for HLE servicesYuri Kunde Schlesner2017-06-113-18/+130
|
* Service/sm: Convert srv: to use IPC helpersYuri Kunde Schlesner2017-06-111-49/+56
|
* IPC: Add Pop/PushObjects methods to RequestParser/BuilderYuri Kunde Schlesner2017-06-111-10/+103
| | | | | These use the context functions to create and look-up handles for the user.
* IPC: Add basic HLERequestContext support to RequestParser/BuilderYuri Kunde Schlesner2017-06-111-1/+32
|
* Kernel: Add methods in HLERequestContext abstracting handle creationYuri Kunde Schlesner2017-06-112-0/+12
|
* ServiceFramework: Use separate copy of command bufferYuri Kunde Schlesner2017-06-113-9/+29
| | | | | | Copy the IPC command buffer to/from the request context before/after the handler is invoked. This is part of a move away from using global data for handling IPC requests.
* Merge pull request #2756 from yuriks/service-frameworkYuri Kunde Schlesner2017-06-098-63/+354
|\ | | | | New service framework
| * Service/sm: Convert 'srv:' to ServiceFrameworkYuri Kunde Schlesner2017-06-095-51/+75
| |
| * Service: Remove a few redundant namespace qualifiersYuri Kunde Schlesner2017-06-081-5/+5
| |
| * Service: Add new ServiceFramework framework for writing HLE servicesYuri Kunde Schlesner2017-06-084-3/+268
| | | | | | | | | | | | | | | | | | | | | | | | 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 qualificationsYuri Kunde Schlesner2017-06-061-4/+6
| |
* | Session: Remove/add some forward declarationsYuri Kunde Schlesner2017-06-082-1/+2
| |
* | Kernel: Ensure objects are kept alive during ClientSession disconnectionYuri Kunde Schlesner2017-06-081-7/+13
| | | | | | | | Fixes #2760
* | Merge pull request #2737 from Subv/decryptbeacondataJames Rowe2017-06-071-1/+97
|\ \ | |/ |/| Services/UDS: Implement DecryptBeaconData.
| * Services/UDS: Implement DecryptBeaconData.Subv2017-06-061-1/+97
| | | | | | | | This function decrypts the encrypted data tags contained in the 802.11 beacon frames.
* | Service: Remove unnecessary includes from service.hYuri Kunde Schlesner2017-06-0631-12/+79
| | | | | | | | | | This has a huge fallout in terms of needing to fix other files because all service implementations included that file.
* | Service: Make service registration part of the sm implementationYuri Kunde Schlesner2017-06-065-24/+145
| | | | | | | | Also enhances the GetServiceHandle implementation to be more accurate.
* | Service/sm: Use an actual semaphore for the notification semaphoreYuri Kunde Schlesner2017-06-061-8/+9
| | | | | | | | | | An Event was used way back then when we didn't have proper working semaphores. Our Semaphore implementation is good enough now.
* | Service: Move SRV interface to a new sm/ subdirectoryYuri Kunde Schlesner2017-06-063-7/+8
| | | | | | | | | | This will contain the implementation of the sm (Service Manager) system module.
* | Kernel: Add a dedicated SetHleHandler method to ServerPort/ServerSessionYuri Kunde Schlesner2017-06-0611-62/+73
| | | | | | | | | | | | This allows attaching a HLE handle to a ServerPort at any point after it is created, allowing port/session creation to be generic between HLE and regular services.
* | ResultVal: Add more convenience utils for creating and cascading resultsYuri Kunde Schlesner2017-06-061-0/+19
| |
* | HLE: Move SessionRequestHandler from Service:: to Kernel::Yuri Kunde Schlesner2017-06-0613-73/+98
| | | | | | | | | | Most of the code that works with this is or will be in the kernel, so it's a more appropriate place for it to be.
* | Addressed Bunnei's review comments, and made some other tweaks:TheKoopaKingdom2017-06-031-1/+2
| | | | | | | | | | - Deleted GetStatus() because it wasn't used anywhere outside of Core::System. - Fixed design flaw where the message bar status could be set despite the game being stopped.
* | Switched to the ERROR_NOT_FOUND constant from errors.h.TheKoopaKingdom2017-06-031-2/+1
| |
* | Moved whitelist checks from FS_User to the Archive_NCCH handler.TheKoopaKingdom2017-06-031-52/+2
| |
* | Created a whitelist of system archives to prevent false positives creating dialogs.TheKoopaKingdom2017-06-032-7/+53
| |
* | Made some changes from review comments:TheKoopaKingdom2017-06-032-9/+6
| | | | | | | | | | | | | | | | - Made LoadKernelSystemMode return a pair consisting of a system mode and a result code (Could use review). - Deleted ErrorOpenGL error code in favor of just having ErrorVideoCore. - Made dialog messages more clear. - Compared archive ID in fs_user.cpp to ArchiveIdCode::NCCH as opposed to hex magic. - Cleaned up some other stuff.
* | Added system for handling core errors in citra-qt.TheKoopaKingdom2017-06-033-2/+12
| |
* | Merge pull request #2722 from wwylele/cam-ipc-helperbunnei2017-06-012-293/+265
|\ \ | | | | | | CAM: use IPCHelper
| * | fixup!cam: use IPCHelperwwylele2017-05-272-30/+43
| | |
| * | cam: move u32->u8 trancation to IPCHelperwwylele2017-05-241-34/+33
| | |
| * | cam: use IPCHelperwwylele2017-05-241-278/+238
| | |
* | | Kernel: Move HandleTable to a separate fileYuri Kunde Schlesner2017-05-3017-203/+240
| | |
* | | Kernel: Move WaitObject to a separate fileYuri Kunde Schlesner2017-05-3012-132/+174
| | | | | | | | | | | | | | | Now that HandleTable doesn't directly depend on WaitObject anymore, this can be separated from the main kernel.h header.
* | | Kernel: Removed HandleTable::GetWaitObjectYuri Kunde Schlesner2017-05-302-11/+2
| | | | | | | | | | | | | | | This isn't necessary anymore since plain Get works correctly for WaitObjects.
* | | Kernel: Extract dynamic Object pointer cast into its own functionYuri Kunde Schlesner2017-05-291-11/+24
| |/ |/|
* | Remove some unnecessary inclusions of video_core.hYuri Kunde Schlesner2017-05-282-2/+0
| |
* | Core: Fix some out-of-style includesYuri Kunde Schlesner2017-05-281-1/+1
| |
* | FS: Remove unused result definitionYuri Kunde Schlesner2017-05-251-5/+0
| |
* | Kernel: Centralize error definitions in errors.hYuri Kunde Schlesner2017-05-2522-132/+177
| |
* | GSP_GPU: Move error codes from result.h to local fileYuri Kunde Schlesner2017-05-252-17/+23
| |
* | FileSys: Move all result description to errors.hYuri Kunde Schlesner2017-05-255-44/+19
| |
* | result: Make error description a generic integerYuri Kunde Schlesner2017-05-253-6/+18
| | | | | | | | | | | | | | | | | | It is now known that result code description vary depending on the module, and so they're best defined on a per-module basis. To support this, allow passing in an arbitrary integer instead of limiting to the ones in the ErrorDescription enum. These will be gradually migrated to their individual users, but a few will be kept as "common" codes shared by all modules.
* | Make BitField and ResultCode constexpr-initializableYuri Kunde Schlesner2017-05-251-18/+15
|/
* Merge pull request #2406 from Subv/session_disconnectYuri Kunde Schlesner2017-05-227-51/+83
|\ | | | | Kernel: Properly update port counters on session disconnection.
| * Kernel/Sessions: Remove the ClientSession::Create function.Subv2017-05-223-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.Subv2017-05-152-8/+0
| |
| * Kernel: Use a Session object to keep track of the status of a Client/Server session pair.Subv2017-05-157-32/+85
| | | | | | | | Reduce the associated port's connection count when a ServerSession is destroyed.
* | Merge pull request #2661 from Subv/uds5bunnei2017-05-194-33/+600
|\ \ | | | | | | Services/UDS: Generate 802.11 beacon frames when a network is open.
| * | Services/UDS: Use the new IPC helper functions.Subv2017-05-151-21/+10
| | |
| * | Services/UDS: Implement RecvBeaconBroadcastData.Subv2017-05-151-19/+69
| | | | | | | | | | | | | | | This allows the applications to retrieve 802.11 beacon frames from nearby UDS networks. Note that the networks are still not announced anywhere.
| * | Services/UDS: Generate the UDS beacons when the beacon callback fires.Subv2017-05-154-7/+535
| | |
* | | use IPCHelper for PTM servicesemmaus2017-05-193-31/+45
| | |
* | | Merge pull request #2687 from yuriks/address-mappingsYuri Kunde Schlesner2017-05-144-45/+102
|\ \ \ | | | | | | | | Kernel: Map special regions according to ExHeader
| * | | Kernel: Map special regions according to ExHeaderYuri Kunde Schlesner2017-05-104-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 RAMYuri Kunde Schlesner2017-05-101-1/+6
| | | | | | | | | | | | | | | | Also move address space mapping out of video_core.
* | | | Merge pull request #2676 from wwylele/irrstbunnei2017-05-108-23/+207
|\ \ \ \ | |/ / / |/| | | ir: implement new 3ds HID via ir:rst
| * | | fixup!ir: implement new 3ds HID via ir:rstwwylele2017-05-071-31/+32
| | | |
| * | | ir: implement new 3ds HID via ir:rstwwylele2017-05-048-23/+206
| | | |
* | | | Remove ability to load symbol mapsYuri Kunde Schlesner2017-05-081-8/+2
| | | | | | | | | | | | | | | | | | | | This was now mostly unused except by thread creation, which used a symbol of the entrypoint, if available, to name the thread.
* | | | Create a random console_unique_id (#2668)B3n302017-05-062-5/+71
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Create a random console_id when config save_file is created Added button in system config to refresh the console unique id * Moved the connect for the button from .ui file to constructor of ConfigureSystem * Added warning and info dialog Fixup: Make use of qt5 style connects, renamed the refresh button, removed some duplicate code, changed random device and moved all to the generate function * Changed the random generator to reflect what a real 3DS stores as console unique id Fixup: Changed the warning message * Fixup: Set and Create * Fixup: Added console id label, therfore removed second message box * Fixup: fixed the endianess * Fixup: more endianness fixes * Fixup: Endianness the 3rd
* | | Merge pull request #2606 from wwylele/irbunnei2017-05-044-44/+757
|\ \ \ | | | | | | | | ir: implement circle pad pro
| * | | ir: implement circle pad prowwylele2017-05-034-44/+757
| | | |
* | | | Merge pull request #2532 from wwylele/ldrro-ipcYuri Kunde Schlesner2017-04-181-193/+138
|\ \ \ \ | |_|_|/ |/| | | ldr_ro: use IPC helper
| * | | ldr_ro: use IPC helperwwylele2017-04-171-193/+138
| |/ /
* | | Merge pull request #2659 from MerryMage/dsp_dsp-correctionbunnei2017-04-131-0/+18
|\ \ \ | |_|/ |/| | dsp_dsp: Messages are modified by service before being sent to DSP
| * | dsp_dsp: Messages are modified by service before being sent to DSPMerryMage2017-04-121-0/+18
| | |
* | | Merge pull request #2628 from Subv/udsSebastian Valle2017-04-122-45/+388
|\ \ \ | |_|/ |/| | Services/UDS: Initial support for hosting local-wlan networks.
| * | Services/UDS: Fixed a style mistake in GetChannel.Sebastian Valle2017-03-271-2/+1
| | |
| * | Services/UDS: Use consistent spelling for WiFi and simplify the GetChannel function.Subv2017-03-261-4/+4
| | |
| * | Services/UDS: Signal the connection event when closing down the network.Subv2017-03-261-0/+1
| | |
| * | Services/UDS: Do not allow trying to start up a network that only the host can connect to.Subv2017-03-261-0/+3
| | |
| * | Service/UDS: Schedule an event to broadcast the beacon frames every 102.4ms.Subv2017-03-262-2/+58
| | |
| * | Services/UDS: Store the entire NetworkInfo structure that was used to create the network.Subv2017-03-261-13/+5
| | | | | | | | | | | | It will be needed when generating the beacon frames.
| * | Services/UDS: Initial support for hosting local-wlan networks.Subv2017-03-262-44/+336
| | | | | | | | | | | | Currently it will let games create a network as hosts, but will not broadcast it anywhere and will not allow clients to connect.
* | | Merge pull request #2533 from Lectem/apt_ipchelperbunnei2017-04-066-257/+386
|\ \ \ | | | | | | | | IpcHelper enhancement and APT refactor
| * | | hopefully fix clang-format issues with old versionLectem2017-03-201-3/+2
| | | |
| * | | address more commentsLectem2017-03-191-20/+20
| | | |
| * | | Cast size_t to u32 for PushStaticBuffer usagesLectem2017-03-181-2/+2
| | | |
| * | | IPCHelper Skip method + address comments for aptLectem2017-03-183-38/+46
| | | |
| * | | fix #2560 and other commentsLectem2017-03-183-22/+22
| | | |
| * | | move push out of class body and add u8 u16 bool specializationsLectem2017-03-184-55/+114
| | | |
| * | | refactor APT service to use the new IPC helpersLectem2017-03-184-195/+258
| | | |
* | | | Merge pull request #2634 from wwylele/batterybunnei2017-04-062-1/+16
|\ \ \ \ | | | | | | | | | | shared_page: stub battery state
| * | | | shared_page: stub battery statewwylele2017-03-212-1/+16
| | | | |
* | | | | error conversion fixes for soc_unoah the goodra2017-04-031-39/+32
| | | | |
* | | | | Fix OutputDebugString syscallMichael Theall2017-04-012-4/+4
| | | | |
* | | | | ptm: create SharedExtSave file before openning itwwylele2017-03-251-1/+1
|/ / / /
* / / / apt: fix RequestBuilder parameters for Unwrapwwylele2017-03-181-1/+1
|/ / /
* | | Merge pull request #2497 from wwylele/input-2bunnei2017-03-172-37/+56
|\ \ \ | | | | | | | | Refactor input emulation & add SDL gamepad support
| * | | Input: remove unused stuff & clean upwwylele2017-03-011-34/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | 1. removed zl, zr and c-stick from HID::PadState. They are handled by IR, not HID 2. removed button handling in EmuWindow 3. removed key_map 4. cleanup #include
| * | | HID: use AnalogDevicewwylele2017-03-011-2/+9
| | | |
| * | | HID: use ButtonDevicewwylele2017-03-012-1/+47
| |/ /
* | | Merge pull request #2620 from FernandoS27/syscore_errorbunnei2017-03-161-5/+15
|\ \ \ | | | | | | | | Refined thread launch on syscore error messages
| * | | Refined thread launch on syscore error messagesFernando Sahmkow2017-03-091-5/+15
| |/ /
* / / cfg: implement GenHashConsoleUniquewwylele2017-03-121-7/+24
|/ /
* | Timer: restore missing signaled=true from #2421wwylele2017-02-271-0/+2
| |
* | Merge pull request #2594 from wwylele/ir-separatebunnei2017-02-276-147/+159
|\ \ | | | | | | IR: separate functions of each port to their own files
| * | IR: separate functions of each port to their own fileswwylele2017-02-266-147/+159
| | |
* | | Fix log entry in timer::signal (#2600)B3n302017-02-271-1/+1
| | |
* | | Doxygen: Amend minor issues (#2593)Mat M2017-02-275-9/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | 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-barYuri Kunde Schlesner2017-02-274-1/+4
|\ \ \ | |/ / |/| | Replace built-in Profiler with indicators in status bar
| * | Core: Make PerfStats internally lockedYuri Kunde Schlesner2017-02-271-2/+1
| | | | | | | | | | | | More ergonomic to use and will be required for upcoming changes.
| * | Add performance statistics to status barYuri Kunde Schlesner2017-02-271-0/+3
| | |
| * | Core: Remove unnecessary include in thread.hYuri Kunde Schlesner2017-02-273-1/+2
| | |
* | | Merge pull request #2569 from wwylele/wrap-unwrapbunnei2017-02-255-6/+149
|\ \ \ | | | | | | | | APT: implemented Wrap and Unwrap
| * | | APT: implement Wrap and Unwrapwwylele2017-02-215-6/+149
| | | |
* | | | Timers: Return an error when calling SetTimer with negative timeouts.Subv2017-02-221-0/+5
| | | |
* | | | Timers: Immediately signal the timer if it was started with an initial value of 0.Subv2017-02-222-16/+31
| |/ / |/| |
* | | HID: move enable_accelerometer/gyroscope_count initialization into Init() (#2574)Weiyi Wang2017-02-171-2/+5
| | | | | | | | | Fixes #2556
* | | HLE/IPC: Fix uninitialized variables in helpers (#2568)Yuri Kunde Schlesner2017-02-141-3/+3
| | | | | | | | | Fixes #2567
* | | NWM changed to NIMnoah the goodra2017-02-141-1/+1
| | |
* | | turned clang format back onnoah the goodra2017-02-141-1/+1
|/ /
* | Merge pull request #2561 from wwylele/fs-romYuri Kunde Schlesner2017-02-132-1/+5
|\ \ | | | | | | file_sys: change RomFS archive to Self NCCH archive
| * | loader: use self NCCH archivewwylele2017-02-131-1/+1
| | |
| * | file_sys: add Self NCCH archivewwylele2017-02-131-0/+4
| | |
* | | hid: remove the touch field from PadState (#2557)Weiyi Wang2017-02-111-4/+0
|/ /
* | Merge pull request #2027 from Lectem/ipcrefactorWeiyi Wang2017-02-055-68/+363
|\ \ | | | | | | IPC helper
| * | fix wwylele's comment and use typename in templatesLectem2017-02-051-4/+4
| | |
| * | fix comments alignmentLectem2016-12-301-22/+22
| | |
| * | move Pop methods out of class bodyLectem2016-12-261-72/+88
| | |
| * | IPC helpers exampleLectem2016-12-263-35/+40
| | |
| * | IPC helpersLectem2016-12-262-48/+322
| | |
* | | Merge pull request #2496 from mailwl/cfg-memYuri Kunde Schlesner2017-02-041-5/+8
|\ \ \ | | | | | | | | Core: update Kernel Config Memory to latest version (11.2)
| * | | Core: update Kernel Config Memory to latest version (11.2)mailwl2017-01-301-5/+8
| | |/ | |/|
* | | GSP_GPU::StoreDataCache stubbed (#2428)mailwl2017-02-031-1/+28
| | |
* | | HLE/Applets: Stub Mint (eShop) Applet (#2463)mailwl2017-01-313-0/+106
|/ / | | | | | | This allows Phoenix Wright - Dual Destinies to boot.
* | Merge pull request #2368 from wwylele/camera-2Yuri Kunde Schlesner2017-01-303-172/+1242
|\ \ | | | | | | CAM: build the service framework with a dummy implementation
| * | CAM: implement basic camera functions with a blank camerawwylele2017-01-113-172/+1242
| |/
* | Merge pull request #2429 from wwylele/auto-language-fixYuri Kunde Schlesner2017-01-301-36/+38
|\ \ | | | | | | CFG: move language override to the boot process
| * | CFG: override language setting on bootwwylele2017-01-191-36/+38
| | |
* | | core: fix err_f.cpp warning about unhandled enumeration value on OSXKloen2017-01-291-0/+2
| | |
* | | Merge pull request #2434 from mailwl/nfc-amiiboYuri Kunde Schlesner2017-01-264-20/+249
|\ \ \ | | | | | | | | Service/NFC: stub some functions
| * | | Service/NFC: stub some functionsmailwl2017-01-144-20/+249
| | | | | | | | | | | | | | | | Tested on: Mini-Mario & Friends - amiibo Challenge
* | | | core: fix mic_u warnings on MSVCKloen2017-01-231-4/+4
| | | |
* | | | HID: reset acceleroeter and gyroscope index in Initwwylele2017-01-201-0/+2
| | | |
* | | | CoreTiming: use named constant for ARM11 clock ratewwylele2017-01-161-3/+3
| | | |
* | | | HID: manages updating itself using correct tickswwylele2017-01-162-58/+93
|/ / /
* / / GSP::WriteHWRegsWithMask: fix register maskmailwl2017-01-141-1/+1
|/ /
* | Merge pull request #2425 from Subv/cleanup_todosbunnei2017-01-124-32/+30
|\ \ | | | | | | Implement some TODOs in the code.
| * | Threads: Check the process' resource limit for the max allowed priority when creating a thread and remove the priority clamping code.Subv2017-01-112-13/+9
| | |
| * | Thread: Added priority range checking to svcSetThreadPriority and removed priority clamping code from Thread::SetPriority.Subv2017-01-113-18/+18
| | |
| * | Y2R: Use the proper error code when GetStandardCoefficient receives an invalid value.Subv2017-01-111-1/+3
| | |
* | | Merge pull request #2308 from mailwl/ac-ibunnei2017-01-128-295/+418
|\ \ \ | |/ / |/| | Service/AC: add ac:i service
| * | Service/AC: add ac:i servicemailwl2016-12-308-295/+418
| | |
* | | Merge pull request #2397 from Subv/pulsebunnei2017-01-105-13/+20
|\ \ \ | | | | | | | | Kernel: Implemented Pulse event and timers.
| * | | Kernel: Implemented Pulse event and timers.Subv2017-01-055-13/+20
| |/ / | | | | | | | | | Closes #1904
* | | Merge pull request #2410 from Subv/sleepthreadbunnei2017-01-073-0/+14
|\ \ \ | | | | | | | | Don't yield execution in SleepThread(0) if there are no available threads to run
| * | | Kernel: Don't attempt to yield execution in SleepThread(0) if there are no available threads to run.Subv2017-01-063-0/+14
| | | | | | | | | | | | | | | | With this we avoid an useless temporary deschedule of the current thread.
* | | | Merge pull request #2396 from Subv/sema_acquirebunnei2017-01-071-1/+2
|\ \ \ \ | | | | | | | | | | Kernel/Semaphore: Fixed a regression in semaphore waits.
| * | | | Kernel/Semaphore: Fixed a regression in semaphore waits.Subv2017-01-051-1/+2
| |/ / / | | | | | | | | | | | | | | | | | | | | The regression was caused by a missing check in #2260. The new behavior is consistent with the real kernel.
* | | | Kernel: Fix SharedMemory objects always returning error when addr = 0 (#2404)Hyper2017-01-061-1/+5
| | | | | | | | | | | | Closes #2400
* | | | Merge pull request #2408 from Subv/priority_boostingbunnei2017-01-061-27/+0
|\ \ \ \ | | | | | | | | | | Kernel: Removed the priority boost code for starved threads.
| * | | | Kernel: Removed the priority boost code for starved threads.Subv2017-01-051-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.Subv2017-01-052-32/+0
|/ / /
* | | Merge pull request #2393 from Subv/synchSebastian Valle2017-01-0517-159/+221
|\ \ \ | | | | | | | | Kernel: Mutex priority inheritance and synchronization improvements.
| * | | Kernel: Add some asserts to enforce the invariants in the scheduler.Subv2017-01-052-2/+13
| | | |
| * | | Kernel: Remove a thread from all of its waiting objects' waiting_threads list when it is awoken.Subv2017-01-051-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.Subv2017-01-054-21/+22
| | | |
| * | | Kernel: Use different thread statuses when a thread calls WaitSynchronization1 and WaitSynchronizationN with wait_all = true.Subv2017-01-043-16/+20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit removes the overly general THREADSTATUS_WAIT_SYNCH and replaces it with two more granular statuses: THREADSTATUS_WAIT_SYNCH_ANY when a thread waits on objects via WaitSynchronization1 or WaitSynchronizationN with wait_all = false. THREADSTATUS_WAIT_SYNCH_ALL when a thread waits on objects via WaitSynchronizationN with wait_all = true.
| * | | Kernel/Mutex: Propagate thread priority changes to other threads inheriting the priority via mutexesSubv2017-01-045-42/+60
| | | |
| * | | Kernel/Mutex: Update a mutex priority when a thread stops waiting on it.Subv2017-01-045-24/+42
| | | |
| * | | Kernel/Mutex: Implemented priority inheritance.Subv2017-01-045-31/+51
| | | | | | | | | | | | | | | | | | | | | | | | | | | | The implementation is based on reverse engineering of the 3DS's kernel. A mutex holder's priority will be temporarily boosted to the best priority among any threads that want to acquire any of its held mutexes. When the holder releases the mutex, it's priority will be boosted to the best priority among the threads that want to acquire any of its remaining held mutexes.
| * | | Kernel: Object ShouldWait and Acquire calls now take a thread as a parameter.Subv2017-01-0417-68/+56
| | | | | | | | | | | | | | | | This will be useful when implementing mutex priority inheritance.
| * | | Kernel/Synch: Do not attempt a reschedule on every syscall.Subv2017-01-042-2/+18
| |/ / | | | | | | | | | Not all syscalls should cause reschedules, this commit attempts to remedy that, however, it still does not cover all cases.
* | | Fix some warnings (#2399)Jonathan Hao2017-01-044-8/+6
| | |
* | | Service/NFC: stub GetTagInRangeEventmailwl2016-12-305-0/+42
|/ / | | | | | | Fix Fatal Error in Mini-Mario & Friends - amiibo Challenge
* | Merge pull request #2240 from wwylele/auto-regionbunnei2016-12-302-2/+62
|\ \ | | | | | | Config: auto-select region and language
| * | Config: auto-select region and languagewwylele2016-12-072-2/+62
| | |
* | | Core: remove unused hle.cppwwylele2016-12-271-58/+0
| |/ |/|
* | core: Move emu_window and key_map into coreMerryMage2016-12-231-1/+1
| | | | | | | | * Removes circular dependences (common should not depend on core)
* | Service/NWM: add nwm servicesmailwl2016-12-2217-8/+301
| |
* | Merge pull request #2343 from bunnei/core-cleanupbunnei2016-12-2213-135/+108
|\ \ | | | | | | Core: Top-level consolidate & misc cleanup
| * | ThreadContext: Move from "core" to "arm_interface".bunnei2016-12-222-4/+5
| | |
| * | core: Replace "AppCore" nomenclature with just "CPU".bunnei2016-12-224-44/+43
| | |
| * | Address clang-format issues.bunnei2016-12-222-11/+12
| | |
| * | core: Remove HLE module, consolidate code & various cleanups.bunnei2016-12-2212-82/+53
| | |
| * | core: Consolidate core and system state, remove system module & cleanups.bunnei2016-12-225-45/+45
| | |
* | | Merge pull request #2285 from mailwl/csnd-formatbunnei2016-12-222-49/+92
|\ \ \ | |/ / |/| | csnd:SND: Reformat source code
| * | csnd:SND reformat source codemailwl2016-12-122-49/+92
| | |
* | | Thread: remove the thread from the thread list when exitingwwylele2016-12-173-3/+15
| | |
* | | Kernel: remove object's waiting thread if it is deadwwylele2016-12-161-1/+2
| | |
* | | Merge pull request #2260 from Subv/schedulingbunnei2016-12-167-195/+209
|\ \ \ | | | | | | | | Threading: Reworked the way our scheduler works.
| * | | Fixed the codestyle to match our clang-format rules.Subv2016-12-143-27/+39
| | | |
| * | | Properly remove a thread from its wait_objects' waitlist when it is awoken by a timeout.Subv2016-12-103-2/+11
| | | |
| * | | WaitSynch: Removed unused variables and reduced SharedPtr copies.Subv2016-12-094-73/+56
| | | | | | | | | | | | | | | | | | | | | | | | Define a variable with the value of the sync timeout error code. Use a boost::flat_map instead of an unordered_map to hold the equivalence of objects and wait indices in a WaitSynchN call.
| * | | Use boost remove_erase_if instead of the erase-remove idiomSubv2016-12-071-2/+3
| | | |
| * | | Improved the algorithm for GetHighestPriorityReadyThread.Subv2016-12-071-14/+13
| | | |
| * | | Threading: Added some utility functions and const correctness.Subv2016-12-043-15/+35
| | | |
| * | | Threading: Reworked the way our scheduler works.Subv2016-12-047-189/+179
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Threads will now be awakened when the objects they're waiting on are signaled, instead of repeating the WaitSynchronization call every now and then. The scheduler is now called once after every SVC call, and once after a thread is awakened from sleep by its timeout callback. This new implementation is based off reverse-engineering of the real kernel. See https://gist.github.com/Subv/02f29bd9f1e5deb7aceea1e8f019c8f4 for a more detailed description of how the real kernel handles rescheduling.
* | | | Merge pull request #2328 from wwylele/fix-traceYuri Kunde Schlesner2016-12-161-11/+9
|\ \ \ \ | | | | | | | | | | Fix debug build from #2249
| * | | | FS: fix debug build from #2249wwylele2016-12-151-11/+9
| | | | |
* | | | | Merge pull request #2320 from mailwl/cecd-updateYuri Kunde Schlesner2016-12-167-13/+79
|\ \ \ \ \ | | | | | | | | | | | | Service/CECD: Add cecd:ndm service
| * | | | | Service/CECD: Add cecd:ndm servicemailwl2016-12-157-13/+79
| | | | | |
* | | | | | Merge pull request #2331 from lioncash/truncbunnei2016-12-151-1/+2
|\ \ \ \ \ \ | | | | | | | | | | | | | | hid: Get rid of a double -> float truncation warning
| * | | | | | hid: Get rid of a double -> float truncation warningLioncash2016-12-151-1/+2
| | |/ / / / | |/| | | | | | | | | | | | | | | | float literals need to have the 'f' prefix.
* | | | | | Merge pull request #2330 from lioncash/pragmaSebastian Valle2016-12-152-0/+4
|\ \ \ \ \ \ | | | | | | | | | | | | | | core: Add missing #pragma once directives where applicable
| * | | | | | core: Add missing #pragma once directives where applicableLioncash2016-12-152-0/+4
| |/ / / / /
* / / / / / act: Fix docstring typoLioncash2016-12-151-1/+1
|/ / / / / | | | | | | | | | | | | | | | These aren't the AM services.
* | | | | Merge pull request #2314 from mailwl/accountbunnei2016-12-157-6/+38
|\ \ \ \ \ | |/ / / / |/| | | | Service/ACT: move ACT services to folder
| * | | | Service/ACT: move ACT services to foldermailwl2016-12-147-6/+38
| | | | |
* | | | | Merge pull request #2249 from Subv/sessions_v3Yuri Kunde Schlesner2016-12-1523-168/+586
|\ \ \ \ \ | |/ / / / |/| | | | Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication.
| * | | | Fixed the codestyle to match our clang-format rules.Subv2016-12-1416-68/+108
| | | | |
| * | | | Moved the HLE command buffer translation task to ServerSession instead of the HLE handler superclass.Subv2016-12-096-47/+38
| | | | |
| * | | | Kernel/IPC: Small codestyle cleanupSubv2016-12-092-3/+1
| | | | |
| * | | | Added a framework for partially handling Session disconnections.Subv2016-12-088-9/+67
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Further implementation will happen in a future commit. Fixes a regression.
| * | | | Use std::move where appropriate.Subv2016-12-0811-177/+186
| | | | |
| * | | | Return an error code when connecting to a saturated port.Subv2016-12-055-7/+20
| | | | | | | | | | | | | | | | | | | | The error code was taken from the 3DS kernel.
| * | | | HLE: Use a member variable instead of a virtual function to retrieve the max number of sessions that can be connected to an HLE service at the same time.Subv2016-12-055-8/+18
| | | | |
| * | | | Split SessionRequestHandler::HandleSyncRequest into HandleSyncRequest, TranslateRequest and HandleSyncRequestImpl.Subv2016-12-056-22/+59
| | | | | | | | | | | | | | | | | | | | HandleSyncRequest now takes care of calling the command buffer translate function before actually invoking the command handler for HLE services.
| * | | | Kernel: Remove the Redirection handle type.Subv2016-12-051-2/+0
| | | | |
| * | | | KServerPorts now have an HLE handler "template", which is inherited by all ServerSessions created from it.Subv2016-12-0512-69/+86
| | | | |
| * | | | Declare empty ServerSession and ClientSession constructors as default.Subv2016-12-032-4/+4
| | | | |
| * | | | Threads do not wait for the server endpoint to call AcceptSession before returning from a ConnectToPort or GetServiceHandle call.Subv2016-12-012-3/+5
| | | | |
| * | | | Fixed the rebase mistakes.Subv2016-12-0110-82/+76
| | | | |
| * | | | A bit of a redesign.Subv2016-12-0113-263/+266
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Sessions and Ports are now detached from each other. HLE services are handled by means of a SessionRequestHandler class, Interface now inherits from this class. The File and Directory classes are no longer kernel objects, but SessionRequestHandlers instead, bound to a ServerSession when requested. File::OpenLinkFile now creates a new session pair and binds the File instance to it.
| * | | | IPC/HLE: Associate the ClientSessions with their parent port's HLE interface if it exists.Subv2016-12-016-26/+21
| | | | | | | | | | | | | | | | | | | | Pass the triggering ServerSession to the HLE command handler to differentiate which session caused the request.
| * | | | Kernel/HLE: Service::Interface no longer inherits from any Kernel object, and is now its own standalone class.Subv2016-12-014-24/+52
| | | | | | | | | | | | | | | | | | | | Interface is now used by aggregation in ClientPort, to forward service commands to their HLE implementation if needed.
| * | | | fixup! Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication.Subv2016-12-014-5/+6
| | | | |
| * | | | Kernel/IPC: Use Ports and Sessions as the fundamental building block of Inter Process Communication.Subv2016-12-0115-86/+310
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | All handles obtained via srv::GetServiceHandle or svcConnectToPort are references to ClientSessions. Service modules will wait on the counterpart of those ClientSessions (Called ServerSessions) using svcReplyAndReceive or svcWaitSynchronization[1|N], and will be awoken when a SyncRequest is performed. HLE Interfaces are now ClientPorts which override the HandleSyncRequest virtual member function to perform command handling immediately.
* | / / Minor amendment of GSP_GPU::ImportDisplayCaptureInfo codeJamePeng2016-12-131-3/+5
| |/ / |/| |
* | | APT::GetStartupArgument: force clear startup argumentmailwl2016-12-112-5/+11
| | |
* | | Add all services to the Service namespaceLioncash2016-12-1142-473/+378
| | | | | | | | | | | | | | | Previously there was a split where some of the services were in the Service namespace and others were not.
* | | Merge pull request #2291 from lioncash/svcbunnei2016-12-099-12/+59
|\ \ \ | | | | | | | | service: Add the cfg:nor service
| * | | service: Add cfg:nor serviceLioncash2016-12-093-0/+47
| | | |
| * | | service: Drop '_Interface' from cfg service namesLioncash2016-12-097-12/+12
| | | |
* | | | Merge pull request #2292 from lioncash/boolYuri Kunde Schlesner2016-12-091-1/+1
|\ \ \ \ | |/ / / |/| | | ptm: Use boolean instead of integral value
| * | | ptm: Use boolean instead of integral valueLioncash2016-12-091-1/+1
| | | | | | | | | | | | | | | | The third parameter of Write is actually a bool type, not an int.
* | | | service: Add the ptm:s serviceLioncash2016-12-083-0/+14
| | | | | | | | | | | | | | | | 3dbrew documents this as being the exact same as ptm:sysm
* | | | service: Add common ptm:u commands to other ptm servicesLioncash2016-12-084-0/+54
| | | | | | | | | | | | | | | | | | | | 3dbrew indicates that all services have access to these commands except for ptm:sets.
* | | | service: Drop '_Interface' in ptm service class namesLioncash2016-12-087-14/+14
| | | | | | | | | | | | | | | | Inheriting from Service::Interface makes this obvious.
* | | | service: Add ptm::gets and ptm::sets servicesLioncash2016-12-085-0/+86
| | | |
* | | | service: Add mvd and qtm servicesLioncash2016-12-0813-0/+259
| | | | | | | | | | | | | | | | | | | | | | | | Adds the two New3DS-only modules. 3dbrew was used for command information.
* | | | service: Add nfc servicesLioncash2016-12-087-30/+193
| | | | | | | | | | | | | | | | 3dbrew was used for the command information.
* | | | Merge pull request #2283 from lioncash/svcYuri Kunde Schlesner2016-12-0821-28/+212
|\ \ \ \ | | | | | | | | | | service: Update function tables
| * | | | ssl_c: Update function tableLioncash2016-12-081-0/+3
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew
| * | | | ptm: Update ptm_sysm function tableLioncash2016-12-083-6/+7
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | pm_app: Update function tableLioncash2016-12-081-6/+9
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | nwm_uds: Update function tableLioncash2016-12-081-5/+7
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | nim: Update function tablesLioncash2016-12-082-0/+2
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | http_c: Update function tableLioncash2016-12-081-0/+4
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | gsp_lcd: Update function tableLioncash2016-12-081-0/+4
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | fs_user: Update function tableLioncash2016-12-081-0/+2
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | dlp_srvr: Update function tableLioncash2016-12-081-0/+7
| | | | |
| * | | | cfg: Update function tablesLioncash2016-12-083-0/+3
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew
| * | | | cecd_u: Update function tableLioncash2016-12-081-1/+13
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | boss_p: Update function tableLioncash2016-12-081-3/+68
| | | | |
| * | | | act: Update function tablesLioncash2016-12-082-0/+10
| | | | | | | | | | | | | | | | | | | | Updated based off information from 3dbrew.
| * | | | apt: Update apt function tablesLioncash2016-12-082-7/+73
| |/ / / | | | | | | | | | | | | Updated based off information from 3dbrew.
* | | | Merge pull request #2281 from lioncash/appletYuri Kunde Schlesner2016-12-088-30/+22
|\ \ \ \ | |/ / / |/| | | applet: minor interface changes
| * | | applet: Move common IsRunning underlying variable to the Applet classLioncash2016-12-078-28/+19
| | | | | | | | | | | | | | | | Gets rid of basic duplication.
| * | | applet: Make virtual destructor defaultedLioncash2016-12-071-1/+1
| | | |
| * | | applet: Make constructor protectedLioncash2016-12-071-1/+2
| | | | | | | | | | | | | | | | | | | | Considering the class is abstract, there's no need to make the constructor public.
* | | | Update AM service function tablesLioncash2016-12-086-113/+246
| |_|/ |/| | | | | | | | Updated based off information from 3dbrew.
* | | Merge pull request #2232 from wwylele/other-savebunnei2016-12-073-2/+15
|\ \ \ | |/ / |/| | FS: implement archives for other game save data
| * | FileSys: Implement OtherSaveDatawwylele2016-11-293-0/+12
| | |
| * | FS: add missing MediaTypewwylele2016-11-291-1/+1
| | |
| * | FileSys: abstract SD save data archive sourcewwylele2016-11-291-1/+2
| | |
* | | GSP: Downgrade log severity of SetAxiConfigQoSModeYuri Kunde Schlesner2016-12-041-1/+1
| |/ |/| | | | | | | This function doesn't need to do anything for HLE and some games call it quite often, spamming up the logs.
* | Set client SDK version to Service APIsmailwl2016-11-307-13/+86
|/
* Merge pull request #2196 from Subv/system_modeYuri Kunde Schlesner2016-11-282-6/+4
|\ | | | | Kernel/Loader: Grab the system mode from the NCCH ExHeader.
| * Kernel/Loader: Grab the system mode from the NCCH ExHeader.Subv2016-11-202-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
* | Merge pull request #2132 from wwylele/fix-fs-errSebastian Valle2016-11-285-43/+37
|\ \ | | | | | | Correct FS error codes & add path boundary checks
| * | FileSys: rename SaveDataCheck archive to NCCH archivewwylele2016-11-192-6/+5
| | | | | | | | | | | | According to the observation from game and 3dbrew "Used for accessing general NCCH data"
| * | PTM & CFG: use the correct path and error code according to the new FileSys policywwylele2016-11-192-5/+6
| | |
| * | FileSys: add SDMCWriteOnlyArchivewwylele2016-11-192-0/+9
| | |
| * | FileSys: add ExtSaveDataArchivewwylele2016-11-191-0/+1
| | | | | | | | | | | | ExtSaveData is more similar to SaveData, so let it be a subclass of SaveData
| * | FileSys: add SaveDataArchivewwylele2016-11-191-0/+7
| | | | | | | | | | | | The error checking of SaveDataArchive is completely different from DiskArchive, so it has to be a new class instead of a subclass of DiskArchive.
| * | FileSys: make Archive interfaces return error codewwylele2016-11-011-32/+9
| | | | | | | | | | | | and make the mode parameter a reference since it is a BitField union
* | | Output parameters to logmailwl2016-11-251-4/+6
| | |
* | | MIC_U: Stub service funcionsmailwl2016-11-252-16/+305
| | |
* | | Bravely Default/Second stuck #1822 (#2188)pippo29312016-11-244-2/+22
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Bravely Default/Second stuck #1822 CancelLibraryApplet stub * Log parameter. * Taking care of comments * Sync with 3DBrew * White space ? * lower case
* | | Merge pull request #2186 from wwylele/config9Yuri Kunde Schlesner2016-11-241-2/+8
|\ \ \ | | | | | | | | cfg: add config block 0x00090000
| * | | cfg: add config block 0x00090000wwylele2016-11-171-2/+8
| | |/ | |/|
* | | Merge pull request #1654 from JamePeng/errdispYuri Kunde Schlesner2016-11-241-118/+198
|\ \ \ | | | | | | | | Rework the code of err:f service!
| * | | Rework the code of err:f serviceJamePeng2016-10-061-118/+198
| | | |
* | | | Merge pull request #2193 from Subv/pulse_eventsbunnei2016-11-202-0/+10
|\ \ \ \ | | | | | | | | | | Kernel/Events: Log an error when trying to create Pulse events and timers
| * | | | Kernel/Events: Log an error when trying to create Pulse events and timers.Subv2016-11-192-0/+10
| | |/ / | |/| | | | | | | | | | Related to #1904
* / | | APT/Applets: Renamed the members of the SignalType enum.Subv2016-11-195-16/+27
|/ / / | | | | | | | | | Names now make sense and match 3dbrew.
* | | Style fixmailwl2016-11-021-2/+2
| | |
* | | Rename AcConfig, change types u8 to u32mailwl2016-11-021-21/+25
| | |
* | | AC_U: Stub functions, used if EULA agreedmailwl2016-11-022-14/+190
| |/ |/|
* | Merge pull request #2126 from wwylele/stub-nwmbunnei2016-10-311-0/+11
|\ \ | | | | | | NWM: stub Initialize with an error
| * | NWM: stub Initialize with an errorwwylele2016-10-121-0/+11
| |/
* | core: some errno values are uncommon on UnixJan Beich2016-10-281-0/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | src/core/hle/service/soc_u.cpp:107:6: error: 'ENODATA' was not declared in this scope {ENODATA, 43}, ^ src/core/hle/service/soc_u.cpp:117:6: error: 'ENOSR' was not declared in this scope {ENOSR, 53}, ^ src/core/hle/service/soc_u.cpp:118:6: error: 'ENOSTR' was not declared in this scope {ENOSTR, 54}, ^ src/core/hle/service/soc_u.cpp:139:6: error: 'ETIME' was not declared in this scope {ETIME, 75}, ^
* | FRD: fix GetMyFriendKeymailwl2016-10-251-1/+1
| |
* | Fix typosRicardo de Almeida Gonzaga2016-10-203-3/+3
| |
* | Merge pull request #2024 from JamePeng/update-boss-codebunnei2016-10-083-4/+1808
|\ \ | |/ |/| Update the stub code of BOSS
| * Update the stub code of BOSSJamePeng2016-10-023-4/+1808
| |
* | Merge pull request #1652 from wwylele/kernal-toolbunnei2016-10-057-7/+26
|\ \ | | | | | | Debugger: implement wait tree widget
| * | move ResetType to kernel.hwwylele2016-09-223-7/+6
| | |
| * | name objectswwylele2016-09-221-0/+4
| | |
| * | implement wait tree widgetwwylele2016-09-224-0/+16
| |/
* | fs: clean up log formatwwylele2016-10-021-22/+24
| |
* | fs: implement DeleteDirectoryRecursivelywwylele2016-10-023-1/+51
|/
* Use negative priorities to avoid special-casing the self-includeYuri Kunde Schlesner2016-09-2172-72/+72
|
* Remove empty newlines in #include blocks.Emmanuel Gil Peyrot2016-09-2182-210/+71
| | | | | | | 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-formatYuri Kunde Schlesner2016-09-1971-362/+383
|
* Sources: Run clang-format on everything.Emmanuel Gil Peyrot2016-09-18132-3462/+4009
|
* arm: ResetContext shouldn't be part of ARM_Interface.bunnei2016-09-151-1/+17
|
* Merge pull request #2023 from yuriks/autobase-bcfntbunnei2016-08-303-30/+68
|\ | | | | Auto-detect original shared_font.bin memory base
| * Auto-detect original shared_font.bin memory baseYuri Kunde Schlesner2016-08-273-30/+68
| | | | | | | | | | This allows a file dumped from either an o3DS or a n3DS (and potentially even an original unrebased file) to be used.
* | Merge pull request #1948 from wwylele/cro++Yuri Kunde Schlesner2016-08-298-97/+3007
|\ \ | | | | | | Implemented CRO
| * | LDR: Implement CROwwylele2016-08-278-97/+3007
| |/
* / fix #1942 and adds a few IPC functions for descriptorsLectem2016-08-025-22/+110
|/
* Merge pull request #1950 from JamePeng/fix-apt-0x0055004-and-0x00560000bunnei2016-07-295-22/+31
|\ | | | | Correct APT::0x00550040 and APT::0x00560000 function
| * Correct APT::0x00550040 and APT::0x00560000 functionJamePeng2016-07-155-22/+31
| |
* | Instead of segfaulting, log an error to remind the user to dump the shared font fileHenrik Rydgard2016-07-281-0/+7
| |
* | HLE: implement system timewwylele2016-07-232-2/+60
|/
* Merge pull request #1894 from wwylele/set-config-blockYuri Kunde Schlesner2016-07-106-37/+253
|\ | | | | Implement config savegame editing & clean up
| * Service::CFG/FS: add and refactor out utilities for front-endwwylele2016-07-034-15/+146
| |
| * Service::CFG: move known block ID to an enumwwylele2016-07-031-11/+25
| |
| * Service::CFG: add SetConfigInfoBlk4wwylele2016-07-034-8/+73
| |
| * Service::CFG: add missing languagewwylele2016-07-021-1/+2
| |
| * Service::CFG: name sound output modeswwylele2016-07-022-2/+7
| |
* | Merge pull request #1940 from JamePeng/fix-archive-error-codebunnei2016-07-072-10/+15
|\ \ | | | | | | Fix the errorcode of archive handle
| * | Fix the errorcode of archive handleJamePeng2016-07-042-10/+15
| | |
* | | Merge pull request #1921 from Subv/fs_funcsSebastian Valle2016-07-051-11/+42
|\ \ \ | | | | | | | | HLE/FS: Document some command parameters and implemented command 0x08560240
| * | | HLE/FS: Document some command parameters and implemented command 0x08560240 (CreateLegacySystemSaveData)Subv2016-07-031-11/+42
| | | |
* | | | HLE/Applets: Implement ErrEula appletmailwl2016-07-044-0/+116
| |/ / |/| |
* | | Result: fix and update ErrorModulewwylele2016-06-301-6/+19
| |/ |/|
* | Merge pull request #1869 from wwylele/dont-be-lazyYuri Kunde Schlesner2016-06-291-2/+6
|\ \ | | | | | | Switch context to the same thread if necessary
| * | Switch context on the same thread if necessarywwylele2016-05-301-2/+6
| | |
* | | Merge pull request #1867 from mailwl/srv-updatebunnei2016-06-292-15/+125
|\ \ \ | | | | | | | | srv: Update according 3dbrew
| * | | Fix parameter name in EnableNotificationmailwl2016-05-312-2/+6
| | | |
| * | | Fix mistakes, add output header codesmailwl2016-05-311-8/+24
| | | |
| * | | remove ugly functionmailwl2016-05-311-35/+3
| | | |
| * | | srv: Update according 3dbrewmailwl2016-05-311-15/+137
| |/ /
* | | Merge pull request #1877 from wwylele/wait-fix-timeoutbunnei2016-06-181-0/+49
|\ \ \ | |_|/ |/| | Thread: update timeout when reruning WaitSynch
| * | Thread: update timeout when rerunning WaitSynchwwylele2016-06-041-0/+49
| |/
* | Merge pull request #1842 from Subv/portsbunnei2016-06-127-3/+174
|\ \ | | | | | | Kernel: Added ClientPort and ServerPort classes, along with svcCreatePort.
| * | Kernel/SVC: Implemented svcCreatePort.Subv2016-06-116-3/+41
| | |
| * | Kernel: Added ClientPort and ServerPort classes.Subv2016-06-055-2/+135
| | | | | | | | | | | | This is part of an ongoing effort to implement support for multiple processes.
* | | hid: add missing headerwwylele2016-06-111-0/+2
| | |
* | | Merge pull request #1789 from wwylele/input-refactorbunnei2016-06-112-35/+36
|\ \ \ | | | | | | | | Refactor input mapping & implement circle pad modifier
| * | | fixup! fixup! Refactor input systemwwylele2016-05-151-1/+1
| | | |
| * | | Refactor input subsystemwwylele2016-05-152-35/+36
| | | |
* | | | service: Add other DLP servicesLioncash2016-06-059-21/+142
| |/ / |/| | | | | | | | | | | | | | Specifically, dlp::CLNT and dlp::FKCL Moves them to their own folder like with other services.
* | | gsp::gpu: Reset g_thread_id in UnregisterInterruptRelayQueuemailwl2016-06-012-15/+22
| |/ |/|
* | Merge pull request #1692 from Subv/rm_getpointer2bunnei2016-05-3013-128/+202
|\ \ | | | | | | Memory: Remove most usages of GetPointer
| * | Memory: Handle RasterizerCachedMemory and RasterizerCachedSpecial page types in the memory block manipulation functions.Subv2016-05-281-1/+0
| | |
| * | Memory: Make ReadBlock and WriteBlock accept void pointers.Subv2016-05-282-13/+11
| | |
| * | SOC_U: Remove usage of GetPointerSubv2016-05-281-27/+73
| | |
| * | SSL_C: Remove use of Memory::GetPointerMerryMage2016-05-281-4/+3
| | |
| * | GSP_GPU: Remove use of Memory::GetPointerMerryMage2016-05-281-33/+50
| | |
| * | DSP_DSP: Remove use of Memory::GetPointerMerryMage2016-05-281-7/+10
| | |
| * | FS/Archive: Remove use of Memory::GetPointerMerryMage2016-05-281-7/+14
| | |
| * | CFG: Remove use of Memory::GetPointerMerryMage2016-05-211-6/+10
| | |
| * | APT: Remove use of Memory::GetPointerMerryMage2016-05-215-35/+36
| | |
| * | Kernel/Thread: Remove use of Memory::GetPointerMerryMage2016-05-211-1/+1
| | |
| * | Applets/swkdb: Remove use of Memory::GetPointerMerryMage2016-05-211-1/+1
| | |
* | | Merge pull request #1756 from wwylele/config-cleanupbunnei2016-05-291-29/+13
|\ \ \ | | | | | | | | Config block: clean up
| * | | clean up config blockwwylele2016-05-031-29/+13
| | | |
* | | | Merge pull request #1855 from MerryMage/memory-headers-20160526Mat M2016-05-261-0/+1
|\ \ \ \ | | | | | | | | | | Memory: Added necessary headers and removed unnecessary header
| * | | | Memory: Added necessary headers and removed unnecessary headerMerryMage2016-05-261-0/+1
| | |/ / | |/| |
* | | | New3DS: Minor style cleanup to #1520.bunnei2016-05-241-2/+2
| | | |
* | | | Merge pull request #1520 from JamePeng/checknew3dsbunnei2016-05-248-10/+135
|\ \ \ \ | | | | | | | | | | Implement CheckNew3DS and CheckNew3DSApp
| * | | | Implement CheckNew3DS and CheckNew3DSAppJamePeng2016-04-208-10/+135
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Append an item[is_new3ds] to config file[System] group Implement APT::SetNSStateField,it will update the unknown NS_state_field
* | | | | SVC::WaitSynchronizationN: Reschedule at the endwwylele2016-05-211-2/+3
| |/ / / |/| | |
* | | | Update ACT:U and create ACT:A (#1809)András Domonkos2016-05-184-0/+54
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Update ACT_U * Create act_a.h * Create act_a.cpp * Add service ACT:A * Add ACT:A source and header * Fix wrong header
* | | | Merge pull request #1800 from JayFoxRox/set-fpscrbunnei2016-05-182-0/+5
|\ \ \ \ | | | | | | | | | | Set fpscr for new threads
| * | | | Set fpscr for new threadsJannik Vogel2016-05-172-0/+5
| | | | |
* | | | | DSP_DSP: Remove GetHeadphoneStatus logspam (#1799)Maribel2016-05-161-2/+2
| |_|_|/ |/| | |
* | | | Memory: Fixed a regression caused by #1695 and #1689.Subv2016-05-141-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/shmembunnei2016-05-1317-128/+415
|\ \ \ | | | | | | | | 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.Subv2016-05-135-5/+44
| | | |
| * | | Kernel: Account for automatically-allocated shared memories in the amount of used linear heap memory.Subv2016-05-131-0/+5
| | | |
| * | | APT: Move the shared font loading and relocation functions to their own subdirectory services/apt/bcfnt.Subv2016-05-133-66/+165
| | | |
| * | | Kernel/SharedMemory: Log an error when Map fails.Subv2016-05-131-1/+10
| | | |
| * | | Kernel: Implemented shared memory permissions.Subv2016-05-134-9/+50
| | | |
| * | | APT: Implement relocating the shared font to its true address.Subv2016-05-131-9/+74
| | | |
| * | | Kernel/Memory: Remove the Shared Memory region from the legacy memory map.Subv2016-05-131-1/+0
| | | |
| * | | Kernel/SharedMemory: Properly implemented shared memory support.Subv2016-05-1310-118/+147
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Applications can request the kernel to allocate a piece of the linear heap for them when creating a shared memory object. Shared memory areas are now properly mapped into the target processes when calling svcMapMemoryBlock. Removed the APT Shared Font hack as it is no longer needed.
| * | | Kernel/SVC: Fixed the register order for svcCreateMemoryBlock.Subv2016-05-132-2/+3
| | | | | | | | | | | | | | | | R0 is used as the last parameter instead of R4.
* | | | Merge pull request #1695 from Subv/tls_allocbunnei2016-05-134-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.Subv2016-05-074-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_cpubunnei2016-05-082-0/+7
|\ \ \ \ | | | | | | | | | | 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).Subv2016-05-072-0/+7
| |/ / / | | | | | | | | | | | | We do not currently implement any cores other than the AppCore (Core 0).
* | | | Merge pull request #1718 from alex-laties/fixup-type-conversionsbunnei2016-05-071-2/+2
|\ \ \ \ | | | | | | | | | | fixup simple type conversions where possible
| * | | | fixup simple type conversions where possibleAlexander Laties2016-05-071-2/+2
| | | | |
* | | | | Merge pull request #1761 from Subv/applets_fbbunnei2016-05-075-23/+44
|\ \ \ \ \ | |/ / / / |/| | | | HLE/Applets: Use the correct size for the framebuffer SharedMemory
| * | | | HLE/Applets: Use the correct size for the framebuffer SharedMemory in the swkbd and MiiSelector applets.Subv2016-05-075-23/+44
| | |_|/ | |/| |
* | | | Merge pull request #1762 from bunnei/globalbunnei2016-05-063-7/+20
|\ \ \ \ | | | | | | | | | | hle: Get rid of direct global access to g_reschedule
| * | | | HLE: Rename RescheduleIsPending to IsReschedulePending.bunnei2016-05-062-2/+2
| | | | |
| * | | | hle: Get rid of global access to g_rescheduleLioncash2016-03-213-7/+20
| | | | | | | | | | | | | | | | | | | | | | | | | 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.
* | | | | Layout Mii parameters input/output, and return success as result of applet workmailwl2016-05-052-0/+49
| |/ / / |/| | |
* | | | Merge pull request #1732 from wwylele/config00170000bunnei2016-05-032-13/+4
|\ \ \ \ | | | | | | | | | | add config block 0x00170000; remove duplicated content
| * | | | remove duplicated function declarationwwylele2016-05-011-13/+0
| | | | |
| * | | | add config block 0x00170000wwylele2016-04-291-0/+4
| | | | |
* | | | | VideoCore: Run include-what-you-use and fix most includes.Emmanuel Gil Peyrot2016-04-302-1/+1
| | | | |
* | | | | Merge pull request #1650 from JamePeng/update-the-ndm-codebunnei2016-04-303-27/+420
|\ \ \ \ \ | | | | | | | | | | | | Update the stub code of NDM service!
| * | | | | Update the stub code of NDM service!JamePeng2016-04-203-27/+420
| | | | | |
* | | | | | Merge pull request #1647 from mailwl/acu-closeasyncbunnei2016-04-302-1/+29
|\ \ \ \ \ \ | | | | | | | | | | | | | | ac:u: stub CloseAsync; align memory size in svc:GetProcessInfo(type=2)
| * | | | | | ac:u: stub CloseAsync; check memory size aling in svc:GetProcessInfo(type=2)mailwl2016-04-212-1/+29
| |/ / / / /
* | | | | | Merge pull request #1699 from mailwl/gpu-rightsbunnei2016-04-301-2/+38
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | gsp::Gpu: implement AcquireRight, ReleaseRight functions
| * | | | | return checks if event and memory createdmailwl2016-04-231-1/+8
| | | | | |
| * | | | | gsp::Gpu: implement AcquireRight, ReleaseRight functionsmailwl2016-04-221-8/+37
| | | | | |
* | | | | | Common: Remove section measurement from profiler (#1731)Yuri Kunde Schlesner2016-04-292-5/+0
| | | | | | | | | | | | | | | | | | | | | | | | This has been entirely superseded by MicroProfile. The rest of the code can go when a simpler frametime/FPS meter is added to the GUI.
* | | | | | Merge pull request #1708 from MerryMage/dsp_dspbunnei2016-04-273-59/+152
|\ \ \ \ \ \ | | | | | | | | | | | | | | DSP Service: Cleanup
| * | | | | | DSP_DSP: Fix log format strings and argumentsMerryMage2016-04-271-12/+20
| | | | | | |
| * | | | | | DSP_DSP: Add return IPC headersMerryMage2016-04-272-4/+27
| | | | | | |
| * | | | | | DSP_DSP: Updated interrupt implementationMerryMage2016-04-272-42/+106
| | | | | | |
| * | | | | | DSP_DSP: Remove unused variableMerryMage2016-04-241-2/+0
| | | | | | |
* | | | | | | y2r_u: Cleanup some formatting.bunnei2016-04-271-52/+89
| | | | | | |
* | | | | | | Merge pull request #1447 from JamePeng/update-y2r-servicebunnei2016-04-272-32/+357
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Update the code of service y2r!
| * | | | | | | Update the code of service y2r!JamePeng2016-04-202-32/+357
| | |_|/ / / / | |/| | | | |
* | | | | | | am: title_id is long long uintSam Spilsbury2016-04-241-1/+1
| |/ / / / / |/| | | | |
* | | | | | fs: Fix what appears to be a typo (filename_size / file_size)Sam Spilsbury2016-04-231-1/+1
| |/ / / / |/| | | |
* | | | | HWRasterizer: Texture forwardingtfarley2016-04-213-24/+18
|/ / / /
* | | | Merge pull request #1612 from ObsidianX/get-set-sockoptbunnei2016-04-191-3/+97
|\ \ \ \ | |_|/ / |/| | | SOC:U GetSockOpt/SetSockOpt
| * | | Rework sockopt translation to match the error translation code already in placeRyan Loebs2016-04-021-22/+30
| | | |
| * | | Code styleRyan Loebs2016-03-301-2/+2
| | | |
| * | | Added GetSockOptNameRyan Loebs2016-03-301-15/+58
| | | | | | | | | | | | | | | | Filter out and translate invalid sockopt names.
| * | | Derp: win32: typedef int socklen_t;Ryan Loebs2016-03-291-4/+0
| | | |
| * | | But of course, Windows uses 'int' while Linux uses 'socklen_t'Ryan Loebs2016-03-291-0/+4
| | | |
| * | | Compiling on Windows nowRyan Loebs2016-03-291-3/+3
| | | |
| * | | Formatting...Ryan Loebs2016-03-291-1/+1
| | | |
| * | | Addressing PR commentsRyan Loebs2016-03-291-4/+4
| | | |
| * | | SOC UpdatesRyan Loebs2016-03-291-3/+46
| | | | | | | | | | | | | | | | | | | | | | | | -Implement GetSockOpt / SetSockOpt -Fix bug in RecvFrom where sending from localhost does not fill in src_addr/src_addr_len on Linux
* | | | core: Clean out some unnecessary header includesLioncash2016-04-162-9/+0
| | | |
* | | | Set Kernel config "Unknown Value" to 0x1mailwl2016-04-112-2/+7
| |_|/ |/| |
* | | update the code of AM service! (#1623)JamePeng2016-04-086-51/+289
| | |
* | | cecd:u: stub GetCecStateAbbreviated (#1648)mailwl2016-04-083-0/+28
| | |
* | | Merge pull request #1577 from JamePeng/update-apta-funcbunnei2016-04-075-8/+47
|\ \ \ | | | | | | | | Append the missing function name"GetAppletInfo", "SetAppCpuTimeLimit" and "GetAppCpuTimeLimit" to APT:A
| * | | append SetAppCpuTimeLimit and GetAppCpuTimeLimit to APT:AJamePeng2016-04-063-13/+16
| | | |
| * | | implement APT::GetStartupArgumentJamePeng2016-04-045-2/+37
| | | |
| * | | Append the missing function name"GetAppletInfo" to APT:AJamePeng2016-04-041-1/+2
| | | |
* | | | Merge pull request #1435 from mailwl/frd_ubunnei2016-04-064-55/+234
|\ \ \ \ | | | | | | | | | | frd:u: Initial stub some functions
| * | | | frd:u: Initial stub some functionsmailwl2016-03-274-55/+234
| | |/ / | |/| |
* | | | Merge pull request #1643 from MerryMage/make_uniqueMathew Maidment2016-04-062-8/+8
|\ \ \ \ | |_|/ / |/| | | Common: Remove Common::make_unique, use std::make_unique
| * | | Common: Remove Common::make_unique, use std::make_uniqueMerryMage2016-04-052-8/+8
| | |/ | |/|
* | | Merge pull request #1616 from exhalatio/dlp_dummybunnei2016-04-033-0/+61
|\ \ \ | | | | | | | | Dummy implementation dlp:SRVR Service.
| * | | Dummy implementation dlp:SRVR Service.exhalatio2016-04-023-0/+61
| | | |
* | | | Merge pull request #1619 from mailwl/cecdbunnei2016-04-023-3/+54
|\ \ \ \ | | | | | | | | | | cecd:u: stub GetCecInfoEventHandle, GetChangeStateEventHandle
| * | | | cecd:u: stub GetCecInfoEventHandle, GetChangeStateEventHandlemailwl2016-03-313-3/+54
| | | | |
* | | | | Merge pull request #1390 from purpasmart96/citra_gsp_error_codesbunnei2016-04-013-80/+97
|\ \ \ \ \ | | | | | | | | | | | | GSP: Return proper error codes for register writes
| * | | | | GSP: Return proper error codes for register writespurpasmart962016-03-313-80/+97
| |/ / / /
* | | | | Merge pull request #1419 from mailwl/branch-gspbunnei2016-03-311-6/+41
|\ \ \ \ \ | |/ / / / |/| | | | Add gsp functions: SetAxiConfigQoSMode, UnregisterInterruptRelayQueue
| * | | | Add gsp functions: SetAxiConfigQoSMode, UnregisterInterruptRelayQueuemailwl2016-03-311-6/+41
| | |_|/ | |/| |
* / | | Add common methods to all cfg:* portsRyan Loebs2016-03-293-0/+21
|/ / /
* | | use reference instead of pointerwwylele2016-03-261-9/+9
| | |
* | | Merge pull request #1549 from wwylele/acc_gyrobunnei2016-03-264-23/+187
|\ \ \ | |/ / |/| | hid: implement accelerometer and gyroscope back-end
| * | implement GyroscopeCalibrateParamwwylele2016-03-252-9/+20
| | |
| * | implement accel and gyro backendwwylele2016-03-224-23/+176
| | |
* | | Merge pull request #1559 from lioncash/vecbunnei2016-03-211-8/+5
|\ \ \ | | | | | | | | soc_u: Get rid of explicit delete and new
| * | | soc_u: Get rid of explicit delete and newLioncash2016-03-211-8/+5
| | |/ | |/|
* / | session: Make helper functions constexprLioncash2016-03-211-6/+6
|/ /
* | HLE/FS: Change the error code returned when an ExtSaveData archive is not found.Subv2016-03-201-4/+8
| | | | | | | | This allows Fire Emblem to boot again.
* | HLE/FS: Corrected some style concerns.Subv2016-03-204-6/+4
| |
* | HLE/FS: Fixed creating the config savefile when it doesn't exist.Subv2016-03-201-1/+1
| | | | | | | | This fixes a regression.
* | HLE/FS: Implemented GetFormatInfoSubv2016-03-206-48/+127
| | | | | | | | Format information is currently only implemented for the ExtSaveData, SharedExtSaveData and SaveData archives, the information is stored in a file alongside the root folder of the archive.
* | HLE/FS: Don't return an error when deleting the ExtSaveData if it does not exist.Subv2016-03-201-1/+1
| |
* | HLE/FS: Return the proper error codes when opening files.Subv2016-03-201-3/+4
| |
* | HLE/FS: Fixed the OpenDirectory error codeSubv2016-03-201-1/+1
| |
* | HLE/FS: Return the proper error codes on file Read/Write operations.Subv2016-03-202-2/+16
| | | | | | | | These operations are limited by the open flags specified while opening the file.
* | HLE/FS: Corrected the error codes for DeleteFileSubv2016-03-201-4/+1
| |
* | HLE/FS: Corrected the error codes for CreateFileSubv2016-03-201-1/+3
| |
* | HLE/FS: FS::CreateFile takes an u64 for the file size.Subv2016-03-203-5/+5
|/
* Merge pull request #1505 from pippo2931/fefbunnei2016-03-181-1/+25
|\ | | | | GetArchiveResource stub
| * Fix headerpippo29312016-03-121-1/+1
| |
| * GetArchiveResource stubpippo29312016-03-121-1/+25
| |
* | Reorganize the ndm service path for dummy implement functionJamePeng2016-03-145-24/+118
| | | | | | | | | | | | SuspendDaemons , ResumeDaemons , OverrideDefaultDaemons The NDM file move to /core/hle/service/ndm/ now!
* | hid: fix pad updatewwylele2016-03-131-1/+1
| |
* | svc: Move ResetType enum to the kernel event headerLioncash2016-03-1310-16/+17
| |
* | svc: Remove unused ArbitrationType enumLioncash2016-03-121-9/+0
| | | | | | | | An equivalent enum already exists within address_arbiter.h
* | svc: Make ResetType an enum classLioncash2016-03-1211-24/+23
|/
* Merge pull request #1266 from Subv/miiappletbunnei2016-03-126-2/+154
|\ | | | | HLE/Applets: Implemented a dummy Mii Selector applet.
| * HLE/Applets: Implemented a dummy Mii Selector applet.Subv2016-03-126-2/+154
| | | | | | | | This prevents some games (like Super Mario 3D Land) from freezing when trying to launch it, however, it's not complete and won't let you go past Mii selection as the parameter structure hasn't been reverse engineered yet.
* | Merge pull request #1500 from lioncash/nullptrbunnei2016-03-121-1/+1
|\ \ | | | | | | gsp_gpu: Change 0 literal to nullptr
| * | gsp_gpu: Change 0 literal to nullptrLioncash2016-03-121-1/+1
| | |
* | | hle: Update service function tablesLioncash2016-03-124-1/+16
|/ /
* | renderer_base: Don't directly expose the rasterizer unique_ptrLioncash2016-03-092-5/+5
| | | | | | | | | | There's no reason to allow direct access to the unique_ptr instance. Only its contained pointer.
* | DSP: Implement Pipe 2MerryMage2016-03-061-43/+151
| | | | | | | | | | | | Pipe 2 is a DSP pipe that is used to initialize both the DSP hardware (the application signals to the DSP to initialize) and the application (the DSP provides the memory location of structures in the shared memory region).
* | Memory: Do correct Phys->Virt address translation for non-APP linheapYuri Kunde Schlesner2016-03-062-2/+5
| |
* | Merge pull request #1455 from yuriks/ResultVal-unionMathew Maidment2016-03-061-42/+16
|\ \ | | | | | | core: Use unrestricted union to hold storage of ResultVal value
| * | core: Use unrestricted union to hold storage of ResultVal valueYuri Kunde Schlesner2016-03-051-42/+16
| | |
* | | DSP: Print hash of firmware to consoleMerryMage2016-03-061-8/+21
|/ /
* | Merge pull request #1429 from mailwl/branch-acubunnei2016-03-051-2/+17
|\ \ | | | | | | ac:u IsConnected implemented
| * | ac:u: Stub IsConnectedmailwl2016-03-041-2/+17
| | |
* | | Merge pull request #1389 from yuriks/stub-cambunnei2016-03-043-20/+563
|\ \ \ | |/ / |/| | Stub CAM:U service
| * | Service/CAM: Add doxycomments to all service functionsYuri Kunde Schlesner2016-03-011-0/+217
| | |
| * | Service/CAM: Dummy implementation of some functionsYuri Kunde Schlesner2016-02-133-20/+346
| | | | | | | | | | | | Thanks to @mailwl for the initial version of the stubs.
* | | Merge pull request #1434 from Kloen/legendbunnei2016-03-021-0/+1
|\ \ \ | | | | | | | | Add THREADPROCESSORID_ALL on SVC::CreateThread
| * | | ThreadProcessorId_All on SVC::CreateThreadKloen2016-03-011-0/+1
| | | |
* | | | Service/CFG: Fix potential endianess issueYuri Kunde Schlesner2016-03-011-2/+3
| | | |
* | | | Service/CFG: Add block 0x000A0000 (username) to default config fileYuri Kunde Schlesner2016-03-011-1/+14
|/ / /
* | | Initial implementation ir:usermailwl2016-02-263-18/+142
| | |
* | | AudioCore: Skeleton ImplementationMerryMage2016-02-213-58/+94
| | | | | | | | | | | | | | | | | | | | | | | | | | | 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 operatorMerryMage2016-02-127-20/+20
|/ /
* | services: Get rid of unnecessary includesLioncash2016-02-0269-132/+32
| |
* | services: Update function tablesLioncash2016-02-022-5/+11
| |
* | Memory: Implement MMIOMerryMage2016-01-302-4/+8
| |
* | Merge pull request #1327 from Subv/unmap_memblockbunnei2016-01-155-5/+60
|\ \ | | | | | | HLE/SVC: Implement UnmapMemoryBlock.
| * | HLE/SVC: Implement UnmapMemoryBlock.Subv2016-01-145-5/+60
| | | | | | | | | | | | This implementation will need to be (almost completely) changed when we implement multiprocess support.
* | | Merge pull request #1283 from Subv/soc_fixupbunnei2016-01-051-3/+13
|\ \ \ | | | | | | | | HLE/Sockets: Fixed the buffer offset in recvfrom.
| * | | HLE/Sockets: Fixed the buffer offset in recvfrom.Subv2015-12-241-3/+13
| | | | | | | | | | | | | | | | Closes #1277
* | | | services: Update some function tablesLioncash2015-12-3025-113/+369
| |/ / |/| |
* | | HLE/Timers: Reset OneShot timers when they are acquired instead of when they're triggered.Subv2015-12-301-3/+3
| | | | | | | | | | | | Closes #1139
* | | Merge pull request #1300 from Subv/arbitrateaddressbunnei2015-12-292-9/+18
|\ \ \ | | | | | | | | SVC: Fixed ArbitrateAddress to behave as it does on hardware.
| * | | SVC: Fixed ArbitrateAddress to behave as it does on hardware.Subv2015-12-282-9/+18
| | | | | | | | | | | | | | | | This was verified with hwtests that i plan to upload later on.
* | | | svc: Remove superfluous printf argumentLioncash2015-12-251-1/+1
|/ / /
* / / svc: Fix compilation with LOG_TRACE enabledLioncash2015-12-131-1/+1
|/ /
* | VideoCore: Unify interface to OpenGL and SW rasterizersYuri Kunde Schlesner2015-12-082-5/+5
| | | | | | | | | | | | This removes explicit checks sprinkled all over the codebase to instead just have the SW rasterizer expose an implementation with no-ops for most operations.
* | VideoCore: Rename HWRasterizer methods to be less confusingYuri Kunde Schlesner2015-12-072-5/+5
| |
* | Merge pull request #1252 from Subv/cambunnei2015-12-041-0/+156
|\ \ | |/ |/| Services/Cam: Added new log type and camera enums from 3dbrew.
| * Services/Cam: Added new log type and camera enums from 3dbrew.Subv2015-11-231-0/+156
| | | | | | | | | | Followup to #1102 Original author @mailwl
* | Kernel: Implement svcGetSystemInfoYuri Kunde Schlesner2015-12-017-1/+95
| | | | | | | | | | This makes smealum/ctrulib@b96dd51d3349961189d4ab1bc2a5c45deff21c09 work with Citra.
* | Merge pull request #1225 from lioncash/cleanbunnei2015-11-291-12/+13
|\ \ | | | | | | csnd_snd: Get rid of type punning
| * | csnd_snd: Get rid of type punningLioncash2015-10-281-12/+13
| | |
* | | Add stub functions for Initialize and GenerateRandomData in ssl:Cpolaris-2015-11-221-2/+51
| |/ |/|
* | Add Initialize and GenerateRandomData stubspolaris-2015-11-221-0/+2
|/
* Merge pull request #1165 from esoteric-programmer/masterbunnei2015-10-282-4/+66
|\ | | | | Added CSND_ExecuteType0Commands stub.
| * Added CSND stub.Matthias Ernst2015-10-282-4/+66
| |
* | Merge pull request #1208 from archshift/free-bytesbunnei2015-10-283-1/+42
|\ \ | | | | | | Implement FS_User::GetFreeBytes
| * | Implement FS_User::GetFreeBytesarchshift2015-10-283-1/+42
| | |
* | | Fix copy pasteFiliph Sandström2015-10-241-1/+1
| | |
* | | Fix wrong branchFiliph Sandström2015-10-231-0/+12
| | |
* | | Add GetTotalStepCount StubFiliph Sandström2015-10-231-1/+1
| | |
* | | Update ptm.hFiliph Sandström2015-10-231-0/+8
|/ /
* | Silence -Wsign-compare warnings.Rohit Nirmal2015-10-071-1/+1
| |
* | Service/CFG: Use a constexpr function for country initializationEmmanuel Gil Peyrot2015-09-301-4/+3
| | | | | | | | This fixes a TODO left over from when we supported MSVC 2013.
* | fix some xcode 7.0 warningsMartin Lindhe2015-09-291-1/+1
| |
* | general: Silence some warnings when using clangLioncash2015-09-165-10/+12
|/
* Service/CFG: Add default entry for block 0x000A0001 (birthday)Yuri Kunde Schlesner2015-09-141-0/+6
|
* Service/CFG: Correct flags in 2 default blocksYuri Kunde Schlesner2015-09-141-2/+2
| | | | Verified against a 9.2.0-20 config save
* Service/CFG: Add additional blocks to default save dataYuri Kunde Schlesner2015-09-141-0/+34
| | | | These blocks are required by various games to boot.
* Fix narrowing conversion warningYuri Kunde Schlesner2015-09-141-1/+1
|
* Service/CFG: Move several private types from the header to the cppYuri Kunde Schlesner2015-09-142-63/+49
|
* Service/CFG: Clean up default block creationYuri Kunde Schlesner2015-09-142-27/+17
|
* GSP: Implement command 0x05, used for flushing cachesYuri Kunde Schlesner2015-09-142-13/+34
| | | | | | May fix additional texture caching issues. (Though mostly in homebrew, I haven't seen any commercial software use this to flush anything but command lists.)
* General: Replace NULL and '0' usages with nullptr where applicableLioncash2015-09-111-1/+1
|
* General: Fix up doxygen commentsLioncash2015-09-104-7/+4
|
* Merge pull request #1101 from archshift/camu-service-namesbunnei2015-09-031-3/+60
|\ | | | | Add cam:u service function names to its function table
| * Add cam:u service function names to its function tablearchshift2015-09-031-3/+60
| |
* | Merge pull request #1072 from yuriks/GetSystemTick-advance-timebunnei2015-09-011-1/+4
|\ \ | |/ |/| SVC: Advance time when calling GetSystemTick to escape busy-wait loops
| * SVC: Advance time when calling GetSystemTick to escape busy-wait loopsYuri Kunde Schlesner2015-08-301-1/+4
| | | | | | | | | | | | | | | | Cubic Ninja waited for the frame to end by spinning on a loop calling GetSystemTick while doing nothing else. Since GetSystemTick doesn't cause a reschedule (which advances time), this meant that very little emulated time would pass inside that loop, causing the game to spend most of the frame burning away CPU.
* | Kernel: Fix wrong linear heap base on titles using newer kernelsYuri Kunde Schlesner2015-08-281-1/+1
| | | | | | | | Typo which sneaked in through review on #1025
* | Kernel: Fix assertion failure when ControlMemory is called with size=0Yuri Kunde Schlesner2015-08-271-0/+8
| |
* | Core: Improve APT Shared Font hackYuri Kunde Schlesner2015-08-273-4/+29
|/ | | | Should fix invalid read loops in some games
* Integrate the MicroProfile profiling libraryYuri Kunde Schlesner2015-08-252-0/+9
| | | | | This brings goodies such as a configurable user interface and multi-threaded timeline view.
* Merge pull request #1025 from yuriks/heap-managementYuri Kunde Schlesner2015-08-2219-88/+659
|\ | | | | Kernel: Correct(er) handling of Heap and Linear Heap allocations
| * Kernel: Remove unused legacy heap MapBlock_* functionsYuri Kunde Schlesner2015-08-162-77/+0
| |
| * APT: Adjust shared font hack so it works with the new linear heap codeYuri Kunde Schlesner2015-08-161-10/+11
| |
| * Kernel: Implement svcGetProcessInfo in a basic wayYuri Kunde Schlesner2015-08-165-2/+70
| | | | | | | | | | 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 layoutsYuri Kunde Schlesner2015-08-168-27/+139
| | | | | | | | | | | | This adds some structures necessary to support multiple memory regions in the future. It also adds support for different system memory types and the new linear heap mapping at 0x30000000.
| * HLE: Remove empty ConfigMem and SharedPage Shutdown functionsYuri Kunde Schlesner2015-08-165-10/+0
| |
| * Move core/mem_map.{cpp,h} => core/hle/kernel/memory.{cpp,h}Yuri Kunde Schlesner2015-08-164-2/+161
| |
| * Memory: Move address type conversion routines to memory.cpp/hYuri Kunde Schlesner2015-08-163-3/+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 loadingYuri Kunde Schlesner2015-08-162-3/+7
| |
| * Kernel: Properly implement ControlMemory FREE and COMMITYuri Kunde Schlesner2015-08-165-36/+338
| |
| * VMManager: Introduce names for used ResultCodesYuri Kunde Schlesner2015-08-162-6/+11
| |
| * VMManager: Make LogLayout log level configurable as a parameterYuri Kunde Schlesner2015-08-163-5/+15
| |
| * VMManager: Change block offsets to size_tYuri Kunde Schlesner2015-08-162-3/+3
| |
* | GPU: Implement TextureCopy-mode display transfersYuri Kunde Schlesner2015-08-162-11/+25
|/ | | | Fixes glitchy garbage in Fire Emblem 3D scenes.
* core: Eliminate some unused variable warningsLioncash2015-07-292-3/+5
|
* core: Fix missing prototype warningsLioncash2015-07-291-0/+1
|
* Merge pull request #1009 from lioncash/tableYuri Kunde Schlesner2015-07-291-1/+2
|\ | | | | am_net: Update function table data
| * am_net: Add missing function to the function tableLioncash2015-07-291-0/+1
| |
| * am_net: Add correct function name to the function tableLioncash2015-07-291-1/+1
| |
* | Merge pull request #982 from Subv/homebunnei2015-07-297-18/+84
|\ \ | |/ |/| Service/APT: Return proper parameters in GetLockHandle.
| * Service/APT: Fixed a regression, PreloadLibraryApplet should also start an applet when called.Subv2015-07-246-5/+36
| |
| * Service/APT: Return proper parameters in GetLockHandle.Subv2015-07-244-14/+49
| | | | | | | | | | Documented some APT functions This allows applets to boot.
* | Merge pull request #899 from zawata/Winsock-Deprecationbunnei2015-07-281-2/+8
|\ \ | | | | | | SOC:U : Fix WinSock function deprecation
| * | SOC:U : Update deprecated function gethostbyname() to getaddrinfo()zawata2015-07-201-2/+8
| | |
* | | Merge pull request #873 from jroweboy/input_arrayTony Wasserka2015-07-282-1/+14
|\ \ \ | | | | | | | | Move input values into an array.
| * | | Move input values into an arrayJames Rowe2015-07-282-1/+14
| | | |
* | | | dyncom: Rename armdefs.h to armstate.hLioncash2015-07-261-1/+1
|/ / /
* | | Merge pull request #888 from zawata/Warning-Fixes-2Yuri Kunde Schlesner2015-07-252-3/+3
|\ \ \ | | | | | | | | Core\HLE : Fix Warning
| * | | Core\HLE : Fix Warningzawata2015-07-172-3/+3
| |/ / | | | | | | | | | "signed/unsigned mismatch"
* | | Merge pull request #983 from yuriks/null-memory-fillYuri Kunde Schlesner2015-07-241-13/+18
|\ \ \ | | | | | | | | GSP: Don't try to write memory fill registers if start address is 0
| * | | GSP: Don't try to write memory fill registers if start address is 0Yuri Kunde Schlesner2015-07-241-13/+18
| | |/ | |/| | | | | | | | | | Verified to be what GSP does via REing. Fixes invalid virt->phys translation error spam in some games.
* / | Qt/GPU Breakpoints: Added three more breakpoint types:Subv2015-07-231-0/+7
|/ / | | | | | | | | | | * IncomingDisplayTransfer: Triggered just before a display transfer is performed. * GSPCommandProcessed: Triggered right after a GSP command is processed. * BufferSwapped: Triggered when the frames flip
* | Merge pull request #962 from Subv/am_appbunnei2015-07-223-3/+33
|\ \ | | | | | | Services/AM: Stubbed am:app::GetNumContentInfos to return 0 results.
| * | Services/AM: Stubbed am:app::GetNumContentInfos to return 0 results.Subv2015-07-213-3/+33
| | | | | | | | | | | | | | | | | | Named the service functions in am:app as per 3dbrew. This fixes an illegal read loop in Steel Diver
* | | Merge pull request #966 from Subv/logbunnei2015-07-211-4/+8
|\ \ \ | | | | | | | | Services/Logging: Log more useful information when some operations fail.
| * | | Services/Logging: Log more useful information when some operations fail.Subv2015-07-211-4/+8
| |/ / | | | | | | | | | Namely OpenFileDirectly, OpenDirectory and OpenArchive
* | | Merge pull request #957 from Subv/hwtest_crashbunnei2015-07-211-0/+8
|\ \ \ | | | | | | | | Kernel/Scheduling: Clean up a thread's wait_objects when its scheduled.
| * | | Kernel/Scheduling: Clean up a thread's wait_objects when its scheduled.Subv2015-07-211-0/+8
| |/ / | | | | | | | | | They'll be reset if needed during the next svcWaitSynchronization call (if there's any pending)
* | | dyncom: Pass SVC immediates directly.Lioncash2015-07-212-5/+4
| | | | | | | | | | | | Previously it would just re-read the already decoded instruction and extract the immediate value.
* | | Services/CFG: Added some missing functions to cfg:sSubv2015-07-211-1/+3
|/ /
* | Merge pull request #939 from Subv/queryprocmembunnei2015-07-202-6/+28
|\ \ | | | | | | Kernel/SVC: Implemented svcQueryProcessMemory
| * | Kernel/SVC: Implemented svcQueryProcessMemorySubv2015-07-172-6/+28
| | |
* | | Merge pull request #946 from archshift/update-frdubunnei2015-07-201-1/+12
|\ \ \ | | | | | | | | Add more frd:u unknown service commands from 3dbrew
| * | | Add more frd:u unknown service commands from 3dbrewarchshift2015-07-191-1/+12
| |/ /
* / / Change trace/unimplemented service call logs to use hexarchshift2015-07-191-1/+1
|/ / | | | | | | Changes the log to use hex in the parameter list instead of decimal.
* | Merge pull request #938 from Subv/querymemYuri Kunde Schlesner2015-07-172-4/+24
|\ \ | | | | | | Kernel/SVC: Implemented svcQueryMemory.
| * | Kernel/SVC: Implemented svcQueryMemory.Subv2015-07-172-4/+24
| | |
* | | Ensure all kernel objects are released during shutdownYuri Kunde Schlesner2015-07-1712-8/+45
|/ / | | | | | | | | | | | | | | This commit fixes several kernel object leaks. The most severe of them was threads not being removed from the private handle table used for CoreTiming events. This resulted in Threads never being released, which in turn held references to Process, causing CodeSets to never be freed when loading other applications.
* | Archive: Correct a few incorrect types in function signaturesYuri Kunde Schlesner2015-07-141-1/+1
| | | | | | | | Buffer lengths should be size_t, and file offsets should be u64.
* | Add CiTrace recording support.Tony Wasserka2015-07-131-1/+1
| | | | | | | | | | | | This is exposed in the GUI as a new "CiTrace Recording" widget. Playback is implemented by a standalone 3DS homebrew application (which only runs reliably within Citra currently; on an actual 3DS it will often crash still).
* | Merge pull request #921 from linkmauve/fix-appletbunnei2015-07-127-7/+32
|\ \ | | | | | | Fix applet includes using iwyu
| * | Core: Fix applet includes using iwyu.Emmanuel Gil Peyrot2015-07-127-7/+32
| | |
* | | Kernel: Add CodeSet case to Object::IsWaitableYuri Kunde Schlesner2015-07-121-0/+1
|/ /
* | Merge pull request #823 from Subv/applets_drawingbunnei2015-07-1210-58/+563
|\ \ | | | | | | Library applet support (swkbd for now)
| * | Applets: Reworked how the Applet update event is handled.Subv2015-07-127-35/+61
| | | | | | | | | | | | Applets are now cleaned up in AppletUpdateEvent after calling their respective Update method.
| * | Applets: Add infrastructure to allow custom drawing and input handling in Applets.Subv2015-07-127-39/+162
| | |
| * | HLE/APT: Initial HLE support for applets.Subv2015-07-128-50/+406
| | | | | | | | | | | | Currently only the SWKBD is emulated, and there's currently no way to ask the user for input, so it always returns "Subv" as the text.
* | | Core: Properly configure address space when loading a binaryYuri Kunde Schlesner2015-07-125-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 EventYuri Kunde Schlesner2015-07-122-2/+1
|/ /
* | Merge pull request #876 from linkmauve/include-cleanupsYuri Kunde Schlesner2015-07-1123-66/+100
|\ \ | | | | | | Cleanup includes, mostly in common
| * | Core: Cleanup hw includes.Emmanuel Gil Peyrot2015-06-283-0/+7
| | |
| * | Core: Cleanup soc:U includes.Emmanuel Gil Peyrot2015-06-282-26/+36
| | |
| * | Core: Cleanup file_sys includes.Emmanuel Gil Peyrot2015-06-284-8/+20
| | |
| * | Core: Cleanup core includes.Emmanuel Gil Peyrot2015-06-284-7/+5
| | |
| * | CitraQt: Cleanup includes.Emmanuel Gil Peyrot2015-06-283-1/+5
| | |
| * | Common: Cleanup key_map includes.Emmanuel Gil Peyrot2015-06-288-16/+20
| | |
| * | Services: Use the standard _WIN32 define in soc:U instead of our own EMU_PLATFORM.Emmanuel Gil Peyrot2015-06-271-8/+7
| |/
* / Services/SOC: Added command headers to some of the soc commands.Subv2015-06-251-5/+13
|/
* Add helpers to create IPC command buffer headers and descriptorsYuri Kunde Schlesner2015-06-233-7/+43
|
* Merge pull request #860 from yuriks/y2r-colorYuri Kunde Schlesner2015-06-222-174/+348
|\ | | | | Color support for Y2R
| * Y2R: Rework conversion process, enabling support for all formatsYuri Kunde Schlesner2015-06-222-163/+309
| |
| * Y2R: Re-organize how params are stored. Support SetConversionParamsYuri Kunde Schlesner2015-06-211-72/+100
| |
* | Merge pull request #855 from purpasmart96/service_rearrangmentbunnei2015-06-2172-607/+1134
|\ \ | |/ |/| Services: Continue separation of services into their own folders
| * Services: Continue separation of services into their own folderspurpasmart962015-06-1272-607/+1134
| |
* | kernel: Fix svcWaitSynch to always acquire requested wait objects.bunnei2015-06-179-113/+68
|/
* ExtSavedata: Save the icon passed to CreateExtSaveData to the correct folder.Subv2015-06-023-11/+32
| | | | Organize the ExtSaveData folders as they are stored in the console.
* Merge pull request #810 from yuriks/memmapYuri Kunde Schlesner2015-05-302-0/+445
|\ | | | | Kernel: Add VMManager to manage process address spaces
| * Kernel: Add VMManager to manage process address spacesYuri Kunde Schlesner2015-05-272-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 Peyrot2015-05-2922-65/+65
| |
* | hid: Get rid of undefined behaviorLioncash2015-05-271-2/+2
|/ | | | Modifying a variable twice across a sequence point.
* Merge pull request #821 from Subv/ImportDisplayCaptureInfobunnei2015-05-261-1/+47
|\ | | | | Service/GSP: Implemented ImportDisplayCaptureInfo.
| * Service/GSP: Implemented ImportDisplayCaptureInfo.Subv2015-05-261-1/+47
| |
* | Core/SVC: Map the shared memory created in CreateMemoryBlock to the specified address.Subv2015-05-251-0/+2
|/ | | | This SharedMemory can be passed to service functions (Which should map the memory into their own address space).
* y2r_u: Remove unused variable in StartConversionLioncash2015-05-231-1/+0
|
* Merge pull request #801 from purpasmart96/hid_stubsbunnei2015-05-234-9/+47
|\ | | | | HID: Stub DisableAccelerometer and DisableGyroscopeLow
| * HID: Stub DisableAccelerometer and DisableGyroscopeLowpurpasmart962015-05-234-9/+47
| |
* | Flush for y2r (moflex)tfarley2015-05-231-0/+11
| |
* | OpenGL renderertfarley2015-05-231-0/+9
|/
* Service::Y2R: Support for grayscale decoding of specific formatsYuri Kunde Schlesner2015-05-221-35/+265
| | | | | | | | | | | | Implements unrotated planar YUV 4:2:0 -> RGB24 conversions in Y2R. Currently only the Y (luma) channel is used, so the results don't contain color. This will be added in a later PR at some point. This is enough to get all currently know Moflex videos to decode. (Some don't display on-screen due to seemingly unrelated reasons.) Thanks to @archshift for doing the initial implementation which I cleaned up and then fixed the 8x8 block mode.
* Kernel: Fix a warning introduced with ResourceLimit, and remove the fallback code to prevent it from happening again.Emmanuel Gil Peyrot2015-05-211-2/+1
|
* y2r_u: Stub StartConversion to prevent moflex games from hanging.bunnei2015-05-211-1/+17
|
* Kernel: Move reschedules from SVCs to actual mechanisms that reschedule.bunnei2015-05-217-20/+22
|
* Merge pull request #766 from purpasmart96/cfg_service_updatebunnei2015-05-185-337/+304
|\ | | | | CFG: Update the cfg service to be like other integrated services
| * CFG: Update the cfg service to be like other integrated servicespurpasmart962015-05-165-337/+304
| |
* | Merge pull request #772 from lioncash/warnbunnei2015-05-181-3/+3
|\ \ | | | | | | core/video_core: Fix a few warnings when compiling on MSVC.
| * | process: Get rid of warningsLioncash2015-05-141-3/+3
| |/ | | | | | | Sign mismatches and "forcing value to bool" warnings.
* | Implement svcBreakarchshift2015-05-172-1/+17
| |
* | Merge pull request #781 from archshift/deletebunnei2015-05-161-33/+0
|\ \ | | | | | | Delete unused hle/coprocessor.cpp
| * | Delete unused hle/coprocessor.cpparchshift2015-05-161-33/+0
| | |
* | | APT/FS: Remove asserts that were causing false positivespurpasmart962015-05-162-5/+5
|/ /
* | Core/ResourceLimits: Implemented the basic structure of ResourceLimits.Subv2015-05-158-14/+326
| | | | | | | | | | | | Implemented svcs GetResourceLimit, GetResourceLimitCurrentValues and GetResourceLimitLimitValues. Note that the resource limits do not currently keep track of used objects, since we have no way to distinguish between an object created by the application, and an object created by some HLE module once we're inside Kernel::T::Create.
* | Memory: Read SharedPage directly from Memory::ReadYuri Kunde Schlesner2015-05-152-58/+35
| |
* | Memory: Read ConfigMem directly from Memory::ReadYuri Kunde Schlesner2015-05-152-49/+36
| |
* | Memmap: Re-organize memory function in two filesYuri Kunde Schlesner2015-05-1511-12/+12
| | | | | | | | | | | | | | 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 RescheduleLioncash2015-05-141-1/+1
|/
* Merge pull request #756 from purpasmart96/ptm_service_changesbunnei2015-05-135-125/+112
|\ | | | | PTM: Changed the ptm services to be like the IR, HID, and APT services.
| * PTM: Changed the way the ptm services are handled to be like thepurpasmart962015-05-125-125/+112
| | | | | | | | IR, HID, and APT services.
* | Merge pull request #748 from Subv/tls_maxbunnei2015-05-123-7/+19
|\ \ | | | | | | Core/Memory: Add TLS support for creating up to 300 threads
| * | Core/Memory: Add TLS support for creating up to 300 threadsSubv2015-05-123-7/+19
| | |
* | | Merge pull request #751 from yuriks/idle-threadbunnei2015-05-122-44/+19
|\ \ \ | | | | | | | | Thread: Remove the idle thread
| * | | Thread: Remove the idle threadYuri Kunde Schlesner2015-05-122-44/+19
| | | | | | | | | | | | | | | | Instead just use nullptr to represent no thread is active.
* | | | Merge pull request #757 from Subv/schedulingbunnei2015-05-121-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 calledSubv2015-05-121-0/+2
| |/ /
* | | Merge pull request #750 from Subv/process_svcYuri Kunde Schlesner2015-05-126-4/+46
|\ \ \ | |_|/ |/| | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThread
| * | fixup!Subv2015-05-123-16/+12
| | |
| * | Core/HLE: Implemented the SVCs GetProcessId and GetProcessIdOfThreadSubv2015-05-116-4/+50
| | |
* | | NWM_UDS: Fix a typo in the nwm service port namepurpasmart962015-05-121-1/+1
| |/ |/|
* | Thread: Correctly set main thread initial stack positionYuri Kunde Schlesner2015-05-113-5/+4
|/
* Merge pull request #740 from yuriks/gsp-shmemarchshift2015-05-117-34/+67
|\ | | | | Fix crashes due to un-initialized GSP shared memory
| * fixup! GSP: Small tweaks to shared memory initializationYuri Kunde Schlesner2015-05-111-1/+1
| |
| * GSP: Small tweaks to shared memory initializationYuri Kunde Schlesner2015-05-111-9/+11
| |
| * Kernel: Zero-fill shared memory blocks when mappingYuri Kunde Schlesner2015-05-111-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 mappingYuri Kunde Schlesner2015-05-117-28/+51
| |
* | fixup! Set the TLS address in the schedulerSubv2015-05-112-2/+7
| |
* | Core/Memory: Give every emulated thread it's own TLS area.Subv2015-05-113-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 macroYuri Kunde Schlesner2015-05-091-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 constantsYuri Kunde Schlesner2015-05-093-4/+5
|
* Kernel: Remove unused g_main_thread variableYuri Kunde Schlesner2015-05-093-5/+1
|
* Process: Rename StaticAddressMapping => AddressMappingYuri Kunde Schlesner2015-05-092-5/+5
|
* Process: Add more documentation to the class membersYuri Kunde Schlesner2015-05-091-2/+16
|
* Process: Use BitField to store process flagsYuri Kunde Schlesner2015-05-092-16/+24
|
* Process: Support parsing of exheader kernel capsYuri Kunde Schlesner2015-05-092-4/+72
|
* Kernel: Remove g_program_idYuri Kunde Schlesner2015-05-092-8/+0
| | | | This has been obsoleted by the field in Process.
* Kernel: Introduce skeleton Process class to hold process dataYuri Kunde Schlesner2015-05-094-19/+101
|
* Fix printf format warningYuri Kunde Schlesner2015-05-071-1/+1
|
* Common: Remove common.hYuri Kunde Schlesner2015-05-0732-18/+48
|
* Clean-up includesYuri Kunde Schlesner2015-05-072-2/+7
|
* FileSys: De-inline Path membersYuri Kunde Schlesner2015-05-071-0/+2
|
* FileSys: Clean-up includes, de-inline destructorsYuri Kunde Schlesner2015-05-074-13/+21
|
* Move typedefs from kernel.h to more appropriate placesYuri Kunde Schlesner2015-05-072-10/+8
|
* HLE: Clean up SVC dispatch mechanismYuri Kunde Schlesner2015-05-064-77/+38
|
* HLE: Properly initialize and shutdown remaining modules.bunnei2015-05-025-3/+20
|
* Kernel: Properly initialize and shutdown all modules.bunnei2015-05-024-9/+20
|
* Services: Initialize all state variables at bootup.bunnei2015-05-028-22/+38
|
* ConfigMem: Remove duplicate retail bitpurpasmart962015-04-291-1/+0
|
* Merge pull request #692 from purpasmart96/log_improvementsbunnei2015-04-282-8/+22
|\ | | | | Services/Loader: Use more sensible log formats for certain functions along with more info being logged.
| * Services/Loader: Use more sensible log formats for certain functionspurpasmart962015-04-282-8/+22
| | | | | | | | along with more info being logged.
* | ptm_sysm: Add static specifier to IsLegacyPowerOffLioncash2015-04-251-1/+1
| |
* | Merge pull request #696 from yuriks/interface-deinlinebunnei2015-04-153-50/+49
|\ \ | | | | | | De-inline functions from Interface, removing them from service.h
| * | De-inline functions from Interface, removing them from service.hYuri Kunde Schlesner2015-04-143-50/+49
| | | | | | | | | | | | This reduces the time for a full recompile from 65.43s to 59.53s (~9%)
* | | Kernel: Use the correct format string for u64 hex.Emmanuel Gil Peyrot2015-04-141-1/+1
|/ /
* | SVC: Assert on unsupported CreateThread processor ID.bunnei2015-04-101-3/+9
| |
* | SVC: Update various SVCs to cause a reschedule.bunnei2015-04-102-6/+22
| | | | | | | | - CreateMutex/ReleaseMutex/ReleaseSemaphore/SetTimer/CancelTimer/ArbitrateAddress
* | Kernel: Implemented priority inheritance for mutexes.bunnei2015-04-103-4/+22
| |
* | Thread: Implement priority boost for starved threads.bunnei2015-04-104-28/+74
| | | | | | | | | | | | SVC: Return correct error code on invalid CreateThread processor ID. SVC: Assert when creating a thread with an invalid userland priority.
* | SVC: Reschedule on svcCreateThread.bunnei2015-04-101-0/+2
| |
* | APT: (Subv) Fix bug where start event was being incorrectly signaled.bunnei2015-04-101-6/+7
| |
* | Kernel: Fixed default thread priority.bunnei2015-04-102-5/+4
| |
* | Initialize base address to 0x0Gareth Higgins2015-04-091-0/+1
|/
* Merge pull request #676 from purpasmart96/ir_service_refcbunnei2015-04-0810-55/+180
|\ | | | | IR: Move The IR services to their own folder and implement "GetHandles"
| * IR: Move The IR services to their own folder and implement "GetHandles"purpasmart962015-04-0410-55/+180
| |
* | Clean-up mem_map constants and fix framebuffer translation errorsYuri Kunde Schlesner2015-04-061-4/+6
|/
* Merge pull request #641 from purpasmart96/service_stubsbunnei2015-04-0416-67/+402
|\ | | | | Services: Stubs and minor changes
| * Services: Stubs and minor changespurpasmart962015-04-0316-67/+402
| |
* | ConfigMem: Set the app memory to be 96MB instead of the default 64MBpurpasmart962015-03-241-2/+2
|/
* Merge pull request #656 from Subv/nzbunnei2015-03-223-24/+189
|\ | | | | Services/FS: Implemented DeleteExtSaveData, CreateSystemSaveData and Del...
| * Service/FS: Document and log some unknown values.Subv2015-03-191-1/+26
| | | | | | | | In CreateExtSaveData, DeleteExtSaveData and CreateSystemSaveData
| * Services/FS: Implemented DeleteExtSaveData, CreateSystemSaveData and DeleteSystemSaveDataSubv2015-03-143-24/+164
| | | | | | | | Also fixed a bug with CreateExtSaveData that made it unable to create ExtSaveData archives in the SDMC directory.
* | Merge pull request #655 from purpasmart96/hid_fixesbunnei2015-03-174-12/+72
|\ \ | | | | | | HID: Proper Signal Interrupts for EnableAccelerometer & EnableGyroscopeLow along with a stub for GetSoundVolume
| * | HID: Proper Signal Interrupts for EnableAccelerometer & EnableGyroscopeLow alongpurpasmart962015-03-174-12/+72
| |/ | | | | | | with a stub for GetSoundVolume
* / arm_interface: Get rid of GetTicks.Lioncash2015-03-162-5/+6
|/ | | | Removes a TODO.
* Merge pull request #642 from bunnei/touchpadbunnei2015-03-123-130/+136
|\ | | | | Touchpad support
| * hid_user: Removed unnecessary includes.bunnei2015-03-111-2/+0
| |
| * HID: Removed unnecessary global variables.bunnei2015-03-112-58/+42
| |
| * HID: Added additional variable comments and some code cleanups.bunnei2015-03-112-20/+29
| |
| * HID: Complete refactor of pad/touch input to fix threading issues.bunnei2015-03-112-111/+28
| |
| * HID: Cleanup how `next_touch_index` is calculated for Pad and touch.bunnei2015-03-101-2/+2
| |
| * HID: Changed TouchDataEntry `valid` to a BitField and added some doc strings.bunnei2015-03-102-4/+4
| |
| * HID: Added static asserts to check register position in shared memory.bunnei2015-03-101-2/+16
| |
| * HID: Added functions to emulate the touchpad.bunnei2015-03-102-0/+61
| |
| * HID: Moved some docstrings to the header.bunnei2015-03-102-24/+16
| |
| * HID: Refactored shared memory decoding for touchpad support.bunnei2015-03-102-33/+64
| |
* | Merge pull request #629 from archshift/lcdfbbunnei2015-03-101-6/+38
|\ \ | |/ |/| Implement SetLcdForceBlack and add implementation for color filling in the GPU code
| * Added LCD registers, and implementation for color filling in OGL code.archshift2015-03-091-17/+15
| |
| * Implement SetLcdForceBlack, move register enum to hw.harchshift2015-03-061-5/+39
| |
* | Merge pull request #589 from kevinhartman/config-errorsbunnei2015-03-091-5/+10
|\ \ | | | | | | Fix errorcodes for bad config block request
| * | Fix error message for bad config block request.Kevin Hartman2015-02-211-5/+10
| | |
* | | Merge pull request #538 from yuriks/perf-statTony Wasserka2015-03-071-0/+6
|\ \ \ | |_|/ |/| | Add profiling infrastructure and widget
| * | Add profiling infrastructure and widgetYuri Kunde Schlesner2015-03-021-0/+6
| | |
* | | Services: Moved the PTM and APT services to their own folderSubv2015-03-0439-1098/+1186
| | | | | | | | | | | | | | | | | | This coincidentally fixes an issue about the PTM service failing to create its SharedExtSaveData archive due to the FS service not being initialized by the time the creating code runs. Ideally I'd like to move each process to its own folder, and have a single file per process that registers the service classes, which would be in their own files inside that folder. Then each service class would just call functions from the process to complete the commands.
* | | Merge pull request #622 from Subv/titlesYuri Kunde Schlesner2015-03-021-8/+45
|\ \ \ | | | | | | | | Services/AM: Stubbed TitleIDListGetTotal and GetTitleIDList.
| * | | Services/AM: Stubbed TitleIDListGetTotal and GetTitleIDList.Subv2015-03-021-8/+45
| |/ / | | | | | | | | | | | | They will always return 0 titles for every media type for now. This is needed to boot Home Menu further
* | | Merge pull request #623 from Subv/cardbunnei2015-03-021-1/+25
|\ \ \ | | | | | | | | Services/FS: Stubbed CardSlotIsInserted to always return false
| * | | Services/FS: Stubbed CardSlotIsInserted to always return falseSubv2015-03-011-1/+25
| |/ / | | | | | | | | | We won't be emulating this for the foreseeable future and it is needed for Home Menu to boot further
* | | Merge pull request #618 from lioncash/refbunnei2015-03-021-2/+2
|\ \ \ | | | | | | | | result: Make comparison operators take references
| * | | result: Make comparison operators take referencesLioncash2015-02-281-2/+2
| |/ / | | | | | | | | | It's unnecessary to make copies for simple comparisons like this.
* / / Services/PTM: Stubbed PTM_Sysm::IsLegacyPowerOff.Subv2015-03-011-1/+13
|/ / | | | | | | This allows the Home Menu to boot further
* | Merge pull request #604 from Subv/arc_ssdYuri Kunde Schlesner2015-02-262-26/+42
|\ \ | | | | | | Archives: Properly implemented the SystemSaveData archive.
| * | Archives: Properly implemented the SystemSaveData archive.Subv2015-02-262-26/+42
| | | | | | | | | | | | Ported to the new factory pattern we have for archives.
* | | Services: Implemented Y2R_U::GetTransferEndEventSubv2015-02-241-1/+18
|/ / | | | | | | Aero Porter was throwing an "Invalid Handle" fatal error without this.
* | Merge pull request #595 from linkmauve/new-3ds-inputbunnei2015-02-241-0/+19
|\ \ | | | | | | Frontends, HID: Add New 3DS specific pad buttons, and stub the touch one.
| * | Frontends, HID: Add New 3DS specific pad buttons, and stub the touch one.Emmanuel Gil Peyrot2015-02-221-0/+19
| | |
* | | Merge pull request #581 from archshift/tfebunnei2015-02-231-1/+164
|\ \ \ | |/ / |/| | Added information reporting from ThrowFatalError
| * | Added information reporting from ThrowFatalErrorarchshift2015-02-221-1/+164
| | | | | | | | | | | | This was RE'd from the errdisp applet.
* | | Merge pull request #588 from archshift/somebranchbunnei2015-02-201-2/+3
|\ \ \ | |_|/ |/| | Sweeping cleanup of Common
| * | Misc cleanup of common and related functionsarchshift2015-02-201-2/+3
| |/
* / Convert a few C stdlib asserts to Citra's own assertsarchshift2015-02-191-6/+4
|/
* GPU: Properly implement memory fills.Tony Wasserka2015-02-182-17/+21
|
* Merge pull request #570 from purpasmart96/config_membunnei2015-02-184-50/+58
|\ | | | | ConfigMem: Clean up the Config memory to be more like the shared page
| * ConfigMem: Clean up the Config memory to be more like the shared page and movedpurpasmart962015-02-174-50/+58
| | | | | | | | the helper macro for padding to common_funcs.h
* | Services: Fixed "Tried to connect to named port err:f".Subv2015-02-161-1/+1
| | | | | | | | err:f is a named port, not a service
* | Merge pull request #529 from Subv/masterbunnei2015-02-146-40/+56
|\ \ | | | | | | Build: Fixed some warnings
| * | Build: Fixed some warningsSubv2015-02-126-40/+56
| |/
* / core: Apply static to local functionsLioncash2015-02-135-17/+18
|/
* Implemented WriteHWRegsWithMask for GSP.Kevin Hartman2015-02-111-6/+91
|
* Asserts: break/crash program, fit to style guide; log.h->assert.harchshift2015-02-1154-72/+27
| | | | | | | Involves making asserts use printf instead of the log functions (log functions are asynchronous and, as such, the log won't be printed in time) As such, the log type argument was removed (printf obviously can't use it, and it's made obsolete by the file and line printing) Also removed some GEKKO cruft.
* GSP: Fixed typo in SignalInterruptbunnei2015-02-111-1/+1
|
* Merge pull request #552 from bunnei/setbufferswap-fixbunnei2015-02-111-4/+3
|\ | | | | GSP SetBufferSwap fix
| * GSP: Call SetBufferSwap for each screen on corresponding signal interrupt.bunnei2015-02-111-4/+3
| |
* | Merge pull request #526 from purpasmart96/citra_stubsbunnei2015-02-113-8/+188
|\ \ | | | | | | Services: Stub some functions
| * | Services: Stub some functionspurpasmart962015-02-083-8/+188
| | |
* | | PTM: Fixed a problem with the gamecoin PTM file.Subv2015-02-101-21/+13
| | |
* | | Archives: Made the Format function more generic.Subv2015-02-103-9/+10
| | |
* | | Archives: Expose the File and Directory classes to HLESubv2015-02-103-58/+62
| | |
* | | ResultVal: Fixed compilation when reassigning a ResultVal.Subv2015-02-101-3/+3
| | |
* | | FS: Allow multiple instances of the same archive type to be open at onceYuri Kunde Schlesner2015-02-103-29/+35
| | |
* | | FS: Get rid of completely useless Archive classYuri Kunde Schlesner2015-02-101-36/+26
| | |
* | | Scheduler refactor Pt. 1Kevin Hartman2015-02-104-228/+267
| |/ |/| | | | | | | | | | | | | | | | | | | | | | | * 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.bunnei2015-02-102-16/+20
| |
* | WaitSynch: Always reschedule (verified behavior on hw).bunnei2015-02-101-4/+4
| |
* | core: Fix some warnings on OSXLioncash2015-02-031-1/+0
| |
* | Kernel: Stop creating useless Handles during object creationYuri Kunde Schlesner2015-02-0218-57/+41
| | | | | | | | | | They're finally unnecessary, and will stop cluttering the application's handle table.
* | Kernel: Make WaitObjects share ownership of Threads waiting on themYuri Kunde Schlesner2015-02-026-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 objectsYuri Kunde Schlesner2015-02-0216-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 ThreadYuri Kunde Schlesner2015-02-023-23/+18
| |
* | HID: Fix crash when pressing a key when the emulator is stoppedYuri Kunde Schlesner2015-02-021-0/+2
| |
* | SVC: Enable CloseHandle, clean up DuplicateHandleYuri Kunde Schlesner2015-02-021-9/+5
| |
* | Kernel: Fix bug in HandleTable::CloseYuri Kunde Schlesner2015-02-021-1/+1
| |
* | Kernel: Remove Object::GetHandle (it's not used anymore :D)Yuri Kunde Schlesner2015-02-022-9/+1
| |
* | Kernel: Introduce unique Object ids for debuggingYuri Kunde Schlesner2015-02-024-8/+16
| |
* | Kernel: Use separate Handle tables for CoreTiming userdataYuri Kunde Schlesner2015-02-024-18/+25
| | | | | | | | This is to support the removal of GetHandle soon
* | Kernel: Remove previous scheduled event when a Timer is re-SetYuri Kunde Schlesner2015-02-021-0/+3
| |
* | FS: Remove use of GetHandleYuri Kunde Schlesner2015-02-021-1/+1
| |
* | Thread: Modernize two functions that slipped through previous rebasesYuri Kunde Schlesner2015-02-024-18/+16
| |
* | Service: Store function names as const char* instead of std::stringYuri Kunde Schlesner2015-02-021-6/+6
| | | | | | | | | | Uses less memory (strings and function table is stored in constant data) and speeds up start up (no need to allocate and copy strings).
* | Service: Clean-up InterfaceYuri Kunde Schlesner2015-02-0246-67/+54
| |
* | Make Port/Service registration and querying more HW-accurateYuri Kunde Schlesner2015-02-024-106/+80
| |
* | Filesys: Move creation of Handles for File/Directory to service handlersYuri Kunde Schlesner2015-02-023-32/+33
| |
* | arm: Clean up ARMul_StateLioncash2015-02-011-1/+1
| | | | | | | | Remove unnecessary/unused struct variables.
* | Merge pull request #512 from lioncash/assignmentTony Wasserka2015-01-312-4/+4
|\ \ | |/ |/| shared_memory: Fix assignments in SharedMemory::Map
| * shared_memory: Fix assignments in SharedMemory::MapLioncash2015-01-302-4/+4
| |
* | archive: Fix initializer list order for the File class.Lioncash2015-01-301-1/+1
| |
* | apt_u: Fix missing printf specifiersLioncash2015-01-301-2/+2
|/
* Kernel: Mark all appropriate kernel objects as "final"Yuri Kunde Schlesner2015-01-307-8/+7
|
* SVC: Use CASCADE_RESULT in SVC handlersYuri Kunde Schlesner2015-01-302-77/+32
|
* Remove result.h InvalidHandleYuri Kunde Schlesner2015-01-304-30/+32
| | | | | It was only being used in two places, where it was replaced by a local constant.
* SVC: Change return type of handlers to ResultCodeYuri Kunde Schlesner2015-01-302-132/+127
|
* Kernel: Convert Event to not use HandlesYuri Kunde Schlesner2015-01-3010-152/+151
|
* Kernel: Convert Timer to (mostly) not use HandlesYuri Kunde Schlesner2015-01-303-111/+112
|
* Kernel: Convert Mutex to not use HandlesYuri Kunde Schlesner2015-01-305-114/+110
|
* Kernel: Convert AddressArbiter to not use HandlesYuri Kunde Schlesner2015-01-303-38/+55
|
* Kernel: Convert Semaphore to not use HandlesYuri Kunde Schlesner2015-01-303-67/+88
|
* Kernel: Convert SharedMemory to not use HandlesYuri Kunde Schlesner2015-01-308-102/+107
|
* Additions to ResultVal to make it more convenient to use.Yuri Kunde Schlesner2015-01-301-1/+25
|
* Move VAddr/PAddr typedefs to kernel.hYuri Kunde Schlesner2015-01-301-0/+5
|
* Kernel: Remove useless/duplicated comments; mark functions staticYuri Kunde Schlesner2015-01-306-32/+8
|
* Merge pull request #412 from purpasmart96/svc_table_cleanupbunnei2015-01-281-7/+7
|\ | | | | SVC: Update the SVC function table
| * SVC: Update the SVC function tablepurpasmart962015-01-271-7/+7
| |
* | Merge pull request #345 from purpasmart96/apt_stubsbunnei2015-01-271-91/+276
|\ \ | | | | | | APT_U: Stub some functions & misc changes
| * | APT_U: Stub some functions & misc changespurpasmart962015-01-231-91/+276
| | |
* | | Merge pull request #485 from Subv/more_servsbunnei2015-01-2618-1/+393
|\ \ \ | | | | | | | | Services: Stubbed more services.
| * | | Services/HID: Removed some files due to a rebase errorSubv2015-01-243-267/+0
| | | |
| * | | Services: Stubbed more services.Subv2015-01-2421-1/+660
| | | | | | | | | | | | | | | | Implemented FSUser::CreateExtSaveData
* | | | cam_u.h: fix indentationarchshift2015-01-221-2/+2
|/ / / | | | | | | Withholding my profanity towards Xcode.
* | | Merge pull request #493 from archshift/ptmplaybunnei2015-01-225-0/+102
|\ \ \ | | | | | | | | Stubbed some services
| * | | Stubbed cam:u servicearchshift2015-01-213-0/+49
| | | |
| * | | Stubbed ptm:play servicearchshift2015-01-213-0/+53
| | | |
* | | | WaitSynchronization: Added a result code for invalid result, fixed bug.bunnei2015-01-221-3/+9
| | | |
* | | | Thread: Fix WaitSynchronization1 to not set register 1 on thread wakeup.bunnei2015-01-223-25/+45
| | | |
* | | | Thread: Use std::find in CheckWait_WaitObject.bunnei2015-01-221-4/+5
| | | |
* | | | Mutex: Cleanup and remove redundant code.bunnei2015-01-223-47/+29
| | | |
* | | | Kernel: Renamed some functions for clarity.bunnei2015-01-227-10/+10
| | | | | | | | | | | | | | | | | | | | - ReleaseNextThread->WakeupNextThread - ReleaseAllWaitingThreads->WakeupAllWaitingThreads.
* | | | Kernel: Changed "ShouldWait" to return bool and "Acquire" to return void.bunnei2015-01-229-71/+42
| | | |
* | | | WaitObject: Renamed "Wait" to "ShouldWait", made "ShouldWait" and "Acquire" pure virtual.bunnei2015-01-229-23/+22
| | | |
* | | | Event: Fix implementation of "non-sticky" events.bunnei2015-01-221-0/+4
| | | |
* | | | Session: Change to a WaitObject.bunnei2015-01-223-2/+9
| | | |
* | | | Kernel: Reschedule on SignalEvent and SendSyncRequest, fix some bugs.bunnei2015-01-222-1/+2
| | | |
* | | | Mutex: Fix a bug where the thread should not wait if it already has the mutex.bunnei2015-01-221-1/+4
| | | |
* | | | Kernel: Moved Wait and Acquire to WaitObject, added way to retrieve a WaitObject safely.bunnei2015-01-224-20/+59
| | | |
* | | | SVC: Removed a Sleep that made no sensebunnei2015-01-221-6/+1
| | | | | | | | | | | | | | | | | | | | - Would deadlock the calling thread - Code would never get hit anyways
* | | | AddressArbiter: Changed to Kernel::Object, big cleanup, removed code that made no sense.bunnei2015-01-225-38/+45
| | | |
* | | | Kernel: Get rid of WaitTypes and simplify lots of code, removing hacks.bunnei2015-01-229-122/+63
| | | |
* | | | WaitSynchronizationN: Improved commentsbunnei2015-01-221-7/+12
| | | |
* | | | WaitSynchronizationN: Refactor to fix several bugsbunnei2015-01-228-79/+76
| | | | | | | | | | | | | | | | | | | | | | | | - Separate wait checking from waiting the current thread - Resume thread when wait_all=true only if all objects are available at once - Set output to correct wait object index when there are duplicate handles
* | | | Kernel: Separate WaitSynchronization into Wait and Acquire methods.bunnei2015-01-228-18/+59
| | | |
* | | | WaitSynchronizationN: Handle case where handles=nullptr.bunnei2015-01-221-0/+4
| | | |
* | | | WaitSynchronizationN: Handle case where handle_count is invalid.bunnei2015-01-221-3/+7
| | | |
* | | | WaitSynchronizationN: Handle case where handle_count=0.bunnei2015-01-221-19/+29
| | | |
* | | | WaitSynchronizationN: Implement return valuesbunnei2015-01-2210-83/+189
| | | |
* | | | Event: Fixed some bugs and cleanup (Subv)bunnei2015-01-224-57/+16
| | | |
* | | | Thread: Keep track of multiple wait objects.bunnei2015-01-223-16/+30
| | | |
* | | | Event: Get rid of permanent_lock hack.bunnei2015-01-222-36/+8
| | | |
* | | | WaitObject: Added RemoveWaitingThread, fixed a bug, and cleanup.bunnei2015-01-222-4/+17
| | | |
* | | | Kernel: Added WaitObject and changed "waitable" objects inherit from it.bunnei2015-01-228-71/+73
| | | |
* | | | Added HID_SPVR service and split HID_U implementation into service/hid/hid.xxxarchshift2015-01-219-217/+327
|/ / /
* | | core: Fix a few docstringsLioncash2015-01-204-4/+4
| | |
* | | Merge pull request #492 from archshift/aptbunnei2015-01-202-1/+4
|\ \ \ | | | | | | | | Expose GetSharedFont and NotifyToWait to APT:A and APT:S respectively
| * | | Expose GetSharedFont and NotifyToWait to APT:A and APT:S respectivelyarchshift2015-01-192-1/+4
| |/ /
* | | Merge pull request #383 from zhuowei/shared_pagebunnei2015-01-193-0/+109
|\ \ \ | |/ / |/| | Add some support for the shared page
| * | Add some support for the shared page (currently 3d slider is implemented)Zhuowei Zhang2015-01-163-0/+109
| | |
* | | APT: Fix typo in setting return code for NotifyToWaitbunnei2015-01-161-1/+1
| | |
* | | DSP: Removed useless spam log for SignalInterruptbunnei2015-01-161-5/+2
| | |
* | | Merge pull request #482 from yuriks/fix-vblankbunnei2015-01-162-35/+25
|\ \ \ | | | | | | | | Correctness fixes for GPU flipping and interrupts
| * | | GSP: Fix appending of interrupts to the shared memory bufferYuri Kunde Schlesner2015-01-142-17/+12
| | | | | | | | | | | | | | | | | | | | The code was previously appending the interrupt to after the end of the buffer, instead of at the end.
| * | | GSP: Update framebuffer info on all interruptsYuri Kunde Schlesner2015-01-141-12/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Hardware testing determined that the GSP processes shared memory framebuffer update info even when no memory transfer or filling GX commands are used. They are now updated on every interrupt, which isn't confirmed correct but matches hardware behaviour more closely. This also reverts the hack introduced in #404. It made a few games behave better, but I believe it's incorrect and also breaks other games.
| * | | GPU: Fire GPU interrupts at the correct places.Yuri Kunde Schlesner2015-01-141-6/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PDC0 and PDC1 are both VBlank interrupts. PDC0 was being treated as a HBlank interrupt and fired many more times than it should. They now both fire together at 60 Hz. This puzzlingly *improves* apparent framerate on many applications. A few other interrupts were being fired inside the GSP command processing instead of on the actual GPU register writes, so they were moved there, which should cover direct writes tho those registers not going through the GX command queue.
* | | | Merge pull request #481 from Subv/hm_bbunnei2015-01-151-7/+21
|\ \ \ \ | | | | | | | | | | APTU: Stubbed NotifyToWait, taken from 3dmoo.
| * | | | APT: Fixed the comment style in some variablesSebastian Valle2015-01-141-2/+2
| | | | |
| * | | | APTU: Stubbed NotifyToWait, taken from 3dmoo.Subv2015-01-141-7/+21
| |/ / / | | | | | | | | | | | | | | | | Also renamed some handles in the APT:U service to be more descriptive. Fixed a typo in InquireNotification
* | | | Merge pull request #480 from Subv/arb_2bunnei2015-01-143-4/+21
|\ \ \ \ | |/ / / |/| | | AddrArbiter: Implement arbitration types 3 and 4.
| * | | AddrArbiter: Implement arbitration types 3 and 4.Subv2015-01-133-4/+21
| | |/ | |/|
* / | Services: Added some missing services.Subv2015-01-138-1/+358
|/ / | | | | | | | | cfg:s, ptm:sysm, apt:s. apt:s is almost exactly the same as apt:u as per 3dbrew
* | Fix building on MinGWdarkf2015-01-121-0/+13
| |
* | Merge pull request #456 from Subv/waitsync1bunnei2015-01-121-3/+2
|\ \ | | | | | | SVC: Wake up the thread after the delay in WaitSync1
| * | SVC: Wake up the thread after the delay in WaitSync1Subv2015-01-111-3/+2
| | |
* | | Merge pull request #466 from Subv/wakebunnei2015-01-111-0/+3
|\ \ \ | |/ / |/| | Thread: Prevent waking a thread multiple times.
| * | Thread: Prevent waking a thread multiple times.Subv2015-01-111-0/+3
| | | | | | | | | | | | If a thread was woken up by something, cancel the wakeup timeout.
* | | Stubbed y2r:u IsBusyConversionarchshift2015-01-111-1/+16
| | | | | | | | | | | | | | | There is no documentation available on this function, but we set the result to false as a stub. This allows Super Little Acorns to move all the way in game with pp3c.
* | | Added Archive ID to fs:USER debug logs involving opening the archive.archshift2015-01-101-3/+3
| | |
* | | Logging: Log all called service functions (under trace). Compile out all trace logs under release for performance.archshift2015-01-109-33/+22
| | |
* | | Kernel: Start using boost::intrusive_ptr for lifetime managementYuri Kunde Schlesner2015-01-0912-90/+95
| | |
* | | Kernel: Don't re-assign object's handle when duplicating oneYuri Kunde Schlesner2015-01-092-2/+3
|/ /
* | Merge pull request #444 from yuriks/handle-reform2bunnei2015-01-0915-360/+289
|\ \ | | | | | | Kernel Lifetime Reform Pt. 2
| * | Thread: Fix nullptr access in a logging functionYuri Kunde Schlesner2015-01-091-1/+2
| | |
| * | Thread: Rename thread_queue => thread_listYuri Kunde Schlesner2015-01-091-6/+6
| | |
| * | Thread: Reduce use of Handles and move some funcs to inside the class.Yuri Kunde Schlesner2015-01-0910-301/+221
| | |
| * | Kernel: Move Thread's definition to the header fileYuri Kunde Schlesner2015-01-093-53/+67
| | |
| * | Move ThreadContext to core/core.h and deal with the falloutYuri Kunde Schlesner2015-01-098-19/+13
| | |
* | | Merge pull request #436 from kevinhartman/system-corebunnei2015-01-091-0/+5
|\ \ \ | |/ / |/| | Warn if a new thread is intended to be run on the system CPU core
| * | Warn if a new thread is intended to be run on the system CPU core until we implement correct scheduling for such a thread.Kevin Hartman2015-01-071-0/+5
| | |
* | | Merge pull request #255 from Subv/cbranch_3bunnei2015-01-097-5/+232
|\ \ \ | | | | | | | | Implemented timers
| * | | SVC: Implemented the Timer service calls.Subv2015-01-097-5/+232
| | | |
* | | | SVC: Fixed SleepThread.Subv2015-01-093-8/+43
| |_|/ |/| | | | | | | | 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.Subv2015-01-083-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.
* | | Merge pull request #404 from bunnei/more-frame-synch-fixesbunnei2015-01-081-1/+4
|\ \ \ | | | | | | | | GPU: Toggle active framebuffer each frame
| * | | GSP: Toggle active framebuffer each framebunnei2015-01-081-1/+4
| | | |
* | | | Merge pull request #431 from yuriks/thread-queue-cleanupbunnei2015-01-071-1/+1
|\ \ \ \ | |_|/ / |/| | | Common: Clean up ThreadQueueList
| * | | Common: Clean up ThreadQueueListYuri Kunde Schlesner2015-01-071-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.
* / | Fix double-free in Service manager during shutdownYuri Kunde Schlesner2015-01-072-25/+4
|/ / | | | | | | Fixes #423.
* | Merge pull request #376 from Subv/arc_reorderbunnei2015-01-074-18/+23
|\ \ | |/ |/| Archives: Change the folder layout of some archives.
| * Archives: Changed the unimplemented archives comment.Subv2015-01-061-1/+1
| | | | | | | | It now refers to me as the PoC
| * Archives: Addressed some commentsSubv2015-01-061-2/+2
| |
| * Archives: Make SYSTEM_ID and SDCARD_ID stringsSubv2015-01-042-4/+4
| |
| * Archives: Changed the way paths are built for the archives.Subv2015-01-044-15/+20
| | | | | | | | Each archive now takes a mount point of either NAND or SDMC, and builds its own directory structure there, trying to simulate an HLE-friendly hardware layout
| * Archives: Change the folder layout of some archives.Subv2015-01-032-2/+2
| | | | | | | | This is to better represent the hardware layout, they are still aren't quite accurate, but this better and will help a bit when implementing the other archives like NAND-RO and NAND-RW
* | Merge pull request #413 from purpasmart96/serv_cleanbunnei2015-01-067-33/+36
|\ \ | | | | | | Services: Clean up a few things and add a few function names
| * | Services: Clean up a few things and add a few function namespurpasmart962015-01-067-33/+36
| | |
* | | Merge pull request #272 from rohit-n/sign-comparebunnei2015-01-061-4/+4
|\ \ \ | | | | | | | | Silence some -Wsign-compare warnings.
| * | | Silence some -Wsign-compare warnings.Rohit Nirmal2015-01-011-4/+4
| |/ /
* | | DSP: Signal (faked) interrupt on every frame.bunnei2015-01-052-4/+21
| | | | | | | | | | | | - Hack to work around games checking that the DSP event has been signaled by a real DSP interrupt.
* | | Merge pull request #407 from Subv/arbiterbunnei2015-01-051-0/+11
|\ \ \ | | | | | | | | AddressArbiter: Ported arbitration type 2 from 3dmoo.
| * | | AddressArbiter: Ported arbitration type 2 from 3dmoo.Subv2015-01-031-0/+11
| | |/ | |/| | | | | | | (Thanks 3dmoo!)
* | | Merge pull request #408 from Subv/mutexbunnei2015-01-051-2/+2
|\ \ \ | | | | | | | | Mutex: Add the calling thread to the waiting list when needed
| * | | Mutex: Add the calling thread to the waiting list when neededSubv2015-01-041-2/+2
| |/ / | | | | | | | | | This will happen when the mutex is already owned by another thread. Should fix some issues with games being stuck due to waiting threads not being awoken.
* | | Merge pull request #386 from archshift/y2rubunnei2015-01-053-0/+70
|\ \ \ | |/ / |/| | Stub the y2r:u service
| * | Stub the y2r:u servicearchshift2015-01-033-0/+70
| |/
* | Archives: Reduced duplicate code in RomFS and SaveCheck.Subv2015-01-032-4/+5
| | | | | | | | Fixed a few warnings and cleaned up the code
* | SaveDataCheck: Preliminary work in this archive.Subv2015-01-032-3/+35
| | | | | | | | | | | | This allows Steel Diver to boot further, some files are needed. This is still not ready and needs a big cleanup, this will possibly be delayed until the way we handle archives is fixed (with factory classes instead of ahead-of-time creation of archives)
* | Merge pull request #391 from lioncash/pedanticbunnei2015-01-031-3/+3
|\ \ | | | | | | archive/elf: Minor misc changes.
| * | archive: Fix initializer list orderLioncash2015-01-031-3/+3
| |/
* / soc_u: Fix a missing formatting argumentLioncash2015-01-031-1/+1
|/
* SOC_U: Preliminary implementation of sockets.Subv2014-12-314-22/+721
| | | | | | | | | | | | | Stubbed CreateMemoryBlock Using Berkeley sockets, and Winsock2.2 on Windows. So far ftpony creates the socket and accepts incoming connections SOC_U: Renamed functions to maintain consistency Also prevents possible scope errors / conflicts with the actual Berkeley socket functions SOCU: Close all the opened sockets when cleaning up SOCU
* APT:A: Some style changesSubv2014-12-301-12/+12
|
* Archives: Implemented ExtSaveData and SharedExtSaveDataSubv2014-12-305-45/+94
| | | | | | | | They will be stored in /extsavedata/SDMC and /extsavedata/NAND respectively. Also redirect some APT_A functions to their APT_U equivalents. Implemented the gamecoin.dat file in SharedExtSaveData in the PTM module. Implemented formatting the savegame. Retake a previous savegame if it exists instead of reporting them as not formatted every time a game is loaded.
* Kernel: New handle managerYuri Kunde Schlesner2014-12-2813-168/+209
| | | | | | | | | | | This handle manager more closely mirrors the behaviour of the CTR-OS one. In addition object ref-counts and support for DuplicateHandle have been added. Note that support for DuplicateHandle is still experimental, since parts of the kernel still use Handles internally, which will likely cause troubles if two different handles to the same object are used to e.g. wait on a synchronization primitive.
* Kernel: Replace GetStaticHandleType by HANDLE_TYPE constantsYuri Kunde Schlesner2014-12-288-15/+15
|
* Rename ObjectPool to HandleTableYuri Kunde Schlesner2014-12-2812-54/+54
|
* Merge pull request #339 from bunnei/fixup-gsp-synchbunnei2014-12-261-0/+8
|\ | | | | Fixup gsp synch
| * ARM: Add a mechanism for faking CPU time elapsed during HLE.bunnei2014-12-261-0/+8
| | | | | | | | - Also a few cleanups.
* | Merge pull request #330 from purpasmart96/new_srvbunnei2014-12-2660-305/+355
|\ \ | | | | | | More services & small clean ups
| * | More services & small clean upspurpasmart962014-12-2660-305/+355
| | |
* | | Stubbed IsSdmcWriteable to always return writeable.archshift2014-12-241-1/+18
| |/ |/|
* | Merge pull request #322 from chinhodado/masterbunnei2014-12-221-2/+2
|\ \ | |/ |/| More warning cleanups
| * More warning cleanupsChin2014-12-211-2/+2
| |
* | CFG: Fixed some warnings and errors in ClangSubv2014-12-222-4/+4
| |
* | CFG: More style changesSubv2014-12-221-5/+5
| |
* | CFGU: IndentationSubv2014-12-211-4/+3
| |
* | CFG: Some indentationSubv2014-12-211-11/+13
| |
* | CFG: Changed the CreateConfigInfoBlk search loopSubv2014-12-211-7/+4
| |
* | CFG: Corrected the licenses in cfg_i.cpp and cfg_u.cppSubv2014-12-212-2/+2
| |
* | CFG: Create a new subfolder cfg inside service to handle cfgSubv2014-12-219-485/+610
| | | | | | | | Moved most of the shared CFG code there, implemented a few CFG:I functions
* | CFGU: Some changesSubv2014-12-211-12/+33
| |
* | CFGU: Addressed some issues.Subv2014-12-211-43/+55
| |
* | CFGU: Addressed some comments.Subv2014-12-211-11/+13
| |
* | Style: Addressed some commentsSubv2014-12-211-4/+5
| |
* | CFG_U: Use Common::make_unique instead of the std versionSubv2014-12-211-1/+2
| |
* | CFG:U: Implemented some more blocksSubv2014-12-211-4/+30
| |
* | CFG: Implemented block 0x00070001 in the config savefileSubv2014-12-211-0/+5
| |
* | CFGU: Use an absolute offset in the config savefile blocksSubv2014-12-211-1/+3
| |
* | CFG: Load the Config savedata file if it already exists.Subv2014-12-211-3/+4
| |
* | CFGU: Added block 0x000A0002 to the default savegame fileSubv2014-12-211-0/+18
| | | | | | | | That's the language id block, we're using LANGUAGE_EN for now. This block allows some games to boot further
* | CFG: Refactored how the config file works.Subv2014-12-211-55/+126
| | | | | | | | It is now kept in memory as per 3dbrew, all updates happen on memory, then they can be saved using UpdateConfigNANDSavegame.
* | CFG:U: Add some data to the 0x00050005 config block.Subv2014-12-211-6/+11
| | | | | | | | Seems to allow some games to boot further, thanks @Normmatt for sharing this information
* | CFG: Implemented the GetConfigInfoBlk2 function.Subv2014-12-212-12/+188
| | | | | | | | | | | | Added a "config" file to the CFG process service (CFG:U), and added a few default blocks to it. Implemented GetSystemModel and GetModelNintendo2DS
* | Merge pull request #291 from purpasmart96/licensebunnei2014-12-2182-84/+84
|\ \ | | | | | | License change
| * | License changepurpasmart962014-12-2182-84/+84
| | |
* | | Merge pull request #271 from archshift/createfbunnei2014-12-213-1/+47
|\ \ \ | | | | | | | | Added CreateFile to the FS_USER service
| * | | Added CreateFile to the FS_USER servicearchshift2014-12-213-1/+47
| | | | | | | | | | | | | | | | Tested with hwtests.
* | | | Thread: Wait current thread on svc_SleepThreadbunnei2014-12-213-22/+35
| |_|/ |/| | | | | | | | | | | | | | - Removed unused VBLANK sleep mode - Added error log for bad context switch - Renamed VerifyWait to CheckWaitType to be more clear
* | | Merge pull request #316 from yuriks/thread-handlebunnei2014-12-203-2/+16
|\ \ \ | | | | | | | | Kernel: Implement support for current thread pseudo-handle
| * | | Kernel: Implement support for current thread pseudo-handleYuri Kunde Schlesner2014-12-203-2/+16
| | | | | | | | | | | | | | | | This boots a few (mostly Nintendo 1st party) games further.
* | | | Merge pull request #315 from chinhodado/masterbunnei2014-12-202-5/+5
|\ \ \ \ | |_|/ / |/| | | Clean up some warnings
| * | | Clean up some warningsChin2014-12-202-5/+5
| | | |
* | | | Common: Add a clone of std::make_uniqueYuri Kunde Schlesner2014-12-201-6/+7
| | | |
* | | | Merge pull request #306 from Subv/even_more_savedatabunnei2014-12-201-2/+31
|\ \ \ \ | |/ / / |/| | | SaveData: Added some documentation to FormatSaveData
| * | | FS_U: Added the command to the docs of SaveData functionsSubv2014-12-201-0/+2
| | | |
| * | | SaveData: Added some documentation to FormatSaveDataSubv2014-12-181-2/+29
| | | | | | | | | | | | | | | | | | | | We still don't know what the other parameters do, but they appear to be very similar to those of FormatThisUserSaveData. Most likely FormatThisUserSaveData is just an alias for FormatSaveData with LowPathType Empty
* | | | Merge pull request #302 from purpasmart96/flushshutupbunnei2014-12-191-1/+25
|\ \ \ \ | |_|_|/ |/| | | GSP_GPU: Shut up FlushDataCache
| * | | GSP_GPU: Shut up FlushDataCachepurpasmart962014-12-191-1/+25
| | | |
* | | | Merge pull request #308 from Subv/more_savedatabunnei2014-12-191-1/+1
|\ \ \ \ | | | | | | | | | | SystemSaveData: Fixed a typo that was segfaulting
| * | | | SystemSaveData: Fixed a typo that was segfaultingSubv2014-12-191-1/+1
| | | | |
* | | | | Merge pull request #301 from Subv/more_savedatabunnei2014-12-181-0/+9
|\| | | | | |/ / / |/| | | SaveData: Implemented the SystemSaveData archive.
| * | | SaveData: Implemented the SystemSaveData archive.Subv2014-12-181-0/+9
| |/ / | | | | | | | | | It will be stored in the /syssavedata folder. This archive is user by various Services and possibly games via the FS:U service.
* | | Merge pull request #185 from purpasmart96/mem_permbunnei2014-12-182-5/+13
|\ \ \ | |/ / |/| | Kernel: Add missing permissions
| * | Kernel:Add missing permissions in shared memory & svcpurpasmart962014-11-192-5/+13
| | |
* | | Filesystem/Archives: Implemented the SaveData archiveSubv2014-12-186-13/+95
| |/ |/| | | | | | | | | | | | | | | | | 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
* | Comment out empty arrays causing compile errors in MSVCYuri Kunde Schlesner2014-12-162-6/+8
| |
* | Merge pull request #283 from yuriks/archive-refactorbunnei2014-12-167-241/+245
|\ \ | | | | | | Archive refactor
| * | Work around libstdc++'s lack of support for std::hash on enumsYuri Kunde Schlesner2014-12-161-0/+15
| | |
| * | FS.Archive: Clean up treatment of archives and their handlesYuri Kunde Schlesner2014-12-163-196/+175
| | | | | | | | | | | | | | | | | | | | | - Refactor FS::Archive internals to make Archive creation and lifetime management clearer. - Remove the "Archive as a File" hack. - Implement 64-bit Archive handles.
| * | Service.FS: Rename FileSys::File to FileBackendYuri Kunde Schlesner2014-12-161-1/+1
| | |
| * | Service.FS: Rename FileSys::Directory to DirectoryBackendYuri Kunde Schlesner2014-12-161-2/+2
| | |
| * | Service.FS: Rename FileSys::Archive to ArchiveBackendYuri Kunde Schlesner2014-12-162-5/+5
| | |
| * | Service.FS: Do archive registration using IdCode instead of nameYuri Kunde Schlesner2014-12-163-16/+27
| | |
| * | HLE: Rename namespaces to match move & fix initialization orderYuri Kunde Schlesner2014-12-167-36/+36
| | |
| * | HLE: Move kernel/archive.* to service/fs/Yuri Kunde Schlesner2014-12-166-6/+5
| | |
* | | Merge pull request #282 from archshift/servicesbunnei2014-12-169-0/+221
|\ \ \ | |/ / |/| | Added stubs for ldr:ro, cecd:u, nim:aoc, and am:app services
| * | Added stub for nim:aoc service...archshift2014-12-163-0/+60
| | |
| * | Added stub for cecd:u service...archshift2014-12-163-0/+52
| | | | | | | | | | | | I couldn't find any information about this service...
| * | Added stub for ldr:ro service...archshift2014-12-163-0/+57
| | |
| * | Added am:app service stub.archshift2014-12-163-0/+52
| | | | | | | | | | | | Apparently nothing at all is known about this service...
* | | Remove SyncRequest from K::Object and create a new K::Session typeYuri Kunde Schlesner2014-12-1514-104/+128
|/ / | | | | | | | | | | | | 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/Semaphores: Fixed buildSubv2014-12-131-2/+2
| |
* | Kernel/Semaphore: Small style changeSubv2014-12-131-1/+1
| |
* | Kernel/Semaphores: Invert the available count checking.Subv2014-12-131-11/+9
| | | | | | | | Same semantics, idea by @yuriks
* | Kernel/Semaphores: Addressed some issues.Subv2014-12-132-32/+18
| |
* | Semaphore: Removed an unneeded functionSubv2014-12-131-5/+0
| |
* | Semaphores: Addressed some style issuesSubv2014-12-131-6/+5
| |
* | Semaphore: Implemented the initial_count parameter.Subv2014-12-132-5/+7
| |
* | SVC: Implemented ReleaseSemaphore.Subv2014-12-134-19/+81
| | | | | | | | This behavior was tested on hardware, however i'm still not sure what use the "initial_count" parameter has
* | SVC: Implemented svcCreateSemaphoreSubv2014-12-134-1/+115
| | | | | | | | | | ToDo: Implement svcReleaseSemaphore * Some testing against hardware needed
* | kernel: Remove unused log argumentsLioncash2014-12-131-3/+3
| |
* | Convert old logging calls to new logging macrosYuri Kunde Schlesner2014-12-1320-191/+138
| |
* | New logging systemYuri Kunde Schlesner2014-12-131-0/+1
| |
* | Merge pull request #267 from bunnei/apt-shared-fontbunnei2014-12-132-35/+101
|\ \ | | | | | | APT shared font loading
| * | APT_U: Added GetSharedFont service function.bunnei2014-12-131-34/+100
| | |
| * | MemMap: Renamed "GSP" heap to "linear", as this is not specific to GSP.bunnei2014-12-121-1/+1
| | | | | | | | | | | | - Linear simply indicates that the mapped physical address is always MappedVAddr+0x0C000000, thus this memory can be used for hardware devices' DMA (such as the GPU).
* | | DSP: Added stub for ReadPipeIfPossible.bunnei2014-12-121-1/+45
|/ /
* | Merge pull request #256 from Subv/mutexbunnei2014-12-113-37/+67
|\ \ | | | | | | Kernel/Mutex: Properly lock the mutex when a thread enters it
| * | Mutex: Remove some forward declarationsSubv2014-12-071-16/+15
| | | | | | | | | | | | Moved Mutex::WaitSynchronization to the end of the file.
| * | Mutex: Release all held mutexes when a thread exits.Subv2014-12-073-22/+56
| | |
| * | Mutex: Properly lock the mutex when a thread enters itSubv2014-12-061-12/+9
| | | | | | | | | | | | Also resume only the next immediate thread waiting for the mutex when it is released, instead of resuming them all.
* | | CFG:U: Store country codes as u16 instead of char pointers, and return the correct error in GetCountryCodeID.Emmanuel Gil Peyrot2014-12-101-44/+48
| | |
* | | GSP: Trigger GPU interrupts at more accurate locations.bunnei2014-12-101-7/+6
| | |
* | | GSP: Updated TriggerCmdReqQueue to return success code.bunnei2014-12-101-0/+3
| | |
* | | GSP: Updated RegisterInterruptRelayQueue to return expected magic number.bunnei2014-12-101-1/+4
| | |
* | | GPU: Fixed bug in command list size decoding.bunnei2014-12-101-1/+1
| | |
* | | Merge pull request #217 from archshift/cmd_buffbunnei2014-12-091-12/+12
|\ \ \ | | | | | | | | Log the cmd_buff arguments when citra comes across an unimplemented function
| * | | Log the cmd_buff arguments when citra comes across an unimplemented functionarchshift2014-11-251-12/+12
| | | |
* | | | Thread: Fixed to wait on address when in arbitration.bunnei2014-12-093-11/+31
| | | |
* | | | Make OpenDirectory fail if the directory doesn't existarchshift2014-12-071-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_2bunnei2014-12-053-4/+31
|\ \ \ | | | | | | | | SVC: Implemented GetThreadId.
| * | | Threads: Remove a redundant function.Subv2014-12-041-9/+1
| | | | | | | | | | | | | | | | Use the next_thread_id variable directly.
| * | | Threads: Implemented a sequential thread idSubv2014-12-042-4/+19
| | | |
| * | | SVC: Implemented GetThreadId.Subv2014-12-043-4/+24
| | | | | | | | | | | | | | | | For now threads are using their Handle value as their Id, it should not really cause any problems because Handle values are unique in Citra, but it should be changed. I left a ToDo there because this is not correct behavior as per hardware.
* | | | Merge pull request #222 from archshift/renamexyzbunnei2014-12-053-38/+163
|\ \ \ \ | | | | | | | | | | Implemented RenameFile and RenameDirectory in FS:USER
| * | | | Updated archive.cpp functions for proper error handlingarchshift2014-12-043-70/+41
| | | | |
| * | | | Implemented RenameDirectory in FS:USERarchshift2014-11-253-1/+78
| | | | |
| * | | | Implemented RenameFile in FS:USERarchshift2014-11-253-1/+78
| | |/ / | |/| |
* | | | Merge pull request #248 from lioncash/kernelbunnei2014-12-052-10/+7
|\ \ \ \ | | | | | | | | | | Misc minor kernel-related changes.
| * | | | kernel: Shorten GetCountLioncash2014-12-041-6/+3
| | | | |
| * | | | kernel: Make some functions constLioncash2014-12-042-4/+4
| | | | |
* | | | | Merge pull request #247 from lioncash/constbunnei2014-12-042-4/+4
|\ \ \ \ \ | | | | | | | | | | | | hid_user: Pass by reference with PadButtonPress/PadButtonRelease
| * | | | | hid_user: Pass by reference with PadButtonPress/PadButtonReleaseLioncash2014-12-042-4/+4
| | |_|/ / | |/| | |
* | | | | Merge pull request #238 from archshift/dspbunnei2014-12-041-25/+44
|\ \ \ \ \ | | | | | | | | | | | | Add stub for ConvertProcessFromDspDram
| * | | | | Add stub for ConvertProcessFromDspDramarchshift2014-12-041-25/+44
| | |/ / / | |/| | | | | | | | | | | | | Should theoretically push retail stuff further along
* | | | | PTM_U: Added a stub for GetBatteryLevel & GetBatteryChargeState & GetAdapterStatepurpasmart962014-12-041-3/+72
| |/ / / |/| | |
* | | | Merge pull request #231 from purpasmart96/serv_ac_wifi_statusbunnei2014-12-031-1/+19
|\ \ \ \ | | | | | | | | | | AC_U: Added a stub for GetWifiStatus
| * | | | AC_U: Added a stub for GetWifiStatuspurpasmart962014-12-031-1/+19
| | |/ / | |/| |
* | | | Merge pull request #219 from Subv/ptmbunnei2014-12-031-1/+18
|\ \ \ \ | |_|/ / |/| | | PTM_U: Implemented the GetShellState function.
| * | | PTM_U: Implemented the GetShellState function.Subv2014-12-011-1/+18
| | | |
* | | | Merge pull request #224 from bunnei/dsp-service-improvementsbunnei2014-12-012-26/+107
|\ \ \ \ | | | | | | | | | | Dsp service improvements
| * | | | DSP: Added stubs for several commonly used DSP service functions.bunnei2014-12-011-25/+106
| | | | |
| * | | | DSP: Fixed typo in port name.bunnei2014-12-011-1/+1
| | |/ / | |/| |
* | | | Merge pull request #214 from Subv/masterbunnei2014-12-011-2/+86
|\ \ \ \ | | | | | | | | | | CFG:U: Implemented the GetCountryCodeID and GetCountryCodeString
| * | | | CFG:U: Implemented the GetCountryCodeID and GetCountryCodeString.Subv2014-11-301-2/+86
| | | | |
* | | | | Merge pull request #225 from bunnei/fix-release-mutexbunnei2014-11-301-8/+7
|\ \ \ \ \ | | | | | | | | | | | | Mutex: Changed behavior to always release mutex for all threads.
| * | | | | Mutex: Changed behavior to always release mutex for all threads.bunnei2014-11-261-8/+7
| | |/ / / | |/| | |
* | | | | Merge pull request #226 from bunnei/svc-and-thread-fixesbunnei2014-11-302-1/+6
|\ \ \ \ \ | |_|/ / / |/| | | | Svc and thread fixes
| * | | | Thread: Check that thread is actually in "wait state" when verifying wait.bunnei2014-11-261-1/+1
| | | | |
| * | | | SVC: Add debug log to ArbitrateAddress.bunnei2014-11-261-0/+2
| | | | |
| * | | | SVC: SleepThread should yield to the next ready thread.bunnei2014-11-261-0/+3
| |/ / /
* / / / Fixed formatting and switch statement warningsvaguilar2014-11-271-3/+3
|/ / /
* | | Use pointers instead of passing handles around in some functions.Yuri Kunde Schlesner2014-11-241-19/+15
| | |
* | | Remove duplicated docs/update them for changed parameters.Yuri Kunde Schlesner2014-11-2410-88/+0
| | |
* | | HLE: Revamp error handling throrough the HLE codeYuri Kunde Schlesner2014-11-2421-294/+670
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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/deletexyzbunnei2014-11-243-26/+114
|\ \ \ | |/ / |/| | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives.
| * | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives.archshift2014-11-233-26/+114
| | |
* | | Add more services and some fixes, along with more "override"purpasmart962014-11-2125-17/+452
| | | | | | | | | | | | in the service's headers
* | | Merge pull request #211 from linkmauve/masterbunnei2014-11-1930-86/+86
|\ \ \ | | | | | | | | Remove trailing spaces from the entire project
| * | | Remove trailing spaces in every file but the ones imported from SkyEye, AOSP or generatedEmmanuel Gil Peyrot2014-11-1930-86/+86
| | | |
* | | | Merge pull request #208 from lioncash/staticsbunnei2014-11-192-23/+23
|\ \ \ \ | |/ / / |/| | | Add static to some variables
| * | | Add static to some variablesLioncash2014-11-192-23/+23
| | | |
* | | | Remove extraneous semicolonsLioncash2014-11-181-1/+1
|/ / /
* / / core: Mark some hle functions as staticLioncash2014-11-185-46/+46
|/ / | | | | | | These functions are not referred to by their linkage name outside of the translation unit, so they can be marked as static.
* | Archive: Fixed to not destroy archive handle on close.bunnei2014-11-181-3/+3
| |
* | Archive: Fixed close archive before freeing.bunnei2014-11-181-1/+1
| |
* | FS_User: Support FileSye::Path in a more generic way.bunnei2014-11-182-42/+76
| | | | | | | | added a todo to kernel archive
* | FileSys: Updated backend code to use FileSys::Path instead of string for paths.bunnei2014-11-183-14/+14
| |
* | Add missing boss:U service, needed according to Nintendo Zone logs.archshift2014-11-173-0/+57
| |
* | Fix two format strings.Lioncash2014-11-141-1/+1
| |
* | Merge pull request #183 from archshift/lowpathbunnei2014-11-131-83/+81
|\ \ | | | | | | Add support for UTF-16 strings for LowPaths in FS:USER
| * | Use std::u16string for conversion between UTF-8 and UTF-16, FS:USER functionsarchshift2014-11-132-138/+40
| | |
| * | Add support for UTF-16 strings for LowPaths in FS:USERarchshift2014-11-102-86/+182
| |/
* | Merge pull request #188 from bunnei/apt-fixesbunnei2014-11-121-19/+90
|\ \ | | | | | | APT_U: Various improvements and bug fixes.
| * | APT_U: Added stub for function AppletUtility.bunnei2014-11-121-1/+29
| | |
| * | APT_U: Set a valid parameter buffer size in GlanceParameter.bunnei2014-11-121-17/+39
| | | | | | | | | | | | - Also Clarified GlanceParameter/ReceiveParameter documentation.
| * | APT_U: Release service lock on initialization.bunnei2014-11-121-0/+4
| | |
| * | APT_U: Fixes for GetLockHandle to boot system titles.bunnei2014-11-121-1/+18
| |/ | | | | | | - Also added comment to GetLockHandle function.
* / Add FRD:U service and functionsarchshift2014-11-113-0/+64
|/
* Merge pull request #163 from archshift/create-directorybunnei2014-11-023-4/+63
|\ | | | | Added CreateDirectory function to service/fs.cpp, and in Archive.
| * Added CreateDirectory function to service/fs.cpp, and in Archive.archshift2014-11-023-4/+63
| |
* | Added ReceiveNotification, PublishToSubscriber unimplemented functions to SRVarchshift2014-11-021-0/+2
|/
* Added stub err:f service.archshift2014-11-023-0/+56
|
* Added a bunch of servicespurpasmart962014-11-0117-0/+581
|
* Merge pull request #162 from SeannyM/warning-fixesbunnei2014-10-302-6/+6
|\ | | | | Fix some warnings
| * Fix some warningsSean2014-10-302-6/+6
| |
* | FS:USER - Implemented IsSdmcDetectedarchshift2014-10-301-1/+17
| |
* | Renamed souce files of services to match port namesGareth Poole2014-10-2911-10/+10
|/
* Merge pull request #141 from archshift/crash-huntbunnei2014-10-281-0/+4
|\ | | | | hid.cpp: Fixed crash when updating pad data while null
| * hid.cpp: Fixed crash when updating pad data while nullarchshift2014-10-141-0/+4
| | | | | | | | Fixes #137
* | Add `override` keyword through the code.Yuri Kunde Schlesner2014-10-2613-46/+46
| | | | | | | | This was automated using `clang-modernize`.
* | ARM: Integrate SkyEye faster "dyncom" interpreter.bunnei2014-10-251-20/+0
| | | | | | | | | | | | | | | | | | | | Fixed typo (make protected member public) Added license header back in. I originally removed this because I mostly rewrote the file, but meh ARM: Fixed a type error in dyncom interpreter. ARM: Updated dyncom to use unique_ptr for internal ARM state.
* | Don’t fail on empty filename in OpenFileDirectly, return the archive handle insteadEmmanuel Gil Peyrot2014-10-251-8/+7
|/
* Merge pull request #128 from purpasmart96/masterbunnei2014-10-081-1/+31
|\ | | | | APT:U Added a stub fuction for "GlanceParameter"
| * APT: Added a stub for the "GlanceParameter" function.purpasmart962014-10-081-1/+31
| |
* | FileSys: split the constructor into an Open method, in order to notify the opener something went wrong.Emmanuel Gil Peyrot2014-10-061-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 Peyrot2014-10-061-0/+8
|/
* Added some more names to the function tablepurpasmart962014-10-051-0/+2
| | | Added "SetApplicationCpuTimeLimit" and "GetApplicationCpuTimeLimit" to apt.cpp
* added "StoreDataCache" to the function tablepurpasmart962014-09-301-0/+1
| | | seems simple enough
* Use the citra user path for the sdmc directoryarchshift2014-09-211-2/+1
|
* Kernel: Implement the Close command for Archive, File and Directory.Emmanuel Gil Peyrot2014-09-172-0/+43
|
* FS: Implement OpenArchive, OpenDirectory, OpenFile and OpenFileDirectly calls.Emmanuel Gil Peyrot2014-09-171-20/+177
|
* Kernel: Add a Directory object and a getter for it from an Archive object.Emmanuel Gil Peyrot2014-09-173-0/+91
|
* Kernel: Add a File object and a getter for it from an Archive object.Emmanuel Gil Peyrot2014-09-172-0/+118
|
* Core: Get rid of unnecessary switch statement in KernelLioncash2014-09-151-41/+2
|
* Added support for multiple input device types for KeyMap and connected Qt.Kevin Hartman2014-09-122-113/+127
|
* Initial HID PAD work, with GLFW only.Kevin Hartman2014-09-122-24/+197
|
* Created structure for PAD.Kevin Hartman2014-09-122-0/+28
|
* Merge pull request #99 from archshift/ext-checkbunnei2014-09-111-1/+1
|\ | | | | loader.cpp: improved file extension checking, made Upper/LowerStr useful, moved string_util into Common namespace
| * Added string_util to common, small changes in loader.cpparchshift2014-09-091-1/+1
| |
* | core: Prune redundant includesarchshift2014-09-0912-23/+0
|/
* core: Pass string by reference in FetchFromPortName and DeleteServiceLioncash2014-09-062-4/+4
|
* Threading: Fix thread starting to execute first instruction correctly.bunnei2014-08-281-0/+5
|
* srv::Initialize: Return "success" status code.bunnei2014-08-281-0/+4
|
* Pica/citra-qt: Replace command list view and command list debugging code with something more sophisticated.Tony Wasserka2014-08-251-5/+0
|
* GSP: Update framebuffer information when necessary.Tony Wasserka2014-08-252-2/+41
|
* GSP: Implement SetBufferSwap.Tony Wasserka2014-08-252-1/+47
|
* GSP: Add a helper function for convenience.Tony Wasserka2014-08-251-17/+22
|
* Added FS functions to Archive and Archive_RomFSarchshift2014-08-231-3/+31
|
* Core: Use std::array for managing kernel object spaceLioncash2014-08-192-5/+5
| | | | These avoid relying on memset for clearing the arrays.
* Merge pull request #55 from lioncash/stringbunnei2014-08-1916-41/+38
|\ | | | | Core: Alter the kernel string functions to use std::string instead of const char*.
| * Core: Alter the kernel string functions to use std::string instead of const char*.Lioncash2014-08-1816-41/+38
| | | | | | | | Most functions already operate on std::strings. This also removes the need to manually null terminate thread names.
* | SVC: Added support for svc_GetSystemTick.bunnei2014-08-192-19/+48
|/ | | | Changed HLE function return methods to be static inline functions.
* Core: Fix a formatting error in svc.cppLioncash2014-08-171-3/+2
| | | | | entry_point would not be added to the string. Also used StringFromFormat so that the buffer is unnecessary.
* Merge pull request #39 from bunnei/hid-minor-improvementsbunnei2014-08-132-6/+45
|\ | | | | Hid minor improvements
| * HID: Added new function entries from 3dbrew to FunctionTable.bunnei2014-08-131-0/+5
| | | | | | | | HID: Fix typo with DisableGyroscopeLow command.
| * HID: Implemented HID_User::GetIPCHandles service function.bunnei2014-08-081-5/+39
| |
| * SVC: Fixed typo with MapMemoryBlock DEBUG_LOG call.bunnei2014-08-081-1/+1
| |
* | Pica/GPU: Change hardware registers to use physical addresses rather than virtual ones.Tony Wasserka2014-08-121-9/+9
| | | | | | | | | | This cleans up the mess that address reading/writing had become and makes the code a *lot* more sensible. This adds a physical<->virtual address converter to mem_map.h. For further accuracy, we will want to properly extend this to support a wider range of address regions. For now, this makes simply homebrew applications work in a good manner though.
* | GSP: Fix a major regression introduced in ffda035c, due to which no display transfers were triggered at all anymore.Tony Wasserka2014-08-121-4/+13
| |
* | Remove the fancy RegisterSet class introduced in 4c2bff61e.Tony Wasserka2014-08-121-18/+18
|/ | | | | While it was some nice and fancy template usage, it ultimately had many practical issues regarding length of involved expressions under regular usage as well as common code completion tools not being able to handle the structures. Instead, we now use a more conventional approach which is a lot more clean to use.
* Thread: Added more descriptive comment to WaitCurrentThread.bunnei2014-08-072-2/+10
|
* GSP: Cleaned up command buffer decoding.bunnei2014-08-072-61/+69
| | | | | | | | GSP: Cleaned up code and added additional comments. GSP: Removed unnecessary TODO comment. GSP: Changed u32 iterators in TriggerCmdReqQueue to unsigned.
* GSP: Added reinitialization of other state objects.bunnei2014-08-061-0/+3
|
* GSP: Removed dumb GX prefixes to functions/structs in GSP namespace.bunnei2014-08-062-77/+78
| | | | - Various other cleanups.
* GSP: Removed unnecessary GX_FinishCommand function.bunnei2014-08-061-13/+5
|
* GSP: Implements preliminary command synchronization via GPU interrupts.bunnei2014-08-062-18/+109
| | | | Core: Added a comment to explain the logic for the RunLoop iterations.
* AddressArbiter: Removed unnecessary HLE::Reschedule.bunnei2014-08-061-1/+0
|
* AddressArbiter: Fixed bug with break statements missing from case statements.bunnei2014-08-061-0/+2
|
* SRV: Updated GetProcSemaphore to create an event instead of a mutex.bunnei2014-08-061-8/+10
|
* SVC: Removed ArbitrateAddress log message that spams to much.bunnei2014-08-061-2/+0
|
* Kernel: Updated Event and Mutex to specify handle that they are blocking for.bunnei2014-08-062-2/+2
|
* FS: Fix port name (old port name was based on an unaligned memory read).bunnei2014-08-061-1/+1
|
* Fix a few warnings.Tony Wasserka2014-07-231-3/+3
| | | | Templates shouldn't be marked as inline if they aren't defined in the header.
* GSP: Add a few comments.Tony Wasserka2014-07-232-1/+15
|
* GSP: Clean up GX command processing a lot and treat command id as a u8 rather than a u32.Tony Wasserka2014-07-232-37/+79
| | | | Anonymous structs are not standard C++, hence don't use them.
* GPU: Make use of RegisterSet.Tony Wasserka2014-07-231-21/+28
|
* GPU: Emulate memory fills.Tony Wasserka2014-07-232-1/+9
|
* GSP: HLE GXCommandId::SET_DISPLAY_TRANSFER and GXCommandId::SET_TEXTURE_COPY.Tony Wasserka2014-07-231-2/+9
|
* GSP: Implement ReadHWRegs and WriteHWRegs properly.Tony Wasserka2014-07-231-27/+46
|
* Kernel: Added preliminary support for address arbiters.bunnei2014-07-094-9/+134
| | | | | | | | 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.bunnei2014-07-092-0/+44
| | | | | | Thread: Cleaned up arbitrate address functions. Thread: Cleaned up ArbitrateAllThreads function.
* function_wrappers: Fixed incorrect wrapper, added another.bunnei2014-07-081-2/+9
|
* SharedMemory: Updated MapSharedMemory to use an enum for permissions.bunnei2014-07-053-16/+36
| | | | - Also added some safety checks to MapSharedMemory.
* GSP: Fixed to use real shared memory object, various cleanups.bunnei2014-07-052-30/+40
| | | | | | | | - Previously, used a hard-coded shared memory handle of 0x10002000 (as used by libctru homebrew) GSP: Added name for shared memory. GSP: Cleaned up assertion message.
* Kernel: Added support for shared memory objects.bunnei2014-07-052-0/+132
| | | | SharedMemory: Added optional name field for tracking known objects.
* Archive: Added Init/Shutdown methods to reset kernel archive state.bunnei2014-07-053-0/+19
|
* FileSys: Added preliminary support for applications reading the RomFS archive.bunnei2014-07-053-13/+135
| | | | | | | | | | Archive: Fixed brace ugliness for neobrain :) FS: Commented out unused local variables to prevent warnings. ...But keeping them here for future use. archive_romfs: Removed unused #include.
* APT: Added stubbed ReceiveParameter and various cleanups.bunnei2014-07-041-71/+93
| | | | | | APT: More cleanups. APT: Changed SignalType to be type u32.
* FS: Added stubbed code to intercept and decode file system service functions.bunnei2014-06-273-0/+154
| | | | FS: Added to CMakeLists.txt
* Kernel: Added stubbed code to support creation of kernel Archive objects.bunnei2014-06-273-0/+85
|
* Merge branch 'threading' of https://github.com/bunnei/citrabunnei2014-06-1424-1124/+1133
|\ | | | | | | | | | | Conflicts: src/core/hle/function_wrappers.h src/core/hle/service/gsp.cpp
| * Kernel: Removed unnecessary "#pragma once".bunnei2014-06-131-2/+0
| |
| * Kernel: Added freeing of kernel objects on emulator shutdown.bunnei2014-06-132-0/+10
| |
| * Event: Updated several log messages to be assertions.bunnei2014-06-131-16/+8
| |
| * HLE: Moved "PARAM" and "RETURN" macros to function_wrappers.h (this is only module where they are needed).bunnei2014-06-132-5/+6
| |
| * SVC: Renamed all function wrapper templates to Wrap, moved to HLE namespace.bunnei2014-06-132-157/+145
| |
| * Thread: Renamed occurrences of "t" to "thread" to improve readability.bunnei2014-06-131-48/+45
| |
| * Thread: Cleaned up VerifyWait, fixed issue where nullptr msg could unnecessarily be logged.bunnei2014-06-131-9/+7
| |
| * HLE: Removed usnused EatCycles function.bunnei2014-06-133-15/+0
| |
| * SVC: Cleaned up function wrappers to pass in correct argument types.bunnei2014-06-132-870/+201
| |
| * Thread: Moved position of * in arguments.bunnei2014-06-131-2/+2
| |
| * Thread: Updated VerifyWait to be more readable (but functionally the same).bunnei2014-06-131-4/+3
| |
| * SVC: Moved declaration of "wait" variable in SendSyncRequest for improved readability.bunnei2014-06-131-1/+1
| |
| * HLE: Updated all uses of NULL to nullptr (to be C++11 compliant)bunnei2014-06-1312-235/+235
| |
| * Kernel: Updated various kernel function "name" arguments to be const references.bunnei2014-06-134-6/+6
| |
| * HLE: Updated various handle debug assertions to be more clear.bunnei2014-06-134-10/+10
| |
| * Mutex: Moved ReleaseMutex iterator declaration to be inside while loop.bunnei2014-06-131-2/+1
| |
| * Kernel: Updated several member functions to be constbunnei2014-06-135-13/+13
| |
| * Thread: Fixed bug with ResetThread where cpu_registers[15] was being incorrectly setbunnei2014-06-131-1/+1
| |
| * Kernel: Made SyncRequest not pure virtual, with a default implementation of error (as this is not required for all kernel objects)bunnei2014-06-133-23/+4
| |
| * Kernel: Added real support for thread and event blockingbunnei2014-06-136-76/+196
| | | | | | | | | | | | | | | | | | | | | | | | | | - SVC: Added ExitThread support - SVC: Added SignalEvent support - Thread: Added WAITTYPE_EVENT for waiting threads for event signals - Thread: Added support for blocking on other threads to finish (e.g. Thread::Join) - Thread: Added debug function for printing current threads ready for execution - Thread: Removed hack/broken thread ready state code from Kernel::Reschedule - Mutex: Moved WaitCurrentThread from SVC to Mutex::WaitSynchronization - Event: Added support for blocking threads on event signalling Kernel: Added missing algorithm #include for use of std::find on non-Windows platforms.
| * hle: added a hokey way to force a thread reschedule during CPU single step mode (as used by the debugger)bunnei2014-06-052-0/+5
| |
| * kernel: changed current default thread priority back to 0x30 - I think this is more correctbunnei2014-06-051-1/+1
| |
| * arm: fixed bug in how thread context switch occurs with SkyEyebunnei2014-06-051-0/+4
| |
| * service: added a error log messages for unimplemented WaitSynchronizationbunnei2014-06-051-0/+1
| |
| * svc: added optional name field to Event and Mutex (used for debugging)bunnei2014-06-036-12/+25
| |
| * kernel: moved position of * for GetTypeName and GetNamebunnei2014-06-031-2/+2
| |
| * coprocessor: reenabled debug logbunnei2014-06-031-1/+1
| |
| * svc: updated WaitSynchronizationN to properly use first pointer argumentbunnei2014-06-022-4/+6
| |
| * svc: changed DuplicateHandle log message from "error" to "debug"bunnei2014-06-021-1/+1
| |
| * svc: added GetThreadPriority and SetThreadPriority, added (incomplete) DuplicateHandle supportbunnei2014-06-023-3/+77
| |
| * kernel: changed main thread priority to default, updated Kernel::Reschedule to use PrepareReschedulebunnei2014-06-026-9/+17
| |
| * svc: cleaned up function_wrappers, updated various SVCs to make use of pointer argumentsbunnei2014-06-022-31/+40
| |
| * svc: added missing function wrapper for SleepThreadbunnei2014-06-011-0/+4
| |
| * gsp: always pass through synchronization barrier for commandsbunnei2014-06-011-1/+16
| |
| * svc: updated waitSychronization to not overwrite handle on return, added stub for SleepThread (does nothing)bunnei2014-06-011-2/+21
| |
| * thread: updated Reschedule to sit at a synchronization barrier when no other threads are ready for executionbunnei2014-06-011-0/+18
| |
| * event: added a hackish ability to set an event as "locked" to its current state, cleaned up some commentsbunnei2014-06-012-4/+32
| |
| * hle: added stubbed service for ndm_ubunnei2014-05-302-0/+65
| |
| * service: cleaned up log messagesbunnei2014-05-301-2/+2
| |
| * service: removed PT_A from, as this was just an alias for APT_Ubunnei2014-05-301-2/+0
| |
| * srv: fix to log unimplemented service (instead of crash)bunnei2014-05-301-6/+2
| |
| * mutex: fixed typo in ReleaseMutexbunnei2014-05-301-1/+3
| |
| * hle: cleaned up log messagesbunnei2014-05-307-42/+47
| |
| * svc: updated OutputDebugString to use OS_LOGbunnei2014-05-301-1/+1
| |
| * svc: changed unimplemented SVC log messages from "debug" messages to "error" messagesbunnei2014-05-301-8/+8
| |
| * svc: added svcClearEvent, stubbed function for svcArbitrateAddress, and various fixesbunnei2014-05-302-22/+38
| | | | | | | | | | | | - force kernel reschedule after svcWaitSynchronization - fixed some bugs with passing in pointer arguments - cleaned up some comments and log messages
| * event: added support for ClearEvent, fixed a bug with CreateEvent, fixed some commentsbunnei2014-05-302-9/+14
| |
| * service: added additional hack to return success on unimplemented service callsbunnei2014-05-301-2/+10
| |
| * srv: changed a NOTICE_LOG to DEBUG_LOGbunnei2014-05-301-1/+1
| |
| * svc: added ArbitrationType enumerationbunnei2014-05-301-0/+9
| |
| * apt: added stubbed function for InquireNotificationbunnei2014-05-291-78/+86
| |
| * hle: properly cast 64-bit function wrapper parameters to (u64)bunnei2014-05-291-2/+2
| |
| * hle: removed PARAM64 macro (this was incorrect), made several bug fixes accordingly for decoding U64 function parametersbunnei2014-05-292-3/+2
| |
| * service: changed interface to return 0 (no error) when a service method is unimplemented - hack to make apps boot furtherbunnei2014-05-291-2/+2
| |
| * APT_U: added stubbed function for APT_U::Enable, fixed some log messages to be more consistentbunnei2014-05-281-3/+10
| |
| * mutex: added preliminary SyncRequest/WaitSynchronization, added some comments/assertionsbunnei2014-05-281-0/+6
| |
| * svc: implemented WaitSynchronization1, WaitSynchronizationN, and CreateEventbunnei2014-05-281-14/+54
| |
| * APT_U: added event creation to Initialize methodbunnei2014-05-281-1/+11
| |
| * event: fixed typos and updated CMakeListsbunnei2014-05-281-1/+1
| |
| * event: added SetEventLocked method to change status an events lockbunnei2014-05-282-0/+18
| |
| * kernel: added event module to support creation of CTR "Event" objectsbunnei2014-05-282-0/+119
| |
| * mutex: removed docstring comment that is no longer relevantbunnei2014-05-271-1/+0
| |
| * mutex: added additional docstringsbunnei2014-05-271-0/+2
| |
| * kernel: added WaitSynchronization method to Kernel::Objectbunnei2014-05-274-0/+39
| |
| * kernel: updated SyncRequest to take boolean thread wait result as a parameterbunnei2014-05-275-10/+33
| |
| * svc: added some assertionsbunnei2014-05-271-6/+4
| |
| * service: Renamed Sync to SyncRequestbunnei2014-05-271-1/+1
| |
| * kernel: added enum for known CurrentThread and CurrentProcess handlesbunnei2014-05-271-0/+5
| |
| * srv: added a real mutex for GetProcSemaphore (instead of stubbed)bunnei2014-05-271-3/+10
| |
| * svc: changed SendSyncRequest to use Kernel::Object SyncRequest (instead of just service Interface class)bunnei2014-05-271-2/+2
| |
| * kernel: add a SyncRequest method to KernelObject for use with svcSendSyncRequestbunnei2014-05-274-6/+11
| |
| * svc: added stub for DuplicateHandle SVC callbunnei2014-05-271-1/+8
| |
* | GPU debugger: Add functionality to inspect command lists.Tony Wasserka2014-06-121-0/+4
| |
* | GPU: Cleanup register definitions.Tony Wasserka2014-06-121-3/+3
| |
* | Rename LCD to GPU.Tony Wasserka2014-06-121-8/+8
| |
* | Add initial graphics debugger interface.Tony Wasserka2014-06-121-0/+6
| |
* | GSP: Define more GX commands.Tony Wasserka2014-06-122-14/+54
| |
* | service: fixed typo that MSVC did not catch as an errorbunnei2014-05-231-1/+1
| |
* | Merge branch 'threading'bunnei2014-05-2321-131/+1124
|\|
| * svc: added a check to ensure that a service was implemented before attempting to connect to its portbunnei2014-05-231-1/+5
| |
| * thread: renamed "WaitCurThread" to "WaitCurrentThread", removed unused "reason" argumentbunnei2014-05-233-6/+6
| |
| * thread: removed unused SwitchContext/Reschedule reason field, added missing arg parameter to SVC CreateThreadbunnei2014-05-233-12/+9
| |
| * kernel: refactored function naming to remove "__" prefixbunnei2014-05-235-62/+72
| |
| * thread: moved ThreadStatus/WaitType to header, added support for arg on CreateThread, added correct CPSR resetbunnei2014-05-232-35/+40
| |
| * APT_U: added a debug log on calling GetLockHandlebunnei2014-05-231-0/+1
| |
| * thread: fixed bug where result of __NextThread was not being properly checked when NULLbunnei2014-05-221-1/+1
| |
| * svc: added Kernel::Reschedule to svc WaitSynchronization1, updated log messages to include newly created handlesbunnei2014-05-221-4/+7
| |
| * svc: enabled use of newly created kernel thread handlebunnei2014-05-211-5/+5
| |
| * mutex: refactored the interface to code to return a Mutex* handlebunnei2014-05-214-5/+16
| |
| * mutex: initial commit of HLE modulebunnei2014-05-214-10/+157
| |
| * svc: added some commentsbunnei2014-05-211-0/+7
| |
| * kernel: fixed include, in general include "common.h" not "common_types.h"bunnei2014-05-211-1/+1
| |
| * service: removed redundant include of common_types.hbunnei2014-05-211-1/+0
| |
| * thread: added correct lowest thread priority, added a thread priority check, and added some commentsbunnei2014-05-212-6/+10
| |
| * thread: exposed ResumeThreadFromWait function for use in other kernel modulesbunnei2014-05-212-8/+11
| |
| * thread: moved threading calls to the Kernel namespacebunnei2014-05-214-103/+117
| |
| * ARM_Interface: added SaveContext and LoadContext functions for HLE thread switchingbunnei2014-05-211-36/+2
| |
| * renamed "syscall" module to "svc" (more accurate naming)bunnei2014-05-216-17/+19
| |
| * thread: whitespace change - fixed * and & placementbunnei2014-05-212-27/+27
| |
| * - created a Kernel namespacebunnei2014-05-216-75/+87
| | | | | | | | | | - cleaned up Kernel code a bit (moved stuff into namespace, fixed whitespace issues) - added handle types for all different CTROS handles
| * apt: changed stubbed handle to be something other than 0xDEADBEEF (used as a magic value in other places) so that I can track how it propagates through the app codebunnei2014-05-201-1/+1
| |
| * thread: added declaration for __KernelReschedule to be used by syscall modulebunnei2014-05-201-0/+3
| |
| * renamed "session" to "handle"bunnei2014-05-191-3/+3
| |
| * - renamed NewHandle to CreateHandlebunnei2014-05-192-8/+8
| | | | | | | | - updated CreateHandle/DeleteHandle to use KernelObject's
| * fix warningbunnei2014-05-191-1/+1
| |
| * - updated service(s) to be KernelObject'sbunnei2014-05-197-59/+31
| | | | | | | | - various cleanups
| * renamed "UID" to "Handle" where appropriatebunnei2014-05-194-24/+22
| |
| * - moved Handle/Result definitions to kernel.hbunnei2014-05-196-14/+19
| | | | | | | | - added ResetType enum
| * - added stub for CreateEventbunnei2014-05-181-8/+22
| | | | | | | | - changed some stubbed SVCs to return unique handle names for debugging purposes
| * added stubbed function for WaitSynchronizationNbunnei2014-05-182-4/+19
| |
| * changed a commentbunnei2014-05-172-2/+2
| |
| * cleanups to SVC CreateThreadbunnei2014-05-171-8/+15
| |
| * - added enum ThreadProcessorIdbunnei2014-05-172-53/+107
| | | | | | | | | | - reorganized some kernel thread functions - added placeholder __KernelWaitThread_Synchronization function
| * - replaced KERNELOBJECT_MAX_NAME_LENGTH with KERNEL_MAX_NAME_LENGTHbunnei2014-05-173-8/+12
| | | | | | | | - added KERNEL_DEFAULT_STACK_SIZE definition (0x4000)
| * added stubbed GetProcSemaphore - does nothing but avoids an exceptionbunnei2014-05-171-1/+7
| |
| * updated APT_U::GetLockHandle to return a valid handlebunnei2014-05-171-1/+5
| |
| * Merge master into threading to add support for VFPbunnei2014-05-172-21/+2
| |\
| * | - added SVC stubs for QueryMemory and GetThreadIdbunnei2014-05-163-2/+30
| | | | | | | | | | | | - added SVC structs MemoryInfo and PageInfo
| * | completely gutted/refactored threading code to be simplerbunnei2014-05-162-658/+230
| | |
| * | changed "UID" to "Handle" to be a little more consistent with CTR namingbunnei2014-05-162-18/+21
| | |
| * | - added ThreadContext structbunnei2014-05-162-8/+26
| | | | | | | | | | | | - cleaned up CreateThread svc
| * | - added helper function for __KernelCreateThreadbunnei2014-05-152-4/+76
| | | | | | | | | | | | | | | - added __KernelSwitchToThread for enabling a thread - added __KernelRotateThreadReadyQueue
| * | changed primary thread priority to 0x30 - this is typical, not 0x31bunnei2014-05-151-1/+2
| | |
| * | added function stubs for EatCycles and ReSchedulebunnei2014-05-152-0/+15
| | |
| * | fixed thread reset to not set stack addressbunnei2014-05-141-1/+1
| | |
| * | various cleanups / remove unused codebunnei2014-05-142-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 pointbunnei2014-05-142-70/+543
| | |
| * | added CreateThread, CreateMutex, and ReleaseMutex SVC stubs (just parameter decoding for now)bunnei2014-05-142-7/+38
| | |
| * | - added __KernelLoadExec functionbunnei2014-05-142-13/+35
| | | | | | | | | | | | - fixed some logging
| * | added initial kernel/thread modulesbunnei2014-05-104-0/+527
| | |
* | | Merge remote-tracking branch 'upstream/master' into issue-7-fixarchshift2014-05-1713-282/+403
|\ \ \ | | |/ | |/|
| * | - reenabled MCR and MRC functions now that VFP is attachedbunnei2014-05-172-21/+2
| |/ | | | | | | - removed HLE::CallMCR function (was pointless)
| * removed unknown fields from GX_CmdBufferHeaderbunnei2014-05-081-5/+0
| |
| * removed unnecessary log messagebunnei2014-05-081-1/+1
| |
| * - removed HLE mem "hack" and replaced with kernel mem regionbunnei2014-05-087-105/+89
| | | | | | | | | | - added a helper function for getting command buffer for services - fixed bug where GSP DMA was incorrectly being done in DataSynchronizationBarrier (instead of gsp_TriggerCmdReqQueue)
| * - added debug logging to syscall.cppbunnei2014-05-072-135/+173
| | | | | | | | - added stubbed HLE syscall functions for svc_GetResourceLimit and svc_GetResourceLimitCurrentValues
| * added config_mem module for HLE of firmware configuration memory settingsbunnei2014-05-072-0/+91
| |
| * - added CallMCR function to coprocessor HLE modulebunnei2014-05-022-7/+20
| | | | | | | | - moved instruction decoding to coprocessor HLE module
| * fixed include in coprocessor.cppbunnei2014-05-021-1/+1
| |
| * renamed hle "mrc" module to "coprocessor"bunnei2014-05-022-0/+0
| |
| * - added some function wrappers for HLEbunnei2014-05-022-10/+29
| | | | | | | | | | - added stub for SVC CreateAddressArbiter - added OutputDebugString SVC
* | Problematic template functionsarchshift2014-04-281-15/+0
|/
* removed DISALLOW_COPY_AND_ASSIGN in favor of NonCopyable classbunnei2014-04-283-9/+0
|
* fixed weird spacingbunnei2014-04-281-1/+1
|
* hackish but working way to set the framebuffer location to VRAM (used in ARM11 demos tested thus far, e.g. yeti3DS)bunnei2014-04-271-3/+9
|
* added simple GSP GPU ReadHWRegs function to support returning the framebuffer addressbunnei2014-04-261-1/+37
|
* added preliminary DataSynchronizationBarrier support with simple DMA copybunnei2014-04-261-7/+39
|
* moved HLE::MRC to its own module, added support for catching data synchronization barrier commandbunnei2014-04-254-10/+52
|
* fixed bug where svc_ControlMemory was not properly getting passed in parametersbunnei2014-04-251-2/+2
|
* - added preliminary support for svc_MapMemoryBlockbunnei2014-04-251-4/+34
| | | | | - added shared memory region - moarrrr cleanups to memory_map
* added GSP::RegisterInterruptRelayQueue functionbunnei2014-04-251-31/+40
|
* - refactored how service functions are calledbunnei2014-04-255-19/+39
| | | | - added option to create/delete service handles
* renamed hw_lcd module to just lcdbunnei2014-04-181-2/+0
|
* added GSP heap memory allocationbunnei2014-04-181-1/+25
|
* added a new function wrapperbunnei2014-04-171-0/+5
|
* fixed bug with printing std::string in log messagesbunnei2014-04-171-2/+2
|
* added class stub for HID:User servicebunnei2014-04-173-0/+72
|
* updated service commentsbunnei2014-04-176-5/+17
|
* - fixed tabs in function_wrappers.hbunnei2014-04-174-395/+413
| | | | | - fixed log message wording in hle.cpp - added syscall stubs for CloseHandle and WaitSynchronization1
* - added stubbed out GSP::Gpu service interfacebunnei2014-04-167-7/+103
| | | | - various cleanups/refactors to HLE services
* removed no longer used function headerbunnei2014-04-161-2/+0
|
* restructured hle:services completely to use function lookup tablesbunnei2014-04-165-137/+215
|
* fixed naming for APT_Ubunnei2014-04-163-9/+9
|
* - extracted srv: calls from service.cpp and put in its own modulebunnei2014-04-164-106/+105
| | | | | - added function tables for service calls - lots of refactoring
* added a stub for GetLockHandlebunnei2014-04-143-9/+44
|
* added framework for APT service (application and title launching service)bunnei2014-04-135-5/+118
|
* renamed class Interface_SRV to SRVbunnei2014-04-131-6/+6
|
* added some very initial command parsing for SRV Syncbunnei2014-04-131-5/+31
|
* added a GetPointer function for reading from HLE command bufferbunnei2014-04-132-0/+14
|
* added OS memory read/write for thread command bufferbunnei2014-04-132-3/+55
|
* cleanups to service HLEbunnei2014-04-132-8/+8
|
* - added HLE to connect to "srv:" servicebunnei2014-04-135-130/+328
| | | | | | - added a manager for keeping track of services/ports - added a memory mapped region for memory accessed by HLE - added HLE for GetThreadCommandBuffer function
* - renamed hle_syscall to just syscallbunnei2014-04-125-101/+145
| | | | - added service.h as an initial service interface
* replace tabs with spacesbunnei2014-04-121-6/+6
|
* moved hle.cpp into hle folder (due to mistake earlier)bunnei2014-04-121-0/+57
|
* added remaining known syscall functions to Syscall_Tablebunnei2014-04-111-0/+80
|
* base code to call a syscall from ARM11 appcorebunnei2014-04-113-7/+56
|
* changed some naming/misc cleanupsbunnei2014-04-113-18/+17
|
* - removed syscall classes (will just use HLEFunction)bunnei2014-04-113-15/+17
| | | | | - added hle.cpp and module registration - removed unused code
* added initial modules for setting up SysCall HLEbunnei2014-04-114-0/+825