summaryrefslogtreecommitdiffstats
path: root/src/core (follow)
Commit message (Collapse)AuthorAgeFilesLines
* dyncom: Switch the app and system cores into the correct mode at initializationLioncash2015-02-135-17/+21
|
* dyncom: Clean up the constructorLioncash2015-02-133-16/+7
| | | | Some function calls aren't necessary and would be handled by regular initialization routines.
* dyncom: Remove warning for SXTAHLioncash2015-02-131-1/+0
| | | | This is tested to work correctly.
* arm: Remove ARMul_EmulateInitLioncash2015-02-124-55/+1
| | | | This was only used for armemu, which has since been removed. Removed components related to this as well.
* armdefs: Remove unnecessary extern CLioncash2015-02-121-6/+0
|
* Implemented WriteHWRegsWithMask for GSP.Kevin Hartman2015-02-111-6/+91
|
* arm: Remove ARM26 support.Lioncash2015-02-112-45/+4
| | | | This will never be used. 32-bit is the norm.
* Merge pull request #559 from lioncash/cleanbunnei2015-02-114-24/+40
|\ | | | | arm: Some cleanup. Also fixed the initial ARM mode that is emulated.
| * arm: Get rid of some magic constants. Specify proper ARM mode.Lioncash2015-02-113-3/+10
| | | | | | | | Initially, we were starting the emulator in USER26MODE, which is incorrect, this should be USER32MODE.
| * arm: Change some more constants into enumsLioncash2015-02-112-21/+30
| |
* | Asserts: break/crash program, fit to style guide; log.h->assert.harchshift2015-02-1159-77/+33
| | | | | | | | | | | | | | Involves making asserts use printf instead of the log functions (log functions are asynchronous and, as such, the log won't be printed in time) As such, the log type argument was removed (printf obviously can't use it, and it's made obsolete by the file and line printing) Also removed some GEKKO cruft.
* | GSP: Fixed typo in 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-114-8/+191
|\ \ \ | | | | | | | | Services: Stub some functions
| * | | Services: Stub some functionspurpasmart962015-02-084-8/+191
| | | |
* | | | Merge pull request #556 from lioncash/cleanbunnei2015-02-114-28/+19
|\ \ \ \ | | |_|/ | |/| | arm: Remove TRUE/FALSE defines
| * | | arm: Remove TRUE/FALSE definesLioncash2015-02-104-28/+19
| | | | | | | | | | | | | | | | | | | | - Removed the Debug parameter from ARMul_State since it isn't used. - Changed ARMul_CoProInit to a void function. It always returned true.
* | | | Merge pull request #555 from lioncash/lutbunnei2015-02-111-7/+7
|\ \ \ \ | | | | | | | | | | arm_dyncom_thumb: Make lookup tables static
| * | | | arm_dyncom_thumb: Make lookup tables staticLioncash2015-02-101-7/+7
| |/ / / | | | | | | | | | | | | These don't need to be recreated all the time.
* | | | 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-1019-159/+199
| | | |
* | | | FS: Get rid of completely useless Archive classYuri Kunde Schlesner2015-02-101-36/+26
|/ / /
* | | Merge pull request #553 from lioncash/denormbunnei2015-02-102-0/+6
|\ \ \ | | | | | | | | vfp: Normalize accumulator for multiply accumulate instructions
| * | | vfp: Normalize accumulator for multiply accumulate instructionsLioncash2015-02-102-0/+6
| | | |
* | | | dyncom: Add more regs to MCR/MRCLioncash2015-02-102-18/+35
|/ / / | | | | | | | | | Adds the registers that were left out of some coprocessor ranges.
* | / Scheduler refactor Pt. 1Kevin Hartman2015-02-107-284/+287
| |/ |/| | | | | | | | | | | | | | | | | | | | | | | * Simplifies scheduling logic, specifically regarding thread status. It should be much clearer which statuses are valid for a thread at any given point in the system. * Removes dead code from thread.cpp. * Moves the implementation of resetting a ThreadContext to the corresponding core's implementation. Other changes: * Fixed comments in arm interfaces. * Updated comments in thread.cpp * Removed confusing, useless, functions like MakeReady() and ChangeStatus() from thread.cpp. * Removed stack_size from Thread. In the CTR kernel, the thread's stack would be allocated before thread creation.
* | Merge pull request #551 from bunnei/mutex-fixesbunnei2015-02-103-20/+24
|\ \ | | | | | | Mutex/synch fixes
| * | Mutex: Locks should be recursive.bunnei2015-02-102-16/+20
| | |
| * | WaitSynch: Always reschedule (verified behavior on hw).bunnei2015-02-101-4/+4
| | |
* | | vfpdouble: Fix the FTOUI NaN sign settingLioncash2015-02-091-1/+1
| | | | | | | | | | | | This was fixed for vfpsingle, but not vfpdouble
* | | Throw more unused/unnecessary VFP code outLioncash2015-02-093-215/+1
| | |
* | | vfp_helper: Convert some flags to enums. Throw out more duplicated FPSCR stuffLioncash2015-02-094-192/+153
| | |
* | | vfp_helper: Normalize tabs to spacesLioncash2015-02-091-172/+170
|/ /
* | vfp_helper: Remove unnecessary extern C blocksLioncash2015-02-061-17/+1
| |
* | vfp: Move FPSID, FPEXC, and FPSCR values over to enums.Lioncash2015-02-063-150/+104
| | | | | | | | Also got rid of duplicate definitions of some of these values.
* | Merge pull request #537 from lioncash/vfpbunnei2015-02-041-6/+6
|\ \ | | | | | | vfp: Fix VCVT
| * | vfp: Fix VCVTLioncash2015-02-041-6/+6
| | | | | | | | | | | | | | | These variants exclusively read from the single precision regs and write to double-precision registers Fixes issues where converted values would be way off from what they should be due to the results being stored in the wrong registers.
* | | Merge pull request #536 from lioncash/deadbunnei2015-02-042-1765/+0
|\ \ \ | |/ / |/| | vfp: Throw out unused code
| * | vfp: Throw out unused codeLioncash2015-02-042-1765/+0
| | |
* | | dyncom: Remove more unnecessary codeLioncash2015-02-031-45/+3
|/ /
* | core: Fix some warnings on OSXLioncash2015-02-034-6/+5
| |
* | 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-0217-8/+51
| | | | | | | | | | | | This should speed up compile times a bit, as well as enable more liberal use of forward declarations. (Due to SharedPtr not trying to emit the destructor anymore.)
* | Mutex: Replace g_mutex_held_locks with a set inside 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
| |
* | Merge pull request #514 from rohit-n/fix-warningsbunnei2015-02-011-2/+2
|\ \ | | | | | | Silence a few warnings.
| * | Silence a few warnings.Rohit Nirmal2015-01-301-2/+2
| | |
* | | Merge pull request #525 from lioncash/armwarnbunnei2015-02-012-6/+3
|\ \ \ | | | | | | | | vfp: Get rid of some compile warnings
| * | | vfp: Get rid of some compile warningsLioncash2015-02-012-6/+3
| | | |
* | | | arm: Clean up ARMul_StateLioncash2015-02-015-138/+84
|/ / / | | | | | | | | | Remove unnecessary/unused struct variables.
* | | arm: Adios armemuLioncash2015-02-0116-8599/+166
| | |
* | | 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
| |/
* | dyncom: clean up arm_dyncom_dec.hLioncash2015-01-301-43/+2
| |
* | arm: Move headers over to pragma onceLioncash2015-01-307-31/+11
| |
* | arm: Get rid of armcpu.h and skyeye_types.hLioncash2015-01-306-115/+0
| |
* | arm: Clean out armos.h and armmmu.hLioncash2015-01-302-181/+23
| |
* | Merge pull request #513 from lioncash/cleanupbunnei2015-01-306-1667/+168
|\ \ | | | | | | arm: Cleanup.
| * | arm: Throw out a lot of unnecessary codeLioncash2015-01-306-1536/+56
| | |
| * | armdefs: Move some defines over to enumsLioncash2015-01-301-131/+112
| |/
* | loader: Add missing printf argumentLioncash2015-01-301-1/+1
| |
* | 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-302-9/+7
|
* 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
| |
* | dyncom: Minor cleanupLioncash2015-01-271-126/+137
| | | | | | | | Narrow scopes for the instruction variables. Remove unnecessary parentheses.
* | 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
| | |
* | | Update vfp.cppbunnei2015-01-271-1/+1
| | | | | | | | | VFP: Changed a debug log to trace.
* | | Merge pull request #485 from Subv/more_servsbunnei2015-01-2621-3/+426
|\ \ \ | | | | | | | | Services: Stubbed more services.
| * | | Services/HID: Removed some files due to a rebase errorSubv2015-01-243-267/+0
| | | |
| * | | Services: Stubbed more services.Subv2015-01-2424-3/+693
| | | | | | | | | | | | | | | | Implemented FSUser::CreateExtSaveData
* | | | Merge pull request #410 from chinhodado/cleanupbunnei2015-01-245-483/+157
|\ \ \ \ | | | | | | | | | | Cleanup: Logging in Core
| * | | | Cleanup: Logging in CoreChin2015-01-195-483/+157
| | | | |
* | | | | vfp: Clean up vertical alignment for instructionsLioncash2015-01-231-131/+125
| | | | |
* | | | | cam_u.h: fix indentationarchshift2015-01-221-2/+2
| |/ / / |/| | | | | | | Withholding my profanity towards Xcode.
* | | | Merge pull request #493 from archshift/ptmplaybunnei2015-01-226-0/+106
|\ \ \ \ | | | | | | | | | | Stubbed some services
| * | | | Stubbed cam:u servicearchshift2015-01-214-0/+51
| | | | |
| * | | | Stubbed ptm:play servicearchshift2015-01-214-0/+55
| | | | |
* | | | | dyncom: Minor cleanupLioncash2015-01-221-282/+270
| | | | | | | | | | | | | | | | | | | | Removes some unused macros and cleans up indentation inconsistencies
* | | | | 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-2110-219/+333
|/ / / /
* | | | Merge pull request #498 from lioncash/staticsbunnei2015-01-201-14/+14
|\ \ \ \ | | | | | | | | | | core_timing: Mark several variables as static
| * | | | core_timing: Mark several variables as staticLioncash2015-01-201-14/+14
| | | | | | | | | | | | | | | | | | | | These are only used in this translation unit.
* | | | | 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 #241 from linkmauve/better-loaderbunnei2015-01-208-352/+344
|\ \ \ \ \ | | | | | | | | | | | | Improve the loader a bit
| * | | | | Loader: Clean up the ELF AppLoader.Emmanuel Gil Peyrot2015-01-152-42/+35
| | | | | |
| * | | | | Loader: Clean up the 3DSX AppLoader.Emmanuel Gil Peyrot2015-01-151-17/+24
| | | | | |
| * | | | | Loader: Clean up the NCCH AppLoader.Emmanuel Gil Peyrot2015-01-151-51/+48
| | | | | |
| * | | | | Loader: Display the type of the file being loaded.Emmanuel Gil Peyrot2015-01-151-3/+23
| | | | | |
| * | | | | Loader: Guess filetype from the magic, or fallback to the extension.Emmanuel Gil Peyrot2015-01-158-26/+112
| | | | | |
| * | | | | Loader: Don’t assume the file hasn’t been read before.Emmanuel Gil Peyrot2015-01-153-4/+13
| | | | | |
| * | | | | Loader: Keep a reference to the file and pass it to the correct AppLoader, instead of loading it multiple times.Emmanuel Gil Peyrot2015-01-158-176/+116
| | | | | |
| * | | | | Loader: Initialize the default NCCH values in the class declaration, not in the constructor.Emmanuel Gil Peyrot2015-01-152-8/+4
| | | | | |
| * | | | | Loader: Remove the useless THREEDSXReader class.Emmanuel Gil Peyrot2015-01-151-10/+4
| | | | | |
| * | | | | Loader: Never forget to change is_loaded.Emmanuel Gil Peyrot2015-01-156-7/+15
| | | | | |
| * | | | | Loader: Don’t duplicate the docstring into the cpp file.Emmanuel Gil Peyrot2015-01-154-56/+0
| | | | | |
| * | | | | Loader: Fix indentation, whitespace, and a few other such cosmetic stuff.Emmanuel Gil Peyrot2015-01-152-26/+24
| | | | | |
* | | | | | dyncom: Clarify precedence for ternary statementsLioncash2015-01-203-3/+3
| | | | | |
* | | | | | Merge pull request #494 from lioncash/shiftbunnei2015-01-191-7/+33
|\ \ \ \ \ \ | |_|_|/ / / |/| | | | | dyncom: Implement missing shifts in ScaledRegisterPostIndexed, etc
| * | | | | dyncom: Implement missing shifts in ScaledRegisterPostIndexed, etcLioncash2015-01-191-7/+33
| | |/ / / | |/| | |
* | | | | Merge pull request #383 from zhuowei/shared_pagebunnei2015-01-195-0/+116
|\ \ \ \ \ | |/ / / / |/| | | | Add some support for the shared page
| * | | | Add some support for the shared page (currently 3d slider is implemented)Zhuowei Zhang2015-01-165-0/+116
| | | | |
* | | | | dyncom: Handle the ARM A2 encoding of STRT/LDRTLioncash2015-01-171-10/+24
| | | | | | | | | | | | | | | | | | | | These were also missing the shifted register case.
* | | | | dyncom: Handle the ARM A2 encoding of LDRBT/STRBT.Lioncash2015-01-171-17/+15
| |_|/ / |/| | |
* | | | 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-165-102/+91
|\ \ \ \ | |_|/ / |/| | | Correctness fixes for GPU flipping and interrupts
| * | | GPU: Fix buffer overrun in Display TransfersYuri Kunde Schlesner2015-01-141-9/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Display transfers with the horizontal downscaling flag were calculating the wrong output size, causing them to write double the amount of data intended. It is likely that this was perceived as correct due to a separate bug in calculating source indices which caused the image to be padded unless the previous bug was present. This fixes both issues, correcting flickering issues in 3dscraft, blargSnes and more (caused by the transfer overwriting the back buffer which followed) as well as potentially fixing other crashes.
| * | | GSP: Fix appending of interrupts to the shared memory 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.
| * | | GPU: Do periodic VBlank updates using CoreTimingYuri Kunde Schlesner2015-01-143-51/+44
| | | |
| * | | GPU: Correct wrong default framebuffer address for sub-screen.Yuri Kunde Schlesner2015-01-141-2/+2
| | | | | | | | | | | | | | | | | | | | It appears this is a mistake, since the sub-screen has no right framebuffer.
| * | | 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-142-21/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | PDC0 and PDC1 are both VBlank interrupts. PDC0 was being treated as a HBlank interrupt and fired many more times than it should. They now both fire together at 60 Hz. This puzzlingly *improves* apparent framerate on many applications. A few other interrupts were being fired inside the GSP command processing instead of on the actual GPU register writes, so they were moved there, which should cover direct writes tho those registers not going through the GX command queue.
* | | | Merge pull request #481 from Subv/hm_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-139-1/+364
|/ / / | | | | | | | | | | | | cfg:s, ptm:sysm, apt:s. apt:s is almost exactly the same as apt:u as per 3dbrew
* | / vfp: Remove dead codeLioncash2015-01-121-50/+14
| |/ |/|
* | dyncom: Fix 32-bit ASR shifts for immediatesLioncash2015-01-121-5/+3
| |
* | dyncom: Remove unused flag macrosLioncash2015-01-121-15/+3
| |
* | Merge pull request #472 from lioncash/overflowbunnei2015-01-123-147/+175
|\ \ | | | | | | dyncom: Fix some more V-flag setting ops. Plus some cleanup.
| * | dyncom: Get rid of unnecessary outer-scope variables in InterpreterMainLoopLioncash2015-01-121-97/+108
| | |
| * | dyncom: Fix overflow flag setting for ADD/RSB/RSC/SUB/SBCLioncash2015-01-121-38/+41
| | | | | | | | | | | | Also cleans up CMN, and CMP.
| * | dyncom: Add a helper function for addition with a carryLioncash2015-01-123-12/+26
| | |
* | | Fix building on MinGWdarkf2015-01-121-0/+13
|/ /
* | dyncom: Fix ADC overflow flag settingLioncash2015-01-121-8/+12
| |
* | 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
| | |
* | | dyncom: Fix conditional execution of MSRLioncash2015-01-121-29/+31
| | |
* | | 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-0924-374/+329
|\ \ | | | | | | 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-0911-302/+222
| | |
| * | 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-0917-32/+52
| | |
* | | 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-098-5/+234
|\ \ \ | | | | | | | | Implemented timers
| * | | SVC: Implemented the Timer service calls.Subv2015-01-098-5/+234
| | | |
* | | | Core: Fixed a crash and removed some unused variables.Subv2015-01-092-8/+2
| | | | | | | | | | | | | | | | ARM_Disasm only has static methods, so there's no need to have an instance of it.
* | | | DynCom: Add a comment to GetTicks.Subv2015-01-091-0/+1
| | | |
* | | | Timing: Use CoreTiming::GetTicks to keep track of ticks.Subv2015-01-092-6/+2
| | | | | | | | | | | | | | | | This will keep track of idle ticks for us, and fixes some tickcount-related issues
* | | | Merge pull request #443 from Subv/sleep_threadbunnei2015-01-093-8/+43
|\ \ \ \ | | | | | | | | | | SVC: Fixed SleepThread
| * | | | SVC: Fixed SleepThread.Subv2015-01-093-8/+43
| | |_|/ | |/| | | | | | | | | | It will now properly wait the specified number of nanoseconds and then wake up the thread.
* | | | Merge pull request #446 from lioncash/umaalbunnei2015-01-081-4/+4
|\ \ \ \ | |/ / / |/| | | dyncom: Fix UMAAL
| * | | dyncom: Fix UMAALLioncash2015-01-081-4/+4
| | | | | | | | | | | | | | | | These need to be done as a 64-bit operation.
* | | | Threads: Use a dummy idle thread when no other are ready.Subv2015-01-084-2/+47
| | | | | | | | | | | | | | | | This thread will not actually execute instructions, it will only advance the timing/events and try to yield immediately to the next ready thread, if there aren't any ready threads then it will be rescheduled and start its job again.
* | | | Merge pull request #404 from bunnei/more-frame-synch-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.
* | | | | Merge pull request #442 from lioncash/smulbunnei2015-01-071-10/+7
|\ \ \ \ \ | |_|_|/ / |/| | | | dyncom: Fix SMULWB/SMULWT
| * | | | dyncom: Fix SMULWB/SMULWTLioncash2015-01-071-10/+7
| |/ / / | | | | | | | | | | | | Wasn't doing proper sign-extension
* | | | Merge pull request #425 from Subv/coretimingbunnei2015-01-074-418/+378
|\ \ \ \ | | | | | | | | | | Ported the CoreTiming namespace from PPSSPP
| * | | | CoreTiming: Ported the CoreTiming namespace from PPSSPPSubv2015-01-074-418/+378
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Implemented the required calls to make it work. CoreTiming: Added a new logging class Core_Timing.
* | | | | Fix double-free in Service manager during shutdownYuri Kunde Schlesner2015-01-072-25/+4
| |/ / / |/| | | | | | | | | | | Fixes #423.
* | | | Merge pull request #438 from lioncash/swpbunnei2015-01-071-0/+1
|\ \ \ \ | | | | | | | | | | dyncom: Fix SWPB
| * | | | dyncom: Fix SWPBLioncash2015-01-071-0/+1
| | |_|/ | |/| |
* | | | Merge pull request #434 from lioncash/smbunnei2015-01-071-1/+56
|\ \ \ \ | |/ / / |/| | | dyncom: Move over SMLALXY
| * | | dyncom: Move over SMLALXYLioncash2015-01-071-1/+56
| | |/ | |/|
* | | Merge pull request #376 from Subv/arc_reorderbunnei2015-01-0711-34/+73
|\ \ \ | |/ / |/| | Archives: Change the folder layout of some archives.
| * | Archives/Exdata: Don't set concrete_mount_point in the ctorSubv2015-01-061-1/+1
| | |
| * | Archives: Changed the unimplemented archives comment.Subv2015-01-061-1/+1
| | | | | | | | | | | | It now refers to me as the PoC
| * | Archives: Addressed some commentsSubv2015-01-065-15/+15
| | |
| * | SaveDataCheck: Fixed a typoSubv2015-01-051-1/+1
| | |
| * | Archives: Make SYSTEM_ID and SDCARD_ID stringsSubv2015-01-046-9/+11
| | |
| * | Archives: Changed the way paths are built for the archives.Subv2015-01-0410-27/+64
| | | | | | | | | | | | Each archive now takes a mount point of either NAND or SDMC, and builds its own directory structure there, trying to simulate an HLE-friendly hardware layout
| * | SaveDataCheck: Move the files to nand/titleSubv2015-01-041-1/+2
| | | | | | | | | | | | under /nand/title/high/low/content/00000000.app.romfs
| * | Archives: Change the folder layout of some archives.Subv2015-01-033-4/+3
| | | | | | | | | | | | This is to better represent the hardware layout, they are still aren't quite accurate, but this better and will help a bit when implementing the other archives like NAND-RO and NAND-RW
* | | Merge pull request #417 from kevinhartman/exclusive-tag-fixbunnei2015-01-062-16/+18
|\ \ \ | | | | | | | | Added exclusive reservation granule from ARMv7 spec to dyncom...
| * | | Added exclusive reservation granule from ARMv7 spec to dyncom to protect LDR/STREX.Kevin Hartman2015-01-062-16/+18
| | | |
* | | | 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
| |/ / /
* | | | Merge pull request #422 from lioncash/bxjbunnei2015-01-051-8/+25
|\ \ \ \ | | | | | | | | | | dyncom: Partially emulate BXJ
| * | | | dyncom: Partially emulate BXJLioncash2015-01-051-8/+25
| | | | | | | | | | | | | | | | | | | | Just in case some game studio let the intern write inline assembly or something.
* | | | | Merge pull request #416 from bunnei/fake-dsp-interruptbunnei2015-01-053-5/+28
|\ \ \ \ \ | |/ / / / |/| | | | DSP: Signal (faked) interrupt on every frame.
| * | | | DSP: Signal (faked) interrupt on every frame.bunnei2015-01-053-5/+28
| | | | | | | | | | | | | | | | | | | | - Hack to work around games checking that the DSP event has been signaled by a real DSP interrupt.
* | | | | dyncom: Actually set the Q flag for SMLABB/SMLABT/SMLATB/SMLATTLioncash2015-01-051-1/+2
| | | | | | | | | | | | | | | | | | | | Easy skyeye todo fix.
* | | | | Merge pull request #418 from lioncash/qdbunnei2015-01-054-25/+117
|\ \ \ \ \ | |/ / / / |/| | | | dyncom: Implement QADD/QSUB/QDADD/QDSUB
| * | | | dyncom: Implement QADD/QSUB/QDADD/QDSUBLioncash2015-01-054-25/+117
| | | | |
* | | | | 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 #415 from Dante38490/masterbunnei2015-01-051-0/+2
|\ \ \ \ \ \ | | | | | | | | | | | | | | Loader: Add support for loading NCCH ROMs with the .3DS extension
| * | | | | | Fix correct espaceDante384902015-01-051-2/+2
| | | | | | |
| * | | | | | Add support load 3DS roomDante384902015-01-051-0/+2
| | | | | | |
* | | | | | | 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-054-0/+72
|\ \ \ \ \ \ | | | | | | | | | | | | | | Stub the y2r:u service
| * | | | | | Stub the y2r:u servicearchshift2015-01-034-0/+72
| | | | | | |
* | | | | | | skyeye: Remove duplicate typedefsLioncash2015-01-044-41/+17
| |/ / / / / |/| | | | | | | | | | | | | | | | | citra already has its own typedefs like this.
* | | | | | FileSys: Fix crash bug in DiskFile exposed by #400Yuri Kunde Schlesner2015-01-031-4/+0
| | | | | |
* | | | | | FileSys: Fix a few memory leaksYuri Kunde Schlesner2015-01-032-6/+7
| | | | | |
* | | | | | Merge pull request #396 from bunnei/default-dyncombunnei2015-01-032-3/+3
|\ \ \ \ \ \ | | | | | | | | | | | | | | Core: Change default CPU to dyncom.
| * | | | | | Core: Change default CPU to dyncom.bunnei2015-01-032-3/+3
| | |_|_|_|/ | |/| | | |
* | | | | | Merge pull request #398 from lioncash/smbunnei2015-01-031-1/+43
|\ \ \ \ \ \ | |_|_|_|_|/ |/| | | | | dyncom: Implement SMLAW
| * | | | | dyncom: Implement SMLAWLioncash2015-01-031-1/+43
| | |_|/ / | |/| | |
* / | | | VFP: Minor cleanup, functionally the same.bunnei2015-01-031-2587/+2476
|/ / / /
* | | | Merge pull request #395 from lioncash/revbunnei2015-01-031-45/+45
|\ \ \ \ | | | | | | | | | | dyncom: Implement REVSH
| * | | | dyncom: Implement REVSHLioncash2015-01-031-45/+45
| |/ / / | | | | | | | | | | | | Also joins the REV ops into one common place.
* / / / dyncom: Implement SMLALD/SMLSLDLioncash2015-01-031-3/+72
|/ / /
* | | Merge pull request #381 from Subv/savedatacheckbunnei2015-01-0314-319/+275
|\ \ \ | | | | | | | | Implemented the SaveDataCheck archive
| * | | IVFCArchive: Use a critical log to notify of invalid operations.Subv2015-01-031-9/+9
| | | |
| * | | SaveDataCheck: Remove unneeded constructor from a classSubv2015-01-031-2/+0
| | | |
| * | | Archives: Added some documentation to IVFCArchiveSubv2015-01-031-0/+5
| | | |
| * | | Archives: Reduced duplicate code in RomFS and SaveCheck.Subv2015-01-0314-341/+238
| | | | | | | | | | | | | | | | Fixed a few warnings and cleaned up the code
| * | | SaveDataCheck: Preliminary work in this archive.Subv2015-01-034-7/+63
| | | | | | | | | | | | | | | | | | | | | | | | This allows Steel Diver to boot further, some files are needed. This is still not ready and needs a big cleanup, this will possibly be delayed until the way we handle archives is fixed (with factory classes instead of ahead-of-time creation of archives)
* | | | Merge pull request #392 from lioncash/smbunnei2015-01-031-3/+64
|\ \ \ \ | |/ / / |/| | | dyncom: Implement SMMLA/SMMUL/SMMLS
| * | | dyncom: Implement SMMLA/SMMUL/SMMLSLioncash2015-01-031-3/+64
| | | |
* | | | Merge pull request #391 from lioncash/pedanticbunnei2015-01-032-4/+4
|\ \ \ \ | | | | | | | | | | archive/elf: Minor misc changes.
| * | | | elf: Make DidRelocate constLioncash2015-01-031-1/+1
| | | | |
| * | | | archive: Fix initializer list orderLioncash2015-01-031-3/+3
| | |/ / | |/| |
* | | | dyncom: Implemented LDREXD/STREXD/LDREXH/STREXHbunnei2015-01-033-227/+282
| |/ / |/| |
* | | Merge pull request #390 from lioncash/wutbunnei2015-01-031-27/+0
|\ \ \ | | | | | | | | dyncom: Remove dead function InterpreterInitInstLength
| * | | dyncom: Remove dead function InterpreterInitInstLengthLioncash2015-01-031-27/+0
| |/ / | | | | | | | | | Technically eliminates two memory leaks as well.
* | | Merge pull request #388 from lioncash/smbunnei2015-01-035-52/+90
|\ \ \ | | | | | | | | dyncom: Implement SMLAD/SMUAD/SMLSD/SMUSD
| * | | armemu: Fix missing Q flag check for SMLSD.Lioncash2015-01-031-2/+6
| | | |
| * | | dyncom: Implement SMLAD/SMUAD/SMLSD/SMUSDLioncash2015-01-035-50/+84
| |/ /
* / / soc_u: Fix a missing formatting argumentLioncash2015-01-031-1/+1
|/ /
* | dyncom: Implement SXTAB16 and SXTB16Lioncash2015-01-021-3/+58
| |
* | Merge pull request #358 from neobrain/pica_progress2bunnei2015-01-022-1/+8
|\ \ | | | | | | pica_progress followups
| * | GPU: Pseudo-implement horizontal scaling.Tony Wasserka2014-12-312-1/+8
| | | | | | | | | | | | | | | It's not really known how this actually works. Some testing has shown that this probably performs no filtering, and common usage in games suggests it's not actually resizing the image at all. However, this patch does seem to fix some homebrew showing quasi-duplicated images while still keeping other applications in a working state.
* | | Merge pull request #379 from lioncash/shbunnei2015-01-021-8/+110
|\ \ \ | | | | | | | | dyncom: Implement SHADD8/SHADD16/SHSUB8/SHSUB16/SHASX/SHSAX
| * | | dyncom: Implement SHADD8/SHADD16/SHSUB8/SHSUB16/SHASX/SHSAXLioncash2015-01-011-8/+110
| | |/ | |/|
* | | Fix SADD8/SSUB8 in the armemuLioncash2015-01-011-50/+28
| | |
* | | dyncom: Implement SADD8/SSUB8Lioncash2015-01-011-55/+108
|/ /
* | 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
* | Merge pull request #375 from lioncash/uopsbunnei2014-12-311-9/+208
|\ \ | |/ |/| dyncom: Implement UADD8/UADD16/USUB8/USUB16/UASX/USAX
| * dyncom: Implement UADD8/UADD16/USUB8/USUB16/UASX/USAXLioncash2014-12-311-9/+208
| |
* | dyncom: Massive refactorbunnei2014-12-312-654/+221
| |
* | Merge pull request #369 from darkf/mingw_bunnei2014-12-311-0/+8
|\ \ | | | | | | Fix MinGW build (2)
| * \ Fix merge conflictsdarkf2014-12-30167-12294/+13495
| |\ \
| * | | Add comment regarding __WIN32__ in SkyEye codedarkf2014-11-291-0/+4
| | | |
| * | | Fix MinGW builddarkf2014-11-291-0/+4
| | | |
* | | | vfp: Get rid of a few warningsLioncash2014-12-302-2/+2
| |_|/ |/| |
* | | vfp: Implement VMOVBRRSSLioncash2014-12-303-12/+44
| | |
* | | dyncom: Implement USAT16/SSAT16Lioncash2014-12-301-2/+61
| | |
* | | Merge pull request #368 from purpasmart96/dsp_membunnei2014-12-303-2/+12
|\ \ \ | | | | | | | | MemMap: Add support for DSP Read & Writes in the memory map
| * | | MemMap: Add support for DSP Read & Writes in the memory mappurpasmart962014-12-303-2/+12
| | | |
* | | | APT:A: Some style changesSubv2014-12-301-12/+12
| | | |
* | | | Archives: Implemented ExtSaveData and SharedExtSaveDataSubv2014-12-3014-60/+264
| |_|/ |/| | | | | | | | | | | | | | | | | | | | They will be stored in /extsavedata/SDMC and /extsavedata/NAND respectively. Also redirect some APT_A functions to their APT_U equivalents. Implemented the gamecoin.dat file in SharedExtSaveData in the PTM module. Implemented formatting the savegame. Retake a previous savegame if it exists instead of reporting them as not formatted every time a game is loaded.
* | | dyncom: Implement USAT/SSATbunnei2014-12-303-2/+131
|/ /
* | Merge pull request #253 from purpasmart96/mem_mapbunnei2014-12-302-69/+76
|\ \ | | | | | | MemMap: Removed I/O address's and added more stuff
| * | MemMap: Added AXI_WRAM & SHARED_PAGE along with other stuffpurpasmart962014-12-142-69/+76
| | | | | | | | | | | | | | | | | | Got rid of I/O address's since the I/O addresses range's overlap with other address's types such as vram, these I/O addresses need to be done in an different way.
* | | dyncom: Various cleanups to match coding style, no functional changes.bunnei2014-12-305-7087/+5962
| | |
* | | Merge pull request #361 from lioncash/moreqopsbunnei2014-12-294-65/+142
|\ \ \ | | | | | | | | dyncom/armemu: Implement QADD8/QSUB8.
| * | | dyncom: Implement QADD8/QSUB8Lioncash2014-12-291-32/+42
| | | |
| * | | armemu: Implement QADD8/QSUB8Lioncash2014-12-293-33/+100
| | | |
* | | | dyncom: Fix SMLALXY's instruction labelsLioncash2014-12-291-2/+2
| | | | | | | | | | | | | | | | They were erroneously labeled as SMLAL.
* | | | Merge pull request #303 from linkmauve/fs-cleanupTony Wasserka2014-12-299-169/+97
|\ \ \ \ | |/ / / |/| | | FileSys cleanup
| * | | FileSys: Clean up according to the coding style, and remove redundant namespaced names.Emmanuel Gil Peyrot2014-12-249-169/+97
| | | |
* | | | Merge pull request #360 from lioncash/dynuxtbunnei2014-12-291-2/+55
|\ \ \ \ | | | | | | | | | | dyncom: Implement UXTB16/UXTAB16
| * | | | dyncom: Implement UXTB16/UXTAB16Lioncash2014-12-291-2/+55
| | | | |
* | | | | Merge pull request #347 from bunnei/frameskipbunnei2014-12-293-27/+38
|\ \ \ \ \ | |/ / / / |/| | | | Frameskip
| * | | | GPU: Implement frameskip and remove forced framebuffer swap hack.bunnei2014-12-293-27/+38
| | | | |
* | | | | Merge pull request #355 from lioncash/simpbunnei2014-12-291-225/+142
|\ \ \ \ \ | | | | | | | | | | | | armemu: Simplify some instructions.
| * | | | | armemu: Simplify SSAT/SSAT16/SXTB/SXTABLioncash2014-12-281-71/+48
| | | | | |
| * | | | | armemu: Simplify REV/REV16/SXTH/SXTAHLioncash2014-12-281-38/+26
| | | | | |
| * | | | | armemu: Simplify USAT16/UXTB/UXTABLioncash2014-12-281-65/+42
| | | | | |
| * | | | | armemu: Simplify REVSH/UXTH/UXTAHLioncash2014-12-281-48/+23
| | | | | |
* | | | | | Merge pull request #359 from lioncash/vfpbunnei2014-12-295-1664/+1053
|\ \ \ \ \ \ | | | | | | | | | | | | | | vfp: Actually make the code somewhat readable
| * | | | | | vfp: Actually make the code somewhat readableLioncash2014-12-295-1664/+1053
| | | | | | |
* | | | | | | Merge pull request #331 from yuriks/handle-reformbunnei2014-12-2914-208/+249
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | New Handle manager
| * | | | | | 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
| | | | | | |
* | | | | | | dyncom: Implement PKHBT and PKHTB.bunnei2014-12-281-2/+57
| | | | | | |
* | | | | | | armemu: Fix PKHTB to do an arithmetic shift and correctly decode immediate field.bunnei2014-12-281-13/+5
| | | | | | |
* | | | | | | dyncom: Implement USAD8/USADA8Lioncash2014-12-283-3/+53
| | | | | | |
* | | | | | | Merge pull request #354 from lioncash/usaduflowbunnei2014-12-283-4/+14
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | armemu: Fix underflows in USAD8/USADA8
| * | | | | | armemu: Fix underflows in USAD8/USADA8Lioncash2014-12-283-4/+14
| |/ / / / / | | | | | | | | | | | | | | | | | | Initially reported by xdec.
* | | | | | dyncom: Implement UQADD8, UQADD16, UQSUB8, UQSUB16, UQASX, and UQSAX.Lioncash2014-12-273-12/+102
| | | | | |
* | | | | | armemu: Implement UQADD8, UQADD16, UQSUB16, UQASX, and UQSAXLioncash2014-12-273-19/+93
|/ / / / /
* | | | | dyncom: Implement UHADD8, UHADD16, UHSUB8, UHSUB16, UHASX, and UHSAXLioncash2014-12-271-11/+123
| | | | |
* | | | | armemu: Implement UHADD8, UHADD16, UHSUB8, UHSUB16, UHASX, and UHSAXLioncash2014-12-271-2/+73
|/ / / /
* | | | Merge pull request #339 from bunnei/fixup-gsp-synchbunnei2014-12-267-117/+59
|\ \ \ \ | | | | | | | | | | Fixup gsp synch
| * | | | GPU: Further improve synchronization.bunnei2014-12-261-22/+20
| | | | |
| * | | | ARM: Add a mechanism for faking CPU time elapsed during HLE.bunnei2014-12-266-95/+39
| | | | | | | | | | | | | | | | | | | | - Also a few cleanups.
* | | | | Merge pull request #330 from purpasmart96/new_srvbunnei2014-12-2661-309/+367
|\ \ \ \ \ | | | | | | | | | | | | More services & small clean ups
| * | | | | More services & small clean upspurpasmart962014-12-2661-309/+367
| | | | | |
* | | | | | Merge pull request #343 from lioncash/smmlabunnei2014-12-261-2/+30
|\ \ \ \ \ \ | | | | | | | | | | | | | | armemu: Implement SMMUL, SMMLA, and SMMLS.
| * | | | | | armemu: Implement SMMUL, SMMLA, and SMMLS.Lioncash2014-12-251-2/+30
| | |_|/ / / | |/| | | |
* | | | | | Merge pull request #341 from lioncash/moresmopsbunnei2014-12-261-2/+33
|\ \ \ \ \ \ | | | | | | | | | | | | | | armemu: Implement SMLALD/SMLSLD
| * | | | | | armemu: Implement SMLALD/SMLSLDLioncash2014-12-241-2/+33
| |/ / / / /
* / / / / / armemu: Fix GE/Q flag setting semanticsLioncash2014-12-241-62/+56
|/ / / / /
* | | | | Merge pull request #328 from archshift/writeablebunnei2014-12-241-1/+18
|\ \ \ \ \ | |_|/ / / |/| | | | Stubbed IsSdmcWriteable to always return writeable.
| * | | | Stubbed IsSdmcWriteable to always return writeable.archshift2014-12-241-1/+18
| | | | |
* | | | | armemu: Set the Q flag correctly for much of the other opsLioncash2014-12-231-8/+8
| | | | | | | | | | | | | | | | | | | | They were setting the old S flag.
* | | | | armemu: Set the Q flag properly for SMLAD/SMUADLioncash2014-12-233-13/+28
| | | | |
* | | | | Merge pull request #334 from lioncash/cpsrbunnei2014-12-231-1/+1
|\ \ \ \ \ | | | | | | | | | | | | armemu: Fix retrieval of the CPSR in MRS instructions.
| * | | | | armemu: Fix retrieval of the CPSR in MRS instructions.Lioncash2014-12-231-1/+1
| | | | | |
* | | | | | Merge pull request #335 from lioncash/cpsrcreatebunnei2014-12-234-25/+78
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | armemu: Emulate the GE and Q flags.
| * | | | | armemu: Properly set the Q flag for SSAT16/USAT16 upon saturation.Lioncash2014-12-231-9/+23
| | | | | |
| * | | | | armemu: Fix SELLioncash2014-12-231-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | Needs to use the updated state of the CPSR.
| * | | | | armemu: Fix construction of the CPSRLioncash2014-12-234-15/+54
| |/ / / /
* / / / / dyncom: Move over QADD16/QASX/QSAX/QSUB16Lioncash2014-12-221-7/+87
|/ / / /
* | | | Merge pull request #322 from chinhodado/masterbunnei2014-12-224-11/+8
|\ \ \ \ | |/ / / |/| | | More warning cleanups
| * | | More warning cleanupsChin2014-12-214-11/+8
| | | |
* | | | Merge pull request #332 from lioncash/selbunnei2014-12-221-1/+58
|\ \ \ \ | | | | | | | | | | dyncom: Move SEL over
| * | | | dyncom: Move SEL overLioncash2014-12-221-1/+58
| | | | |
* | | | | Merge pull request #312 from Subv/still_more_savedata_stuffbunnei2014-12-2214-30/+508
|\ \ \ \ \ | |/ / / / |/| | | | CFG: Implemented the GetConfigInfoBlk2 function.
| * | | | 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-2111-489/+617
| | | | | | | | | | | | | | | | | | | | 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-212-6/+12
| | | | |
| * | | | 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-212-56/+127
| | | | | | | | | | | | | | | | | | | | It is now kept in memory as per 3dbrew, all updates happen on memory, then they can be saved using UpdateConfigNANDSavegame.
| * | | | CFG:U: Add some data to the 0x00050005 config block.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-215-15/+197
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Added a "config" file to the CFG process service (CFG:U), and added a few default blocks to it. Implemented GetSystemModel and GetModelNintendo2DS
* | | | | Merge pull request #324 from lioncash/dyncbunnei2014-12-221-7/+102
|\ \ \ \ \ | |/ / / / |/| | | | dyncom: Move over SASX/SSAX/SADD16/SSUB16
| * | | | dyncom: Move over SASX/SSAX/SADD16/SSUB16Lioncash2014-12-221-7/+102
| | | | |
* | | | | Merge pull request #291 from purpasmart96/licensebunnei2014-12-21130-137/+137
|\ \ \ \ \ | | | | | | | | | | | | License change
| * | | | | License changepurpasmart962014-12-21130-137/+137
| | | | | |
* | | | | | Merge pull request #271 from archshift/createfbunnei2014-12-218-1/+91
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | Added CreateFile to the FS_USER service
| * | | | | Added CreateFile to the FS_USER servicearchshift2014-12-218-1/+91
| | | | | | | | | | | | | | | | | | | | | | | | Tested with hwtests.
* | | | | | Merge pull request #323 from lioncash/saddsubbunnei2014-12-211-14/+87
|\ \ \ \ \ \ | | | | | | | | | | | | | | armemu: Implement SADD8/SSUB8
| * | | | | | armemu: Implement SADD8/SSUB8Lioncash2014-12-211-14/+87
| | | | | | |
* | | | | | | 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 #296 from lioncash/dynbunnei2014-12-201-1/+47
|\ \ \ \ \ \ | | | | | | | | | | | | | | dyncom: Implement UMAAL
| * | | | | | dyncom: Implement UMAALLioncash2014-12-191-1/+47
| | | | | | |
* | | | | | | Merge pull request #310 from lioncash/ssat16bunnei2014-12-201-14/+20
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | armemu: Fix SSAT16.
| * | | | | | | armemu: Fix SSAT16Lioncash2014-12-191-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The lower-bound would never be negative like it should
| * | | | | | | armemu: Clean up naming and formatting for SSAT16Lioncash2014-12-191-14/+20
| | |_|_|/ / / | |/| | | | |
* | | | | | | armemu: Should be using labs for USAD8/USADA8Lioncash2014-12-201-4/+4
| | | | | | |
* | | | | | | Merge pull request #311 from lioncash/usadabunnei2014-12-201-1/+24
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | armemu: Implement USAD8 and USADA8
| * | | | | | | armemu: Implement USAD8 and USADA8Lioncash2014-12-191-1/+24
| | | | | | | |
* | | | | | | | Merge pull request #313 from lioncash/smlsdbunnei2014-12-201-6/+10
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | armemu: Implement SMLSD
| * | | | | | | | armemu: Implement SMLSDLioncash2014-12-191-6/+10
| | |_|/ / / / / | |/| | | | | |
* | | | | | | | Merge pull request #314 from lioncash/qsax-qasxbunnei2014-12-201-7/+20
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | armemu: Implement QASX and QSAX
| * | | | | | | | armemu: Implement QASX and QSAXLioncash2014-12-191-7/+20
| |/ / / / / / /
* | | | | | | | Merge pull request #315 from chinhodado/masterbunnei2014-12-204-9/+16
|\ \ \ \ \ \ \ \ | |_|_|_|_|/ / / |/| | | | | | | Clean up some warnings
| * | | | | | | Clean up some warningsChin2014-12-204-9/+16
| | | | | | | |
* | | | | | | | Common: Add a clone of std::make_uniqueYuri Kunde Schlesner2014-12-203-10/+14
| | | | | | | |
* | | | | | | | 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 #294 from lioncash/varbunnei2014-12-191-12/+9
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | armemu: Narrow the scope of some variables in handle_v6_insn
| * | | | | | | | armemu: Narrow the scope of some variables in handle_v6_insnLioncash2014-12-171-12/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no reason to have these in the outer-most scope.
* | | | | | | | | Merge pull request #305 from lioncash/parenbunnei2014-12-191-4/+4
|\ \ \ \ \ \ \ \ \ | |_|_|/ / / / / / |/| | | | | | | | armemu: Get rid of bitwise parenthesis warnings
| * | | | | | | | armemu: Get rid of bitwise parenthesis warningsLioncash2014-12-181-4/+4
| | |_|/ / / / / | |/| | | | | |
* | | | | | | | 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 #304 from lioncash/sflagsbunnei2014-12-181-4/+29
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | armemu: Set GE flags properly for SSUB16, SADD16, SSAX, and SASX.
| * | | | | | | | | armemu: Set GE flags correctly for SSUB16, SADD16, SSAX, and SASX.Lioncash2014-12-181-4/+29
| | |_|/ / / / / / | |/| | | | | | |
* | | | | | | | | Merge pull request #307 from lioncash/usat16bunnei2014-12-181-11/+20
|\ \ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | armemu: Fix USAT16.
| * | | | | | | | | armemu: Fix lower-bounds clamping for USAT16Lioncash2014-12-181-1/+6
| | | | | | | | | |
| * | | | | | | | | armemu: More concise names for USAT16-related variablesLioncash2014-12-181-11/+15
| |/ / / / / / / /
* | | | | | | | | Merge pull request #301 from Subv/more_savedatabunnei2014-12-185-2/+78
|\ \ \ \ \ \ \ \ \ | |/ / / / / / / / |/| / / / / / / / | |/ / / / / / / SaveData: Implemented the SystemSaveData archive.
| * | | | | | | SystemSaveData: Added a TODO to move it to the NAND.Subv2014-12-181-1/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Maybe sometime when we actually implement that
| * | | | | | | SaveData: Implemented the SystemSaveData archive.Subv2014-12-185-2/+76
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | It will be stored in the /syssavedata folder. This archive is user by various Services and possibly games via the FS:U service.
* | | | | | | Merge pull request #299 from lioncash/joinbunnei2014-12-181-34/+23
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | Combine SSUB16, SADD16, SASX, and SSAX.
| * | | | | | armemu: Combine SSUB16, SADD16, SASX, and SSAX.Lioncash2014-12-181-34/+23
| | | | | | |
* | | | | | | Merge pull request #298 from lioncash/flagsbunnei2014-12-181-4/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | armemu: Unset GE flags for UADD8 if results are < 0x100
| * | | | | | | armemu: Unset GE flags for UADD8 if results are < 0x100Lioncash2014-12-171-4/+22
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reference manual states these must be set to zero if this case is true.
* | | | | | | | Merge pull request #295 from lioncash/umaalbunnei2014-12-181-3/+25
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | armemu: Implement UMAAL
| * | | | | | | armemu: Implement UMAALLioncash2014-12-171-3/+25
| | |_|/ / / / | |/| | | | |
* | | | | | | Merge pull request #292 from lioncash/backportsbunnei2014-12-181-19/+30
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Backport more skyeye fixes from 3dmoo
| * | | | | | | armemu: Fix PKHTBNormmatt2014-12-171-6/+12
| | | | | | | |
| * | | | | | | armemu: Implement REVSHNormmatt2014-12-171-5/+9
| | | | | | | |
| * | | | | | | armemu: Fix UXTAB/UXTAHNormmatt2014-12-171-4/+4
| | | | | | | |
| * | | | | | | armemu: Fix SXTABNormmatt2014-12-171-2/+2
| | | | | | | |
| * | | | | | | armemu: Fix SXTAHNormmatt2014-12-171-2/+3
| |/ / / / / /
* | | | | | | Merge pull request #297 from lioncash/ssub16bunnei2014-12-181-8/+8
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | armemu: Fix SSUB16
| * | | | | | | armemu: Fix SSUB16Lioncash2014-12-171-8/+8
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Broken from the same reason SADD16 was. The lo part of the result should only be constructed from the lo halfwords of rm and rn. The hi part of the result should only be constructed from the hi halfwords of rm and rn.
* | | | | | | Merge pull request #185 from purpasmart96/mem_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-1822-490/+454
| |/ / / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The savedata for each game is stored in /savedata/<ProgramID> for NCCH files. ELF files and 3DSX files use the folder 0 because they have no ID information Got rid of the code duplication in File and Directory Files that deal with the host machine's file system now live in DiskFile, similarly for directories and DiskDirectory and archives with DiskArchive. FS_U: Use the correct error code when a file wasn't found
* | | | | | Merge pull request #293 from lioncash/sopsbunnei2014-12-171-8/+9
|\ \ \ \ \ \ | | | | | | | | | | | | | | armemu: Fix SADD16
| * | | | | | armemu: Fix SADD16Lioncash2014-12-171-8/+9
| | |/ / / / | |/| | | | | | | | | | | | | | | | The lo and hi parts of the result were being constructed as a result of hi and lo halfword intermixing from the rm and rn regs. However the lo part of the result should be constructed only from the lo halfwords of rm and rn, and the hi part of the result should only be constructed from the hi halfwords of rm and rn.
* | | | | | Merge pull request #287 from lioncash/qaddsub16bunnei2014-12-171-33/+37
|\ \ \ \ \ \ | |/ / / / / |/| | | | | armemu: Join QADD16/QSUB16 and fix saturation clamping.
| * | | | | armemu: Fix lower-bound signed saturation clamping for QADD16/QSUB16.Lioncash2014-12-161-2/+2
| | | | | |
| * | | | | armemu: Join QADD16 and QSUB16 together.Lioncash2014-12-161-33/+37
| | | | | | | | | | | | | | | | | | | | | | | | The only difference between these ops is one adds and one subtracts. Everything is literally the same.
* | | | | | Merge pull request #289 from lioncash/smopsbunnei2014-12-171-38/+35
|\ \ \ \ \ \ | | | | | | | | | | | | | | Join SMUAD, SMUSD, and SMLAD ops. Also fix them as well.
| * | | | | | armemu: Fix SMUAD, SMUSD, and SMLADLioncash2014-12-161-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Wrong values were being multiplied together.
| * | | | | | armemu: Join SMUAD, SMUSD, and SMLADLioncash2014-12-161-38/+35
| |/ / / / /
* | | | | | Merge pull request #290 from lioncash/vsubbunnei2014-12-171-2/+5
|\ \ \ \ \ \ | |_|_|/ / / |/| | | | | armemu: Backport some VFP fixes from 3dmoo.
| * | | | | armemu: Fix FTOUI NaN sign.Normmatt2014-12-161-1/+1
| | | | | |
| * | | | | armemu: Fix FSUBS bug where NaN shouldn't be negatedNormmatt2014-12-161-1/+4
| |/ / / /
* | | | | Merge pull request #286 from yuriks/msvc-fixbunnei2014-12-162-6/+8
|\ \ \ \ \ | | | | | | | | | | | | Comment out empty arrays causing compile errors in MSVC
| * | | | | Comment out empty arrays causing compile errors in MSVCYuri Kunde Schlesner2014-12-162-6/+8
| | | | | |
* | | | | | Merge pull request #285 from lioncash/uxtab16bunnei2014-12-161-10/+25
|\ \ \ \ \ \ | |/ / / / / |/| | | | | armemu: Implement UXTAB16
| * | | | | armemu: Implement UXTAB16Lioncash2014-12-161-10/+25
| |/ / / /
* | | | | Merge pull request #283 from yuriks/archive-refactorbunnei2014-12-1623-506/+320
|\ \ \ \ \ | | | | | | | | | | | | 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-1611-387/+197
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Refactor FS::Archive internals to make Archive creation and lifetime management clearer. - Remove the "Archive as a File" hack. - Implement 64-bit Archive handles.
| * | | | | Service.FS: Rename FileSys::File to FileBackendYuri Kunde Schlesner2014-12-1610-17/+17
| | | | | |
| * | | | | Service.FS: Rename FileSys::Directory to DirectoryBackendYuri Kunde Schlesner2014-12-1610-18/+18
| | | | | |
| * | | | | Service.FS: Rename FileSys::Archive to ArchiveBackendYuri Kunde Schlesner2014-12-166-12/+12
| | | | | |
| * | | | | Service.FS: Do archive registration using IdCode instead of nameYuri Kunde Schlesner2014-12-167-42/+32
| | | | | |
| * | | | | HLE: Rename namespaces to match move & fix initialization orderYuri Kunde Schlesner2014-12-169-43/+43
| | | | | |
| * | | | | HLE: Move kernel/archive.* to service/fs/Yuri Kunde Schlesner2014-12-169-12/+11
| | | | | |
* | | | | | Merge pull request #282 from archshift/servicesbunnei2014-12-1610-0/+229
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | Added stubs for ldr:ro, cecd:u, nim:aoc, and am:app services
| * | | | | Added stub for nim:aoc service...archshift2014-12-164-0/+62
| | | | | |
| * | | | | Added stub for cecd:u service...archshift2014-12-164-0/+54
| | | | | | | | | | | | | | | | | | | | | | | | I couldn't find any information about this service...
| * | | | | Added stub for ldr:ro service...archshift2014-12-164-0/+59
| | | | | |
| * | | | | Added am:app service stub.archshift2014-12-164-0/+54
| | | | | | | | | | | | | | | | | | | | | | | | Apparently nothing at all is known about this service...
* | | | | | Merge pull request #281 from lioncash/uxtb16bunnei2014-12-161-12/+12
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | armemu: Fix UXTB16
| * | | | | armemu: Fix UXTB16Lioncash2014-12-151-12/+12
| |/ / / / | | | | | | | | | | | | | | | Rotation bits are 10 and 11, not 9 and 10.
* / / / / Remove SyncRequest from K::Object and create a new K::Session typeYuri Kunde Schlesner2014-12-1515-104/+129
|/ / / / | | | | | | | | | | | | | | | | | | | | | | | | This is a first step at fixing the conceptual insanity that is our handling of service and IPC calls. For now, interfaces still directly derived from Session because we don't have the infrastructure to do it properly. (That is, Processes and scheduling them.)
* | | | Merge pull request #276 from lioncash/decrappifybunnei2014-12-151-306/+169
|\ \ \ \ | | | | | | | | | | Clean up armdefs.h a little.
| * | | | Clean up armdefs.hLioncash2014-12-141-306/+169
| | |/ / | |/| |
* | | | Merge pull request #246 from Subv/cbranch_1bunnei2014-12-155-2/+160
|\ \ \ \ | | | | | | | | | | SVC: Implemented Semaphores
| * | | | 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-135-1/+117
| |/ / / | | | | | | | | | | | | | | | | ToDo: Implement svcReleaseSemaphore * Some testing against hardware needed
* | | | Merge pull request #273 from bunnei/more-skyeye-fixesbunnei2014-12-153-419/+485
|\ \ \ \ | |/ / / |/| | | ARM: Pull some SkyEye fixes from 3dmoo.
| * | | ARM: Pull some SkyEye fixes from 3dmoo.bunnei2014-12-153-419/+485
| | | |
* | | | kernel: Remove unused log argumentsLioncash2014-12-131-3/+3
|/ / /
* | | Add configurable per-class log filteringYuri Kunde Schlesner2014-12-131-1/+3
| | |
* | | Convert old logging calls to new logging macrosYuri Kunde Schlesner2014-12-1340-385/+336
| | |
* | | New logging systemYuri Kunde Schlesner2014-12-131-0/+1
| | |
* | | Merge pull request #267 from bunnei/apt-shared-fontbunnei2014-12-135-66/+132
|\ \ \ | | | | | | | | 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-124-32/+32
| | | | | | | | | | | | | | | | - Linear simply indicates that the mapped physical address is always MappedVAddr+0x0C000000, thus this memory can be used for hardware devices' DMA (such as the GPU).
* | | | DSP: Added stub for ReadPipeIfPossible.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-103-4/+3
| | | |
* | | | Remove unused NDMA moduleYuri Kunde Schlesner2014-12-094-88/+0
| | | |
* | | | 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
| | | | |
* | | | | Merge pull request #244 from bunnei/cleanup-memmapbunnei2014-12-092-31/+21
|\ \ \ \ \ | | | | | | | | | | | | MemMap: Updated memory map to subtract base address instead of mask.
| * | | | | MemMap: Updated memory map to subtract base address instead of mask.bunnei2014-12-032-31/+21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - More readable, a little less error prone. Conflicts: src/core/mem_map.h src/core/mem_map_funcs.cpp
* | | | | | Merge pull request #263 from lioncash/sasxbunnei2014-12-091-4/+4
|\ \ \ \ \ \ | | | | | | | | | | | | | | Fix emulation of SASX and SSAX instructions.
| * | | | | | armemu: Fix SSAXLioncash2014-12-081-1/+1
| | | | | | |
| * | | | | | armemu: Fix SASXLioncash2014-12-081-1/+1
| | | | | | |
| * | | | | | armemu: Fix parenthesis warnings regarding bitwise opsLioncash2014-12-081-4/+4
| | | | | | |
* | | | | | | Merge pull request #259 from ichfly/masterbunnei2014-12-095-0/+278
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Loader: Add 3DSX support
| * | | | | | | Loader: Add 3DSX supportichfly2014-12-085-0/+278
| |/ / / / / /
* | | | | | | Merge pull request #264 from Subv/filesbunnei2014-12-091-3/+6
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Kernel/File: Fixed file read/write hwtests
| * | | | | | | Kernel/File: Fixed file read/write hwtestsSubv2014-12-081-3/+6
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The 3DS allows the user to read from files opened with the Write access modifier, even if he did not specify the Read access modifier. Open the files in binary mode so that we can prevent CR/LF problems in Windows, where a line-end is replaced by these two bytes instead of just 0xA, this was causing problems with the GetSize test
* | | | | | | Merge pull request #260 from archshift/opendirbunnei2014-12-097-3/+40
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | Make OpenDirectory fail if the directory doesn't exist
| * | | | | | Make OpenDirectory fail if the directory doesn't existarchshift2014-12-077-3/+40
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is in line with what the hardware itself does. It does this by splitting the initial directory opening into Directory.Open(), which will return false if a stat fails. Then, Archive::OpenDirectory will return nullptr, and archive.cpp will return an error code .
* | | | | | Merge pull request #245 from rohit-n/null-nullptrbunnei2014-12-071-6/+6
|\ \ \ \ \ \ | |/ / / / / |/| | | | | Change NULLs to nullptrs.
| * | | | | Change NULLs to nullptrs.Rohit Nirmal2014-12-031-6/+6
| | | | | |
* | | | | | 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-058-38/+229
|\ \ \ \ \ \ | | | | | | | | | | | | | | Implemented RenameFile and RenameDirectory in FS:USER
| * | | | | | Updated archive.cpp functions for proper error handlingarchshift2014-12-045-94/+41
| | | | | | |
| * | | | | | Implemented RenameDirectory in FS:USERarchshift2014-11-258-1/+123
| | | | | | |
| * | | | | | Implemented RenameFile in FS:USERarchshift2014-11-258-1/+123
| | |_|/ / / | |/| | | |
* | | | | | 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 #249 from lioncash/enumbunnei2014-12-041-1/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | mem_map: Make enum for addresses use u32 as the underlying type
| * | | | | | mem_map: Make enum for addresses use u32 as the underlying typeLioncash2014-12-041-1/+1
| |/ / / / /
* | | | | | 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-042-26/+47
|\ \ \ \ \ \ | | | | | | | | | | | | | | Add stub for ConvertProcessFromDspDram
| * | | | | | Add stub for ConvertProcessFromDspDramarchshift2014-12-042-26/+47
| | |/ / / / | |/| | | | | | | | | | | | | | | | 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
| |/ / / / /
* | | | | | Merge pull request #235 from yuriks/dyncom-mapbunnei2014-11-301-33/+15
|\ \ \ \ \ \ | | | | | | | | | | | | | | dyncom: Use unordered_map rather than the terrible 2-level bb_map
| * | | | | | dyncom: Use unordered_map rather than the terrible 2-level bb_mapYuri Kunde Schlesner2014-11-291-33/+15
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | Seems (probably just placebo/wishful thinking) to make it slightly faster. Also reduces memory usage and makes shutdown when debugging from MSVC fast.
* / | | | | arm_dyncom_interpreter: Get rid of unused var warningsLioncash2014-11-291-4/+2
|/ / / / /
* | | / / Fixed formatting and switch statement warningsvaguilar2014-11-277-11/+13
| |_|/ / |/| | |
* | | | Remove unused includes to common/thread.hEmmanuel Gil Peyrot2014-11-251-2/+0
|/ / /
* | | 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-2423-310/+689
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All service calls in the CTR OS return result codes indicating the success or failure of the call. Previous to this commit, Citra's HLE emulation of services and the kernel universally either ignored errors or returned dummy -1 error codes. This commit makes an initial effort to provide an infrastructure for error reporting and propagation which can be use going forward to make HLE calls accurately return errors as the original system. A few parts of the code have been updated to use the new system where applicable. One part of this effort is the definition of the `ResultCode` type, which provides facilities for constructing and parsing error codes in the structured format used by the CTR. The `ResultVal` type builds on `ResultCode` by providing a container for values returned by function that can report errors. It enforces that correct error checking will be done on function returns by preventing the use of the return value if the function returned an error code. Currently this change is mostly internal since errors are still suppressed on the ARM<->HLE border, as a temporary compatibility hack. As functionality is implemented and tested this hack can be eventually removed.
* | | Change some SkyEye defines to const intsYuri Kunde Schlesner2014-11-242-34/+16
| | | | | | | | | | | | | | | This prevents them from interfering with other constants defined in different namespaces.
* | | Merge pull request #191 from archshift/deletexyzbunnei2014-11-248-26/+194
|\ \ \ | |/ / |/| | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives.
| * | Added DeleteFile and DeleteDirectory functions to FS:USER and the archives.archshift2014-11-238-26/+194
| | |
* | | Add more services and some fixes, along with more "override"purpasmart962014-11-2126-17/+464
| | | | | | | | | | | | in the service's headers
* | | Merge pull request #211 from linkmauve/masterbunnei2014-11-1945-142/+142
|\ \ \ | | | | | | | | Remove trailing spaces from the entire project
| * | | Remove tabs in all files except in skyeye imports and in generated GL codeEmmanuel Gil Peyrot2014-11-192-32/+32
| | | |
| * | | Remove trailing spaces in every file but the ones imported from SkyEye, AOSP or generatedEmmanuel Gil Peyrot2014-11-1944-111/+111
| | | |
* | | | Merge pull request #208 from lioncash/staticsbunnei2014-11-195-69/+69
|\ \ \ \ | |/ / / |/| | | Add static to some variables
| * | | Add static to some variablesLioncash2014-11-195-69/+69
| | | |
* | | | Merge pull request #207 from lioncash/docsTony Wasserka2014-11-183-3/+3
|\ \ \ \ | | | | | | | | | | Fix documentation of parameters
| * | | | Fix documentation of parametersLioncash2014-11-183-3/+3
| |/ / /
* | | | Merge pull request #209 from lioncash/warnTony Wasserka2014-11-181-1/+1
|\ \ \ \ | | | | | | | | | | directory_sdmc: Fix a signed/unsigned mismatch comparison
| * | | | directory_sdmc: Fix a signed/unsigned mismatch comparisonLioncash2014-11-181-1/+1
| |/ / /
* | | | Merge pull request #210 from lioncash/typedefTony Wasserka2014-11-181-10/+10
|\ \ \ \ | | | | | | | | | | system: Get rid of an unnecessary enum typedef
| * | | | system: Get rid of an unnecessary enum typedefLioncash2014-11-181-10/+10
| |/ / /
* / / / Remove extraneous semicolonsLioncash2014-11-186-6/+6
|/ / /
* / / core: Mark some hle functions as staticLioncash2014-11-186-48/+48
|/ / | | | | | | These functions are not referred to by their linkage name outside of the translation unit, so they can be marked as static.
* | Archive: Fixed to not destroy archive handle on close.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-1812-38/+38
| |
* | FileSys: Added DebugStr method to Path class.bunnei2014-11-181-0/+29
| |
* | Merge pull request #201 from archshift/bossbunnei2014-11-174-0/+59
|\ \ | | | | | | Add missing boss:U service
| * | Add missing boss:U service, needed according to Nintendo Zone logs.archshift2014-11-174-0/+59
| | |
* | | mem_map: Add missing prototype for Write64Lioncash2014-11-171-0/+1
|/ /
* | Merge pull request #159 from SeannyM/enable_logTony Wasserka2014-11-151-0/+2
|\ \ | | | | | | Add support for disabling log from settings
| * | Add support for disabling log from settingsSean2014-11-031-0/+2
| | |
* | | Merge pull request #193 from lioncash/fmtbunnei2014-11-151-1/+1
|\ \ \ | | | | | | | | Fix two format strings.
| * | | Fix two format strings.Lioncash2014-11-141-1/+1
| | | |
* | | | Merge pull request #194 from lioncash/virtbunnei2014-11-151-1/+1
|\ \ \ \ | |/ / / |/| | | ARM_Interface: Make destructor virtual
| * | | ARM_Interface: Make destructor virtualLioncash2014-11-141-1/+1
| | | | | | | | | | | | | | | | Fixes some warnings on OSX.
* | | | Merge pull request #183 from archshift/lowpathbunnei2014-11-132-83/+180
|\ \ \ \ | | | | | | | | | | Add support for UTF-16 strings for LowPaths in FS:USER
| * | | | Use std::u16string for conversion between UTF-8 and UTF-16, FS:USER functionsarchshift2014-11-133-138/+139
| | | | |
| * | | | 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.
* | | | ARM: Fixed dyncom to use reg15 for PC (this core doesn't use pc variable).bunnei2014-11-121-2/+2
| | | | | | | | | | | | | | | | - Fixes single stepping in debugger.
* | | | Core: Changed RunLoop iterations to 1000 (slightly better performance).bunnei2014-11-121-6/+6
| | | |
* | | | ARM: Removed unnecessary goto with each instruction.bunnei2014-11-121-43/+39
| | | |
* | | | ARM: Fixed several dyncom bugs.bunnei2014-11-123-17/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | - Fixed NZCVT flags to properly save state when function returns. - Fixed counter to keep track of the actual number of instructions executed. - Fixed single-step mode to only execute one instruction at a time. - DefaultIni: Removed comment that no longer applied to dyncom.
* | | | Add FRD:U service and functionsarchshift2014-11-114-0/+66
|/ / /
* | | Fix compilation errorsSean Maas2014-11-031-2/+2
| | |
* | | Merge pull request #163 from archshift/create-directorybunnei2014-11-028-4/+103
|\ \ \ | | | | | | | | Added CreateDirectory function to service/fs.cpp, and in Archive.
| * | | Added CreateDirectory function to service/fs.cpp, and in Archive.archshift2014-11-028-4/+103
| | | |
* | | | Merge pull request #166 from bunnei/skyeye-vfp-fixesbunnei2014-11-025-2138/+2622
|\ \ \ \ | | | | | | | | | | SkyEye ARM/VFP fixes
| * | | | ARM: Merged additional ARMv6 instructions implemented by 3dmoo.bunnei2014-11-021-42/+234
| | | | |
| * | | | ARM: Merge latest VFP fixes from 3dmoo team.bunnei2014-11-024-2096/+2388
| |/ / /
* / / / Added ReceiveNotification, PublishToSubscriber unimplemented functions to SRVarchshift2014-11-021-0/+2
|/ / /
* | | Added stub err:f service.archshift2014-11-024-0/+58
| | |
* | | Merge pull request #135 from purpasmart96/masterbunnei2014-11-0218-0/+597
|\ \ \ | | | | | | | | Added a bunch of services
| * | | Added a bunch of servicespurpasmart962014-11-0118-0/+597
| | | |
* | | | Fix VFP compilation errors with gccYuri Kunde Schlesner2014-10-311-12/+12
|/ / /
* | | Merge pull request #162 from SeannyM/warning-fixesbunnei2014-10-307-14/+14
|\ \ \ | | | | | | | | Fix some warnings
| * | | Fix some warningsSean2014-10-307-14/+14
| | | |
* | | | FS:USER - Implemented IsSdmcDetectedarchshift2014-10-301-1/+17
| | | |
* | | | Renamed souce files of services to match port namesGareth Poole2014-10-2913-21/+21
|/ / /
* | | Merge pull request #151 from archshift/dyncom-enabledbunnei2014-10-285-6/+32
|\ \ \ | | | | | | | | Use configuration files to enable or disable the new dyncom interpreter.
| * | | Added `gpu_refresh_rate` config setting for the new interpreter speed hack.archshift2014-10-282-10/+2
| | | |
| * | | Use configuration files to enable or disable the new dyncom interpreter.archshift2014-10-285-6/+40
| | | |
* | | | 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
* | | | | Merge pull request #153 from yuriks/add-overridebunnei2014-10-2815-64/+64
|\ \ \ \ \ | |_|_|_|/ |/| | | | Add override keyword where appropriate
| * | | | Add `override` keyword through the code.Yuri Kunde Schlesner2014-10-2615-64/+64
| | |/ / | |/| | | | | | | | | | This was automated using `clang-modernize`.
* / | | vfp_helper: Get rid of integer type redefinitionsLioncash2014-10-261-7/+1
|/ / /
* | | ARM: Removed unnecessary and unused SkyEye MMU code.bunnei2014-10-2522-7743/+326
| | | | | | | | | | | | Added license header back in. I originally removed this because I mostly rewrote the file, but meh
* | | ARM: Removed unused armos code from SkyEye.bunnei2014-10-254-747/+0
| | |
* | | ARM: Updated dyncom core to use fast label lookup table on clang.bunnei2014-10-251-3/+7
| | |
* | | ARM: Integrate SkyEye faster "dyncom" interpreter.bunnei2014-10-2520-75/+8230
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Fixed typo (make protected member public) Added license header back in. I originally removed this because I mostly rewrote the file, but meh ARM: Fixed a type error in dyncom interpreter. ARM: Updated dyncom to use unique_ptr for internal ARM state.
* | | ARM: Reorganized file structure to move shared SkyEye code to a more common area.bunnei2014-10-2533-79/+79
| | | | | | | | | | | | Removed s_ prefix
* | | Don’t fail on empty filename in OpenFileDirectly, return the archive handle insteadEmmanuel Gil Peyrot2014-10-251-8/+7
| | |
* | | Use config files to store whether SDMC is enabled or notarchshift2014-10-232-2/+10
|/ / | | | | | | Before, it used to use whether the directory actually existed. As a result, .citra-emu/sdmc was never auto-created (something quite confusing to me until I read through the logs).
* | Rename GPU::Regs::FramebufferFormat to PixelFormatYuri Kunde Schlesner2014-10-122-14/+10
| | | | | | | | | | | | This name better represents what the enum does, and is less overloaded in the context. (The whole register the enum is part of is also called 'format'.)
* | Merge pull request #119 from lioncash/warnbunnei2014-10-092-3/+3
|\ \ | | | | | | Fix warnings in video_core
| * | Fix warnings in video_coreLioncash2014-10-082-3/+3
| | |
* | | 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
| | | |
* | | | Merge pull request #108 from archshift/configbunnei2014-10-083-0/+42
|\ \ \ \ | | | | | | | | | | Configuration files
| * | | | Added configuration file system.archshift2014-10-083-0/+42
| | |/ / | |/| | | | | | | | | | Uses QSettings on citra-qt, and inih on citra-cli.
* | | | Common: Add a helper function to generate a 8.3 filename from a long one.Emmanuel Gil Peyrot2014-10-063-29/+27
| | | | | | | | | | | | | | | | Core: Fix the SDMC Directory implementation to make blargSnes work.
* | | | FileSys: Add static asserts for the Directory struct, and fix its fields position.Emmanuel Gil Peyrot2014-10-061-2/+8
| | | |
* | | | FileSys: split the constructor into an Open method, in order to notify the opener something went wrong.Emmanuel Gil Peyrot2014-10-067-14/+57
| | | | | | | | | | | | | | | | Kernel: Return an invalid handle to OpenFile when it failed to open.
* | | | FileSys/Kernel: Implement SetSize service call for File objects.Emmanuel Gil Peyrot2014-10-066-0/+49
| | | |
* | | | FileSys: Add forgotten docstrings.Emmanuel Gil Peyrot2014-10-067-4/+35
| |/ / |/| |
* | | 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
* | | Fix warnings in core and commonLioncash2014-09-282-2/+2
|/ /
* | 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
| |
* | Core: Add a method to obtain a Directory from an Archive.Emmanuel Gil Peyrot2014-09-175-0/+44
| |
* | Core: Add a Directory object, with both a stub and a passthrough implementations.Emmanuel Gil Peyrot2014-09-176-0/+264
| |
* | Kernel: Add a File object and a getter for it from an Archive object.Emmanuel Gil Peyrot2014-09-172-0/+118
| |
* | Core: Add a passthrough backend for the filesystem, exposed as SDMC.Emmanuel Gil Peyrot2014-09-175-0/+302
| |
* | Core: Add a new File class, obtainable from an Archive, and a stub implementation.Emmanuel Gil Peyrot2014-09-177-0/+208
| |
* | Common: Rename the File namespace to FileUtil, to match the filename and prevent collisions.Emmanuel Gil Peyrot2014-09-173-5/+5
| |
* | Merge pull request #107 from lioncash/sprintfbunnei2014-09-161-5/+7
|\ \ | | | | | | Core: Replace a sprintf in core_timing with StringFromFormat
| * | Core: Replace a sprintf in core_timing with StringFromFormatLioncash2014-09-131-5/+7
| | |
* | | Merge pull request #109 from lioncash/cruftbunnei2014-09-151-41/+2
|\ \ \ | | | | | | | | Core: Get rid of unnecessary switch statement in Kernel
| * | | Core: Get rid of unnecessary switch statement in KernelLioncash2014-09-151-41/+2
| |/ /
* | | Merge pull request #110 from lioncash/warningsbunnei2014-09-151-6/+6
|\ \ \ | | | | | | | | Core: Fix warnings in gpu.cpp
| * | | Core: Fix warnings in gpu.cppLioncash2014-09-141-6/+6
| |/ /
* | | Merge pull request #97 from archshift/cleanupbunnei2014-09-141-1/+1
|\ \ \ | |/ / |/| | Small, general code cleanup
| * | Dead code removal: video_core.cpp, load_symbol_map.cpparchshift2014-09-071-1/+1
| | |
* | | 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-113-55/+56
|\ \ \ | | | | | | | | loader.cpp: improved file extension checking, made Upper/LowerStr useful, moved string_util into Common namespace
| * | | Added string_util to common, small changes in loader.cpparchshift2014-09-093-56/+55
| | | |
| * | | loader.cpp: improved file extension checking, made Upper/LowerStr usefularchshift2014-09-091-6/+8
| | |/ | |/| | | | | | | Instead of forcibly taking the last 4 characters, it now finds the last extension separator (the period) and takes a substr of its location.
* / | core: Prune redundant includesarchshift2014-09-0920-37/+0
|/ /
* | Merge pull request #95 from lioncash/disassemblerbunnei2014-09-083-189/+143
|\ \ | | | | | | core: Make the ARM disassembler use std::string internally
| * | core: Make the ARM disassembler use std::string internallyLioncash2014-09-063-189/+143
| | |
* | | Merge pull request #87 from archshift/remove-cruftbunnei2014-09-081-1/+1
|\ \ \ | |_|/ |/| | Removed redundant headers for std implementations
| * | Removed common/std_xyz, instead using the std headerarchshift2014-09-071-1/+1
| |/
* | Merge pull request #93 from lioncash/refbunnei2014-09-062-4/+4
|\ \ | | | | | | core: Pass string by reference in FetchFromPortName and DeleteService
| * | core: Pass string by reference in FetchFromPortName and DeleteServiceLioncash2014-09-062-4/+4
| |/
* | ncch: Remove C-style struct typedefsLioncash2014-09-061-4/+4
| | | | | | | | In C++ you can simply just declare it as is.
* | ncch: inline declare some variables in LZSS_DecompressLioncash2014-09-061-7/+5
|/
* Removed common/atomic, instead using std::atomicarchshift2014-09-031-4/+4
|
* Remove hand-crafted Visual Studio solution.Yuri Kunde Schlesner2014-09-012-592/+0
|
* CMake cleanupYuri Kunde Schlesner2014-09-011-47/+56
| | | | | | | | Several cleanups to the buildsystem: - Do better factoring of common libs between platforms. - Add support to building on Windows. - Remove Qt4 support. - Re-sort file lists and add missing headers.
* Merge pull request #84 from bunnei/fix-hw-synchronizationbunnei2014-08-313-33/+48
|\ | | | | Fix GPU/HW synchronization
| * GPU: Improve frame synchronization, increases compatibility with both homebrew and retail applications.bunnei2014-08-311-13/+31
| |
| * Core: Refactor core to use only one function for execution.bunnei2014-08-312-20/+17
| | | | | | | | | | | | Core: Cleaned up comment to be more readable. Citra: Changed loop to be more readable.
| * Loader: Added support for loading raw BIN executables.bunnei2014-08-312-0/+21
| | | | | | | | | | | | - Useful for debugging homebrew Qt: Updated GUI to support loading .bin files.
| * Threading: Fix thread starting to execute first instruction correctly.bunnei2014-08-312-1/+6
| |
| * srv::Initialize: Return "success" status code.bunnei2014-08-311-0/+4
| |
* | Merge pull request #82 from yuriks/addr-typesbunnei2014-08-312-31/+40
|\ \ | | | | | | Introduce VAddr and PAddr typedefs for ARM addresses.
| * | Introduce VAddr and PAddr typedefs for ARM addresses.Yuri Kunde Schlesner2014-08-312-31/+40
| |/
* | Loader: Added support for loading raw BIN executables.bunnei2014-08-282-0/+21
| | | | | | | | | | | | - Useful for debugging homebrew Qt: Updated GUI to support loading .bin files.
* | Threading: Fix thread starting to execute first instruction correctly.bunnei2014-08-282-1/+6
| |
* | srv::Initialize: Return "success" status code.bunnei2014-08-281-0/+4
|/
* VideoCore: Fixes rendering issues on Qt and corrects framebuffer output size.bunnei2014-08-261-9/+8
|
* GPU: Fix a compiler warning about redundant semicolons.Tony Wasserka2014-08-251-2/+2
|
* 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
|
* Merge pull request #68 from archshift/readfilebunnei2014-08-234-11/+88
|\ | | | | Added FS functions to Archive and Archive_RomFS
| * Added FS functions to Archive and Archive_RomFSarchshift2014-08-234-11/+88
| |
* | ARM: Remove a forgotten const in vfp.Emmanuel Gil Peyrot2014-08-202-2/+2
|/
* 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.
* Merge pull request #53 from lioncash/memmapbunnei2014-08-181-4/+8
|\ | | | | Core: Fix undefined behavior in mem_map_funcs' WriteBlock function
| * Core: Fix undefined behavior in mem_map_funcs' WriteBlock functionLioncash2014-08-171-4/+8
| |
* | 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: Add command processor.Tony Wasserka2014-08-121-3/+5
| |
* | Pica/GPU: Change hardware registers to use physical addresses rather than virtual ones.Tony Wasserka2014-08-126-208/+72
| | | | | | | | | | This cleans up the mess that address reading/writing had become and makes the code a *lot* more sensible. This adds a physical<->virtual address converter to mem_map.h. For further accuracy, we will want to properly extend this to support a wider range of address regions. For now, this makes simply homebrew applications work in a good manner though.
* | GSP: Fix a major regression introduced in ffda035c, due to which no display transfers were triggered at all anymore.Tony Wasserka2014-08-121-4/+13
| |
* | Remove the fancy RegisterSet class introduced in 4c2bff61e.Tony Wasserka2014-08-123-150/+230
|/ | | | | While it was some nice and fancy template usage, it ultimately had many practical issues regarding length of involved expressions under regular usage as well as common code completion tools not being able to handle the structures. Instead, we now use a more conventional approach which is a lot more clean to use.
* GPU: Updated g_last_ticks variable to be more descriptive (represents CPU tick count of last vertical line).bunnei2014-08-071-5/+5
|
* GPU: Updated horizontal sync line counter to use framebuffer height.bunnei2014-08-071-2/+3
|
* 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-063-79/+80
| | | | - Various other cleanups.
* GSP: Removed unnecessary GX_FinishCommand function.bunnei2014-08-061-13/+5
|
* GSP: Implements preliminary command synchronization via GPU interrupts.bunnei2014-08-064-29/+140
| | | | Core: Added a comment to explain the logic for the RunLoop iterations.
* MemMap: Fixed typo with GetPointer to VRAM address.bunnei2014-08-061-1/+1
|
* 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
|
* Merge pull request #36 from bunnei/fix-memory-unaligned-readsbunnei2014-08-062-16/+28
|\ | | | | Fix memory unaligned reads
| * MemMap: Added an error for unaligned 16-bit memory reads.bunnei2014-08-061-0/+7
| |
| * MemMap: Removed Read64 function.bunnei2014-08-061-6/+0
| | | | | | | | | | - Unused code - Was not correct for unaligned memory reads
| * FS: Fix port name (old port name was based on an unaligned memory read).bunnei2014-08-061-1/+1
| |
| * MemMap: Fix Read32 for unaligned memory reads.bunnei2014-08-061-12/+23
| | | | | | | | MemMap: Cleaned up Read32 unaligned memory access.
* | ARM: Synchronize Citra's SkyEye core with 3dmoo's.bunnei2014-07-246-5919/+5303
|/
* Use uniform formatting when printing hexadecimal numbers.Tony Wasserka2014-07-231-3/+3
|
* Fix a few warnings.Tony Wasserka2014-07-233-7/+7
| | | | Templates shouldn't be marked as inline if they aren't defined in the header.
* GPU: Clarify display transfer code.Tony Wasserka2014-07-231-12/+15
| | | | Also makes the illogical component order more obvious.
* GPU: Add documentation.Tony Wasserka2014-07-231-2/+14
|
* 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.
* RegisterSet: Simplify code by using structs for register definition instead of unions.Tony Wasserka2014-07-232-133/+123
|
* GPU: Make use of RegisterSet.Tony Wasserka2014-07-233-327/+200
|
* GPU: Make framebuffer code format-aware.Tony Wasserka2014-07-231-6/+47
|
* GPU: Interface cleanup.Tony Wasserka2014-07-232-13/+20
|
* GPU: Initialize GPU registers to some sensible default state.Tony Wasserka2014-07-231-1/+16
|
* GPU: Emulate memory fills.Tony Wasserka2014-07-234-3/+89
|
* GPU: Add proper framebuffer register handling.Tony Wasserka2014-07-232-11/+105
|
* GPU: Properly implement display transfers.Tony Wasserka2014-07-231-1/+19
|
* GPU: Add display transfer configuration.Tony Wasserka2014-07-232-0/+92
|
* GSP: HLE GXCommandId::SET_DISPLAY_TRANSFER and GXCommandId::SET_TEXTURE_COPY.Tony Wasserka2014-07-232-2/+17
|
* GSP: Implement ReadHWRegs and WriteHWRegs properly.Tony Wasserka2014-07-231-27/+46
|
* Use a more compatible choice of initial framebuffer addresses.Tony Wasserka2014-07-221-10/+22
|
* core: Kill off type redefenitions in armdefs.hLioncash2014-07-201-7/+0
|
* Kernel: Added preliminary support for address arbiters.bunnei2014-07-097-9/+144
| | | | | | | | AddressArbiter: Added documentation comment, fixed whitespace issue. AddressArbiter: Fixed incorrect comment, reordered if-statement to be more clear. SVC: Removed trailing whitespace.
* Thread: Added functions to resume threads from address arbitration.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.
* Memory: Removed deprecated MapBlock_Shared function.bunnei2014-07-052-30/+0
|
* 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-055-0/+142
| | | | SharedMemory: Added optional name field for tracking known objects.
* mem_map: Updated interface to expose template functions to other modules.bunnei2014-07-052-10/+16
|
* NCCH: Updated ExeFS memory allocation to be safer.bunnei2014-07-052-1/+7
|
* Archive: Added Init/Shutdown methods to reset kernel archive state.bunnei2014-07-053-0/+19
|
* Marked AppLoader_ELF, AppLoader_NCCH, and Archive_RomFS virtual functions as "override".bunnei2014-07-053-13/+13
|
* Marked AppLoader_ELF, AppLoader_NCCH, and Archive_RomFS classes as "final"bunnei2014-07-053-3/+3
|
* Loader: Updated read methods to be constbunnei2014-07-055-68/+79
| | | | - Required "file" handle to be made local and explicitly opened/closed as needed
* FileSys: Added preliminary support for applications reading the RomFS archive.bunnei2014-07-0511-160/+311
| | | | | | | | | | Archive: Fixed brace ugliness for neobrain :) FS: Commented out unused local variables to prevent warnings. ...But keeping them here for future use. archive_romfs: Removed unused #include.
* APT: Added stubbed ReceiveParameter and various cleanups.bunnei2014-07-041-71/+93
| | | | | | APT: More cleanups. APT: Changed SignalType to be type u32.
* Loader: Refactored interface such that data is no longer stored by loader.bunnei2014-06-273-96/+73
| | | | NCCH: Removed extra qualification ‘Loader::AppLoader_NCCH::’.
* FS: Added stubbed code to intercept and decode file system service functions.bunnei2014-06-276-0/+164
| | | | FS: Added to CMakeLists.txt
* Kernel: Added stubbed code to support creation of kernel Archive objects.bunnei2014-06-276-0/+95
|
* Core: Removed unused directory_file_system and meta_file_system modules.bunnei2014-06-279-1477/+0
| | | | Core: Updated CMakeLists.txt to remove directory_file_system and meta_file_system modules.
* Loader: Refactored loading functions to only read data from binary if called.bunnei2014-06-253-74/+141
| | | | NCCH: Updated LoadExec to use Memory::WriteBlock function to load binary code.
* MemMap: Added a WriteBlock function to write a buffer of data to memory.bunnei2014-06-252-0/+14
|
* ELF: Refactored LoadInto(..) to use memcpy, removed unnecessary code.bunnei2014-06-251-19/+8
|
* Loader: Refactored use of const.bunnei2014-06-256-20/+19
|
* NCCH: Added RomFS loading.bunnei2014-06-252-1/+36
|
* NCCH: Fixes reduce unnecessary logging and load logo/banner/etc. sections correctly.bunnei2014-06-253-22/+29
| | | | Loader: Added ErrorNotUsed ReturnStatus type to specify when something is not used.
* Loader: Implemented AppLoader interface for abstracting application loading.bunnei2014-06-256-523/+672
| | | | | | | | | | | | | | | | | | - Various cleanups/refactorings to Loader, ELF, and NCCH modules. - Added AppLoader interface to ELF and NCCH. - Updated Qt/GLFW frontends to check AppLoader ResultStatus. NCCH: Removed extra qualification typos. Loader: Removed unnecessary #include's. NCCH: Improved readability of memcmp statements. NCCH: Added missing space. Elf: Removed unnecessary usage of unique_ptr. Loader: Removed unnecessary usage of unique_ptr.
* NCCH: Changed decompression to load .code directly into memory rather than an intermediate buffer.bunnei2014-06-171-9/+3
|
* Elf: Removed unused macros, changed #include of "common.h" to just "common_types.h".bunnei2014-06-171-117/+1
|
* Loader: Cleaned up and removed unused code, refactored ELF namespace.bunnei2014-06-174-209/+70
|
* Elf: Renamed modules to be consistent with new loader naming, fixed tabs -> spaces.bunnei2014-06-178-372/+342
|
* Loader: Added support for booting NCCH executables.bunnei2014-06-176-0/+384
| | | | NCCH: Fixed typo in printing NCCH filename.
* Loader: Moved elf and loader modules to a "loader" subdirectory.bunnei2014-06-178-30/+34
|
* Loader: Added stubbed detection of CXI and CCI files.bunnei2014-06-161-0/+6
|
* Loader: Removed unused CXI and DAT loading code.bunnei2014-06-161-76/+0
|
* Merge branch 'threading' of https://github.com/bunnei/citrabunnei2014-06-1436-1155/+1194
|\ | | | | | | | | | | 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-133-0/+13
| |
| * 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-1313-239/+239
| |
| * 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
| |
| * Core: Cleaned up SingleStep(), updated default LCD refresh to assume each instruction is ~3 cyclesbunnei2014-06-132-12/+14
| |
| * Core: Changed HW update/thread reschedule to occur more frequently (assume each instruction is ~3 cycles)bunnei2014-06-131-2/+2
| |
| * 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-053-1/+7
| |
| * arm: fixed a bug where ARM_Interpreter::ExecuteInstructions was actually executing one more instruction than expectedbunnei2014-06-051-1/+1
| |
| * 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-052-2/+9
| |
| * service: added a error log messages for unimplemented WaitSynchronizationbunnei2014-06-051-0/+1
| |
| * arm: reverting a change made with cb0663de - this has to have been a typo!bunnei2014-06-051-1/+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
| |
| * arm: added option to prepare CPU core (while mid-instruction) for thread reschedulebunnei2014-06-023-0/+11
| |
| * 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-305-0/+74
| |
| * 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-308-45/+49
| |
| * svc: updated OutputDebugString to use OS_LOGbunnei2014-05-301-1/+1
| |
| * arm: removed unnecessary code when calling SVC from skyeyebunnei2014-05-301-16/+0
| |
| * core: changed time delay before kernel reschedule to "approximate" a screen refreshbunnei2014-05-301-3/+12
| |
| * 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
| |
| * lcd: moved kFrameTicks to lcd.h for use in other modulesbunnei2014-05-292-2/+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-282-1/+2
| |
| * 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-284-0/+127
| |
| * 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-123-31/+31
| |
* | Rename LCD to GPU.Tony Wasserka2014-06-128-36/+36
| |
* | Add initial graphics debugger interface.Tony Wasserka2014-06-121-0/+6
| |
* | GSP: Define more GX commands.Tony Wasserka2014-06-122-14/+54
| |
* | Pica: Add command list registers.Tony Wasserka2014-06-122-5/+52
| |
* | Added 'this' reference to num_instructions field so it's properly updated,as before the method was affecting the local method parameter rather than the class fieldDisruption2014-06-011-1/+1
| |
* | service: fixed typo that MSVC did not catch as an errorbunnei2014-05-231-1/+1
| |
* | core: fixed headers in CMakeListsbunnei2014-05-231-1/+4
| |
* | Merge branch 'threading'bunnei2014-05-2337-189/+1330
|\|
| * core: added Kernel::Reschedule() call to check for thread changes, shortened delay time to 100 instructionsbunnei2014-05-231-1/+6
| |
| * svc: added a check to ensure that a service was implemented before attempting to connect to its portbunnei2014-05-231-1/+5
| |
| * lcd: added thread wait after (faked) vblank interrupt (would have) occurredbunnei2014-05-231-0/+4
| |
| * 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-236-65/+75
| |
| * core: moved armcopro.cpp to correct filter folder (arm/interpreter)bunnei2014-05-231-3/+3
| |
| * 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
| |
| * arm_interpreter: fixed load context to currently resume a threadbunnei2014-05-231-1/+4
| |
| * 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-217-10/+166
| |
| * 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
| |
| * arm: removed include of windows.h from armdefs.h to arminit.c (only module that uses it)bunnei2014-05-212-4/+3
| |
| * armemu: missed rename of "Syscall" to "SVC"bunnei2014-05-211-1/+1
| |
| * 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_Interpreter/ARM_Interface: Fixed member variable naming to be consistent with style guidebunnei2014-05-213-45/+45
| |
| * ARM_Interface: added SaveContext and LoadContext functions for HLE thread switchingbunnei2014-05-214-37/+65
| |
| * renamed "syscall" module to "svc" (more accurate naming)bunnei2014-05-219-26/+28
| |
| * 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
| |
| * VFP: disable DBG messages because they spam the console with unimportant skyeye junkbunnei2014-05-201-1/+1
| |
| * 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
| |
| * ignore thumbemu 0xDEADCODE debugging catch on MCRbunnei2014-05-171-2/+1
| |
| * changed a commentbunnei2014-05-172-2/+2
| |
| * cleanups to SVC CreateThreadbunnei2014-05-171-8/+15
| |
| * Merge branch 'master' into threadingbunnei2014-05-176-23/+36
| |\
| * | - 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
| | |
| * | add kernel.* and thread.* to VS filtersbunnei2014-05-171-0/+15
| | |
| * | updated APT_U::GetLockHandle to return a valid handlebunnei2014-05-171-1/+5
| | |
| * | Merge master into threading to add support for VFPbunnei2014-05-1733-195/+14287
| |\ \
| * | | - added SVC stubs for QueryMemory and GetThreadIdbunnei2014-05-163-2/+30
| | | | | | | | | | | | | | | | - added SVC structs MemoryInfo and PageInfo
| * | | added memory mapped region for system mem - sdk demos load a segment here on ELF loadbunnei2014-05-163-1/+23
| | | |
| * | | added ability to load AXF files (same as ELF)bunnei2014-05-161-0/+3
| | | |
| * | | 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
| | | |
| * | | changed loader to use __KernelLoadExecbunnei2014-05-141-8/+9
| | | |
| * | | 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 option to set CPSR register to arm_interfacebunnei2014-05-123-0/+20
| | | |
| * | | added initial kernel/thread modulesbunnei2014-05-107-0/+548
| | | |
* | | | Merge pull request #2 from archshift/issue-7-fixbunnei2014-05-206-26/+54
|\ \ \ \ | |_|_|/ |/| | | Fixes issues with building Citra on OSX
| * | | CMakeLists: rename HEADS, improved commentsarchshift2014-05-201-2/+2
| | | | | | | | | | | | | | | | Changes for clarity of comments, removed redundant compiler flags.
| * | | Fixed vfp issuesarchshift2014-05-174-10/+10
| | | |
| * | | Updated cmakelistsarchshift2014-05-171-6/+12
| | | |
| * | | Merge remote-tracking branch 'upstream/master' into issue-7-fixarchshift2014-05-1751-473/+14858
| |\ \ \ | | | |/ | | |/|
| * | | Fixed indentsarchshift2014-05-011-2/+2
| | | |
| * | | Merge commit upstream/master into issue-7-fixarchshift2014-05-013-22/+43
| |\ \ \
| * | | | A bit of Cmake lovearchshift2014-05-011-1/+38
| | | | |
| * | | | Merge commit upstream/master into issue-7-fixarchshift2014-04-292-5/+11
| |\ \ \ \
| * | | | | Problematic template functionsarchshift2014-04-281-15/+0
| | | | | |
* | | | | | updated how we call ARM core to make things much fasterbunnei2014-05-176-23/+36
| |_|_|/ / |/| | | |
* | | | | same fix as last commit - just for vfpsingle.cppbunnei2014-05-171-2/+2
| | | | |
* | | | | another VFP fix for GCCbunnei2014-05-171-2/+2
| | | | |
* | | | | fixed VFP DBG log for GCCbunnei2014-05-171-1/+1
| | | | |
* | | | | fixed typo in CMakeLists.txtbunnei2014-05-171-1/+1
| | | | |
* | | | | - reenabled MCR and MRC functions now that VFP is attachedbunnei2014-05-174-116/+94
| | | | | | | | | | | | | | | | | | | | - removed HLE::CallMCR function (was pointless)
* | | | | - removed unused stubbed out codebunnei2014-05-175-33/+27
| | | | | | | | | | | | | | | | | | | | | | | | | - fixed some compiler issues with xscale_copro when porting code to Windows - fixed some #include's
* | | | | added maverick.cpp to ARM core from skyeyebunnei2014-05-164-1/+1212
| | | | |
* | | | | fixed includesbunnei2014-05-161-2/+2
| | | | |
* | | | | enabled CP_ACCESS_ALLOWEDbunnei2014-05-161-6/+4
| | | | |
* | | | | fixed include pathbunnei2014-05-161-1/+1
| | | | |
* | | | | removed undefined function ARMul_ConsolePrintbunnei2014-05-161-1/+1
| | | | |
* | | | | added missing armcopro from skyeyebunnei2014-05-166-251/+1098
| | | | |
* | | | | added missing skyeye mmu codebunnei2014-05-1612-44/+3333
| | | | |
* | | | | fixed armmmu importsbunnei2014-05-161-5/+5
| | | | |
* | | | | - moved mmu to arm/interpreter folderbunnei2014-05-1616-1/+8791
| |_|_|/ |/| | | | | | | | | | | - added initial VFP code from skyeye
* | | | 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-088-116/+100
| | | | | | | | | | | | | | | | | | | | - added a helper function for getting command buffer for services - fixed bug where GSP DMA was incorrectly being done in DataSynchronizationBarrier (instead of gsp_TriggerCmdReqQueue)
* | | | added kernel memory to mem_mapbunnei2014-05-082-0/+9
| | | |
* | | | - added debug logging to syscall.cppbunnei2014-05-072-135/+173
| | | | | | | | | | | | | | | | - added stubbed HLE syscall functions for svc_GetResourceLimit and svc_GetResourceLimitCurrentValues
* | | | added mem_map read for config_membunnei2014-05-072-7/+17
| | | |
* | | | added config_mem module for HLE of firmware configuration memory settingsbunnei2014-05-075-0/+100
| | | |
* | | | - disable strict alignment on LDRD/STRDbunnei2014-05-071-17/+22
| | | | | | | | | | | | | | | | - handle RD in STREX/STREXB
* | | | commented out useless debug logs that just spammed consolebunnei2014-05-061-3/+3
| | | |
* | | | - added CallMCR function to coprocessor HLE modulebunnei2014-05-023-29/+43
| | | | | | | | | | | | | | | | - moved instruction decoding to coprocessor HLE module
* | | | fixed include in coprocessor.cppbunnei2014-05-021-1/+1
| | | |
* | | | renamed hle "mrc" module to "coprocessor"bunnei2014-05-026-17/+17
| | | |
* | | | - added some function wrappers for HLEbunnei2014-05-022-10/+29
| | | | | | | | | | | | | | | | | | | | - added stub for SVC CreateAddressArbiter - added OutputDebugString SVC
* | | | - added option to load a code.bin file extracted from a CXI filebunnei2014-05-012-14/+63
| | | | | | | | | | | | | | | | - updated load launcher.dat function to use ARM11 format hack
* | | | added a module to load symbol map files for debuggingbunnei2014-05-015-0/+55
| | | |
* | | | fixed a bug where ExeFs code was being incorrectly maskedbunnei2014-05-011-1/+1
| |_|/ |/| |
* | | added virtual memory map for ExeFS (where ARM11 code is supposed to be loaded)bunnei2014-05-013-1/+17
| | |
* | | reorganized memory regions enum, added regions for ExeFS codebunnei2014-05-012-21/+26
| |/ |/|
* | added virtual address conversion for firmware FW0Bbunnei2014-04-282-5/+11
|/
* removed DISALLOW_COPY_AND_ASSIGN in favor of NonCopyable classbunnei2014-04-285-12/+1
|
* fixed weird spacingbunnei2014-04-281-1/+1
|
* removed commented out line - this was for an unimplemented MRC call, no longer need to leave this herebunnei2014-04-281-1/+0
|
* 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 helper functions to mem_map to convert physical addresses to virtual addressesbunnei2014-04-272-1/+15
|
* added code to LCD modules keep track of framebuffer location in FCRAM or VRAMbunnei2014-04-272-15/+153
|
* - changed HW IO map to use virtual addressesbunnei2014-04-264-42/+64
| | | | - added hooks to catch LCD IO read/writes
* 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
|
* added (fake) physical addresses for where to put framebuffer in VRAMbunnei2014-04-261-0/+10
|
* added vram to memory_mapbunnei2014-04-262-8/+15
|
* moved HLE::MRC to its own module, added support for catching data synchronization barrier commandbunnei2014-04-259-13/+66
|
* added disassembly to unimplemented instructionbunnei2014-04-251-1/+6
|
* removed some cruftbunnei2014-04-251-7/+1
|
* fixed bug where svc_ControlMemory was not properly getting passed in parametersbunnei2014-04-251-2/+2
|
* - added preliminary support for svc_MapMemoryBlockbunnei2014-04-254-14/+70
| | | | | - added shared memory region - moarrrr cleanups to memory_map
* added functions to map Heap and Shared memory spacebunnei2014-04-253-9/+76
|
* 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
* fixes to build on linuxbunnei2014-04-233-22/+24
|
* updated CMakeLists for missing filesShizZy2014-04-231-1/+9
|
* Add a quick way to load Launcher.dat filesMathieu Vaillancourt2014-04-222-5/+60
|
* Merge branch 'hle-interface'bunnei2014-04-1834-212/+2339
|\
| * renamed hw_lcd module to just lcdbunnei2014-04-186-12/+10
| |
| * added NDMA hardware interfacebunnei2014-04-185-2/+141
| |
| * added GSP heap memory allocationbunnei2014-04-183-1/+76
| |
| * fixed bug in Memory::GetPointerbunnei2014-04-181-2/+2
| |
| * moved enums into Memory:: namespacebunnei2014-04-181-4/+2
| |
| * added memory read/write to GSP heapbunnei2014-04-183-7/+16
| |
| * more various refactors to memory interfacebunnei2014-04-183-48/+58
| |
| * cleaned up memory interfaces a lot, removed some hackish stuffbunnei2014-04-183-106/+50
| |
| * added a new function wrapperbunnei2014-04-171-0/+5
| |
| * fixed bug with printing std::string in log messagesbunnei2014-04-171-2/+2
| |
| * changed unknown memory read/write to report the sizebunnei2014-04-171-2/+3
| |
| * added class stub for HID:User servicebunnei2014-04-175-0/+80
| |
| * 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-169-7/+111
| | | | | | | | - 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-166-106/+113
| | | | | | | | | | - 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-137-5/+126
| |
| * renamed class Interface_SRV to SRVbunnei2014-04-131-6/+6
| |
| * replace tabs with spacesbunnei2014-04-131-3/+3
| |
| * 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
| |
| * fixed hw write declarations to not be constbunnei2014-04-131-4/+4
| |
| * added OS memory read/write for thread command bufferbunnei2014-04-134-12/+60
| |
| * cleanups to service HLEbunnei2014-04-132-8/+8
| |
| * - added HLE to connect to "srv:" servicebunnei2014-04-1311-168/+386
| | | | | | | | | | | | - added a manager for keeping track of services/ports - added a memory mapped region for memory accessed by HLE - added HLE for GetThreadCommandBuffer function
| * hacked CPU interpreter to ignore branch on SVC instruction (as we are HLEing this...)bunnei2014-04-121-2/+6
| |
| * added a SETABORT method that does not update LR (for HLE'd SVC that does not jump appcore CPU to an IRQ vector)bunnei2014-04-121-0/+11
| |
| * added a memory mapped option for HLEbunnei2014-04-121-5/+8
| |
| * - renamed hle_syscall to just syscallbunnei2014-04-127-106/+157
| | | | | | | | - 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-123-2/+2
| |
| * added remaining known syscall functions to Syscall_Tablebunnei2014-04-111-0/+80
| |
| * base code to call a syscall from ARM11 appcorebunnei2014-04-115-9/+85
| |
| * updated logging messagebunnei2014-04-111-2/+2
| |
| * cleaned up some logging messagesbunnei2014-04-115-32/+19
| |
| * changed some naming/misc cleanupsbunnei2014-04-114-21/+20
| |
| * - removed syscall classes (will just use HLEFunction)bunnei2014-04-116-15/+54
| | | | | | | | | | - added hle.cpp and module registration - removed unused code
| * Merge branch 'master' into hle-interfacebunnei2014-04-111-8/+21
| |\
| * | added initial modules for setting up SysCall HLEbunnei2014-04-117-0/+862
| | |
| * | missed this file with commit 95e5436fbunnei2014-04-111-1/+10
| | |
| * | added Memory::GetCharPointer to read strings from HLE functionsbunnei2014-04-111-0/+4
| | |
| * | cleaned up arm_interface, added a setter to set registers for use with HLE return valuesbunnei2014-04-112-6/+70
| | |
* | | Implement simple LoadSymbols for ELF filesMathieu Vaillancourt2014-04-131-63/+13
| |/ |/|
* | fixed a bunch of errors in CMakeListsbunnei2014-04-101-1/+1
| |
* | updated CMakeListsbunnei2014-04-101-8/+21
|/
* fixed licensing and updated code style naming for arm_interface/arm_interpreter frontend modulebunnei2014-04-093-94/+57
|
* fixed project includes to use new directory structurebunnei2014-04-0934-251/+255
|
* got rid of 'src' folders in each sub-projectbunnei2014-04-0948-0/+0
|
* fixed some license headers that I missedbunnei2014-04-092-46/+6
|
* fixed all license file headers in corebunnei2014-04-0912-303/+44
|
* fixed licensing issue with core_timing being GPL v2+ instead of Dolphin's GPL v2bunnei2014-04-092-487/+455
|
* Merge branch 'hardware-interface'bunnei2014-04-0713-47/+386
|\ | | | | | | | | Conflicts: src/core/src/core.h
| * removed log message from hw_lcdbunnei2014-04-071-2/+0
| |
| * added hack physical memory reads with Memory::GetPointerbunnei2014-04-071-2/+9
| |
| * calling SwapBuffers from hw_lcd.cppbunnei2014-04-061-0/+2
| |
| * initialize VideoCorebunnei2014-04-061-2/+3
| |
| * added g_app_core->Step and HW::Update to Core::SingleStep to be consistent with other changes madebunnei2014-04-051-1/+5
| |
| * changed hw_lcd to use ARM core correct tick counter instead of [what was actually] just an instruction count. this seems to fix timing issues with the 3DS_Homebrew_Pong3Dv2 demo.bunnei2014-04-053-8/+48
| |
| * add hw_lcd.* to VS project filesbunnei2014-04-052-0/+8
| |
| * added an "Update" method to update all hardwarebunnei2014-04-052-0/+10
| |
| * added a module for interfacing to hardware LCDbunnei2014-04-052-0/+129
| |
| * added a tick counterbunnei2014-04-051-4/+12
| |
| * added initial support for hw.cpp modulebunnei2014-04-058-52/+69
| |
| * added hw module to interface h/w register reads/writesbunnei2014-04-055-3/+118
| |
| * renamed some functionsbunnei2014-04-051-11/+11
| |
* | Remove Core::GetState(). Use new ARM_Interface instead.Mathieu Vaillancourt2014-04-051-2/+0
|/
* added entry point loading from ELF filebunnei2014-04-051-2/+4
|
* - added an interface layer for ARM coresbunnei2014-04-057-77/+213
| | | | - cleaned up core.cpp a bit
* renamed ARM disassembler class from "Arm" to "ARM_Disasm"bunnei2014-04-052-27/+27
|
* got rid of some really poorly named macros in SkyEye corebunnei2014-04-053-9/+9
|
* moved arm core to interpreter directorybunnei2014-04-0517-65/+71
|
* added some commented out ARMulator functionsbunnei2014-04-041-20/+3
|
* added hack to allow physical mem read/writesbunnei2014-04-041-2/+20
|
* made memory #define's enum to make debugging easierbunnei2014-04-041-15/+21
|
* Add Core::GetState() for debuggerMathieu Vaillancourt2014-04-042-0/+9
|
* removed some useless log messagesbunnei2014-04-041-2/+0
|
* added thumb mode emulationbunnei2014-04-046-4/+522
|
* convert tabs to spacesbunnei2014-04-0210-6796/+6796
|
* -converted tabs to spacesbunnei2014-04-022-149/+145
| | | | -moved scratchpad memory out of MemArena
* added very hackish ARMulator core initialization and CPU steppingbunnei2014-04-011-6/+97
|
* added ELF loading support to loader.cppbunnei2014-04-011-69/+113
|
* commented out bswap stuff... ARM ELF files are little endian anywaybunnei2014-04-011-9/+10
|
* added support for reading/writing to stack membunnei2014-04-013-17/+40
|
* replaced some error logs with debug assertsbunnei2014-03-301-4/+2
|
* removed unnecessary debug assertbunnei2014-03-301-1/+0
|
* added ARM11 MMU from skyeyebunnei2014-03-306-145/+116
|
* initialize mem regionsbunnei2014-03-301-0/+2
|
* added various arm modules from skyeye to make project link OKbunnei2014-03-309-166/+2582
|
* added a GetPointer function to Memory for use with ELF loadingbunnei2014-03-253-30/+33
|
* updated Windows project files to include ELF filesbunnei2014-03-252-0/+7
|
* added Dolphin's ELF reader to the projectbunnei2014-03-253-0/+594
|
* renamed FILETYPE_CTR_DIRECTORY to FILETYPE_DIRECTORY_CXIShizZy2013-10-062-12/+10
|
* fixed a typo in declaration of meta file systemShizZy2013-10-061-2/+2
|
* moved some core functions over to system moduleShizZy2013-10-034-13/+11
|
* added core_timing and system modules to core vcprojShizZy2013-10-026-2/+823
|
* added an early function for booting from a directoryShizZy2013-10-022-16/+35
|
* added a message option to Core::Halt functionShizZy2013-10-022-2/+2
|
* upgraded proj files to vs 2013ShizZy2013-09-271-1/+5
|
* added system.h to projectShizZy2013-09-275-22/+87
|
* added meta_file_system to projectShizZy2013-09-264-0/+637
|
* renamed file_sys_directory.* to directory_file_system.*ShizZy2013-09-264-5/+5
|
* moved file_sys back to coreShizZy2013-09-265-0/+982
|
* removed <windows.h> include from common.h and added it only where neededShizZy2013-09-241-0/+4
|
* moved file_sys to commonShizZy2013-09-245-982/+0
|
* removed unused commented-out codeShizZy2013-09-241-154/+0
|
* renamed PSPFileInfo to just FileInfoShizZy2013-09-243-21/+21
|
* added PPSSPP's file system directory module for game loadingShizZy2013-09-243-10/+138
|
* ppsspp file system module - currently unusedShizZy2013-09-203-0/+1008
|
* added a module for loading bootable binariesShizZy2013-09-204-0/+203
|
* added mem_map hardware writingShizZy2013-09-203-75/+76
|
* added hw R/W/ memory functionsShizZy2013-09-195-3/+161
|
* refactored some mem_map stuffShizZy2013-09-192-19/+36
|
* added log msg to coreShizZy2013-09-191-0/+2
|
* added ARMulator/skyeye ARM11 core to the projectShizZy2013-09-1818-0/+11356
|
* renamed project to 'citrus'ShizZy2013-09-144-4/+4
|
* cleaned up VS project filesShizZy2013-09-091-52/+7
|
* updated common pathsShizZy2013-09-081-0/+2
|
* start of 3DS memory mapShizZy2013-09-062-4/+77
|
* added core and mem_map files to the projectShizZy2013-09-066-2/+232
|
* added an ARM disassembler from the android projectShizZy2013-09-054-0/+1175
|
* added missing filesShizZy2013-09-051-0/+2
|
* various fixes to be able to build projectShizZy2013-09-051-16/+19
|
* adding initial project layoutShizZy2013-08-302-0/+196