summaryrefslogtreecommitdiffstats
path: root/src/core/hle (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Merge pull request #13048 from liamwhite/new-shellNarr the Reg2024-02-1944-1177/+1990
|\ | | | | ns: rewrite for new IPC
| * ns: address review commentsLiam2024-02-193-25/+35
| |
| * ns: rewrite IQueryServiceLiam2024-02-184-73/+67
| |
| * ns: rewrite IServiceGetterInterfaceLiam2024-02-186-109/+190
| |
| * ns: rewrite IApplicationManagerInterfaceLiam2024-02-1810-489/+631
| |
| * ns: move IDevelopInterfaceLiam2024-02-183-32/+56
| |
| * ns: rewrite ISystemUpdateInterfaceLiam2024-02-184-39/+107
| |
| * ns: move ISystemUpdateControlLiam2024-02-183-36/+61
| |
| * ns: rewrite IVulnerabilityManagerInterfaceLiam2024-02-183-25/+55
| |
| * ns: rewrite IReadOnlyApplicationControlDataInterfaceLiam2024-02-185-55/+158
| |
| * ns: rewrite IReadOnlyApplicationRecordInterfaceLiam2024-02-184-45/+61
| |
| * ns: add IDynamicRightsInterfaceLiam2024-02-183-1/+86
| |
| * ns: rewrite IDownloadTaskInterfaceLiam2024-02-184-27/+60
| |
| * ns: rewrite IDocumentInterfaceLiam2024-02-185-51/+66
| |
| * ns: rewrite IContentManagementInterfaceLiam2024-02-185-52/+112
| |
| * ns: move IFactoryResetInterfaceLiam2024-02-184-25/+44
| |
| * ns: move IECommerceInterfaceLiam2024-02-184-25/+44
| |
| * ns: move IApplicationVersionInterfaceLiam2024-02-184-31/+50
| |
| * ns: move IAccountProxyInterfaceLiam2024-02-185-19/+100
| |
| * ns: rewrite IPlatformServiceManagerLiam2024-02-184-89/+78
| |
| * ns: rename results headerLiam2024-02-182-1/+1
| |
* | Merge pull request #13070 from liamwhite/offsetliamwhite2024-02-191-2/+2
|\ \ | | | | | | am: account for offset in transfer memory storage
| * | am: account for offset in transfer memory storageLiam2024-02-181-2/+2
| | |
* | | Merge pull request #13030 from german77/audio-controllerliamwhite2024-02-195-253/+234
|\ \ \ | |/ / |/| | service: audio: Rewrite IAudioController to new IPC
| * | service: audio: Rewrite IAudioController to new IPCNarr the Reg2024-02-175-253/+234
| | |
* | | Merge pull request #13032 from german77/qlauncherliamwhite2024-02-187-9/+48
|\ \ \ | |_|/ |/| | service: Implement functions needed by Qlaunch
| * | service: erpt: Implement SubmitContextNarr the Reg2024-02-161-1/+11
| | |
| * | service: caps: Implement GetAlbumFIleListNarr the Reg2024-02-162-1/+13
| | |
| * | service: am: Fix GetMainAppletAvailableUsers for user creationNarr the Reg2024-02-163-7/+6
| | |
| * | service: am: Add QLaunch launcherNarr the Reg2024-02-161-0/+18
| |/
* | Merge pull request #13049 from Leystryku/masterliamwhite2024-02-184-2/+28
|\ \ | | | | | | Fix Just Dance 2023 not booting
| * | service: Change unique_ptr to make_unique in GetCacheStorageMaxLeystryku2024-02-181-1/+1
| | |
| * | file_sys: Formatting changes and use unique_ptr in GetCacheStorageMaxLeystryku2024-02-181-6/+6
| | |
| * | file_sys: Fix nacp field cache_storage_max_index datatypeLeystryku2024-02-181-8/+5
| | |
| * | service: Add proper GetCacheStorageMax implementation to IApplicationFunctionsLeystryku2024-02-183-7/+17
| | |
| * | fsp: Add FlushAccessLogOnSdCard stubLeystryku2024-02-182-2/+10
| | |
| * | service: Add GetCacheStorageMax stub to IApplicationFunctionsLeystryku2024-02-182-1/+12
| |/
* | Merge pull request #13017 from liamwhite/suspensionNarr the Reg2024-02-183-27/+38
|\ \ | | | | | | kernel: add and enable system suspend type
| * | kernel: add and enable system suspend typeLiam2024-02-143-27/+38
| | |
* | | Close reference to TimeZoneBinary on game closeKelebek12024-02-172-0/+5
| |/ |/|
* | Merge pull request #13016 from german77/set-interface2liamwhite2024-02-169-1026/+662
|\ \ | | | | | | service: set: Migrate ISystemSettingsServer to new IPC
| * | service: set: Migrate ISystemSettingsServer to new IPCNarr the Reg2024-02-149-1026/+662
| |/
* | vi: rewrite IApplicationDisplayServiceLiam2024-02-143-309/+228
| |
* | vi: rewrite ISystemDisplayServiceLiam2024-02-142-148/+92
| |
* | vi: rewrite IManagerDisplayServiceLiam2024-02-142-61/+28
| |
* | vi: rewrite IHOSBinderDriverLiam2024-02-145-49/+53
| |
* | vi: rewrite IApplicationRootService, IManagerRootService, ISystemRootServiceLiam2024-02-1411-90/+143
| |
* | vi: split into implementation filesLiam2024-02-1417-917/+1043
| |
* | vi: extract typesLiam2024-02-147-69/+78
|/
* Merge pull request #12996 from german77/settings-ipcliamwhite2024-02-145-174/+1188
|\ | | | | service: set: Migrate ISettingsServer to new interface
| * service: set: Migrate ISettingsServer to new interfacegerman772024-02-145-174/+1188
| |
* | Merge pull request #12993 from liamwhite/am-rewrite-part1Narr the Reg2024-02-14113-4038/+4174
|\ \ | | | | | | am: rewrite part 1
| * | am: move out omm interfaces to new moduleLiam2024-02-1213-81/+116
| | |
| * | am: rewrite IApplicationCreatorLiam2024-02-123-6/+24
| | |
| * | am: add IApplicationAccessorLiam2024-02-122-0/+178
| | |
| * | am: rewrite ILockAccessorLiam2024-02-125-100/+108
| | |
| * | am: rewrite IWindowControllerLiam2024-02-127-116/+119
| | |
| * | am: rewrite IStorageLiam2024-02-1218-79/+71
| | |
| * | am: rewrite IStorageAccessor, ITransferStorageAccessorLiam2024-02-124-101/+80
| | |
| * | am: rewrite ISelfControllerLiam2024-02-128-540/+477
| | |
| * | am: rewrite IProcessWindingControllerLiam2024-02-126-62/+64
| | |
| * | am: rewrite ILibraryAppletSelfAccessorLiam2024-02-127-385/+406
| | |
| * | am: rewrite ILibraryAppletCreatorLiam2024-02-126-119/+86
| | |
| * | am: rewrite ILibraryAppletAccessorLiam2024-02-126-247/+204
| | |
| * | am: rewrite IHomeMenuFunctionsLiam2024-02-126-86/+112
| | |
| * | am: rewrite IGlobalStateController, add ICradleFirmwareUpdaterLiam2024-02-128-52/+183
| | |
| * | am: rewrite IDisplayControllerLiam2024-02-127-168/+144
| | |
| * | am: move IDebugFunctionsLiam2024-02-125-5/+4
| | |
| * | am: rewrite ICommonStateGetterLiam2024-02-1213-435/+383
| | |
| * | am: rewrite IApplicationFunctionsLiam2024-02-127-656/+588
| | |
| * | am: rewrite IAppletCommonFunctionsLiam2024-02-125-22/+24
| | |
| * | am: rewrite IAudioControllerLiam2024-02-127-130/+109
| | |
| * | am: rewrite ISystemAppletProxyLiam2024-02-125-175/+189
| | |
| * | am: rewrite ILibraryAppletProxyLiam2024-02-125-182/+191
| | |
| * | am: rewrite IApplicationProxyLiam2024-02-125-150/+157
| | |
| * | am: rewrite appletAE, appletOELiam2024-02-1211-200/+216
| |/
* | Merge pull request #12974 from german77/ldn-interfaceliamwhite2024-02-1317-778/+898
|\ \ | |/ |/| service: ldn: Migrate and refractor service to new IPC
| * service: ldn: Migrate and refractor service to new IPCNarr the Reg2024-02-1117-778/+898
| |
* | Merge pull request #12756 from liamwhite/applet-multiprocess-hwcNarr the Reg2024-02-1224-99/+359
|\ \ | | | | | | general: applet multiprocess
| * | am: use applet program loading for tested versionsLiam2024-02-103-7/+28
| | |
| * | am: fix focus states and display of indirect keyboardLiam2024-02-093-15/+10
| | |
| * | am: stub SetMediaPlaybackState for self controllerLiam2024-02-092-1/+16
| | |
| * | general: add default configurations for applet modeLiam2024-02-091-7/+44
| | |
| * | nvnflinger/gpu: implement applet captureLiam2024-02-092-5/+31
| | |
| * | nvnflinger/gpu: implement blendingLiam2024-02-0916-66/+217
| | |
| * | nvservices: unmap only on last container freeLiam2024-02-093-3/+13
| | |
| * | core: fix multiprocess with nceLiam2024-02-091-1/+6
| | |
* | | service: news: Stub remaining functionsgerman772024-02-127-13/+54
| |/ |/|
* | Merge pull request #12969 from german77/bcat-interfaceliamwhite2024-02-1034-734/+1257
|\ \ | | | | | | service: bcat: Migrate and refractor service to new IPC
| * | service: bcat: Address review issuesNarr the Reg2024-02-1027-140/+148
| | |
| * | service: bcat: Implement news interfacesNarr the Reg2024-02-1013-0/+413
| | |
| * | service: bcat: Migrate and refractor service to new IPCNarr the Reg2024-02-1021-733/+835
| | |
* | | Merge pull request #12949 from liamwhite/multi-waitliamwhite2024-02-1014-348/+560
|\ \ \ | |/ / |/| | service: add os types and multi wait API
| * | glue: use multi wait APILiam2024-02-071-82/+48
| | |
| * | server_manager: use multi wait APILiam2024-02-072-261/+234
| | |
| * | service: add os types and multi wait APILiam2024-02-0712-5/+278
| | |
* | | Merge pull request #12951 from liamwhite/more-ipcNarr the Reg2024-02-093-4/+16
|\ \ \ | | | | | | | | ipc: additional fixes
| * | | ipc: additional fixesLiam2024-02-073-4/+16
| |/ /
* | | Merge pull request #12966 from german77/free_npadliamwhite2024-02-091-8/+1
|\ \ \ | |_|/ |/| | service: hid: Free npad applet resource
| * | service: hid: Free npad applet resourceNarr the Reg2024-02-091-8/+1
| | |
* | | service: Fix OutLargeData attributesNarr the Reg2024-02-091-1/+1
|/ /
* | Merge pull request #12954 from german77/hidbus-interfaceliamwhite2024-02-083-346/+206
|\ \ | | | | | | service: hid: Migrate hidbus to new interface
| * | service: hid: Migrate hidbus to new interfaceNarr the Reg2024-02-083-346/+206
| |/
* | Merge pull request #12914 from FernandoS27/vc-refactorliamwhite2024-02-081-144/+43
|\ \ | |/ |/| VideoCore Refactor Part 1.
| * Common: Rename SplitRangeSet to OverlapRangeSetFernando Sahmkow2024-02-051-1/+1
| |
| * NVDRV: Refactor HeapMapper to use RangeSetsFernando Sahmkow2024-02-041-144/+43
| |
* | Merge pull request #12883 from FernandoS27/memory_manager_memliamwhite2024-02-061-2/+4
|\ \ | | | | | | MemoryManager: Reduce the page table size based on last big page address.
| * | MemoryManager: Reduce the page table size based on last big page address.Fernando Sahmkow2024-02-011-2/+4
| | |
* | | Merge pull request #12933 from german77/irs-interfaceliamwhite2024-02-062-410/+262
|\ \ \ | | | | | | | | service: irs: Migrate service to new interface
| * | | service: irs: Migrate service to new interfacegerman772024-02-062-410/+262
| | | |
* | | | service: hid: Migrate hid debug service to new interfacegerman772024-02-062-119/+78
|/ / /
* | | Merge pull request #12905 from liamwhite/hwc-releaseCharles Lombardo2024-02-053-28/+27
|\ \ \ | | | | | | | | nvnflinger: release buffers before presentation sleep
| * | | nvnflinger: release buffers before presentation sleepLiam2024-02-033-28/+27
| | |/ | |/|
* | | Merge pull request #12892 from liamwhite/serialization-stuffliamwhite2024-02-042-2/+31
|\ \ \ | |/ / |/| | cmif_serialization: enforce const for references
| * | cmif_serialization: enforce const for referencesLiam2024-02-022-2/+31
| | |
* | | Merge pull request #12901 from Kelebek1/timezone_firmware_fixliamwhite2024-02-031-0/+1
|\ \ \ | | | | | | | | Fix firmware timezone boot load check.
| * | | Fix firmware timezone boot load check.Kelebek12024-02-031-0/+1
| |/ /
* / / service: fs: Skip non user id foldersNarr the Reg2024-02-021-0/+9
|/ /
* | Merge pull request #12857 from liamwhite/constFernando S2024-02-0231-91/+100
|\ \ | | | | | | service: use const references for input raw data
| * | service: use const references for input raw dataLiam2024-02-0131-91/+100
| | |
* | | Merge pull request #12845 from liamwhite/notifFernando S2024-02-023-126/+324
|\ \ \ | | | | | | | | notif: rewrite for new IPC
| * | | notif: rewrite for new IPCLiam2024-01-293-126/+324
| | | |
* | | | Merge pull request #12761 from liamwhite/mp-compositeFernando S2024-02-0210-57/+357
|\ \ \ \ | |_|/ / |/| | | video_core: rewrite presentation for layer composition
| * | | hardware_composer: implement speed limit extensionsLiam2024-01-315-22/+50
| | | |
| * | | nvnflinger/gpu: implement layer stack compositionLiam2024-01-3111-54/+326
| | |/ | |/|
* | | Merge pull request #12848 from german77/caps-interfaceliamwhite2024-02-0113-388/+263
|\ \ \ | | | | | | | | service: capsrv: Migrate to new IPC
| * | | service: capsrv: Migrate to new IPCNarr the Reg2024-01-3013-388/+263
| | |/ | |/|
* | | Merge pull request #12780 from german77/touch_resource5liamwhite2024-02-019-34/+318
|\ \ \ | |_|/ |/| | service: hid: Fully implement touch resource
| * | service: hid: Fully implement touch resourceNarr the Reg2024-01-299-34/+318
| | |
* | | Merge pull request #12760 from liamwhite/mp-amNarr the Reg2024-01-31105-4446/+6719
|\ \ \ | | | | | | | | am: rewrite for multiprocess support
| * | | am: push storage from error applet with non-zero sizeLiam2024-01-311-1/+1
| | | |
| * | | am: stop emulation when all applets are closedLiam2024-01-301-0/+8
| | | |
| * | | core: support offline web appletLiam2024-01-3031-57/+466
| | | |
| * | | am: return AppletDataBroker and use for frontend appletsLiam2024-01-3030-508/+422
| | | |
| * | | am: rework IStorage for transfer storageLiam2024-01-306-109/+117
| | | |
| * | | am: migrate global state to per-applet state structureLiam2024-01-3037-702/+676
| | | |
| * | | am: re-namespace frontend applets to frontend directoryLiam2024-01-3028-325/+243
| | | |
| * | | am: add new datatypes for per-applet stateLiam2024-01-3018-1/+1479
| | | |
| * | | service: split am into componentsLiam2024-01-3058-3482/+4046
| | | |
* | | | Merge pull request #12869 from FernandoS27/smmu-fixesliamwhite2024-01-311-1/+3
|\ \ \ \ | | | | | | | | | | SMMU: A set of different fixes.
| * | | | NVDRV: Join the heaper optimization blocksFernando Sahmkow2024-01-311-1/+3
| | | | |
* | | | | Merge pull request #12864 from Kelebek1/small_time_fixesliamwhite2024-01-319-84/+66
|\ \ \ \ \ | | | | | | | | | | | | Small time fixes
| * | | | | Remove a few hacks for clock setups, which seem to no longer be needed, but fix network clock to local clock on every boot. Also fix some logging strings.Kelebek12024-01-319-84/+66
| | | | | |
* | | | | | aoc: fix DLC listing (#12867)liamwhite2024-01-311-1/+1
| |/ / / / |/| | | |
* | | | | Merge pull request #12860 from liamwhite/serialization2liamwhite2024-01-301-3/+3
|\ \ \ \ \ | | | | | | | | | | | | cmif_serialization: fix LargeData types
| * | | | | cmif_serialization: fix LargeData typesLiam2024-01-301-3/+3
| |/ / / /
* | | | | Merge pull request #12859 from german77/ledliamwhite2024-01-302-13/+37
|\ \ \ \ \ | |/ / / / |/| | | | service: hid: Implement GetPlayerLedPattern accurately
| * | | | service: hid: Implement GetPlayerLedPattern accuratelyNarr the Reg2024-01-302-13/+37
| | |_|/ | |/| |
* | | | Merge pull request #12856 from liamwhite/serializationliamwhite2024-01-301-12/+38
|\ \ \ \ | | | | | | | | | | cmif_serialization: fix out layout calculation
| * | | | cmif_serialization: fix out layout calculationLiam2024-01-301-12/+38
| | |/ / | |/| |
* | | | Update sockets.hLotP12024-01-301-1/+1
| | | | | | | | | | | | forgot to realign the enum
* | | | Update src/core/hle/service/sockets/sockets.hLotP12024-01-301-1/+1
| | | | | | | | | | | | Co-authored-by: liamwhite <liamwhite@users.noreply.github.com>
* | | | Update sockets_translate.cppLotP12024-01-301-2/+2
| | | | | | | | | | | | Align the error case with it's index in the Errno enum
* | | | Update sockets.hLotP12024-01-301-0/+1
| | | | | | | | | | | | Add the CONNREFUSED error to the Service::Sockets::Errno enum
* | | | Update sockets_translate.cppLotP12024-01-301-0/+2
|/ / / | | | | | | | | | Add support for the CONNREFUSED Errno. Without this Connect() will return SUCCESS when a connection is refused, instead of an error code. This causes code, that relies on the result of Connect() being SUCCESS, to execute when it shouldn't.
* / / service: mii: Set arguments as constNarr the Reg2024-01-291-7/+8
|/ /
* | Merge pull request #12837 from german77/catliamwhite2024-01-291-1/+1
|\ \ | | | | | | service: am: Focus state changed goes last
| * | service: am: Focus state changed goes lastgerman772024-01-291-1/+1
| |/
* | Merge pull request #12814 from Kelebek1/time_new_ipcliamwhite2024-01-2932-2039/+1204
|\ \ | | | | | | Move time services to new IPC and add debug printing
| * | Move time services to new IPC.Kelebek12024-01-2732-2039/+1204
| | | | | | | | | | | | Add some fixes/improvements to usage with the new IPC
* | | fix build for gcc 11amazingfate2024-01-291-1/+1
| |/ |/|
* | Merge pull request #12831 from Kelebek1/audren_multiliamwhite2024-01-281-6/+10
|\ \ | | | | | | Use the input process handle to get the correct application's memory
| * | Use the input process handle to get the correct application's memoryKelebek12024-01-281-6/+10
| |/
* | Merge pull request #12825 from liamwhite/whyliamwhite2024-01-281-1/+2
|\ \ | | | | | | kernel: clear pinned waiter list on unpin
| * | kernel: clear pinned waiter list on unpinLiam2024-01-281-1/+2
| |/
* | Merge pull request #12823 from german77/set-audioliamwhite2024-01-287-59/+350
|\ \ | | | | | | service: set: Implement more Qlaunch Settings
| * | service: set: Increase settings versiongerman772024-01-281-2/+2
| | |
| * | service: set: Implement more Qlaunch Settingsgerman772024-01-287-57/+348
| |/
* | Merge pull request #12802 from german77/mii_interfaceliamwhite2024-01-284-412/+171
|\ \ | |/ |/| service: mii: Migrate service to new interface
| * service: mii: Migrate service to new interfaceNarr the Reg2024-01-264-412/+171
| |
* | Merge pull request #12765 from german77/sys-hidliamwhite2024-01-269-72/+227
|\ \ | | | | | | service: set: Implement more settings functions for Qlaunch
| * | service: set: Implement more settings functions for QlaunchNarr the Reg2024-01-269-72/+227
| | |
* | | Merge pull request #12707 from FearlessTobi/fs-housekeepingliamwhite2024-01-2635-627/+792
|\ \ \ | |_|/ |/| | fs: Various cleanups & add path class for later use
| * | Address review comments and fix compilation problemsFearlessTobi2024-01-254-3/+4
| | |
| * | fs: Add path classFearlessTobi2024-01-252-2/+5
| | |
| * | result: Make fully constexpr, add ON_RESULT_INCLUDEDFearlessTobi2024-01-256-18/+46
| | |
| * | fs/errors: Unify naming of result codesFearlessTobi2024-01-256-32/+32
| | |
| * | fs: Replace Mode enum by OpenMode enumFearlessTobi2024-01-258-53/+50
| | |
| * | vfs: Move vfs files to their own directoryFearlessTobi2024-01-2513-14/+14
| | |
| * | fs: Move fsp_srv subclasses to separate filesFearlessTobi2024-01-2516-540/+676
| |/ | | | | | | fs: Move additional files to the fsp directory
* | cmif_serialization: support non-domain sessions on domain serversLiam2024-01-261-33/+32
| |
* | cmif_types: improve ergonomics of typesLiam2024-01-264-38/+97
|/
* Merge pull request #12759 from liamwhite/mp-miscliamwhite2024-01-254-4/+25
|\ | | | | core: miscellaneous fixes
| * nvservices: close map handles on session closeLiam2024-01-233-0/+16
| |
| * kernel: target invalidate to given processLiam2024-01-231-4/+9
| |
* | Merge pull request #12783 from liamwhite/cmif-generationliamwhite2024-01-257-353/+727
|\ \ | | | | | | service: add template serializer for method calls
| * | service: add template serializer for method callsLiam2024-01-257-353/+727
| | |
* | | Merge pull request #12499 from Kelebek1/timeliamwhite2024-01-25112-3800/+6745
|\ \ \ | |/ / |/| | Rework time services
| * | Rework time service to fix time passing offline.Kelebek12024-01-24112-3800/+6745
| | |
* | | service: properly convert buffers to stringsNarr the Reg2024-01-233-8/+8
| |/ |/|
* | Merge pull request #12579 from FernandoS27/smmuliamwhite2024-01-2239-196/+657
|\ \ | | | | | | Core: Implement Device Mapping & GPU SMMU
| * | nvhost_vic: use map erase by keyLiam2024-01-191-4/+1
| | |
| * | nvdrv: clean up preallocationLiam2024-01-191-3/+5
| | |
| * | nvdrv: use correct names for interface factoryLiam2024-01-191-3/+3
| | |
| * | nvdrv: use static typing for SessionId, smmu Asid typesLiam2024-01-1931-59/+68
| | |
| * | Core: Make sure GPU Dirty Managers ae shared by all processes.Fernando Sahmkow2024-01-192-14/+4
| | |
| * | Core: Clang format and other small issues.Fernando Sahmkow2024-01-1911-31/+52
| | |
| * | SMMU: Fix software rendering and cleanupFernando Sahmkow2024-01-197-30/+24
| | |
| * | SMMU: Add continuity tracking optimization.Fernando Sahmkow2024-01-192-1/+2
| | |
| * | SMMU: Add Android compatibilityFernando Sahmkow2024-01-191-2/+4
| | |
| * | GPU-SMMU: Estimate game leak and preallocate device region.Fernando Sahmkow2024-01-196-21/+323
| | |
| * | GPU SMMU: Expand to 34 bitsFernando Sahmkow2024-01-192-5/+34
| | |
| * | SMMU: Implement physical memory mirroringFernando Sahmkow2024-01-193-6/+13
| | |
| * | SMMU: Initial adaptation to video_core.Fernando Sahmkow2024-01-1910-156/+94
| | |
| * | NVDRV: Implement sessions and initial implementation of SMMUFernando Sahmkow2024-01-1933-83/+252
| | |
* | | Merge pull request #12734 from german77/enable-appletliamwhite2024-01-221-2/+2
|\ \ \ | | | | | | | | service: hid: Implement EnableAppletForInput
| * | | service: hid: Implement EnableAppletForInputNarr the Reg2024-01-211-2/+2
| | | |
* | | | service: set: Don't allow invalid mii author idgerman772024-01-211-0/+5
|/ / /
* | | Merge pull request #12660 from german77/better-vibrationliamwhite2024-01-205-151/+289
|\ \ \ | | | | | | | | service: hid: Fully implement abstract vibration
| * | | service: hid: Fully implement abstract vibrationNarr the Reg2024-01-165-151/+289
| |/ /
* | | Merge pull request #12701 from liamwhite/flinger-layer-issuesliamwhite2024-01-206-15/+42
|\ \ \ | | | | | | | | vi: check layer state before opening or closing
| * | | vi: check layer state before opening or closingLiam2024-01-184-12/+27
| | | |
| * | | nvnflinger: ensure display abandonment considers all layers and future layersLiam2024-01-183-3/+15
| |/ /
* | | Merge pull request #12695 from anpilley/user-arguments-v2liamwhite2024-01-192-0/+18
|\ \ \ | |_|/ |/| | Allow -u to accept a username string in addition to index
| * | Update based on feedbackAndrew Pilley2024-01-181-2/+2
| | |
| * | Allow -u to accept a username string in addition to index, and suppress the User selector even if settings requires it to be shown for one instance only.Andrew Pilley2024-01-172-0/+18
| |/
* | Merge pull request #12678 from german77/settings_implliamwhite2024-01-1914-628/+809
|\ \ | | | | | | service: set: Implement stubbed functions
| * | service: set: Implement stubbed functionsNarr the Reg2024-01-166-49/+200
| | |
| * | service: set: Refractor setting serviceNarr the Reg2024-01-1613-580/+610
| |/
* / service: nfc: Create backup when none existNarr the Reg2024-01-151-1/+4
|/
* Merge pull request #12677 from GPUCode/whyy-moddersliamwhite2024-01-151-2/+2
|\ | | | | core: Support multiple modules per patcher
| * core: Support multiple modules per patcherGPUCode2024-01-141-2/+2
| |
* | Merge pull request #12665 from german77/proofliamwhite2024-01-152-3/+17
|\ \ | | | | | | service: acc: Only save profiles when profiles have changed
| * | service: acc: Only save profiles when profiles have changedgerman772024-01-132-3/+17
| | |
* | | Merge pull request #12659 from liamwhite/audio-memoryCharles Lombardo2024-01-152-13/+49
|\ \ \ | | | | | | | | audio: fetch process object from handle table
| * | | audio: fetch process object from handle tableLiam2024-01-122-13/+49
| |/ /
* | | Merge pull request #12612 from liamwhite/fs-pidCharles Lombardo2024-01-159-234/+322
|\ \ \ | | | | | | | | fsp-srv: use program registry for SetCurrentProcess
| * | | fsp-srv: use program registry for SetCurrentProcessLiam2024-01-119-234/+322
| | | |
* | | | Merge pull request #12611 from liamwhite/resource-management-is-hardCharles Lombardo2024-01-1511-72/+124
|\ \ \ \ | | | | | | | | | | kernel: fix resource management issues
| * | | | kernel: optimize page free on shutdownLiam2024-01-133-63/+18
| | | | |
| * | | | kernel: fix debugger and process list lifetimeLiam2024-01-136-65/+82
| | | | |
| * | | | kernel: fix page leak on process terminationLiam2024-01-133-1/+81
| | |_|/ | |/| |
* | | | Merge pull request #12610 from liamwhite/reply-and-dont-receiveCharles Lombardo2024-01-151-2/+7
|\ \ \ \ | |/ / / |/| | | server_manager: respond to session close correctly
| * | | server_manager: respond to session close correctlyLiam2024-01-081-2/+7
| |/ /
* | / service: hid: Create abstracted pad structuregerman772024-01-121-1/+1
| |/ |/|
* | Merge pull request #12609 from liamwhite/wrong-name-againNarr the Reg2024-01-095-51/+38
|\ \ | | | | | | vi: minor cleanups
| * | vi: connect vsync event handle lifetime to application display service interfaceLiam2024-01-084-24/+11
| | |
| * | vi: fix name of nvnflingerLiam2024-01-082-27/+27
| |/
* / Fix typos in src/core (#12625)Viktor Szépe2024-01-0826-93/+93
|/ | | | | | | | | * Fix typos in src/core * Fix typo correction * Fix indentation of MemoryStateNames * Fix indent
* Merge pull request #12600 from german77/npad-implliamwhite2024-01-083-21/+72
|\ | | | | service: hid: Hook interface implementations
| * service: hid: Implement GetLastActiveNpadgerman772024-01-071-3/+6
| |
| * service: hid: Implement AssigningSingleOnSlSrPressgerman772024-01-071-2/+12
| |
| * service: hid: Implement SetNpadSystemExtStateEnabledgerman772024-01-073-8/+20
| |
| * service: hid: Implement CaptureButtonAssignmentgerman772024-01-073-8/+34
| |
* | Merge pull request #12599 from german77/settingsliamwhite2024-01-0811-370/+384
|\ \ | |/ |/| service: set: Use official names
| * service: set: Rename filesgerman772024-01-0711-11/+11
| |
| * service: set: Use official namesgerman772024-01-079-359/+373
| |
* | service: hid: Add functions needed by QlaunchNarr the Reg2024-01-062-6/+60
|/
* hid_core: Move hid to it's own subprojectNarr the Reg2024-01-0595-9717/+60
|
* Merge pull request #12557 from merryhime/termination-ipiliamwhite2024-01-041-4/+4
|\ | | | | KThread: Send termination interrupt to all cores a thread has affinity to
| * KThread: Send termination interrupt to all cores a thread has affinity toMerry2024-01-021-4/+4
| | | | | | | | | | KThread::RequestTerminate may run from a thread which is not the CurrentCore, and thus masking this out is erroneous.
* | service: hid: Remove data races when handling shared memoryNarr the Reg2024-01-0417-29/+45
| |
* | service: hid: Implement NpadResource and NpadDataNarr the Reg2024-01-0417-676/+1925
|/
* Merge pull request #12536 from german77/npad_interfaceliamwhite2024-01-0136-227/+698
|\ | | | | service: hid: Use applet resource to get latest shared memory handle
| * service: hid: Use applet resource to get latest shared memory handleNarr the Reg2023-12-3136-227/+698
| |
* | Merge pull request #12454 from liamwhite/ct-stuffNarr the Reg2024-01-017-46/+43
|\ \ | | | | | | core_timing: minor refactors
| * | core_timing: use static typing for no-wait unscheduleLiam2023-12-231-1/+2
| | |
| * | core_timing: remove user data valueLiam2023-12-237-46/+42
| | |
* | | Merge pull request #12466 from liamwhite/sh2Narr the Reg2024-01-013-12/+23
|\ \ \ | | | | | | | | core: track separate heap allocation for linux
| * | | core: track separate heap allocation for linuxLiam2023-12-263-12/+23
| | | |
* | | | Merge pull request #12513 from liamwhite/jit-fixNarr the Reg2024-01-013-18/+144
|\ \ \ \ | |_|_|/ |/| | | jit: use code memory handles correctly
| * | | jit: use code memory handles correctlyLiam2023-12-293-18/+144
| | | |
* | | | k_capabilities: simplify KTrace map skip logicLiam2023-12-281-2/+4
|/ / /
* | | Merge pull request #12455 from liamwhite/end-waitliamwhite2023-12-263-31/+10
|\ \ \ | | | | | | | | kernel: use simple mutex for object list container
| * | | kernel: use simple mutex for object list containerLiam2023-12-233-31/+10
| | |/ | |/|
* | | am/jit: reference memory instance from contextLiam2023-12-253-5/+7
| | |
* | | kernel: remove unecessary process member from handle tableLiam2023-12-252-6/+3
| | |
* | | service: fetch objects from the client handle tableLiam2023-12-2512-66/+45
| |/ |/|
* | kernel: fix resource limit imbalanceLiam2023-12-233-8/+7
| |
* | kernel: restrict nce to applicationsLiam2023-12-232-3/+2
| |
* | general: properly support multiple memory instancesLiam2023-12-2314-85/+72
| |
* | k_server_session: remove scratch buffer usage in favor of direct copyLiam2023-12-231-39/+124
| |
* | k_server_session: process for guest serversLiam2023-12-236-250/+1135
| |
* | kernel: instantiate memory separately for each guest processLiam2023-12-237-42/+41
|/
* service: hid: Fix crash on InitializeVibrationDeviceNarr the Reg2023-12-211-1/+1
|
* Merge pull request #12392 from liamwhite/modeFernando S2023-12-192-8/+17
|\ | | | | fs: implement OpenDirectoryMode
| * fs: implement OpenDirectoryModeLiam2023-12-182-8/+17
| |
* | Merge pull request #12304 from liamwhite/flinger-wtfFernando S2023-12-193-3/+37
|\ \ | | | | | | nvnflinger: mark buffer as acquired when acquired
| * | nvnflinger: mark buffer as acquired when acquiredLiam2023-12-163-3/+37
| | |
* | | Merge pull request #12349 from Kelebek1/return_system_channels_activeliamwhite2023-12-181-1/+1
|\ \ \ | |_|/ |/| | Have GetActiveChannelCount return the system channels instead of host device channels
| * | Have GetActiveChannelCount return the system channels instead of host device channelsKelebek12023-12-161-1/+1
| | |
* | | Merge pull request #12378 from liamwhite/offsetofliamwhite2023-12-162-0/+2
|\ \ \ | | | | | | | | set: add cstddef for offsetof macro
| * | | set: add cstddef for offsetof macroLiam2023-12-162-0/+2
| |/ /
* | | Merge pull request #12331 from liamwhite/layer-confusionliamwhite2023-12-168-42/+74
|\ \ \ | |/ / |/| | vi: fix confusion between closing and destroying layers
| * | vi: fix confusion between closing and destroying layersLiam2023-12-128-42/+74
| | |
* | | Merge pull request #12184 from Kelebek1/system_settingsliamwhite2023-12-1611-406/+1603
|\ \ \ | | | | | | | | Make system settings persistent across boots
| * | | Make system settings persistent across bootsKelebek12023-12-1611-406/+1603
| | |/ | |/|
* | | Merge pull request #12290 from liamwhite/deferred-path-splitliamwhite2023-12-161-5/+1
|\ \ \ | | | | | | | | Improve path splitting speed
| * | | Improve path splitting speedBreadFish642023-12-061-5/+1
| | | |
* | | | Merge pull request #12358 from liamwhite/optimized-allocliamwhite2023-12-162-8/+11
|\ \ \ \ | | | | | | | | | | common: use memory holepunching when clearing memory
| * | | | common: use memory holepunching when clearing memoryLiam2023-12-152-8/+11
| | |/ / | |/| |
* | | | Merge pull request #12359 from german77/real_sharedliamwhite2023-12-1639-867/+1064
|\ \ \ \ | | | | | | | | | | service: hid: Allow to create multiple instances of shared memory
| * | | | core: hid: Clean up headersNarr the Reg2023-12-1420-36/+16
| | | | |
| * | | | service: hid: Allow to create multiple instances of shared memoryNarr the Reg2023-12-1439-840/+1057
| |/ / /
* / / / ssl: fix output byte buffer size issue (#12372)liamwhite2023-12-161-3/+3
|/ / /
* | | Merge pull request #12333 from german77/aruid_freeliamwhite2023-12-126-13/+149
|\ \ \ | | | | | | | | service: hid: Improve CreateAppletResource implementation and free resources
| * | | service: hid: Improve CreateAppletResource implementation and free resourcesgerman772023-12-106-13/+149
| | |/ | |/|
* | | Merge pull request #12322 from liamwhite/savedata-absurdityliamwhite2023-12-111-1/+7
|\ \ \ | | | | | | | | fs: don't enumerate hidden savedata size file
| * | | fs: don't enumerate hidden savedata size fileLiam2023-12-091-1/+7
| | | |
* | | | Merge pull request #12327 from liamwhite/tipcliamwhite2023-12-112-7/+25
|\ \ \ \ | | | | | | | | | | sm:: fix tipc deserialization
| * | | | sm:: fix tipc deserializationLiam2023-12-102-7/+25
| | |/ / | |/| |
* | | | Merge pull request #12317 from liamwhite/sc-fixliamwhite2023-12-111-1/+1
|\ \ \ \ | | | | | | | | | | kernel: fix single core
| * | | | kernel: fix single coreLiam2023-12-091-1/+1
| | | | |
* | | | | Merge pull request #12321 from liamwhite/ro2liamwhite2023-12-1115-670/+1197
|\ \ \ \ \ | |_|/ / / |/| | | | ro: add separate ro service
| * | | | ro: add separate ro serviceLiam2023-12-098-634/+1141
| | | | |
| * | | | service: populate pid and handle table from clientLiam2023-12-093-13/+19
| | | | |
| * | | | service: use interface factory in server managerLiam2023-12-095-23/+37
| | |/ / | |/| |
* | | | Merge pull request #12296 from liamwhite/client-sessionliamwhite2023-12-106-105/+244
|\ \ \ \ | | | | | | | | | | kernel: implement remaining IPC syscalls
| * | | | kernel: implement remaining IPC syscallsLiam2023-12-066-105/+244
| | |/ / | |/| |
* | | | Merge pull request #12299 from liamwhite/light-ipcliamwhite2023-12-1017-20/+807
|\ \ \ \ | | | | | | | | | | kernel: implement light IPC
| * | | | kernel: implement light IPCLiam2023-12-0717-20/+807
| |/ / /
* | / / fbshare: set external format correctlyLiam2023-12-091-0/+1
| |/ / |/| |
* | | Merge pull request #12289 from german77/aruidliamwhite2023-12-099-13/+524
|\ \ \ | |/ / |/| | service: hid: Introduce proper AppletResource emulation
| * | service: hid: Introduce proper AppletResource emulationNarr the Reg2023-12-079-13/+524
| |/
* / core: refactor emulated cpu core activationLiam2023-12-0419-1786/+1894
|/
* Merge pull request #12255 from german77/amiiboliamwhite2023-12-021-5/+5
|\ | | | | service: nfc: Don't tag amiibos as corrupted if they are loaded as read only
| * service: nfc: Don't tag amiibos as corrupted if they are loaded as read onlyNarr the Reg2023-12-011-5/+5
| |
* | Merge pull request #12074 from GPUCode/yuwu-on-the-metalliamwhite2023-11-309-21/+109
|\ \ | |/ |/| Implement Native Code Execution (NCE)
| * general: fix mac compileLiam2023-11-271-1/+1
| |
| * Address more review commentsGPUCode2023-11-251-9/+2
| |
| * core: Define HAS_NCE macroGPUCode2023-11-255-5/+14
| |
| * Address some review commentsGPUCode2023-11-252-4/+2
| |
| * arm: Implement native code execution backendLiam2023-11-256-3/+60
| |
| * kernel: Manually specify aslr region startLiam2023-11-255-15/+20
| |
| * core: Respect memory permissions in MapGPUCode2023-11-251-3/+29
| |
* | Merge pull request #12203 from liamwhite/crash-fixliamwhite2023-11-291-1/+3
|\ \ | | | | | | set: don't load version nca with null romfs
| * | set: don't load version nca with null romfsLiam2023-11-271-1/+3
| | |
* | | Fixed controller applet crashing when on FW17+FrozenAra2023-11-274-3/+30
|/ /
* | Merge pull request #12183 from german77/justmiiliamwhite2023-11-274-34/+39
|\ \ | | | | | | service: nfc: Validate mii data
| * | service: nfc: Validate mii datagerman772023-11-264-34/+39
| |/
* | Merge pull request #12180 from german77/cabinetmiiliamwhite2023-11-261-1/+2
|\ \ | | | | | | service: am: Create random mii for cabinet applet
| * | service: am: Create random mii for cabinet appletgerman772023-11-261-1/+2
| |/
* | Merge pull request #12156 from german77/firmwarevsliamwhite2023-11-262-31/+59
|\ \ | | | | | | yuzu: Display firmware version
| * | yuzu: Display firmware versionNarr the Reg2023-11-242-31/+59
| | |
* | | time: undef GetCurrentTime for WindowsLiam2023-11-251-0/+5
| |/ |/|
* | Merge pull request #12076 from german77/resourceliamwhite2023-11-2329-1339/+1577
|\ \ | |/ |/| service: hid: Create appropriate hid resources
| * service: hid: Create appropriate hid resourcesNarr the Reg2023-11-2129-1339/+1577
| |
* | Merge pull request #12107 from daisymlleung/patch-1liamwhite2023-11-211-1/+12
|\ \ | |/ |/| Stub CheckBlockedUserListAvailability for Super Bomberman R 2
| * Stub CheckBlockedUserListAvailabilitydaisymlleung2023-11-201-1/+12
| |
* | Merge pull request #12011 from Macj0rdan/controller-appletNarr the Reg2023-11-2012-73/+539
|\ \ | |/ |/| Implemented qlaunch version of the controller applet
| * Implemented qlaunch version of the controller appletFrozenAra2023-11-1912-73/+539
| |
* | service: hid: Ensure resource manager is initializedSquall-Leonhart2023-11-201-1/+1
| | | | | | | | | | | | Ensures the proper initialization of the IActiveVibrationDeviceList. By using GetResourceManager() instead of resource_manager, we make sure that the IActiveVibrationDeviceListis initialized before it's used, preventing potential null issues. Fixes #12088
* | Merge pull request #11912 from liamwhite/nv-graphic-bufferliamwhite2023-11-1811-37/+70
|\ \ | | | | | | nvnflinger: use graphic buffer lifetime for map handle
| * | nvnflinger: use graphic buffer lifetime for map handleLiam2023-10-3011-37/+70
| | |
* | | Merge pull request #11917 from liamwhite/abandonmentliamwhite2023-11-188-21/+60
|\ \ \ | |_|/ |/| | nvnflinger: implement consumer abandonment
| * | nvnflinger: implement consumer abandonmentLiam2023-10-308-21/+60
| | |
* | | service: hid: Introduce firmware settings and update activate controller callsNarr the Reg2023-11-1711-54/+293
| | |
* | | service: hid: Implement xpad callsNarr the Reg2023-11-162-36/+139
| | |
* | | Merge pull request #12038 from german77/no_implementliamwhite2023-11-1611-3055/+3252
|\ \ \ | | | | | | | | service: hid: Split hid.cpp into individual interfaces
| * | | service: hid: Split hid.cpp into individual interfacesNarr the Reg2023-11-1511-3055/+3252
| | | |
* | | | Merge pull request #12007 from german77/moar_buttonsliamwhite2023-11-161-2/+4
|\ \ \ \ | |/ / / |/| | | core: hid: Split SL and SR buttons
| * | | core: hid: Split SL and SR buttonsgerman772023-11-121-2/+4
| | | |
* | | | fix apple clang build againLiam2023-11-141-2/+2
|/ / /
* | | Merge pull request #11980 from german77/momentliamwhite2023-11-126-17/+169
|\ \ \ | | | | | | | | service: irs: Implement moment image processor
| * | | service: irs: Implement moment image processorNarr the Reg2023-11-116-17/+169
| | | |
* | | | k_capabilities: ignore map region when KTrace is disabledLiam2023-11-111-0/+3
| | | |
* | | | k_page_table: fix shutdownLiam2023-11-101-7/+0
| | | |
* | | | k_page_table: use more precise icache invalidatesLiam2023-11-101-4/+9
| | | |
* | | | kernel: add KPageTableBaseLiam2023-11-1026-4811/+7111
|/ / / | | | | | | | | | Co-authored-by: Kelebek1 <eeeedddccc@hotmail.co.uk>
* | | Merge pull request #11896 from liamwhite/cropliamwhite2023-11-061-0/+2
|\ \ \ | | | | | | | | renderer_vulkan: fix cropping for presentation
| * | | renderer_vulkan: fix cropping for presentationLiam2023-10-281-0/+2
| | | |
* | | | Merge pull request #11873 from liamwhite/buffer-controlliamwhite2023-11-0618-428/+407
|\ \ \ \ | | | | | | | | | | nvdrv: add ioctl command serialization wrapper
| * | | | nvdrv: rework to remove memcpyLiam2023-10-2516-225/+243
| | | | |
| * | | | nvdrv: fix up remaining copy callsLiam2023-10-253-17/+22
| | | | |
| * | | | nvdrv: convert nvmapLiam2023-10-253-60/+26
| | | | |
| * | | | nvdrv: convert codec devicesLiam2023-10-256-34/+29
| | | | |
| * | | | nvdrv: convert nvhost_gpuLiam2023-10-252-76/+49
| | | | |
| * | | | nvdrv: convert nvhost_ctrlLiam2023-10-252-34/+29
| | | | |
| * | | | nvdrv: convert nvhost_ctrl_gpuLiam2023-10-252-97/+43
| | | | |
| * | | | nvdrv: add ioctl command serialization, convert nvhost_as_gpuLiam2023-10-255-71/+152
| | | | |
* | | | | service: am: Set the correct album program idgerman772023-11-061-2/+2
| | | | |
* | | | | Merge pull request #11969 from german77/profileliamwhite2023-11-051-9/+47
|\ \ \ \ \ | | | | | | | | | | | | service: acc: Ensure proper profile size
| * | | | | service: acc: Ensure proper profile sizegerman772023-11-051-9/+47
| | | | | |
* | | | | | Merge pull request #11961 from german77/recentliamwhite2023-11-051-0/+24
|\ \ \ \ \ \ | |/ / / / / |/| | | | | yuzu: Only store games in the recently played list
| * | | | | yuzu: Only store games in the recently played listgerman772023-11-051-0/+24
| | | | | |
* | | | | | Merge pull request #11960 from german77/silenceliamwhite2023-11-041-7/+5
|\ \ \ \ \ \ | | | | | | | | | | | | | | service: hid: Silence EnableUnintendedHomeButtonInputProtection
| * | | | | | service: hid: Silence EnableUnintendedHomeButtonInputProtectiongerman772023-11-041-7/+5
| |/ / / / /
* | | | | | Merge pull request #11881 from liamwhite/sockets-safe-accessliamwhite2023-11-042-41/+38
|\ \ \ \ \ \ | |/ / / / / |/| | | | | sockets: use safe access helpers
| * | | | | sockets: use safe access helpersLiam2023-10-252-41/+38
| |/ / / /
* | | | | Merge pull request #11948 from german77/hard_ringliamwhite2023-11-031-3/+3
|\ \ \ \ \ | | | | | | | | | | | | service: hid: Ensure GetNextEntryIndex can't fail
| * | | | | service: hid: Ensure GetNextEntryIndex can't failgerman772023-11-031-3/+3
| | |_|/ / | |/| | |
* | | | | Merge pull request #11947 from german77/batteryliamwhite2023-11-031-3/+3
|\ \ \ \ \ | | | | | | | | | | | | core: hid: Fix wrong battery values
| * | | | | core: hid: Fix wrong battery valuesgerman772023-11-031-3/+3
| |/ / / /
* | | | | Merge pull request #11936 from liamwhite/romfs-nonsenseliamwhite2023-11-031-2/+1
|\ \ \ \ \ | | | | | | | | | | | | romfs: fix extraction of single-directory root
| * | | | | romfs: fix extraction of single-directory rootLiam2023-11-011-2/+1
| |/ / / /
* | | | | Merge pull request #11929 from dima-xd/swkbd-appletliamwhite2023-10-312-2/+80
|\ \ \ \ \ | | | | | | | | | | | | service: am: Add support for LLE Software Keyboard Applet
| * | | | | service: am: Add support for LLE Software Keyboard AppletDzmitry Dubrova2023-10-312-2/+80
| |/ / / /
* | | | | Merge pull request #11892 from german77/pkm_screenshotliamwhite2023-10-316-17/+82
|\ \ \ \ \ | |/ / / / |/| | | | service: am: Implement ISelfController::SaveCurrentScreenshot
| * | | | service: am: Implement ISelfController::SaveCurrentScreenshotNarr the Reg2023-10-276-17/+82
| | |/ / | |/| |
* | | | Merge pull request #11911 from german77/leak_eventliamwhite2023-10-306-5/+26
|\ \ \ \ | |_|_|/ |/| | | core: Close all KEvents
| * | | core: Close all KEventsgerman772023-10-296-5/+26
| |/ /
* | | Merge pull request #11843 from liamwhite/sync-processliamwhite2023-10-2930-964/+1763
|\ \ \ | | | | | | | | kernel: update KProcess
| * | | kernel: fix extraneous refLiam2023-10-221-1/+0
| | | |
| * | | kernel: signal thread on termination completedLiam2023-10-221-4/+7
| | | |
| * | | kernel: add missing TLR clearLiam2023-10-221-0/+1
| | | |
| * | | kernel: update KProcessLiam2023-10-2230-960/+1756
| | | |
* | | | Merge pull request #11827 from liamwhite/preallocatedliamwhite2023-10-292-5/+6
|\ \ \ \ | |_|/ / |/| | | nvnflinger: fix reporting and freeing of preallocated buffers
| * | | nvnflinger: fix reporting and freeing of preallocated buffersLiam2023-10-202-5/+6
| | | | | | | | | | | | | | | | Co-authored-by: Kelebek1 <eeeedddccc@hotmail.co.uk>
* | | | cmake: prefer system stb headersAlexandre Bouvier2023-10-251-10/+10
| |_|/ |/| |
* | | Merge pull request #11812 from german77/save_captureliamwhite2023-10-258-13/+250
|\ \ \ | | | | | | | | service: caps: Implement SaveScreenShotEx0 and variants
| * | | service: caps: Implement SaveScreenShotEx0 and variantsgerman772023-10-238-13/+250
| | |/ | |/|
* / | service: ipc: Add third read buffer indexNarr the Reg2023-10-231-0/+6
|/ /
* | Merge pull request #11831 from liamwhite/hosversionbetweenliamwhite2023-10-221-19/+30
|\ \ | | | | | | set: return version info from system archive
| * | set: return version info from system archiveLiam2023-10-201-19/+30
| | |
* | | ts: add OpenSessionLiam2023-10-202-6/+40
|/ /
* | Merge pull request #11748 from liamwhite/kern_1700Fernando S2023-10-2015-223/+432
|\ \ | | | | | | kernel: update for 17.0.0
| * | kernel: fix format string errorLiam2023-10-201-1/+1
| | |
| * | kernel: make check fully constexpr for broken msvc constant foldingLiam2023-10-201-1/+1
| | |
| * | k_page_table: add MapFirstGroupLiam2023-10-203-34/+49
| | |
| * | kernel: update KMemoryRegionType valuesLiam2023-10-202-48/+80
| | |
| * | k_page_table: implement PermissionLockedLiam2023-10-206-26/+128
| | |
| * | k_page_table: add new CheckMemoryState helperLiam2023-10-202-12/+40
| | |
| * | kernel: split Io memory state, add PermissionLocked attributeLiam2023-10-205-92/+116
| | |
| * | kernel: reshuffle ini1 size, add slab clear noteLiam2023-10-204-10/+18
| |/
* / kernel: fix incorrect calculation of used non system memory valueLiam2023-10-201-1/+1
|/
* Merge pull request #11822 from german77/no-nameliamwhite2023-10-191-0/+1
|\ | | | | service: mii: Create random mii with name
| * service: mii: Create random mii with nameNarr the Reg2023-10-191-0/+1
| |
* | Merge pull request #11791 from german77/bufferxliamwhite2023-10-184-46/+70
|\ \ | |/ |/| service: hle: Allow to access read buffer A and X directly
| * service: hle: Allow to access read buffer A and X directlygerman772023-10-174-46/+70
| |
* | service: acc: Implement functions needed for profile select (#11653)Narr the Reg2023-10-176-8/+91
|/
* Merge pull request #11766 from liamwhite/open-sesameliamwhite2023-10-131-0/+5
|\ | | | | k_page_table: add missing page group open when locking memory
| * k_page_table: add missing page group open when locking memoryLiam2023-10-121-0/+5
| |
* | Merge pull request #11746 from liamwhite/relrliamwhite2023-10-131-2/+34
|\ \ | | | | | | jit: add support for relr-type relocations
| * | jit: add support for relr-type relocationsLiam2023-10-111-2/+34
| | |
* | | Merge pull request #11763 from liamwhite/lto-noinlineliamwhite2023-10-131-8/+8
|\ \ \ | | | | | | | | kernel: mark TLS accessors as noinline for non-MSVC LTO
| * | | kernel: mark TLS accessors as noinline for non-MSVC LTOLiam2023-10-121-8/+8
| |/ /
* | / service: caps: Remove ambiguous callNarr the Reg2023-10-121-2/+2
| |/ |/|
* | service: caps: Fix GetAlbumFileList3AaeAruid and GetAlbumFileList0AafeAruidDeprecatedNarr the Reg2023-10-125-51/+134
|/
* Merge pull request #11650 from german77/lle_albumFernando S2023-10-1027-244/+1168
|\ | | | | service: am: Add support for LLE Album Applet
| * service: caps: Implement album manager and reorganize serviceNarr the Reg2023-10-0819-519/+849
| |
| * service: Stub multiple functions to increase stability of album appletNarr the Reg2023-10-087-6/+144
| |
| * service: caps: Partially implement IAlbumAccessorServiceNarr the Reg2023-10-025-15/+450
| |
| * yuzu: Allow to launch album applet from firmwareNarr the Reg2023-10-022-0/+21
| |
* | kernel: implement transfer memoryLiam2023-10-055-17/+160
| |
* | ci: fix new codespell errorsLiam2023-10-031-1/+1
|/
* Merge pull request #11652 from liamwhite/shutdown-goes-brrrliamwhite2023-10-021-4/+8
|\ | | | | k_page_table: skip page table clearing on finalization
| * k_page_table: skip page table clearing on finalizationLiam2023-10-021-4/+8
| |
* | fsp-srv: enable auto save data creation on initLiam2023-10-021-0/+3
|/
* Merge pull request #11632 from german77/hle_cabinetliamwhite2023-10-0219-58/+899
|\ | | | | service: am: Add support for LLE Cabinet Applet
| * service: nfc: Implement SetRegisterInfoPrivate mii supportNarr the Reg2023-10-011-7/+2
| |
| * service: am: Implement shared bufferNarr the Reg2023-10-012-10/+125
| | | | | | | | Co-authored-by: Liam <byteslice@airmail.cc>
| * service: nvnflinger: Implement shared bufferNarr the Reg2023-10-0111-22/+570
| | | | | | | | Co-authored-by: Liam <byteslice@airmail.cc>
| * service: ldn: Implement lp2p:m and stub IMonitorServiceNarr the Reg2023-10-011-2/+89
| |
| * service: am: Set push in arguments according to the launched appletNarr the Reg2023-10-016-17/+113
| |
* | Merge pull request #11546 from Kelebek1/core_timing_mutexFernando S2023-09-291-1/+3
|\ \ | | | | | | Reduce core timing mutex contention
| * | Reduce core timing mutex contentionKelebek12023-09-201-1/+3
| | |
* | | Don't send a double focus change messageKelebek12023-09-291-3/+0
| |/ |/|
* | Merge pull request #11626 from german77/mii-fixliamwhite2023-09-285-4/+6
|\ \ | | | | | | service: mii: Fix reported bugs
| * | service: mii: Fix reported bugsgerman772023-09-285-4/+6
| | |
* | | fsp-srv: add GetFileSystemAttributeLiam2023-09-261-0/+41
|/ /
* | service: mii: Limit checks to string sizegerman772023-09-241-1/+1
| |
* | service: hid: Set last connected controller as activegerman772023-09-241-0/+1
| |
* | service: am: Stub to exit applet cleanlygerman772023-09-242-3/+31
| |
* | service: am: Implement stuff needed for Mii Editgerman772023-09-243-22/+238
| |
* | service: fsp: Implement CreateSaveDataFileSystemBySystemSaveDataId and OpenSaveDataFileSystemBySystemSaveDataIdgerman772023-09-242-2/+24
| |
* | service: ns: Implement GetSharedFontInOrderOfPriorityForSystemgerman772023-09-241-4/+13
| |
* | am: mii_edit: Implement DB operationsNarr the Reg2023-09-228-73/+139
|/
* Merge pull request #11526 from german77/mii_service_v2liamwhite2023-09-1918-244/+1857
|\ | | | | service: mii: Update implementation Part2 - Mii database support
| * service: mii: Address review commentsgerman772023-09-187-22/+24
| |
| * service: mii: Implement the rest of the servicegerman772023-09-183-103/+751
| |
| * service: mii: Implement database managergerman772023-09-182-0/+478
| |
| * service: mii: Implement figurine databasegerman772023-09-182-0/+208
| |
| * service: mii: Add device crc16german772023-09-181-0/+26
| |
| * service: nfc: Fully Implement GetRegisterInfoPrivategerman772023-09-181-3/+5
| |
| * service: mii: Complete structs and fix mistakesgerman772023-09-189-138/+387
| |
* | aoc: stub purchase info callsLiam2023-09-181-2/+18
|/
* mii_types: Remove null terminator checklat9nq2023-09-171-4/+1
| | | | | | | This is an OoB array access, causing a crash on at least the Linux Flatpak releases. Co-authored-by: german77 <juangerman-13@hotmail.com>
* Reimplement HardwareOpusKelebek12023-09-164-334/+427
|
* Merge pull request #11519 from german77/system-policyliamwhite2023-09-164-8/+52
|\ | | | | service: hid: Implement ApplyNpadSystemCommonPolicy
| * service: hid: Implement ApplyNpadSystemCommonPolicygerman772023-09-164-8/+52
| |
* | Merge pull request #11518 from german77/bad-npadliamwhite2023-09-163-36/+27
|\ \ | | | | | | service: hid: Implement last active Npad and fix some errors.
| * | hid: service: Remove outdated field from npadgerman772023-09-162-27/+14
| | |
| * | hid: service: Implement Last active Npadgerman772023-09-162-1/+5
| | |
| * | service: hid: Ensure state is correctgerman772023-09-161-8/+8
| |/
* | Merge pull request #11517 from german77/amiibo-formatliamwhite2023-09-161-6/+8
|\ \ | | | | | | service: nfc: Fix amiibo formatting
| * | service: nfc: Fix amiibo formattinggerman772023-09-161-6/+8
| |/
* | Merge pull request #11500 from liamwhite/debug-stuffliamwhite2023-09-164-4/+17
|\ \ | | | | | | core: improve debug workflow
| * | core: improve debug workflowLiam2023-09-144-4/+17
| | |
* | | Merge pull request #11483 from FearlessTobi/save-size-maxliamwhite2023-09-163-2/+15
|\ \ \ | |/ / |/| | am: Stub GetSaveDataSizeMax
| * | am: Stub GetSaveDataSizeMaxFearlessTobi2023-09-122-1/+14
| | | | | | | | | | | | Needed for Minecraft Legends.
| * | bsd: Demote "Select" log to dehugFearlessTobi2023-09-121-1/+1
| | | | | | | | | | | | This is very spammy in Minecraft Legends.
* | | ngc: implement serviceLiam2023-09-144-66/+154
| |/ |/|
* | Merge pull request #11480 from german77/mii_serviceliamwhite2023-09-1322-1939/+4451
|\ \ | | | | | | service: mii: Update implementation Part1
| * | service: mii: Remove most magic valuesNarr the Reg2023-09-1210-1069/+1537
| | |
| * | mii: service: Address reviewgerman772023-09-1112-103/+133
| | |
| * | mii: Prepare Interface for new implementationgerman772023-09-116-138/+210
| | |
| * | service: mii: Fix ver3 inconsistenciesgerman772023-09-119-217/+473
| | |
| * | service: mii: move char info operationsgerman772023-09-114-21/+576
| | |
| * | service: mii: Move store data operationsgerman772023-09-115-73/+512
| | |
| * | service: mii: Move core data operationsgerman772023-09-115-246/+730
| | |
| * | service: mii: Move ver3 operationsgerman772023-09-117-243/+241
| | |
| * | service: mii: separate mii types into their own filegerman772023-09-1119-539/+575
| | |
| * | service: mii: Move all raw data to it's filegerman772023-09-115-381/+479
| | |
| * | service: mii: Add mii util and resultgerman772023-09-114-11/+87
| |/
* | am: Implement UserChannel parametersFearlessTobi2023-09-101-10/+30
| | | | | | | | Used by the Super Mairo 3D All-Stars collection.
* | am: Remove bcat from PopLaunchParameterFearlessTobi2023-09-102-21/+5
|/ | | | | | This never belonged here and has no use anymore since the Boxcat backend was removed. .
* service: mii: Fix broken mii on MK8Narr the Reg2023-09-076-7/+118
|
* Merge pull request #11428 from Kelebek1/adsp_reworkliamwhite2023-09-064-5/+5
|\ | | | | Rework ADSP into a wrapper for apps
| * Rework ADSP into a wrapper for appsKelebek12023-09-044-5/+5
| |
* | Merge pull request #11434 from danilaml/fix-warningsliamwhite2023-09-063-4/+4
|\ \ | | | | | | msvc: set warning level to /W4 globally
| * | msvc: set warning level to /W4 globallyDanila Malyutin2023-09-033-4/+4
| |/ | | | | | | And fix a bunch of warnings
* | Merge pull request #11451 from german77/mob_miiliamwhite2023-09-063-105/+3
|\ \ | | | | | | service: mii: Fix default mii database
| * | service: mii: Fix default mii databasegerman772023-09-053-105/+3
| | |
* | | core: Add support for loading NSPs with personalized tickets. (#10048)Steveice102023-09-051-6/+4
|/ / | | | | | | Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com>
* | Merge pull request #11384 from liamwhite/am-shutdownliamwhite2023-09-021-2/+6
|\ \ | |/ |/| am: shorten shutdown timeout when lock is not held
| * am: shorten shutdown timeout when lock is not heldLiam2023-08-261-2/+6
| |
* | hwopus: Implement GetWorkBufferSizeExExFearlessTobi2023-08-302-1/+6
| | | | | | | | | | | | Allows Sea of Stars to boot. Fixes https://github.com/yuzu-emu/yuzu/issues/11415.
* | Merge pull request #11409 from liamwhite/splatoon-nsd-v2liamwhite2023-08-292-2/+21
|\ \ | | | | | | sfdnsres: ensure lp1 is not resolved
| * | sfdnsres: ensure lp1 is not resolvedLiam2023-08-282-2/+21
| | |
* | | hwopus: Implement OpenHardwareOpusDecoderForMultiStreamEx and DecodeInterleavedForMultiStreamFearlessTobi2023-08-272-3/+51
|/ / | | | | | | | | | | Allows MLB The Show 22 to boot. Fixes https://github.com/yuzu-emu/yuzu/issues/7911.
* | Merge pull request #11356 from lat9nq/console-mode-pgliamwhite2023-08-275-7/+8
|\ \ | |/ |/| general,config-qt: Present Console Mode as an enum with separate options in game properties
| * general: Use console mode helper across projectlat9nq2023-08-235-9/+6
| |
| * general: Convert use_docked_mode to an enumerationlat9nq2023-08-225-7/+11
| | | | | | | | Allows some special interactions with it in the Qt frontend.
* | Merge pull request #11370 from FearlessTobi/fix-filesizeliamwhite2023-08-261-1/+10
|\ \ | | | | | | filesystem: Return correct error for RenameFile when dest_path already exists
| * | filesystem: Return correct error for RenameFile when dest_path already existsFearlessTobi2023-08-241-1/+10
| |/ | | | | | | | | | | Allows Grid Autosport to boot. Fixes https://github.com/yuzu-emu/yuzu/issues/8287.
* | ssl: tolerate handshake without hostname set (#11328)liamwhite2023-08-263-24/+14
| |
* | kernel: offset code entry point for 39-bit address space type (#11326)liamwhite2023-08-252-5/+27
| |
* | nvhost_as_gpu: ensure mappings are aligned to big page size when deallocatedLiam2023-08-251-1/+3
| |
* | Merge pull request #11327 from liamwhite/skyline-2liamwhite2023-08-243-2/+10
|\ \ | |/ |/| sockets: avoid locking around socket session calls
| * sockets: avoid locking around socket session callsLiam2023-08-203-2/+10
| |
* | Merge pull request #11284 from liamwhite/nca-releaseFernando S2023-08-214-2/+11
|\ \ | |/ |/| vfs: expand support for NCA reading
| * fssystem: rework for yuzu styleLiam2023-08-151-2/+2
| |
| * vfs: expand support for NCA readingLiam2023-08-154-4/+13
| |
* | Merge pull request #11288 from liamwhite/svc-tickliamwhite2023-08-1811-33/+67
|\ \ | | | | | | kernel: remove relative task registration
| * | kernel: remove relative task registrationLiam2023-08-1511-33/+67
| |/
* / Improve behavior when sending to closed connectioncomex2023-08-162-0/+6
|/ | | | | | | | | | | - On Unix, this would previously kill the Yuzu process with SIGPIPE. Send MSG_NOSIGNAL to opt out of this. - Add support for the proper error code in this situation, EPIPE. - Windows has nonstandard behavior in this situation; translate it to the standard behavior. Kind of pointless, but isn't it nice to be correct?
* Merge pull request #11281 from liamwhite/vi-scale-modeliamwhite2023-08-142-0/+2
|\ | | | | nvnflinger: add missing scale mode
| * nvnflinger: add missing scale modeLiam2023-08-132-0/+2
| |
* | Merge pull request #11259 from german77/hidliamwhite2023-08-142-24/+60
|\ \ | | | | | | service: hid: Implement functions needed by QLaunch
| * | service: hid: Implement functions needed by QLaunchNarr the Reg2023-08-112-24/+60
| |/
* / ssl_backend_securetransport: remove stray .Code()Liam2023-08-121-1/+1
|/
* Merge pull request #11093 from liamwhite/result-ergonomicsbunnei2023-08-1033-553/+494
|\ | | | | core: remove ResultVal type
| * fs: return result on null outputsLiam2023-08-081-4/+24
| |
| * general: fix incorrect conversionsLiam2023-08-084-5/+5
| |
| * ssl: remove ResultVal useLiam2023-08-087-124/+127
| |
| * core: remove ResultVal typeLiam2023-08-0826-428/+346
| |
* | service: pctl: Partially revert 11221Narr the Reg2023-08-091-9/+15
|/
* Merge pull request #11217 from german77/olscliamwhite2023-08-071-6/+152
|\ | | | | service: olsc: Implement IOlscServiceForSystemService ITransferTaskListController interfaces for QLaunch
| * service: olsc: Implement IOlscServiceForSystemService ITransferTaskListController interfaces for QLaunchgerman772023-08-051-6/+152
| |
* | Merge pull request #11221 from german77/pctlliamwhite2023-08-071-18/+134
|\ \ | | | | | | service: pctl: Implement functions needed for QLaunch
| * | service: pctl: Implement functions needed for QLaunchgerman772023-08-051-18/+134
| |/
* | service: audctl: Stub functions needed by Qlaunchgerman772023-08-062-4/+64
| |
* | Merge pull request #11210 from german77/settingsliamwhite2023-08-055-119/+723
|\ \ | | | | | | service: set: Implement system settings for Qlaunch
| * | service: set: Add more system settings and address commentsNarr the Reg2023-08-052-7/+100
| | |
| * | service: set: Implement system settings for QlaunchNarr the Reg2023-08-035-114/+625
| |/
* / service: am: Fix wrong interfaceNarr the Reg2023-08-023-3/+55
|/
* Merge pull request #10839 from lat9nq/pgc-plusliamwhite2023-08-026-12/+31
|\ | | | | general: Reimplement per-game configurations
| * k_system_control: Always return some memory sizelat9nq2023-07-211-0/+2
| |
| * core,common: Give memory layout setting an enumlat9nq2023-07-211-4/+16
| | | | | | | | Allows for 6GB and 8GB layouts to be selected.
| * settings: Require time zone setting value for stirnglat9nq2023-07-211-1/+2
| |
| * configure_system: Implement with for looplat9nq2023-07-212-5/+7
| |
| * settings,core,config_sys: Remove optional type from custom_rtc, rng_seedlat9nq2023-07-212-2/+4
| | | | | | | | core: Fix MSVC errors
* | audren_u: Fix parameter alignmentMorph2023-08-011-2/+3
| | | | | | | | The reduction in size from 0x38 to 0x34 caused the parameter to be misaligned. Skipping 1 word fixes this.
* | tz_content_man: Generate the time zone binary oncelat9nq2023-07-302-8/+11
| | | | | | | | Fixes a memory leak with time zone binaries accumulating on theirselves.
* | Merge pull request #10990 from comex/ubsanliamwhite2023-07-264-6/+8
|\ \ | | | | | | Fixes and workarounds to make UBSan happier on macOS
| * | Fixes and workarounds to make UBSan happier on macOScomex2023-07-154-6/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There are still some other issues not addressed here, but it's a start. Workarounds for false-positive reports: - `RasterizerAccelerated`: Put a gigantic array behind a `unique_ptr`, because UBSan has a [hardcoded limit](https://stackoverflow.com/questions/64531383/c-runtime-error-using-fsanitize-undefined-object-has-a-possibly-invalid-vp) of how big it thinks objects can be, specifically when dealing with offset-to-top values used with multiple inheritance. Hopefully this doesn't have a performance impact. - `QueryCacheBase::QueryCacheBase`: Avoid an operation that UBSan thinks is UB even though it at least arguably isn't. See the link in the comment for more information. Fixes for correct reports: - `PageTable`, `Memory`: Use `uintptr_t` values instead of pointers to avoid UB from pointer overflow (when pointer arithmetic wraps around the address space). - `KScheduler::Reload`: `thread->GetOwnerProcess()` can be `nullptr`; avoid calling methods on it in this case. (The existing code returns a garbage reference to a field, which is then passed into `LoadWatchpointArray`, and apparently it's never used, so it's harmless in practice but still triggers UBSan.) - `KAutoObject::Close`: This function calls `this->Destroy()`, which overwrites the beginning of the object with junk (specifically a free list pointer). Then it calls `this->UnregisterWithKernel()`. UBSan complains about a type mismatch because the vtable has been overwritten, and I believe this is indeed UB. `UnregisterWithKernel` also loads `m_kernel` from the 'freed' object, which seems to be technically safe (the overwriting doesn't extend as far as that field), but seems dubious. Switch to a `static` method and load `m_kernel` in advance.
* | | Merge pull request #11095 from liamwhite/memory2liamwhite2023-07-242-14/+8
|\ \ \ | | | | | | | | memory: cleanup
| * | | core: reduce TOCTTOU memory accessLiam2023-07-222-14/+8
| | | |
* | | | core: implement GetGaiStringErrorRequest, IContextRegistrarLiam2023-07-2310-5/+115
|/ / /
* | | Merge pull request #11094 from liamwhite/getliamwhite2023-07-2220-158/+85
|\ \ \ | | | | | | | | kernel: misc cleanup of page table accessors
| * | | kernel: reduce page table region checkingLiam2023-07-157-85/+21
| | | |
| * | | k_process: PageTable -> GetPageTableLiam2023-07-1519-75/+66
| |/ /
* | | Merge pull request #11113 from liamwhite/nsd1bunnei2023-07-222-1/+17
|\ \ \ | | | | | | | | nsd: add GetApplicationServerEnvironmentType
| * | | nsd: add GetApplicationServerEnvironmentTypeLiam2023-07-182-1/+17
| | | |
* | | | core: remove remaining uses of dynamic_castLiam2023-07-221-2/+6
| |_|/ |/| |
* | | Merge pull request #11096 from german77/amiiboooliamwhite2023-07-217-54/+143
|\ \ \ | | | | | | | | service: nfc: Update Implementation to match with latest RE
| * | | service: nfc: Update Implementation to match with latest RENarr the Reg2023-07-177-54/+143
| | |/ | |/|
* | | Merge pull request #11116 from lat9nq/clang-shadowingliamwhite2023-07-192-5/+5
|\ \ \ | | | | | | | | general: Silence -Wshadow{,-uncaptured-local} warnings
| * | | general: Silence -Wshadow{,-uncaptured-local} warningslat9nq2023-07-192-5/+5
| | | | | | | | | | | | | | | | These occur in the latest commits in LLVM Clang.
* | | | Merge pull request #11114 from Kelebek1/warningsliamwhite2023-07-191-2/+2
|\ \ \ \ | |/ / / |/| | | Mark SetIdleTimeDetectionExtension logging as debug
| * | | Debug SetIdleTimeDetectionExtensionKelebek12023-07-181-2/+2
| |/ /
* | | ssl: Link with crypt32 for secure channel backendMorph2023-07-171-0/+1
| | |
* | | ssl: Reorder inclusionsMorph2023-07-175-24/+27
| | |
* | | network: Forward declarationsMorph2023-07-172-3/+5
| |/ |/|
* | Merge pull request #10912 from comex/sslliamwhite2023-07-1615-205/+2072
|\ \ | |/ |/| Implement SSL service
| * Rename variables to avoid -Wshadow warnings under GCCcomex2023-07-021-5/+5
| |
| * ...actually add the SecureTransport backend to Git.comex2023-07-021-0/+219
| |
| * Updates:comex2023-07-025-207/+268
| | | | | | | | | | - Address PR feedback. - Add SecureTransport backend for macOS.
| * Merge remote-tracking branch 'origin/master' into sslcomex2023-07-0258-436/+417
| |\
| * | PR feedback + constificationcomex2023-06-268-60/+62
| | |
| * | re-formatcomex2023-06-261-4/+5
| | |
| * | Fix more Windows build errorscomex2023-06-262-23/+30
| | | | | | | | | | | | | | | I did test this beforehand, but not on MinGW, and the error that showed up on the msvc builder didn't happen for me...
| * | ssl: fix compatibility with OpenSSL 1.1.1comex2023-06-261-1/+10
| | | | | | | | | | | | Turns out changes were needed after all.
| * | Fixes:comex2023-06-262-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Add missing virtual destructor on `SSLBackend`. - On Windows, filter out `POLLWRBAND` (one of the new flags added) when calling `WSAPoll`, because despite the constant being defined on Windows, passing it calls `WSAPoll` to yield `EINVAL`. - Reduce OpenSSL version requirement to satisfy CI; I haven't tested whether it actually builds (or runs) against 1.1.1, but if not, I'll figure it out. - Change an instance of memcpy to memmove, even though the arguments cannot overlap, to avoid a [strange GCC error](https://github.com/yuzu-emu/yuzu/pull/10912#issuecomment-1606283351).
| * | ssl: rename argument to avoid false positive codespell warningcomex2023-06-251-2/+2
| | | | | | | | | | | | | | | | | | The original name `larg` was copied from the OpenSSL documentation and is not a typo of 'large' but rather an abbreviation of '`long` argument'. But whatever, no harm in adding an underscore.
| * | Implement SSL servicecomex2023-06-2514-203/+1770
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This implements some missing network APIs including a large chunk of the SSL service, enough for Mario Maker (with an appropriate mod applied) to connect to the fan server [Open Course World](https://opencourse.world/). Connecting to first-party servers is out of scope of this PR and is a minefield I'd rather not step into. ## TLS TLS is implemented with multiple backends depending on the system's 'native' TLS library. Currently there are two backends: Schannel for Windows, and OpenSSL for Linux. (In reality Linux is a bit of a free-for-all where there's no one 'native' library, but OpenSSL is the closest it gets.) On macOS the 'native' library is SecureTransport but that isn't implemented in this PR. (Instead, all non-Windows OSes will use OpenSSL unless disabled with `-DENABLE_OPENSSL=OFF`.) Why have multiple backends instead of just using a single library, especially given that Yuzu already embeds mbedtls for cryptographic algorithms? Well, I tried implementing this on mbedtls first, but the problem is TLS policies - mainly trusted certificate policies, and to a lesser extent trusted algorithms, SSL versions, etc. ...In practice, the chance that someone is going to conduct a man-in-the-middle attack on a third-party game server is pretty low, but I'm a security nerd so I like to do the right security things. My base assumption is that we want to use the host system's TLS policies. An alternative would be to more closely emulate the Switch's TLS implementation (which is based on NSS). But for one thing, I don't feel like reverse engineering it. And I'd argue that for third-party servers such as Open Course World, it's theoretically preferable to use the system's policies rather than the Switch's, for two reasons 1. Someday the Switch will stop being updated, and the trusted cert list, algorithms, etc. will start to go stale, but users will still want to connect to third-party servers, and there's no reason they shouldn't have up-to-date security when doing so. At that point, homebrew users on actual hardware may patch the TLS implementation, but for emulators it's simpler to just use the host's stack. 2. Also, it's good to respect any custom certificate policies the user may have added systemwide. For example, they may have added custom trusted CAs in order to use TLS debugging tools or pass through corporate MitM middleboxes. Or they may have removed some CAs that are normally trusted out of paranoia. Note that this policy wouldn't work as-is for connecting to first-party servers, because some of them serve certificates based on Nintendo's own CA rather than a publicly trusted one. However, this could probably be solved easily by using appropriate APIs to adding Nintendo's CA as an alternate trusted cert for Yuzu's connections. That is not implemented in this PR because, again, first-party servers are out of scope. (If anything I'd rather have an option to _block_ connections to Nintendo servers, but that's not implemented here.) To use the host's TLS policies, there are three theoretical options: a) Import the host's trusted certificate list into a cross-platform TLS library (presumably mbedtls). b) Use the native TLS library to verify certificates but use a cross-platform TLS library for everything else. c) Use the native TLS library for everything. Two problems with option a). First, importing the trusted certificate list at minimum requires a bunch of platform-specific code, which mbedtls does not have built in. Interestingly, OpenSSL recently gained the ability to import the Windows certificate trust store... but that leads to the second problem, which is that a list of trusted certificates is [not expressive enough](https://bugs.archlinux.org/task/41909) to express a modern certificate trust policy. For example, Windows has the concept of [explicitly distrusted certificates](https://learn.microsoft.com/en-us/previous-versions/windows/it-pro/windows-server-2012-r2-and-2012/dn265983(v=ws.11)), and macOS requires Certificate Transparency validation for some certificates with complex rules for when it's required. Option b) (using native library just to verify certs) is probably feasible, but it would miss aspects of TLS policy other than trusted certs (like allowed algorithms), and in any case it might well require writing more code, not less, compared to using the native library for everything. So I ended up at option c), using the native library for everything. What I'd *really* prefer would be to use a third-party library that does option c) for me. Rust has a good library for this, [native-tls](https://docs.rs/native-tls/latest/native_tls/). I did search, but I couldn't find a good option in the C or C++ ecosystem, at least not any that wasn't part of some much larger framework. I was surprised - isn't this a pretty common use case? Well, many applications only need TLS for HTTPS, and they can use libcurl, which has a TLS abstraction layer internally but doesn't expose it. Other applications only support a single TLS library, or use one of the aforementioned larger frameworks, or are platform-specific to begin with, or of course are written in a non-C/C++ language, most of which have some canonical choice for TLS. But there are also many applications that have a set of TLS backends just like this; it's just that nobody has gone ahead and abstracted the pattern into a library, at least not a widespread one. Amusingly, there is one TLS abstraction layer that Yuzu already bundles: the one in ffmpeg. But it is missing some features that would be needed to use it here (like reusing an existing socket rather than managing the socket itself). Though, that does mean that the wiki's build instructions for Linux (and macOS for some reason?) already recommend installing OpenSSL, so no need to update those. ## Other APIs implemented - Sockets: - GetSockOpt(`SO_ERROR`) - SetSockOpt(`SO_NOSIGPIPE`) (stub, I have no idea what this does on Switch) - `DuplicateSocket` (because the SSL sysmodule calls it internally) - More `PollEvents` values - NSD: - `Resolve` and `ResolveEx` (stub, good enough for Open Course World and probably most third-party servers, but not first-party) - SFDNSRES: - `GetHostByNameRequest` and `GetHostByNameRequestWithOptions` - `ResolverSetOptionRequest` (stub) ## Fixes - Parts of the socket code were previously allocating a `sockaddr` object on the stack when calling functions that take a `sockaddr*` (e.g. `accept`). This might seem like the right thing to do to avoid illegal aliasing, but in fact `sockaddr` is not guaranteed to be large enough to hold any particular type of address, only the header. This worked in practice because in practice `sockaddr` is the same size as `sockaddr_in`, but it's not how the API is meant to be used. I changed this to allocate an `sockaddr_in` on the stack and `reinterpret_cast` it. I could try to do something cleverer with `aligned_storage`, but casting is the idiomatic way to use these particular APIs, so it's really the system's responsibility to avoid any aliasing issues. - I rewrote most of the `GetAddrInfoRequest[WithOptions]` implementation. The old implementation invoked the host's getaddrinfo directly from sfdnsres.cpp, and directly passed through the host's socket type, protocol, etc. values rather than looking up the corresponding constants on the Switch. To be fair, these constants don't tend to actually vary across systems, but still... I added a wrapper for `getaddrinfo` in `internal_network/network.cpp` similar to the ones for other socket APIs, and changed the `GetAddrInfoRequest` implementation to use it. While I was at it, I rewrote the serialization to use the same approach I used to implement `GetHostByNameRequest`, because it reduces the number of size calculations. While doing so I removed `AF_INET6` support because the Switch doesn't support IPv6; it might be nice to support IPv6 anyway, but that would have to apply to all of the socket APIs. I also corrected the IPC wrappers for `GetAddrInfoRequest` and `GetAddrInfoRequestWithOptions` based on reverse engineering and hardware testing. Every call to `GetAddrInfoRequestWithOptions` returns *four* different error codes (IPC status, getaddrinfo error code, netdb error code, and errno), and `GetAddrInfoRequest` returns three of those but in a different order, and it doesn't really matter but the existing implementation was a bit off, as I discovered while testing `GetHostByNameRequest`. - The new serialization code is based on two simple helper functions: ```cpp template <typename T> static void Append(std::vector<u8>& vec, T t); void AppendNulTerminated(std::vector<u8>& vec, std::string_view str); ``` I was thinking there must be existing functions somewhere that assist with serialization/deserialization of binary data, but all I could find was the helper methods in `IOFile` and `HLERequestContext`, not anything that could be used with a generic byte buffer. If I'm not missing something, then maybe I should move the above functions to a new header in `common`... right now they're just sitting in `sfdnsres.cpp` where they're used. - Not a fix, but `SocketBase::Recv`/`Send` is changed to use `std::span<u8>` rather than `std::vector<u8>&` to avoid needing to copy the data to/from a vector when those methods are called from the TLS implementation.
* | | Merge pull request #10985 from liamwhite/handle-translatebunnei2023-07-122-7/+770
|\ \ \ | | | | | | | | k_server_session: translate special header for non-HLE requests
| * | | k_server_session: translate special header for non-HLE requestsLiam2023-07-082-7/+770
| | | |
* | | | Merge pull request #10996 from Kelebek1/readblock_optimisationbunnei2023-07-111-10/+22
|\ \ \ \ | |/ / / |/| | | Use spans over guest memory where possible instead of copying data
| * | | Use spans over guest memory where possible instead of copying data.Kelebek12023-07-031-10/+22
| | | |
* | | | service: nfc: Ensure controller is in the correct modegerman772023-07-031-11/+21
|/ / /
* | | Merge pull request #10969 from Morph1984/k-synchronizeliamwhite2023-07-023-36/+52
|\ \ \ | | | | | | | | kernel: Synchronize
| * | | kernel: SynchronizeMorph2023-07-013-36/+52
| | |/ | |/|
* | | parcel: Optimize small_vector sizesMorph2023-07-011-11/+13
| | |
* | | general: Use ScratchBuffer where possibleMorph2023-07-016-45/+53
|/ /
* | Merge pull request #10859 from liamwhite/no-more-atomic-waitliamwhite2023-06-234-18/+10
|\ \ | | | | | | general: remove atomic signal and wait
| * | general: remove atomic signal and waitLiam2023-06-224-18/+10
| | |
* | | Merge pull request #10842 from german77/native_mifareliamwhite2023-06-237-116/+109
|\ \ \ | | | | | | | | input_common: Implement native mifare/skylander support for joycons/pro controller
| * | | input_common: Implement native mifare supportNarr the Reg2023-06-227-116/+109
| | | |
* | | | Remove memory allocations in some hot pathsKelebek12023-06-2237-275/+270
| |/ / |/| |
* | | Merge pull request #10086 from Morph1984/coretiming-ng-1bunnei2023-06-2211-27/+24
|\ \ \ | | | | | | | | core_timing: Use CNTPCT as the guest CPU tick
| * | | nvdisp: Fix SingleCore frametime reportingMorph2023-06-081-1/+1
| | | |
| * | | core_timing: Fix SingleCore cycle timerMorph2023-06-081-9/+1
| | | |
| * | | time: Use compile time division for TimeSpanType conversionMorph2023-06-085-11/+15
| | | |
| * | | core_timing: Use CNTPCT as the guest CPU tickMorph2023-06-083-5/+5
| | | | | | | | | | | | | | | | | | | | Previously, we were mixing the raw CPU frequency and CNTFRQ. The raw CPU frequency (1020 MHz) should've never been used as CNTPCT (whose frequency is CNTFRQ) is the only counter available.
| * | | nvnflinger: Acquire lock prior to signaling the vsync variableMorph2023-06-081-1/+2
| | | |
* | | | time_zone_manager: Add null terminatorlat9nq2023-06-201-2/+4
| | | | | | | | | | | | | | | | We aren't null-terminating this string after the copy, and we need to.
* | | | time_zone_manager: Stop on commalat9nq2023-06-201-1/+3
| |_|/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is a deviation from the reference time zone implementation. The actual code will set a pointer to the time zone name here, but for us we have a limited number of characters to work with, and the name of the time zone here could be larger than 8 characters. We can make the assumption that time zone names greater than five characters in length include a comma that denotes more data. Nintendo just truncates that data for the name, so we can do the same. time_zone_manager: Check for length of array Just to be double sure that we never break past the array length, directly compare against it.
* | | Merge pull request #10797 from lat9nq/tzdb-patchbunnei2023-06-182-10/+5
|\ \ \ | | | | | | | | time: Various time zone fixes
| * | | time_zone_service: Always write time zone rule datalat9nq2023-06-181-8/+2
| | | | | | | | | | | | | | | | | | | | Switch firmware will initialize this data even if the given parameters are invalid. We should do the same.
| * | | time_zone_manager: Compare to the correct booleanlat9nq2023-06-161-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reference implementation does not compare the booleans as we had them. Use the correct ones as in the reference. Also adds an assert. I have been made aware of a crash here and am not able to reproduce currently.
* | | | k_thread: Use a mutex and cond_var to sync boollat9nq2023-06-172-5/+14
| |_|/ |/| | | | | | | | | | | std::atomic<bool> is broken on MinGW and causes deadlocks there. Use a normal cond var in its stead.
* | | service: nfc: Read tag protocol only for nfc backendNarr the Reg2023-06-152-5/+6
| | |
* | | service: nfc: Accuracy fixesNarr the Reg2023-06-1510-110/+192
|/ /
* | Merge pull request #10603 from lat9nq/tz-more-completebunnei2023-06-137-50/+232
|\ \ | | | | | | core,common: Implement missing time zone data/computations
| * | tz_manager: Fix comparison to wrong integerlat9nq2023-06-051-1/+1
| | |
| * | tz_manager: Implement missing transition timeslat9nq2023-06-051-1/+59
| | | | | | | | | | | | time_zone_manager: Use s64 storage
| * | tz_manager: Warn on unimplemented codelat9nq2023-06-051-0/+7
| | |
| * | tz_manager: Fix character offset not advancinglat9nq2023-06-051-0/+1
| | |
| * | tz_manager: Fix off-by-one errorlat9nq2023-06-051-4/+4
| | |
| * | time: Implement missing servicesNarr the Reg2023-06-057-11/+106
| | | | | | | | | | | | | | | | | | | | | Implements GetTotalLocationNameCount LoadLocationNameList and GetTimeZoneRuleVersion. tz-manager: Fix sign issue
| * | time_zone_manager: Implement go_ahead/go_backlat9nq2023-06-051-1/+39
| | |
| * | tz_content_manager: Try the system time zone firstlat9nq2023-06-051-2/+9
| | | | | | | | | | | | | | | If we can't find the normal time zone string, try searching for the closest one.
| * | time: Remove auto timezone considerationlat9nq2023-06-053-33/+3
| | | | | | | | | | | | | | | GetTimeZoneString no longer reports a setting unique to yuzu, so we can assume a valid timezone string in core.
| * | time_manager: Don't offset RTC by system time zonelat9nq2023-06-051-5/+1
| | | | | | | | | | | | | | | | | | | | | This causes the emulated system's universal time to be on the user's clock, and the user time to be off if they set a time zone. time_manager: Remove GetExternalRtcTime
| * | tz_content_manager: Detect system time zonelat9nq2023-06-051-1/+11
| | | | | | | | | | | | | | | | | | Uses C++20 tzdb to determine the system timezone. The switch uses the 597 posix time zones, so this needs tests if the system time zone isn't posix-compliant.
* | | Merge pull request #10623 from german77/backupliamwhite2023-06-097-39/+181
|\ \ \ | | | | | | | | service: nfc: Add backup support
| * | | service: nfc: Add backup supportgerman772023-06-077-39/+181
| | |/ | |/|
* / | nvnflinger: allow locking framerate during video playbackLiam2023-06-082-2/+6
|/ /
* | Merge pull request #10508 from yuzu-emu/limebunnei2023-06-062-0/+6
|\ \ | |/ |/| Project Lime - yuzu Android Port
| * service: account: Save user profile folder on first user creationgerman772023-06-031-0/+1
| |
| * device_memory: Use smaller virtual reservation size for compatibility with 39-bit pagingLiam2023-06-031-0/+5
| |
* | fsp-srv: avoid patching romfs multiple timesLiam2023-06-031-8/+12
|/
* Fix incorrect id check and potential out of bounds lookupKelebek12023-05-311-1/+1
|
* Merge pull request #10396 from german77/amiibo_writebunnei2023-05-251-4/+4
|\ | | | | input_common: Implement amiibo writing
| * input_common: Implement amiibo writtingNarr the Reg2023-05-221-4/+4
| |
* | Merge pull request #10415 from german77/amiibo-no-keybunnei2023-05-253-21/+52
|\ \ | | | | | | service: nfc: Remove encryption key requirement
| * | service: nfc: Remove encryption key requirementNarr the Reg2023-05-233-21/+52
| |/
* / k_memory_block_manager: remove auditing callsLiam2023-05-231-6/+2
|/
* service: hid: Use span instead of vector referencegerman772023-05-153-14/+14
|
* Merge pull request #10244 from liamwhite/lower-upperFernando S2023-05-133-2/+34
|\ | | | | time: implement ContinuousAdjustmentTimePoint
| * time: implement ContinuousAdjustmentTimePointLiam2023-05-123-2/+34
| |
* | Merge pull request #10237 from liamwhite/cache-storagebunnei2023-05-134-4/+48
|\ \ | | | | | | fs: stub cache storage
| * | fs: adjust future save pathLiam2023-05-111-2/+2
| | |
| * | am: stub CreateCacheStorageLiam2023-05-112-1/+33
| | |
| * | fs: stub cache storage and fix params alignmentLiam2023-05-112-5/+17
| |/
* | nvnflinger: fix Parcel serializationLiam2023-05-113-39/+49
| |
* | nvnflinger: fix producer slot fence initLiam2023-05-111-0/+1
|/
* service: nfc: Seed all random valuesNarr the Reg2023-05-102-6/+14
|
* service: nfp: Allow to load with a different amiibo idgerman772023-05-101-4/+13
|
* Merge pull request #10075 from Kelebek1/silence_nifm_spambunnei2023-05-081-3/+3
|\ | | | | Silence network spam
| * Silence nifm spamKelebek12023-04-221-3/+3
| |
* | core: hid: Update motion on a better placegerman772023-05-081-2/+2
| |
* | Merge pull request #10097 from german77/nfp_fullbunnei2023-05-0727-2596/+2217
|\ \ | | | | | | service: nfc: Merge device interfaces and create the device manager
| * | service: nfc: Merge device interfaces and create the device managerNarr the Reg2023-05-0625-2374/+1994
| | |
| * | core: service: Add FunctionInfoTyped to allow expanding existing interfacesgerman772023-04-261-8/+12
| | |
| * | service: nfc: Create mifare interfaceNarr the Reg2023-04-243-50/+58
| | |
| * | service: nfc: Create interfaceNarr the Reg2023-04-245-115/+104
| | |
* | | Merge pull request #10117 from liamwhite/sync-registerbunnei2023-05-038-5/+49
|\ \ \ | | | | | | | | kernel: match calls to Register and Unregister
| * | | kernel: match calls to Register and UnregisterLiam2023-04-308-5/+49
| | | |
* | | | Merge pull request #10124 from liamwhite/pebkacMorph2023-05-031-3/+4
|\ \ \ \ | | | | | | | | | | settings: rename extended memory layout to unsafe, move from general to system
| * | | | settings: rename extended memory layout to unsafe, move from general to systemLiam2023-04-301-3/+4
| |/ / /
* / / / kernel: remove general boost listsLiam2023-04-307-19/+26
|/ / /
* | | Merge pull request #10056 from vonchenplus/audout_uFernando S2023-04-241-6/+8
|\ \ \ | |/ / |/| | core: audio: return result when audio_out initialize failed
| * | core: audio: return result when audio_out initialize failedFengChen2023-04-161-6/+8
| | |
* | | core: am: Demote TryPopFromFriendInvitationStorageChannel Log levelgerman772023-04-221-1/+1
| |/ |/|
* | service: nfp: Implement debug InterfaceNarr the Reg2023-04-156-8/+444
| |
* | service: nfp: Implement system interfaceNarr the Reg2023-04-156-17/+289
| |
* | service: nfp: Use an unique interfaceNarr the Reg2023-04-143-69/+225
|/
* kernel: move more memory to application in 8GB arrangementLiam2023-04-101-2/+4
|
* kernel: switch extended memory setting to 8GB arrangementLiam2023-04-081-2/+2
|
* service: hid: Fix handle validationgerman772023-04-021-5/+1
|
* Merge pull request #10006 from german77/profile_selectliamwhite2023-04-012-14/+140
|\ | | | | service: am: Improve profile select applet
| * service: am: Improve profile select appletNarr the Reg2023-03-292-14/+140
| |
* | Merge pull request #9997 from german77/cancel_controllerliamwhite2023-04-012-7/+14
|\ \ | | | | | | applet: controller: Implement cancel button
| * | applet: controller: Implement cancel buttongerman772023-03-302-7/+14
| |/
* | Merge pull request #9999 from german77/new_hid_hurraliamwhite2023-04-014-22/+56
|\ \ | | | | | | service: hid: Implement SetNpadJoyAssignmentModeSingleWithDestination
| * | service: hid: Implement SetNpadJoyAssignmentModeSingleWithDestinationgerman772023-03-304-22/+56
| | | | | | | | | | | | Used by Let's Get Fit
* | | Merge pull request #10005 from liamwhite/kernel-atomicsbunnei2023-04-012-39/+56
|\ \ \ | |_|/ |/| | kernel: fix unbounded stack usage in atomics
| * | kernel: fix unbounded stack usage in atomicsLiam2023-03-292-39/+56
| | |
* | | Merge pull request #9505 from liamwhite/request-exitliamwhite2023-03-2918-1/+71
|\ \ \ | |/ / |/| | applets: implement RequestExit
| * | qt: implement RequestExit for appletsLiam2023-03-258-9/+9
| | |
| * | applets: implement RequestExitLiam2023-03-2518-1/+71
| |/
* | Merge pull request #10003 from german77/disconnectliamwhite2023-03-281-1/+2
|\ \ | | | | | | service: hid: Silence warning on MergeSingleJoyAsDualJoy
| * | service: hid: Silence warning on MergeSingleJoyAsDualJoyNarr the Reg2023-03-271-1/+2
| |/
* | Merge pull request #9984 from liamwhite/global-memoryliamwhite2023-03-2728-103/+129
|\ \ | | | | | | memory: rename global memory references to application memory
| * | memory: rename global memory references to application memoryLiam2023-03-2428-103/+129
| | |
* | | service: nfp: Add plain amiibo supportgerman772023-03-265-8/+37
| |/ |/|
* | Merge pull request #9981 from german77/nfp_connectliamwhite2023-03-244-4/+30
|\ \ | |/ |/| nfc: Initialize device when controller is connected
| * nfc: Initialize device when controller is connectedNarr the Reg2023-03-224-4/+30
| |
* | Merge pull request #9964 from liamwhite/typed-addressliamwhite2023-03-2381-862/+967
|\ \ | | | | | | kernel: use KTypedAddress for addresses
| * | kernel: use KTypedAddress for addressesLiam2023-03-2281-862/+967
| | |
* | | kernel: fix LOG_TRACE in ipcLiam2023-03-191-1/+1
| |/ |/|
* | service: nfp: Replace crc function with boost equivalentNarr the Reg2023-03-172-28/+17
| |
* | service: nfp: Close app area and recreate crcNarr the Reg2023-03-161-0/+10
| |
* | service: nfp: Convert mii colors to v3Narr the Reg2023-03-166-15/+100
| |
* | service: nfp: Actually write correct crcNarr the Reg2023-03-156-23/+44
|/
* kernel: additional style fixes to KThread, KProcessLiam2023-03-132-27/+27
|
* kernel: fix clang buildLiam2023-03-131-2/+2
|
* kernel: remove unnecessary finalize callsLiam2023-03-132-7/+1
|
* kernel: convert KProcess to new styleLiam2023-03-137-236/+250
|
* kernel: convert KThread to new styleLiam2023-03-1311-560/+510
|
* kernel: prefer std::addressofLiam2023-03-1321-134/+139
|
* kernel: convert KResourceLimitLiam2023-03-132-59/+59
|
* kernel: remove kernel_Liam2023-03-1341-295/+290
|
* kernel: remove gratitutous attribute usageLiam2023-03-138-29/+24
|
* kernel/svc: convert to new styleLiam2023-03-1321-304/+192
|
* kernel: convert miscellaneousLiam2023-03-137-94/+81
|
* kernel: conver KScopedLock, KScopedResourceReservation, KSessionRequest, KSharedMemory, KSpinLockLiam2023-03-139-97/+99
|
* kernel: convert KAbstractSchedulerLockLiam2023-03-131-31/+24
|
* kernel: convert KMemoryLayout, KMemoryRegion*, KPageTableSlabHeap, KPriorityQueueLiam2023-03-136-121/+121
|
* kernel: move KMemoryLayout for NX boardLiam2023-03-131-0/+0
|
* kernel: remove KLinkedListLiam2023-03-134-244/+0
|
* kernel: convert KConditionVariable, KLightConditionVariable, KLightLockLiam2023-03-137-75/+77
|
* kernel: convert KPort, KSessionLiam2023-03-1327-223/+194
|
* kernel: convert GlobalSchedulerContext, KAddressArbiter, KScopedSchedulerLockAndSleep, KThreadQueue to new styleLiam2023-03-138-142/+130
|
* general: fix spelling mistakesLiam2023-03-1214-16/+16
|
* Merge pull request #9923 from liamwhite/khtliamwhite2023-03-108-15/+42
|\ | | | | kernel: add timer pointer to KThreadQueue
| * kernel: add timer pointer to KThreadQueueLiam2023-03-088-15/+42
| |
* | Merge pull request #9928 from german77/super_nfpliamwhite2023-03-105-52/+234
|\ \ | | | | | | service: nfp: Improve implementation
| * | service: nfp: Improve implementationNarr the Reg2023-03-105-52/+234
| | |
* | | Merge pull request #9917 from Morph1984/the-real-timeliamwhite2023-03-102-5/+5
|\ \ \ | | | | | | | | native_clock: Re-adjust the RDTSC frequency to its real frequency
| * | | hid: Use nanosecond timestamps instead of ticksMorph2023-03-082-5/+5
| | |/ | |/|
* | | Merge pull request #9916 from liamwhite/fpuliamwhite2023-03-093-1/+28
|\ \ \ | |_|/ |/| | kernel: clone fpu status on CreateThread
| * | kernel: clone fpu status on CreateThreadLiam2023-03-083-1/+28
| |/
* | Merge pull request #9912 from liamwhite/errliamwhite2023-03-0821-118/+105
|\ \ | | | | | | hle: rename legacy errors to Results
| * | hle: rename legacy errors to ResultsLiam2023-03-0721-118/+105
| |/
* | Merge pull request #9904 from liamwhite/wsliamwhite2023-03-081-16/+29
|\ \ | | | | | | kernel: fix WaitSynchronization
| * | kernel: fix WaitSynchronizationLiam2023-03-051-16/+29
| | |
* | | Merge pull request #9921 from liamwhite/overrideMorph2023-03-083-5/+5
|\ \ \ | | | | | | | | general: fix type inconsistencies
| * | | general: fix type inconsistenciesLiam2023-03-083-5/+5
| | |/ | |/|
* / | kernel: avoid signed overflow UB on MSVCLiam2023-03-081-1/+2
|/ /
* | Merge pull request #9910 from jbeich/libc++liamwhite2023-03-061-0/+1
|\ \ | | | | | | kernel: add missing header for libc++
| * | kernel: add missing header for libc++Jan Beich2023-03-061-0/+1
| |/ | | | | | | | | | | | | | | In file included from src/core/hle/kernel/k_light_lock.cpp:4: In file included from src/./core/hle/kernel/k_light_lock.h:8: src/./core/hle/kernel/k_scoped_lock.h:25:51: error: no member named 'addressof' in namespace 'std' explicit KScopedLock(T& l) : KScopedLock(std::addressof(l)) {} ~~~~~^
* | service: psc: Update namesNarr the Reg2023-03-051-9/+9
| |
* | service: ssl: Add missing properties and update namesNarr the Reg2023-03-051-18/+58
| |
* | service: usb: Update namesNarr the Reg2023-03-051-35/+35
|/
* Merge pull request #9884 from liamwhite/service-cleanupMorph2023-03-04175-2037/+1970
|\ | | | | service: miscellaneous cleanups
| * nvnflinger: fix nameLiam2023-03-0150-311/+310
| |
| * service: move hle_ipc from kernelLiam2023-03-01145-1725/+1660
| |
| * sm:: remove unused memberLiam2023-03-011-1/+0
| |
* | kernel: be more careful about kernel address keysLiam2023-03-015-11/+23
| |
* | kernel: refactor priority inheritance to represent locks as C++ objectsLiam2023-03-018-190/+436
| |
* | kernel: simplify AddressSpaceInfo, update valuesLiam2023-03-011-66/+13
| |
* | kernel: barrier memory before condition variable writeLiam2023-03-011-15/+15
| |
* | kernel: document previous location of interrupt disables in arbiter/condvarLiam2023-03-012-3/+9
| |
* | kernel: adjust pool allocationsLiam2023-03-012-7/+16
| |
* | kernel: simplify KAbstractSchedulerLock::LockLiam2023-03-011-5/+6
| |
* | kernel: add InfoType::IoRegionHintLiam2023-03-011-0/+1
|/
* Merge pull request #9832 from liamwhite/hle-mpliamwhite2023-03-01135-1140/+1538
|\ | | | | service: HLE multiprocess
| * sm:: fix lingering session initialization issuesLiam2023-02-212-2/+19
| |
| * sm:: support service registration deferralLiam2023-02-215-8/+151
| |
| * service: refactor server architectureLiam2023-02-21135-1135/+1373
| | | | | | | | Converts services to have their own processes
* | Merge pull request #9859 from liamwhite/tmem-useliamwhite2023-02-2821-75/+95
|\ \ | | | | | | service: avoid direct pointer access of transfer memory objects
| * | am: avoid direct pointer access of transfer memory objectsLiam2023-02-241-6/+4
| | |
| * | hid: avoid direct pointer access of transfer memory objectsLiam2023-02-2420-69/+91
| | |
* | | service: btm: Fix handle functionsNarr the Reg2023-02-271-4/+8
| | |
* | | Merge pull request #9857 from german77/fwupdateliamwhite2023-02-2513-2/+63
|\ \ \ | | | | | | | | core: Update service function tables to 16.0.0+
| * | | core: Update service function tables to 16.0.0+Narr the Reg2023-02-2513-2/+63
| |/ /
* / / core: hidbus: Fix BusType sizeNarr the Reg2023-02-252-15/+15
|/ /
* | core: hid: Fix native mouse mappingsNarr the Reg2023-02-223-1/+12
| |
* | Merge pull request #9846 from merryhime/type-constliamwhite2023-02-2213-53/+53
|\ \ | | | | | | svc: Fix type consistency (exposed on macOS)
| * | svc: Fix type consistency (exposed on macOS)Merry2023-02-2113-53/+53
| |/
* / net: translate ECONNRESET network errorMonsterDruide12023-02-212-0/+3
|/
* Merge pull request #9771 from ameerj/host-thread-idliamwhite2023-02-191-27/+18
|\ | | | | kernel: Refactor thread_local variable usage
| * kernel: Refactor thread_local variable usageameerj2023-02-111-27/+18
| | | | | | | | | | | | On MSVC at least, there seems to be a non-trivial overhead to calling GetHostThreadId(). This slightly reworks the host_thread_id variable to reduce some of the complexity around its usage, along with some small refactors around current_thread and dummy thread
* | kernel: add KObjectNameLiam2023-02-176-3/+263
| |
* | Merge pull request #9796 from liamwhite/currentliamwhite2023-02-1558-221/+245
|\ \ | | | | | | general: rename CurrentProcess to ApplicationProcess
| * | general: rename CurrentProcess to ApplicationProcessLiam2023-02-1427-94/+99
| | |
| * | kernel: use GetCurrentProcessLiam2023-02-1334-128/+147
| | |
* | | Merge pull request #9782 from arades79/fix-consexpr-value-declaration-usageliamwhite2023-02-155-5/+5
|\ \ \ | | | | | | | | Fix consexpr value declaration usage
| * | | remove static from pointer sized or smaller types for aesthetics, change constexpr static to static constexpr for consistencyarades792023-02-1432-86/+85
| | | | | | | | | | | | | | | | Signed-off-by: arades79 <scravers@protonmail.com>
| * | | apply clang-formatarades792023-02-142-4/+5
| | | | | | | | | | | | | | | | Signed-off-by: arades79 <scravers@protonmail.com>
| * | | add static lifetime to constexpr values to force compile time evaluation where possiblearades792023-02-1431-82/+82
| |/ / | | | | | | | | | Signed-off-by: arades79 <scravers@protonmail.com>
* / / service: remove deleted servicesLiam2023-02-1423-605/+0
|/ /
* | Merge pull request #9757 from german77/gyrobunnei2023-02-123-15/+12
|\ \ | | | | | | core: hid: Use gyro thresholds modes set by the game
| * | core: hid: Use gyro thresholds modes set by the gameNarr the Reg2023-02-103-15/+12
| | |
* | | kernel/svc: Fix undefined info_idColin Kinloch2023-02-111-2/+2
| | |
* | | Merge pull request #9773 from bunnei/fix-process-resourceliamwhite2023-02-113-1/+15
|\ \ \ | | | | | | | | core: kernel: k_process: Use application system resource.
| * | | core: kernel: k_process: Use application system resource.bunnei2023-02-113-1/+15
| | | |
* | | | Merge pull request #9742 from liamwhite/svc-wrap-onlybunnei2023-02-1143-1570/+7466
|\ \ \ \ | |/ / / |/| | | kernel/svc: switch to generated wrappers
| * | | kernel/svc: switch to generated wrappersLiam2023-02-0743-1570/+7466
| | | |
* | | | kernel: avoid usage of bit_castLiam2023-02-101-2/+2
| |_|/ |/| |
* | | Merge pull request #9747 from german77/SetSupportedNpadIdTypesliamwhite2023-02-084-6/+15
|\ \ \ | | |/ | |/| service: hid: Return error if arguments of SetSupportedNpadIdType is invalid
| * | service: hid: Return error if arguments of SetSupportedNpadIdType is invalidNarr the Reg2023-02-084-6/+15
| |/
* / kernel: fix compilation with older gccLiam2023-02-062-4/+5
|/
* kernel/svc: Split implementations into separate filesLiam2023-02-0539-2687/+3160
|
* fsp_srv: Copy HLE Read Buffer for OutputAccessLogToSdCardameerj2023-02-031-1/+1
|
* Revert "Merge pull request #9718 from yuzu-emu/revert-9508-hle-ipc-buffer-span"ameerj2023-02-0353-312/+349
| | | | | This reverts commit 25fc5c0e1158cb8e81cbc769b24ad84032a1fbfd, reversing changes made to af20e25081f97d55b451606c87922e2b49f0d363.
* Merge pull request #9718 from yuzu-emu/revert-9508-hle-ipc-buffer-spanbunnei2023-02-0353-349/+312
|\ | | | | Revert "hle_ipc: Use std::span to avoid heap allocations/copies when calling ReadBuffer"
| * Revert "hle_ipc: Use std::span to avoid heap allocations/copies when calling ReadBuffer"liamwhite2023-02-0253-349/+312
| |
* | kernel: add KDeviceAddressSpaceLiam2023-02-015-0/+230
|/
* Merge pull request #9696 from german77/please_forgive_me_for_this_sinbunnei2023-02-011-0/+3
|\ | | | | input_common: Implement turbo buttons
| * input_common: Implement turbo buttonsgerman772023-02-011-0/+3
| |
* | Merge pull request #9697 from liamwhite/kcapbunnei2023-01-314-0/+716
|\ \ | | | | | | kernel: add KCapabilities
| * | kernel: add KCapabilitiesLiam2023-01-304-0/+716
| | |
* | | Merge pull request #9508 from ameerj/hle-ipc-buffer-spanbunnei2023-01-3053-312/+349
|\ \ \ | |_|/ |/| | hle_ipc: Use std::span to avoid heap allocations/copies when calling ReadBuffer
| * | hle_ipc: Use thread_local ReadBufferameerj2022-12-291-4/+14
| | |
| * | hle_ipc: Rename ReadBufferSpan to ReadBufferameerj2022-12-2933-97/+97
| | |
| * | hle_ipc: Rename ReadBuffer to ReadBufferCopyameerj2022-12-293-4/+6
| | | | | | | | | | | | Indicates explicitly that a copy is occurring
| * | bsd: Use std::span for read payloadsameerj2022-12-292-26/+26
| | | | | | | | | | | | Allows the use of HLERequestContext::ReadBufferSpan
| * | nvdrv: Use std::span for inputsameerj2022-12-2924-211/+209
| | | | | | | | | | | | Allows the use of HLERequestContext::ReadBufferSpan
| * | hidbus: Use ReadBufferSpanameerj2022-12-2911-12/+16
| | |
| * | nvflinger: Split Parcel class into InputParcel and OutputParcelameerj2022-12-255-48/+53
| | | | | | | | | | | | | | | The usages of the Parcel class were already unique to either Read or Write operations. Avoids needing a vector of the input payload for the InputParcel use-case, instead it can remain as a span.
| * | service: Use ReadBufferSpan where it is trivial to do soameerj2022-12-2529-75/+74
| | |
| * | fsp_srv: Use ReadBufferSpanameerj2022-12-251-17/+14
| | |
| * | hle_ipc: Add ReadBufferSpan functionameerj2022-12-252-0/+22
| | | | | | | | | | | | Returns a std::span to the buffer address, rather than create a copy of the memory into a std::vector
* | | Move to Clang Format 15Levi Behunin2023-01-305-52/+47
| |/ |/| | | | | | | | | Depends on https://github.com/yuzu-emu/build-environments/pull/69 clang-15 primary run
* | Merge pull request #9666 from liamwhite/wait-for-mebunnei2023-01-286-42/+52
|\ \ | | | | | | kernel: fix incorrect locking order in suspension
| * | kernel: split SetAddressKey into user and kernel variantsLiam2023-01-245-11/+29
| | |
| * | kernel: fix incorrect locking order in suspensionLiam2023-01-233-31/+23
| | |
* | | kernel: unbreak min/max template deduction on Apple ClangLiam2023-01-261-2/+2
| | |
* | | Merge pull request #9604 from liamwhite/ptbunnei2023-01-266-215/+477
|\ \ \ | | | | | | | | kernel: KPageTable: update
| * | | kernel: KPageTable: updateLiam2023-01-226-215/+477
| |/ /
* | | core: hid: Only set the polling mode to the correct sideNarr the Reg2023-01-205-16/+43
| | |
* | | input_common: Fix issue where ring and irs are enabled at the same timegerman772023-01-201-3/+1
| | |
* | | input_common: Implement joycon ir cameraNarr the Reg2023-01-201-0/+11
| | |
* | | yuzu: Add ring controller test buttongerman772023-01-202-2/+4
| | |
* | | core: hid: Fix input regressionsNarr the Reg2023-01-202-12/+13
| | |
* | | service: hid: Set led pattern and fix color detectionNarr the Reg2023-01-201-0/+5
| | |
* | | core: hid: Migrate ring from emulated devices to emulated controllerNarr the Reg2023-01-202-4/+6
|/ /
* | Merge pull request #9619 from liamwhite/timing-spaghettibunnei2023-01-191-2/+4
|\ \ | | | | | | timing: wait for completion on unregister
| * | timing: wait for completion on unregisterLiam2023-01-141-2/+4
| | |
* | | nvnflinger: correct swap interval handlingLiam2023-01-122-5/+5
|/ /
* | Revert "Revert "k_page_group: synchronize""bunnei2023-01-0810-181/+321
| |
* | Merge pull request #9518 from gidoly/revert-9504-pg2liamwhite2023-01-0410-321/+181
|\ \ | | | | | | Revert "k_page_group: synchronize"
| * | Revert "k_page_group: synchronize"gidoly2022-12-2910-321/+181
| | |
* | | service: nifm: Initialize request stategerman772023-01-021-0/+1
| | |
* | | service: nifm: Match documentation namesgerman772023-01-021-31/+56
|/ /
* | k_page_table: remove HACK_OpenPages/ClosePagesLiam2022-12-253-58/+54
| |
* | k_page_group: synchronizeLiam2022-12-2510-125/+269
|/
* Merge pull request #9496 from liamwhite/shm3liamwhite2022-12-253-58/+62
|\ | | | | kernel: workaround static shared memory initialization
| * kernel: workaround static shared memory initializationLiam2022-12-233-58/+62
| |
* | time: add LockFreeAtomicTypeLiam2022-12-223-40/+65
|/
* kernel: remove TimeManagerLiam2022-12-1910-115/+33
|
* kernel: add KHardwareTimerLiam2022-12-185-6/+267
|
* service: nfc: Silence ListDevicesgerman772022-12-182-2/+2
|
* Merge pull request #9452 from ameerj/hle-read-buffer-resreveliamwhite2022-12-171-8/+6
|\ | | | | hle_ipc: Refactor ReadBuffer to set buffer size upon initialization
| * hle_ipc: Refactor ReadBuffer to set buffer size upon initializationameerj2022-12-161-8/+6
| | | | | | | | Initializing the vector size during initialization is more efficient than a later call to resize()
* | Merge pull request #6354 from ogniK5377/device-nameliamwhite2022-12-164-2/+19
|\ \ | | | | | | Set: Allow setting device nickname
| * | Set: Allow setting device nicknameChloe Marcec2022-12-144-2/+19
| | |
* | | Merge pull request #9450 from ameerj/hle-ipc-vector-reserveliamwhite2022-12-161-0/+8
|\ \ \ | | | | | | | | hle_ipc: Reserve vectors before populating
| * | | hle_ipc: Reserve vectors before populatingameerj2022-12-161-0/+8
| | |/ | |/|
* | | kernel: svc: Fix duplicated InfoType enumNarr the Reg2022-12-151-90/+47
| | |
* | | kernel: process: Implement GetFreeThreadCountNarr the Reg2022-12-153-1/+28
|/ / | | | | | | Used by Just Dance® 2023 Edition
* / Revert "hle: service: audio: Use default service thread."bunnei2022-12-143-12/+18
|/
* Merge pull request #9398 from liamwhite/failbunnei2022-12-121-5/+9
|\ | | | | general: improve handling of system startup failure
| * general: improve handling of system startup failureLiam2022-12-061-5/+9
| |
* | Remove the lock entirely as per PR discussionSalvage2022-12-091-3/+0
|/ | | | | | | | Correctly unlock mutex before its destruction As per https://en.cppreference.com/w/cpp/thread/mutex/~mutex destroying a locked mutex is undefined behavior and MSVC++ decides to throw in this case Swap out unique for scoped lock and readd comment
* Merge pull request #9386 from lioncash/initliamwhite2022-12-066-27/+25
|\ | | | | kernel: Ensure relevant class members are always initialized on construction
| * kernel/k_shared_memory: Ensure device_memory is always initializedLioncash2022-12-051-1/+1
| |
| * kernel/k_memory_block: Ensure members are always initializedLioncash2022-12-052-22/+20
| |
| * kernel/physical_core: Ensure is_interrupted is always initializedLioncash2022-12-051-1/+1
| |
| * kernel/thread: Ensure stack_top and argument are always initializedLioncash2022-12-051-2/+2
| |
| * kernel/kernel: Ensure shutdown threads are always initializedLioncash2022-12-051-1/+1
| |
* | Merge pull request #9369 from german77/mifareliamwhite2022-12-068-36/+598
|\ \ | |/ |/| service: nfc: Implement mifare service
| * service: nfc: Implement mifare serviceNarr the Reg2022-12-028-36/+598
| |
* | Merge pull request #9381 from liamwhite/uninitMai2022-12-041-7/+7
|\ \ | | | | | | service_thread: fix uninitialized memory usage
| * | service_thread: fix uninitialized memory usageLiam2022-12-041-7/+7
| | |
* | | Merge pull request #9232 from bunnei/audio-default-threadliamwhite2022-12-043-18/+12
|\ \ \ | |/ / |/| | hle: service: audio: Use default service thread.
| * | hle: service: audio: Use default service thread.bunnei2022-11-123-18/+12
| | | | | | | | | | | | - This was arbitrarily added by me, and does not appear to be helpful.
* | | Merge pull request #9289 from liamwhite/fruit-companyliamwhite2022-12-0310-10/+14
|\ \ \ | | | | | | | | general: fix compile for Apple Clang
| * | | general: fix compile for Apple ClangLiam2022-11-2310-10/+14
| | | |
* | | | Merge pull request #9348 from Morph1984/when-the-network-is-downliamwhite2022-12-021-7/+34
|\ \ \ \ | |_|_|/ |/| | | service: nifm: Update stubs for Submit/GetRequestState/GetResult
| * | | service: nifm: Update stubs for Submit/GetRequestState/GetResultMorph2022-11-291-7/+34
| | | |
* | | | Merge pull request #9340 from lioncash/nvdrvliamwhite2022-11-291-26/+18
|\ \ \ \ | | | | | | | | | | nvdrv: Simplify builder declarations
| * | | | nvdrv: Simplify builder declarationsLioncash2022-11-281-26/+18
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just use auto here. If one of these ever happens to not be derived from nvdevice, then this will cause a compilation error. We can also move the devices into the collection to get rid of an unnecessary atomic reference count increment and decrement.
* | | | Merge pull request #9346 from lioncash/vtableliamwhite2022-11-291-0/+1
|\ \ \ \ | | | | | | | | | | producer_listener: Add virtual destructor to IProducerListener
| * | | | producer_listener: Add virtual destructor to IProducerListenerLioncash2022-11-291-0/+1
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | Several member variables are shared_ptr's to this base class. Even though producer listeners are still unimplemented, this ensures we always have consistent deletion behavior once this ends up being used polymorphically.
* | | | Merge pull request #9345 from lioncash/fenceliamwhite2022-11-296-16/+15
|\ \ \ \ | | | | | | | | | | consumer_base: Pass std::shared_ptr by const reference
| * | | | buffer_item_consumer: Pass fence by const-ref in ReleaseBuffer()Lioncash2022-11-293-4/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This isn't directly modified. Also allows rvalues to be used with it.
| * | | | buffer_queue_consumer: std::move std::shared_ptr in Connect()Lioncash2022-11-291-1/+1
| | | | | | | | | | | | | | | | | | | | Avoids an unnecessary reference count increment and decrement
| * | | | consumer_base: Pass shared_ptr by const referenceLioncash2022-11-292-6/+6
| | | | | | | | | | | | | | | | | | | | Avoids churning atomic reference count increments and decrements.
| * | | | consumer_base: Remove redundant virtualLioncash2022-11-291-5/+5
| |/ / / | | | | | | | | | | | | override already serves this purpose
* | | | syncpoint_manager: Mark IsSyncpointAllocated() as constLioncash2022-11-282-3/+3
| | | | | | | | | | | | | | | | This doesn't modify class state at all.
* | | | syncpoint_manager: Reduce number of bounds checksLioncash2022-11-281-14/+28
|/ / / | | | | | | | | | The only time we need to check bounds is on the first access.
* | | service: Make use of buffer element count helpersLioncash2022-11-2312-47/+41
| | |
* | | hle_ipc: Add helper functions for getting number of buffer elementsLioncash2022-11-231-0/+12
| | |
* | | hle_ipc: Mark relevant member functions as [[nodiscard]]Lioncash2022-11-231-25/+25
| | | | | | | | | | | | | | | Will allow the compiler to complain about cases where ignoring the return value would be a bug.
* | | Merge pull request #9299 from lioncash/castliamwhite2022-11-222-15/+18
|\ \ \ | | | | | | | | k_handle_table: Remove cast to void* in GetObjectForIpc
| * | | k_handle_table: Remove cast to void* in GetObjectForIpcLioncash2022-11-222-15/+18
| |/ / | | | | | | | | | | | | | | | This was used to get around the KProcess class being incomplete. We can just move this to the cpp file and eliminate the cast entirely, letting the compiler do its work.
* | | Merge branch 'master' into nfc_implNarr the Reg2022-11-2027-48/+522
|\| |
| * | Merge pull request #9238 from german77/cabinet_appletbunnei2022-11-208-15/+358
| |\ \ | | | | | | | | service: am: Implement cabinet applet
| | * | general: Address review commentsgerman772022-11-143-14/+17
| | | |
| | * | service: am: Fix cabinet applet resultgerman772022-11-132-10/+22
| | | |
| | * | service: am: Implement cabinet applet backendgerman772022-11-135-7/+300
| | | |
| | * | service: nfc: fix tagprotocol and implement GetApplicationAreaIdgerman772022-11-134-8/+43
| | | |
| * | | Merge pull request #9191 from german77/touching_soulsliamwhite2022-11-192-6/+30
| |\ \ \ | | | | | | | | | | core: hid: Implement true multitouch support
| | * | | service: hid: Only overclock npad controllersgerman772022-11-192-6/+30
| | |/ /
| * | | Merge pull request #9234 from liamwhite/data-cash-moneybunnei2022-11-182-8/+26
| |\ \ \ | | | | | | | | | | kernel: implement data cache management operations
| | * | | kernel: implement FlushProcessDataCacheLiam2022-11-122-8/+26
| | | |/ | | |/|
| * | | Merge pull request #9244 from liamwhite/lost-wakeupbunnei2022-11-184-12/+16
| |\ \ \ | | | | | | | | | | nvnflinger: fix lost wakeup
| | * | | nvnflinger: fix lost wakeupLiam2022-11-154-12/+16
| | | | |
| * | | | Merge pull request #9229 from Docteh/achy_breaky_heartMorph2022-11-189-6/+14
| |\ \ \ \ | | | | | | | | | | | | Add break for default cases
| | * | | | Add break for default casesKyle Kienapfel2022-11-149-6/+14
| | | |/ / | | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Visual Studio has an option to search all files in a solution, so I did a search in there for "default:" looking for any missing break statements. I've left out default statements that return something, and that throw something, even if via ThrowInvalidType. UNREACHABLE leads towards throw R_THROW macro leads towards a return
| * | | | Merge pull request #9243 from german77/resultbunnei2022-11-151-1/+75
| |\ \ \ \ | | |_|/ / | |/| | | core: Update result module
| | * | | core: Update result moduleNarr the Reg2022-11-151-1/+75
| | | |/ | | |/|
| * | | Merge pull request #9225 from liamwhite/debugger-instanceliamwhite2022-11-131-0/+3
| |\ \ \ | | |/ / | |/| | Debugger improvements
| | * | gdbstub: add ams monitor commandsLiam2022-11-111-0/+3
| | | |
* | | | service: nfc: Implement nfc userNarr the Reg2022-11-1911-84/+718
|/ / /
* | | Merge pull request #9224 from liamwhite/services-arent-processesbunnei2022-11-122-29/+13
|\ \ \ | |_|/ |/| | service_thread: remove explicit KProcess
| * | service_thread: remove explicit KProcessLiam2022-11-102-29/+13
| |/
* | Merge pull request #9198 from liamwhite/arm64bunnei2022-11-111-2/+2
|\ \ | |/ |/| Initial ARM64 support
| * Initial ARM64 supportLiam2022-11-091-2/+2
| |
* | kernel/svc_types: refreshLiam2022-11-1019-137/+563
| |
* | Merge pull request #9182 from liamwhite/services-are-processesbunnei2022-11-105-25/+56
|\ \ | |/ |/| kernel: assign KProcess to service threads
| * service_thread: register service threads to the logical owner processLiam2022-11-045-20/+39
| |
| * kernel: avoid racy behavior in global suspensionLiam2022-11-041-5/+17
| |
* | Merge pull request #9215 from liamwhite/swordfightFernando S2022-11-092-3/+9
|\ \ | | | | | | Ensure correctness of atomic store ordering
| * | Ensure correctness of atomic store orderingLiam2022-11-092-3/+9
| | |
* | | service_thread: fix deletionLiam2022-11-074-39/+33
|/ /
* | Merge pull request #9173 from bunnei/kern-update-15liamwhite2022-11-0537-737/+2780
|\ \ | |/ |/| Kernel: Various updates for FW 15.0.x
| * core: hle: kernel: Address review comments.Liam2022-11-052-2/+2
| |
| * core: hle: kernel: k_page_table: Remove unnecessary casts.bunnei2022-11-041-17/+8
| |
| * core: hle: kernel: k_page_table: Manually open/close pages for IPC methods.bunnei2022-11-041-0/+18
| |
| * core: hle: kernel: k_page_table: Implement IPC memory methods.bunnei2022-11-043-3/+910
| |
| * core: hle: kernel: k_memory_manager: Refresh.bunnei2022-11-044-369/+460
| |
| * core: hle: kernel: Integrate system KSystemResource.bunnei2022-11-047-69/+209
| |
| * core: hle: kernel: k_dynamic_page_manager: Refresh.bunnei2022-11-041-17/+50
| |
| * core: hle: kernel: Add KSystemResource.bunnei2022-11-044-1/+171
| |
| * core: hle: kernel: k_handle_table: Refresh.bunnei2022-11-042-54/+87
| |
| * core: hle: kernel: k_memory_layout: Refresh.bunnei2022-11-043-12/+23
| |
| * core: hle: kernel: k_memory_region_type: Refresh.bunnei2022-11-041-49/+74
| |
| * core: hle: kernel: slab_helpers: Add KAutoObjectWithSlabHeap.bunnei2022-11-041-0/+78
| |
| * core: hle: kernel: k_dynamic_resource_manager: Add KBlockInfoManager, KBlockInfoSlabHeap.bunnei2022-11-041-0/+3
| |
| * core: hle: kernel: k_page_bitmap: Refresh.bunnei2022-11-041-88/+155
| |
| * core: hle: kernel: k_memory_block: Refresh.bunnei2022-11-042-48/+66
| |
| * core: hle: kernel: k_page_heap: Refresh.bunnei2022-11-042-17/+108
| |
| * core: hle: kernel: k_page_group: Add KPageBufferSlabHeap.bunnei2022-11-041-0/+86
| |
| * core: hle: kernel: k_system_control: Add SecureAppletMemorySize.bunnei2022-11-041-0/+4
| |
| * core: hle: kernel: k_page_buffer: Add KPageBufferSlabHeap.bunnei2022-11-041-3/+11
| |
| * core: hle: kernel: Add KPageTableManager.bunnei2022-11-041-0/+55
| |
| * core: hle: kernel: Add KPageTableSlabHeap.bunnei2022-11-041-0/+93
| |
| * core: hle: kernel: Add KEventInfo.bunnei2022-11-043-1/+101
| |
| * core: hle: kernel: Add KDebug.bunnei2022-11-041-0/+20
| |
| * core: hle: result: Fix code for compilers.bunnei2022-11-041-6/+7
| |
* | Merge pull request #9135 from liamwhite/service-thread-eventbunnei2022-11-0422-335/+438
|\ \ | |/ |/| kernel: invert session request handling flow
| * sm:: avoid excessive port recreationLiam2022-10-313-18/+24
| |
| * kernel: fix single core for service threadsLiam2022-10-311-1/+2
| |
| * kernel: fix port trackingLiam2022-10-315-49/+4
| |
| * k_server_session: add SendReplyHLELiam2022-10-313-5/+6
| |
| * service_thread: convert to map for session managementLiam2022-10-311-23/+21
| |
| * kernel: invert session request handling flowLiam2022-10-3122-279/+421
| |
* | core: hle: service: acc: Fix ListOpenContextStoredUsers/StoreOpenContext.bunnei2022-11-035-23/+42
|/ | | | | | - These APIs are used to capture the opened users and allow that state to be persisted across processes. - They are not intended to just return the system opened users, that is what ListOpenUsers is for. - Fixes the launch hang with Bayonetta 3.
* kernel: more complete fix for KPort reference countingLiam2022-10-312-13/+27
|
* k_thread: fix single coreLiam2022-10-301-2/+4
|
* Merge pull request #9149 from german77/volumbunnei2022-10-302-1/+13
|\ | | | | service: am: Stub SetRecordVolumeMuted
| * service: am: Stub SetRecordVolumeMutedgerman772022-10-302-1/+13
| | | | | | | | Used by bayonetta 3
* | k_server_session: fix crashesLiam2022-10-302-2/+1
| |
* | Merge pull request #9137 from liamwhite/hbmenubunnei2022-10-308-10/+45
|\ \ | |/ |/| Improved support for nx-hbmenu
| * nvnflinger: release queued handles immediately on disconnectionLiam2022-10-274-6/+17
| |
| * vi: implement CloseDisplayLiam2022-10-274-4/+28
| |
* | Merge pull request #9134 from lioncash/initliamwhite2022-10-272-2/+2
|\ \ | |/ |/| audio_in/out_system: Pass Initialize members by value where applicable
| * audio_in/out_system: Pass Initialize members by value where applicableLioncash2022-10-262-2/+2
| | | | | | | | | | | | | | | | | | | | | | applet_resource_user_id isn't actually modified and is just assigned to a member variable, so this doesn't need to be a mutable reference. Similarly, the device name itself isn't modified and is only moved. We pass by value here, since we can still perform the move, but eliminate a sneaky set of calls that can unintentionally destroy the original string. Given how nested the calls are, it's good to get rid of this potential vector for a use-after-move bug.
* | Merge pull request #9125 from liamwhite/dummy-schedulerbunnei2022-10-265-26/+76
|\ \ | |/ |/| kernel: refactor dummy thread wakeups
| * kernel: refactor dummy thread wakeupsLiam2022-10-255-26/+76
| |
* | concepts: Use the std::contiguous_iterator conceptMorph2022-10-261-1/+1
| | | | | | | | | | | | This also covers std::span, which does not have a const iterator. Also renames IsSTLContainer to IsContiguousContainer to explicitly convey its semantics.
* | Merge pull request #9113 from german77/peer_pressureliamwhite2022-10-257-12/+25
|\ \ | | | | | | service: nfp: Allow amiibos without keys
| * | service: nfp: Allow amiibos without keysNarr the Reg2022-10-223-1/+18
| | |
| * | service: nfp: remove unnecessary includeNarr the Reg2022-10-225-11/+7
| | |
* | | Merge pull request #9107 from german77/gidoly_rulesliamwhite2022-10-251-2/+2
|\ \ \ | | | | | | | | input_common: cache vibration tests
| * | | input_common: cache vibration testsgerman772022-10-211-2/+2
| |/ /
* | | Merge pull request #9119 from liamwhite/shutdown-barrierliamwhite2022-10-255-7/+25
|\ \ \ | | | | | | | | core: barrier service thread shutdown
| * | | core: barrier service thread shutdownLiam2022-10-235-7/+25
| | |/ | |/|
* | | Merge pull request #9122 from liamwhite/burnt-chickenFernando S2022-10-242-4/+4
|\ \ \ | | | | | | | | nvdrv: fix container destruction order
| * | | nvdrv: fix container destruction orderLiam2022-10-242-4/+4
| |/ /
* | | ipc_helpers: Ignore GCC compiler warnings only on GCCMorph2022-10-221-2/+2
| | | | | | | | | | | | Clang and ICC for whatever reason also defines __GNUC__. Exclude them from this check.
* | | general: Enforce C4800 everywhere except in video_coreMorph2022-10-223-13/+13
|/ /
* | Merge pull request #9106 from lioncash/copy-errliamwhite2022-10-211-2/+3
|\ \ | | | | | | hid/npad: Fix copy size in GetSupportedNpadIdTypes
| * | hid/npad: Fix copy size in GetSupportedNpadIdTypesLioncash2022-10-211-2/+3
| |/ | | | | | | | | | | | | | | Previously this was passing the size of the vector into memcpy rather than the size in bytes to copy, which would result in a partial read. Thankfully, this function isn't used yet, so this gets rid of a bug before it's able to do anything.
* | k_session_request: Add missing override specifierLioncash2022-10-211-1/+1
| |
* | k_session_request: Turn C-style array into std::arrayLioncash2022-10-211-1/+3
| | | | | | | | | | Makes for stronger typing and allows tooling bounds checks provided by the standard library for debugging purposes.
* | k_session_request: Simplify constructor initializationLioncash2022-10-211-14/+11
|/
* Merge pull request #9078 from liamwhite/session-requestliamwhite2022-10-2116-200/+606
|\ | | | | kernel: Session request cleanup
| * kernel: remove most SessionRequestManager handling from KServerSessionLiam2022-10-196-138/+119
| |
| * kernel: add KSessionRequestLiam2022-10-1912-62/+487
| |
* | Merge pull request #9096 from Kelebek1/audio_15bunnei2022-10-202-0/+42
|\ \ | |/ |/| [audio_core] Update for firmware 15.0.0
| * Update audio_core for firmware 15.0.0Kelebek12022-10-192-0/+42
| |
* | Merge pull request #9083 from liamwhite/take-a-chance-on-meliamwhite2022-10-191-10/+17
|\ \ | | | | | | kernel: fix slab heap ABA
| * | kernel: fix slab heap ABALiam2022-10-171-10/+17
| | |
* | | Merge pull request #9071 from bunnei/mp-mmliamwhite2022-10-1928-1161/+2323
|\ \ \ | | | | | | | | Kernel Multiprocess (Part 1) - Persist memory & core timing
| * | | core: hle: kernel: Migrate ProcessState to enum class.bunnei2022-10-192-17/+17
| | | |
| * | | core: hle: kernel: Use result macros for new/changed code.bunnei2022-10-199-128/+110
| | | |
| * | | core: hle: kernel: Fix InitializePreemption order.bunnei2022-10-191-1/+1
| | | |
| * | | core: hle: kernel: k_process: Improve management of page table & cleanup.bunnei2022-10-197-60/+92
| | | |
| * | | core: hle: kernel: k_interrupt_manager: HandleInterrupt should not depend on current process.bunnei2022-10-191-12/+9
| | | |
| * | | core: hle: kernel: Remove junk.bunnei2022-10-191-9/+0
| | | |
| * | | core: hle: kernel: k_page_table: Impl. LockForUn/MapDeviceAddressSpace, cleanup.bunnei2022-10-193-545/+624
| | | |
| * | | core: hle: kernel: Integration application memory block slab manager.bunnei2022-10-193-3/+44
| | | |
| * | | core: hle: kernel: k_page_table: Update, and integrate with new KMemoryBlockManager/SlabManager.bunnei2022-10-192-251/+393
| | | |
| * | | core: hle: kernel: k_memory_block: Update.bunnei2022-10-192-119/+391
| | | |
| * | | core: hle: kernel: k_memory_block_manager: Update.bunnei2022-10-192-174/+380
| | | |
| * | | core: hle: kernel: k_thread: Implement thread termination DPC.bunnei2022-10-194-1/+91
| | | |
| * | | core: hle: kernel: Add KDynamicResourceManager.bunnei2022-10-191-0/+58
| | | |
| * | | core: hle: kernel: Add KDynamicSlabHeap.bunnei2022-10-191-0/+122
| | | |
| * | | core: hle: kernel: Add KDynamicPageManager.bunnei2022-10-191-0/+136
| | | |
| * | | core: hle: kernel: k_process: Change Status -> State.bunnei2022-10-193-37/+27
| | | |
| * | | core: hle: kernel: svc_types: Add SystemThreadPriorityHighest and ProcessState.bunnei2022-10-191-0/+13
| | | |
| * | | core: device_memory: Templatize GetPointer(..).bunnei2022-10-197-12/+12
| | | |
| * | | core: hle: result: Add GetInnerValue and Includes methods.bunnei2022-10-191-0/+8
| | | |
| * | | core: hle: kernel: svc_common: Add WaitInfinite & cleanup.bunnei2022-10-191-2/+5
| | |/ | |/|
* | | Merge pull request #9084 from vonchenplus/dma_copyFernando S2022-10-191-4/+8
|\ \ \ | |/ / |/| | video_core: implement 1D copies based on VMM 'kind'
| * | video_core: Implement memory manager page kindFengChen2022-10-171-4/+8
| | |
* | | Merge pull request #9087 from Morph1984/oncebunnei2022-10-181-0/+2
|\ \ \ | | | | | | | | general: Add missing pragma once
| * | | general: Add missing pragma onceMorph2022-10-171-0/+2
| | |/ | |/|
* / | general: Fix spelling of "unknown"Morph2022-10-162-3/+3
|/ /
* | Merge pull request #9061 from liamwhite/writable-eventliamwhite2022-10-1433-222/+143
|\ \ | | | | | | kernel: remove KWritableEvent
| * | kernel: remove KWritableEventLiam2022-10-1333-222/+143
| | |
* | | Merge pull request #9055 from liamwhite/hblliamwhite2022-10-1414-55/+571
|\ \ \ | |_|/ |/| | Preliminary support for nx-hbloader
| * | k_server_session: preliminary support for userspace server sessionsLiam2022-10-128-49/+345
| | |
| * | Add implementation of svcCreateSessionLiam2022-10-122-1/+103
| | |
| * | general: preliminary support for hblLiam2022-10-126-6/+124
| |/
* | Merge pull request #9032 from liamwhite/stub-friendsliamwhite2022-10-141-1/+12
|\ \ | | | | | | IFriendService: stub CheckFriendListAvailability
| * | IFriendService: stub CheckFriendListAvailabilityLiam2022-10-081-1/+12
| | |
* | | result: enforce reference check specializationLiam2022-10-131-4/+3
| | |
* | | Merge pull request #9034 from liamwhite/result-macrosbunnei2022-10-131-6/+114
|\ \ \ | |_|/ |/| | kernel: add expanded result macros
| * | kernel: add expanded result macrosLiam2022-10-081-6/+114
| |/
* / fsp_srv: stub GetCacheStorageSizeLiam2022-10-082-1/+14
|/
* nfp_types: silence -Wtype-limitsLiam2022-10-071-1/+1
|
* General: address feedbackFernando Sahmkow2022-10-0618-128/+131
|
* general: rework usages of UNREACHABLE macroLiam2022-10-062-12/+12
|
* nvdisp: End system frame after requesting to swap buffersMorph2022-10-061-1/+1
| | | | Fixes frametime reporting
* address_space: Address feedbackMorph2022-10-061-4/+4
|
* general: Format licenses as per SPDX guidelinesMorph2022-10-0614-56/+42
|
* NvHostChannels: improve hack for supporting multiple channels.Fernando Sahmkow2022-10-062-2/+11
|
* Address Feedback from bylaws.Fernando Sahmkow2022-10-062-6/+2
|
* Nvflinger: correct duplication.Fernando Sahmkow2022-10-064-5/+5
|
* Core: Fix get nvmap object random crashVonChenPlus2022-10-0612-35/+66
|
* NvDec: Fix regressions.Fernando Sahmkow2022-10-066-5/+31
|
* General: Fix compilation for GCCLiam White2022-10-069-23/+39
|
* NVDRV: Further improvements.Fernando Sahmkow2022-10-0613-127/+256
|
* VideoCore: Refactor fencing system.Fernando Sahmkow2022-10-063-15/+8
|
* MemoryManager: initial multi paging system implementation.Fernando Sahmkow2022-10-063-20/+36
|
* NVDRV: Further refactors and eliminate old code.Fernando Sahmkow2022-10-067-61/+8
|
* NVDRV: Refactor Host1xFernando Sahmkow2022-10-068-64/+62
|
* VideoCore: Refactor syncing.Fernando Sahmkow2022-10-065-12/+32
|
* Texture cache: Fix the remaining issues with memory mnagement and unmapping.Fernando Sahmkow2022-10-061-0/+3
|
* VideoCore: Extra Fixes.Fernando Sahmkow2022-10-061-1/+3
|
* NVDRV: Remake ASGPUFernando Sahmkow2022-10-062-235/+388
|
* NVDRV: Update copyright notices.Fernando Sahmkow2022-10-064-7/+13
|
* NvHostCtrl: Fix merge of nvflinger.Fernando Sahmkow2022-10-061-1/+2
|
* NVHOST_CTRl: Implement missing method and fix some stuffs.Fernando Sahmkow2022-10-062-6/+29
|
* VideoCore: implement channels on gpu caches.Fernando Sahmkow2022-10-066-30/+65
|
* NVASGPU: Fix Remap.Fernando Sahmkow2022-10-061-0/+8
|
* NVDRV: Fix clearing when destroying.Fernando Sahmkow2022-10-063-14/+9
|
* NVMAP: Fix the Free return parameters.Fernando Sahmkow2022-10-063-15/+18
|
* NVDRV: Fix Open/Close and make sure each device is correctly created.Fernando Sahmkow2022-10-0614-199/+291
|
* NVDRV: Implement new NvMapFernando Sahmkow2022-10-0618-277/+307
|
* NVDRV: Refactor and add new NvMap.Fernando Sahmkow2022-10-0618-38/+544
|
* NVDRV: Cleanup.Fernando Sahmkow2022-10-064-32/+40
|
* NVDRV: Implement QueryEvent.Fernando Sahmkow2022-10-0610-40/+133
|
* NvHost: Remake Ctrl Implementation.Fernando Sahmkow2022-10-066-169/+311
|
* NvHost: Try a different approach to blocking.Fernando Sahmkow2022-10-062-10/+7
|
* NvHost: Fix some regressions and correct signaling on timeout.Fernando Sahmkow2022-10-061-25/+19
|
* Merge pull request #9013 from liamwhite/spinning-a-yarnbunnei2022-10-064-4/+4
|\ | | | | common: remove "yuzu:" prefix from thread names
| * common: remove "yuzu:" prefix from thread namesLiam2022-10-044-4/+4
| |
* | service: nfp: Fix errors to pass unit testingNarr the Reg2022-10-045-40/+108
|/
* Merge pull request #8955 from german77/amiibo-rewritebunnei2022-10-0213-1304/+1803
|\ | | | | core: nfp: Rewrite implementation to remove direct access from the frontend
| * service: mii: Copy only valid name bytesgerman772022-10-021-3/+18
| |
| * service: nfp: Implement mount target and open application area errors, minor fixesNarr the Reg2022-10-025-19/+124
| |
| * nfp: Multiple fixes against HWgerman772022-10-029-62/+163
| |
| * service: nfp: address commentsgerman772022-10-023-19/+21
| |
| * service: nfp: Rewrite and implement applet callsgerman772022-10-0212-1262/+1538
| |
* | Merge pull request #8992 from Morph1984/vi-vsync-eventbunnei2022-10-026-29/+66
|\ \ | | | | | | service: vi: Retrieve vsync event once per display
| * | service: vi: Retrieve vsync event once per displayMorph2022-09-265-14/+42
| | | | | | | | | | | | | | | | | | The display vsync event can only be retrieved once per display. Returns VI::ResultPermissionDenied if we attempt to retrieve the vsync event for the same display. Prevents games such as .hack//G.U. Last Recode from consuming all the handles in the handle table by spamming vsync event retrievals and allows it to go in game.
| * | service: vi: Move VI results into its own fileMorph2022-09-262-16/+25
| | |
* | | Merge pull request #8876 from FearlessTobi/multiplayer-part3bunnei2022-10-015-117/+928
|\ \ \ | |_|/ |/| | ldn: Implement "local wireless" networked multiplayer
| * | Address some review commentsFearlessTobi2022-09-204-48/+34
| | |
| * | yuzu: Multiple room UI improvementsgerman772022-09-101-1/+2
| | |
| * | ldn: Initial implementationFearlessTobi2022-09-094-116/+940
| | |
* | | Merge pull request #8934 from german77/palma_releasebunnei2022-09-296-33/+840
|\ \ \ | | | | | | | | service: hid: Partially implement palma controller
| * | | service: hid: Partially implement palma controllerNarr the Reg2022-09-256-33/+840
| | |/ | |/|
* | | Merge pull request #8940 from german77/silencebunnei2022-09-281-1/+2
|\ \ \ | | | | | | | | yuzu: Silence some clang warnings
| * | | yuzu: Silence some clang warningsNarr the Reg2022-09-211-1/+2
| |/ /
* / / chore: fix some typosAndrea Pappacoda2022-09-232-3/+3
|/ / | | | | | | Fix some typos reported by Lintian
* | Merge pull request #8915 from vonchenplus/opus_multi_streambunnei2022-09-182-1/+38
|\ \ | | | | | | core: implement HwOpus GetWorkBufferSizeForMultiStreamEx
| * | core: implement HwOpus GetWorkBufferSizeForMultiStreamExFengChen2022-09-162-1/+38
| |/
* | Merge pull request #8827 from german77/amiibo_releasebunnei2022-09-1710-282/+1366
|\ \ | | | | | | core: nfp: Implement amiibo encryption
| * | core: nfp: Remove magic numbersgerman772022-09-073-105/+103
| | |
| * | core: nfp: Workaround for lack of multiple nfp interfacesgerman772022-09-071-1/+3
| | |
| * | core: nfp: Correct date and amiibo nameNarr the Reg2022-09-074-18/+36
| | |
| * | core: nfp: Implement Convert and RecreateApplicationArea, accuracy fixesNarr the Reg2022-09-0710-257/+356
| | |
| * | core: nfp: Implement amiibo encryptiongerman772022-09-075-256/+1223
| |/
* | Merge pull request #8650 from Kelebek1/vsyncbunnei2022-09-172-17/+30
|\ \ | | | | | | [Coretiming/NVNFlinger] Improve multi-core vsync timing, and core timing accuracy
| * | Rework multi-core vsyncKelebek12022-08-022-17/+30
| | |
* | | audio_device: Mark member functions as const where applicableLioncash2022-09-151-2/+2
| | | | | | | | | | | | These member functions don't modify any internal state.
* | | audio_device: Make AudioDeviceName constructor constexprLioncash2022-09-151-2/+1
| | | | | | | | | | | | | | | | | | | | | | | | These are used as read-only arrays, so we can make the data read-only and available at compile-time. Now constructing an AudioDevice no longer needs to initialize some tables
* | | Merge pull request #8842 from Kelebek1/AudOutbunnei2022-09-102-1/+8
|\ \ \ | |_|/ |/| | [audio_core] Rework audio output
| * | Don't stall with nvdecKelebek12022-09-041-1/+6
| | |
| * | Rework audio output, connecting AudioOut into coretiming to fix desync during heavy loads.Kelebek12022-09-021-0/+2
| | |
* | | Merge pull request #8855 from german77/plsliamwhite2022-09-044-23/+24
|\ \ \ | | | | | | | | core: ns: Implement pl:s service
| * | | core: ns: Implement pl:s serviceNarr the Reg2022-09-034-23/+24
| | | |
* | | | Merge pull request #8822 from FearlessTobi/multiplayer-fixesbunnei2022-09-023-6/+18
|\ \ \ \ | |/ / / |/| | | network: Fixes and improvements to the room feature
| * | | Address review commentsFearlessTobi2022-09-021-13/+6
| | | |
| * | | core/ldn_types: Minor corrections and additionsFearlessTobi2022-08-271-1/+16
| | | |
| * | | core/bsd: Correctly unbind methods in destructorFearlessTobi2022-08-271-1/+5
| | | | | | | | | | | | | | | | Prevents yuzu from crashing when the BSD service is created a second time.
| * | | core/acc: Make CheckAvailability use LOG_DEBUGFearlessTobi2022-08-271-1/+1
| |/ / | | | | | | | | | Previously it was spamming the logs in certain multiplayer games like Puyo Puyo Tetris.
* / / Demote services from warning/info to debug to reduce log spam:Kelebek12022-09-015-16/+16
|/ / | | | | | | | | | | | | | | | | | | | | GetCurrentFocusState SetClockSpeed EnableSixAxisSensorUnalteredPassthrough IsSixAxisSensorUnalteredPassthroughEnabled Get, GetOld SetAndWait, SetAndWaitOld IocParam IocFree
* | Merge pull request #8812 from Kelebek1/autobunnei2022-08-241-6/+21
|\ \ | | | | | | [Audio] Implement AudRenU:RequestUpdateAuto
| * | Implement AudRenU:RequestUpdateAuto, and use C descriptors when B reports as empty.Kelebek12022-08-241-6/+21
| | |
* | | Merge pull request #8804 from vonchenplus/speed_up_idirectory_servicesbunnei2022-08-231-1/+2
|\ \ \ | | | | | | | | core:filesystem: speed up IDirectory service
| * | | core:filesystem: speed up IDirectory servicevonchenplus2022-08-231-1/+2
| | | |
* | | | hid: core: Add missing function table namesgerman772022-08-221-0/+6
|/ / /
* / / core: implement clkrst servicevonchenplus2022-08-202-0/+184
|/ /
* | core, yuzu: Address first part of review commentsFearlessTobi2022-08-151-0/+1
| |
* | core, network: Add ability to proxy socket packetsFearlessTobi2022-08-156-172/+257
| |
* | Merge pull request #8731 from FearlessTobi/better-ldnliamwhite2022-08-125-56/+709
|\ \ | | | | | | ldn: Add better stubs and more data types
| * | core: ldn: Address review comments part 2german772022-08-122-334/+297
| | |
| * | core: ldn: Address review commentsNarr the Reg2022-08-084-56/+46
| | |
| * | ldn: Add better stubs and more data typesFearlessTobi2022-08-075-71/+771
| |/ | | | | | | | | Co-Authored-By: Narr the Reg <5944268+german77@users.noreply.github.com> Co-Authored-By: Morph <39850852+Morph1984@users.noreply.github.com>
* | Merge pull request #8724 from german77/no_alphabunnei2022-08-101-15/+62
|\ \ | | | | | | hid: core: Properly emulate controller color and battery level
| * | hid: core: Properly emulate controller color and battery levelNarr the Reg2022-08-081-15/+62
| |/
* | Merge pull request #8637 from liamwhite/bad-interruptsbunnei2022-08-084-61/+34
|\ \ | |/ |/| kernel: unlayer CPU interrupt handling
| * kernel: unlayer CPU interrupt handlingLiam2022-07-254-61/+34
| |
* | Properly write out the command buffer when serving close requestNikita Strygin2022-07-311-2/+5
| |
* | Merge pull request #8636 from german77/irs_cluster_releaseliamwhite2022-07-274-6/+320
|\ \ | | | | | | service: irs: Implement clustering processor
| * | Address commentsNarr the Reg2022-07-251-16/+16
| | |
| * | fix compiler errorsgerman772022-07-242-12/+14
| | |
| * | service: irs: Implement clustering processorgerman772022-07-244-6/+318
| | |
* | | Merge pull request #8633 from Morph1984/optional-keysliamwhite2022-07-271-0/+6
|\ \ \ | | | | | | | | applet/swkbd: Implement optional symbol keys
| * | | applet/swkbd: Implement optional symbol keysMorph2022-07-241-0/+6
| | | | | | | | | | | | | | | | These are only used in the numeric keyboard, and correspond to the keys to the left and right of the "0" key on the numeric keyboard.
* | | | chore: make yuzu REUSE compliantAndrea Pappacoda2022-07-279-27/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | [REUSE] is a specification that aims at making file copyright information consistent, so that it can be both human and machine readable. It basically requires that all files have a header containing copyright and licensing information. When this isn't possible, like when dealing with binary assets, generated files or embedded third-party dependencies, it is permitted to insert copyright information in the `.reuse/dep5` file. Oh, and it also requires that all the licenses used in the project are present in the `LICENSES` folder, that's why the diff is so huge. This can be done automatically with `reuse download --all`. The `reuse` tool also contains a handy subcommand that analyzes the project and tells whether or not the project is (still) compliant, `reuse lint`. Following REUSE has a few advantages over the current approach: - Copyright information is easy to access for users / downstream - Files like `dist/license.md` do not need to exist anymore, as `.reuse/dep5` is used instead - `reuse lint` makes it easy to ensure that copyright information of files like binary assets / images is always accurate and up to date To add copyright information of files that didn't have it I looked up who committed what and when, for each file. As yuzu contributors do not have to sign a CLA or similar I couldn't assume that copyright ownership was of the "yuzu Emulator Project", so I used the name and/or email of the commit author instead. [REUSE]: https://reuse.software Follow-up to 01cf05bc75b1e47beb08937439f3ed9339e7b254
* | | | yuzu: Add ui files for multiplayer roomsFearlessTobi2022-07-255-7/+7
| |_|/ |/| |
* | | Merge pull request #8549 from liamwhite/kscheduler-scMorph2022-07-2510-531/+534
|\ \ \ | |_|/ |/| | kernel: use KScheduler from Mesosphere
| * | kernel: Ensure all uses of disable_count are balancedLiam2022-07-153-10/+21
| | |
| * | kernel: be more careful about initialization path for HLE threadsLiam2022-07-152-1/+8
| | |
| * | kernel: fix single-core preemption pointsLiam2022-07-154-11/+14
| | |
| * | kernel: fix issues with single core modeLiam2022-07-157-131/+120
| | |
| * | kernel: use KScheduler from mesosphereLiam2022-07-159-497/+490
| | |
* | | yuzu: Add webcam support and rebase to latest masterNarr the Reg2022-07-243-4/+4
| | |
* | | service: irs: Move to IRS namespace and minor fixesgerman772022-07-2418-69/+66
| | |
* | | service: irs: Split processors and implement ImageTransferProcessorgerman772022-07-2417-291/+1077
| |/ |/|
* | Project AndioKelebek12022-07-2214-760/+838
| |
* | Merge pull request #8598 from Link4565/recv-dontwaitbunnei2022-07-221-1/+19
|\ \ | | | | | | Enable the use of MSG_DONTWAIT flag on RecvImpl
| * | Enable the use of MSG_DONTWAIT flag on RecvImplLink45652022-07-161-1/+19
| | |
* | | implement resume messageGus Caplan2022-07-182-0/+5
| | |
* | | Merge pull request #8508 from yuzu-emu/mc-speed-limitbunnei2022-07-171-3/+15
|\ \ \ | | | | | | | | hle: service: nvflinger: Factor speed limit into frame time calculation.
| * | | hle: service: nvflinger: Fix implicit conversion.bunnei2022-07-171-1/+4
| | | |
| * | | yuzu: settings: Remove framerate cap and merge unlocked framerate setting.bunnei2022-07-171-8/+10
| | | | | | | | | | | | | | | | - These were all somewhat redundant.
| * | | hle: service: nvflinger: Factor speed limit into frame time calculation.bunnei2022-07-171-1/+8
| | | | | | | | | | | | | | | | | | | | - This allows the %-based "Limit Speed Percent" setting to work with MC emulation. - This is already supported for SC emulation.
* | | | Merge pull request #8544 from german77/14dot0bunnei2022-07-178-29/+45
|\ \ \ \ | |/ / / |/| | | service: Update some services to 14.0.0+
| * | | service: fatal: Add function tablegerman772022-07-141-1/+7
| | | |
| * | | service: btdrv,bcat,btm: Update service tables to 14.0.0german772022-07-143-4/+13
| | | |
| * | | service am: Update service tables to 14.0.0german772022-07-141-0/+3
| | | |
| * | | service: ac: Replace intances of ProfileData with UserDatagerman772022-07-143-24/+22
| | | |
* | | | Merge pull request #8511 from german77/hbmenubunnei2022-07-168-83/+218
|\ \ \ \ | |_|/ / |/| | | service: ptm: Add TS, nifm: Stub GetInternetConnectionStatus
| * | | service: nifm: Stub GetInternetConnectionStatusgerman772022-06-291-1/+41
| | | |
| * | | service: ptm: Rewrite PSM and add TSgerman772022-06-297-82/+177
| | | |
* | | | Merge pull request #8588 from merryhime/IBinder-vdestructMorph2022-07-151-0/+1
|\ \ \ \ | | | | | | | | | | nvflinger: Polymorphic destructor requried for abstract class IBinder
| * | | | nvflinger: Polymorphic destructor requried for abstract class IBinderMerry2022-07-151-0/+1
| | |_|/ | |/| |
* / | | KCodeMemory: Mark virtual methods as overrideMerry2022-07-151-3/+3
|/ / /
* | | Merge pull request #8510 from german77/vibrationliamwhite2022-07-151-2/+2
|\ \ \ | |_|/ |/| | input_common: sdl: lower vibration frequency and use it's own unique thread
| * | input_common: sdl: lower vibration frequency and use it's own unique threadgerman772022-06-291-2/+2
| |/
* | Merge pull request #8559 from liamwhite/waiter-listbunnei2022-07-111-3/+9
|\ \ | | | | | | kernel: fix usage of waiter_list in Finalize
| * | kernel: fix usage of waiter_list in FinalizeLiam2022-07-101-3/+9
| | |
* | | PRKelebek12022-07-104-10/+8
| | |
* | | Rework CoreTimingKelebek12022-07-105-58/+43
|/ /
* | Merge pull request #8502 from liamwhite/end-waitliamwhite2022-07-072-4/+5
|\ \ | | | | | | kernel: clean up waiting implementation
| * | kernel: clean up waiting implementationLiam2022-06-252-4/+5
| | |
* | | Merge pull request #8492 from german77/no_more_errorsFernando S2022-07-074-40/+75
|\ \ \ | | | | | | | | service: hid: Correct some mistakes and add more validations
| * | | service: hid: Correct some mistakes and add more validationsNarr the Reg2022-06-294-40/+75
| | |/ | |/|
* | | Merge pull request #8532 from liamwhite/fiber-supplementsliamwhite2022-07-064-19/+7
|\ \ \ | | | | | | | | common/fiber: make fibers easier to use
| * | | common/fiber: make fibers easier to useLiam2022-07-024-19/+7
| |/ /
* / / cpu_manager: properly check idle on return from preemptionLiam2022-06-301-0/+5
|/ /
* | Merge pull request #8512 from german77/nnResultMorph2022-06-29128-1160/+1120
|\ \ | | | | | | Replace multiple names with a better name
| * | core: kernel: Replace instances of KPageLinkedList with KPageGroupgerman772022-06-2710-63/+62
| | |
| * | core: Replace all instances of ResultCode with Resultgerman772022-06-27128-1130/+1091
| | |
* | | Merge pull request #8504 from comex/mesosphere-current-processbunnei2022-06-271-0/+24
|\ \ \ | |/ / |/| | Support `InfoType_MesosphereCurrentProcess`
| * | Re-add missing `case` and braces, and trim whitespacecomex2022-06-261-1/+3
| | |
| * | Update src/core/hle/kernel/svc.cppcomex2022-06-261-6/+14
| | | | | | | | | Co-authored-by: liamwhite <liamwhite@users.noreply.github.com>
| * | Support InfoType_MesosphereCurrentProcesscomex2022-06-261-0/+14
| |/
* / kernel: make current thread pointer thread localLiam2022-06-2311-42/+60
|/
* Merge pull request #8491 from Morph1984/extra-assertbunnei2022-06-221-1/+0
|\ | | | | KPageTable: Remove extraneous assert
| * KPageTable: Remove extraneous assertMorph2022-06-221-1/+0
| | | | | | | | Since start is always 0 and VAddr is unsigned, we can safely remove this assert.
* | Merge pull request #8483 from liamwhite/fire-emblem-three-semaphoresbunnei2022-06-223-0/+22
|\ \ | |/ |/| kernel: wait for threads to stop on pause
| * kernel: wait for threads to stop on pauseLiam2022-06-183-0/+22
| |
* | Merge pull request #8432 from liamwhite/watchpointbunnei2022-06-223-0/+77
|\ \ | | | | | | core/debugger: memory breakpoint support
| * | core/debugger: memory breakpoint supportLiam2022-06-163-0/+77
| | |
* | | Merge pull request #8468 from liamwhite/dispatch-trackingbunnei2022-06-224-14/+7
|\ \ \ | | | | | | | | kernel: fix some uses of disable_count
| * | | kernel: fix some uses of disable_countLiam2022-06-164-14/+7
| |/ /
* | / service: am: Stub PerformSystemButtonPressingIfInFocusNarr the Reg2022-06-202-1/+24
| |/ |/| | | | | Used by Ring Fit Adventure
* | Implement ExitProcess svcNikita Strygin2022-06-161-1/+2
|/ | | | | | | Currently this just stops all the emulation This works under assumption that only application will try to use ExitProcess, with services not touching it If application exits - it quite makes sense to end the emulation
* Merge pull request #8457 from liamwhite/kprocess-suspendFernando S2022-06-167-39/+110
|\ | | | | kernel: implement KProcess suspension
| * kernel: implement KProcess suspensionLiam2022-06-147-39/+110
| |
* | Merge pull request #8317 from german77/notifabunnei2022-06-152-8/+172
|\ \ | | | | | | service: notifa: Implement most part of this service
| * | service: notifa: Implement most part of this servicegerman772022-05-092-8/+172
| | | | | | | | | | | | | | | Implements partially RegisterAlarmSetting, UpdateAlarmSetting, LoadApplicationParameter, DeleteAlarmSetting. Needed for Fitness `Boxing 2: Rhythm & Exercise` and `Ring Fit Adventure`.
* | | Merge pull request #8464 from liamwhite/break-debugMai2022-06-151-0/+7
|\ \ \ | | | | | | | | kernel: notify debugger on break SVC
| * | | kernel: notify debugger on break SVCLiam2022-06-151-0/+7
| | |/ | |/|
* / | core: centralize profile scope for DynarmicLiam2022-06-151-3/+0
|/ /
* | kernel: fix passthrough of local captures in lambdaLiam2022-06-141-1/+3
| |
* | kernel: ensure class token lambda exit is unreachableLiam2022-06-141-0/+1
| |
* | kernel: fix inconsistency in AutoObjectTraits macro definitionsLiam2022-06-141-4/+7
| |
* | common: Change semantics of UNREACHABLE to unconditionally crashLiam2022-06-1428-50/+46
| |
* | Merge pull request #8388 from liamwhite/simpler-pausebunnei2022-06-141-3/+1
|\ \ | | | | | | CpuManager: simplify pausing
| * | CpuManager: simplify pausingLiam2022-06-091-3/+1
| | |
* | | Merge pull request #8443 from liamwhite/code-membunnei2022-06-133-26/+118
|\ \ \ | | | | | | | | kernel: fix KCodeMemory initialization
| * | | kernel: fix KCodeMemory initializationLiam2022-06-093-26/+118
| |/ /
* / / service: hid: Fix gesture regressionNarr the Reg2022-06-102-4/+3
|/ /
* | Merge pull request #8428 from bunnei/nvflinger-fix-timingbunnei2022-06-083-31/+3
|\ \ | | | | | | Follow-up fixes for NVFlinger rewrite (Part 3)
| * | hle: service: nvflinger: buffer_queue_consumer: Always free released buffers.bunnei2022-06-063-31/+3
| | |
* | | Merge pull request #8426 from liamwhite/elfbunnei2022-06-061-24/+8
|\ \ \ | |/ / |/| | common: consolidate ELF structure definitions
| * | common: consolidate ELF structure definitionsLiam2022-06-051-24/+8
| | |
* | | Merge pull request #8395 from german77/ir_stubbunnei2022-06-042-21/+460
|\ \ \ | |/ / |/| | service: hid: Improve stub of IRS
| * | service: hid: Improve stub of IRSNarr the Reg2022-05-312-21/+460
| | |
* | | core/debugger: Support reading guest thread namesLiam2022-06-022-0/+14
| | |
* | | core/debugger: Improved stepping mechanism and misc fixesLiam2022-06-011-0/+15
| | |
* | | core/debugger: Implement new GDB stub debuggerLiam2022-06-011-0/+4
|/ /
* | Merge pull request #8368 from german77/seventimesbunnei2022-05-305-368/+600
|\ \ | | | | | | Service: hid: Several improvements and implementations
| * | service: hid: Implement ResetIsSixAxisSensorDeviceNewlyAssignedgerman772022-05-274-6/+115
| | | | | | | | | | | | Needed by Nintendo Switch Sports
| * | service: hid: Implement LoadSixAxisSensorCalibrationParameter and GetSixAxisSensorIcInformationgerman772022-05-274-3/+103
| | | | | | | | | | | | Needed by Nintendo Switch Sports
| * | service: hid: Implement EnableSixAxisSensorUnalteredPassthrough and IsSixAxisSensorUnalteredPassthroughEnabledgerman772022-05-274-2/+88
| | | | | | | | | | | | Needed by Nintendo Switch Sports
| * | service: hid: Add error handling to sixaxis functionsgerman772022-05-273-31/+55
| | |
| * | service: hid: Refractor sixaxis functionsgerman772022-05-272-185/+88
| | |
| * | service: hid: Implement MergeSingleJoyAsDualJoy according to REgerman772022-05-274-65/+57
| | |
| * | service: hid: Add error handling to setNpadAssignment and variantsgerman772022-05-273-23/+27
| | |
| * | service: hid: Quick RE fixes and commentsgerman772022-05-274-54/+68
| | |
* | | Merge pull request #8332 from Morph1984/reduce_exec_sizebunnei2022-05-291-4/+3
|\ \ \ | | | | | | | | general: Use smaller array types where applicable
| * | | time_zone_manager: Use s8 for month length tablesMorph2022-05-131-4/+3
| |/ / | | | | | | | | | Using this smaller type saves 512 bytes in the compiled executable.
* / / input_common: touch: Rewrite touch driver to support multiple touch pointsgerman772022-05-231-1/+5
|/ /
* | service: hid: Fix motion refresh rateNarr the Reg2022-05-062-2/+6
| |
* | service: hid: Disable correctly motion inputgerman772022-05-061-50/+41
|/
* hle/result: Update std::expected replacement messageMorph2022-05-031-1/+1
| | | | std::expected is included in C++23
* hle/result: Add ResultRange overload in ResultValMorph2022-05-031-1/+3
| | | | Also marks the implicit conversion operator as constexpr instead of consteval as the constructor is not constant evaluated.
* hle/result: Implement ResultRangeMorph2022-05-031-0/+42
| | | | | | A ResultRange defines an inclusive range of error descriptions within an error module. This can be used to check whether the description of a given ResultCode falls within the range. The conversion function returns a ResultCode with its description set to description_start.
* Merge pull request #8274 from german77/firmwareMorph2022-04-292-1/+21
|\ | | | | service: hid: Stub IsFirmwareUpdateNeededForNotification
| * service: hid: Stub IsFirmwareUpdateNeededForNotificationgerman772022-04-272-1/+21
| | | | | | | | Used in Fitness Boxing 2: Rhythm & Exercise (0100073011382000)
* | chore: add missing SPDX tagsAndrea Pappacoda2022-04-281-19/+2
| | | | | | | | Follow-up to 99ceb03a1cfcf35968cab589ea188a8c406cda52
* | Merge pull request #8229 from german77/reinterpret2bunnei2022-04-2721-350/+393
|\ \ | |/ |/| service: hid: Access shared memory directly
| * service: hid: Ensure all structs are initializedNarr the Reg2022-04-2415-68/+69
| |
| * service: hid: Access shared memory directlyNarr the Reg2022-04-2321-305/+347
| |
* | Merge pull request #8261 from liamwhite/jit-cleanupMai M2022-04-253-132/+225
|\ \ | | | | | | service: jit: document and clean up
| * | service: jit: document and clean upLiam2022-04-253-132/+225
| |/
* / kernel: svc: Replace -1ULL with 0xFFFFFFFFFFFFFFFFMorph2022-04-241-1/+1
|/ | | | Resolves the C4146 compiler warning on MSVC.
* general: Convert source file copyright comments over to SPDXMorph2022-04-23527-1581/+1065
| | | | | This formats all copyright comments according to SPDX formatting guidelines. Additionally, this resolves the remaining GPLv2 only licensed files by relicensing them to GPLv2.0-or-later.
* service: hid: Improve accuracy of sixaxis functionsNarr the Reg2022-04-185-97/+360
|
* yuzu: Add custom ringcon configurationgerman772022-04-165-64/+54
|
* hidbus: Implement hidbus and ringcongerman772022-04-1613-26/+1669
|
* Merge pull request #8172 from bunnei/kernel-mutexFernando S2022-04-1610-84/+40
|\ | | | | hle: kernel: Use std::mutex instead of spin locks for most kernel locking.
| * core: hle: kernel: k_thread: Rework dummy thread waiting.bunnei2022-04-122-28/+21
| |
| * core: hle: service: Allocate a service thread.bunnei2022-04-121-1/+2
| |
| * hle: kernel: k_spin_lock: Remove unused ThreadPause.bunnei2022-04-121-28/+0
| |
| * hle: kernel: Use std::mutex instead of spin locks for most kernel locking.bunnei2022-04-128-27/+17
| |
* | service: jit: Implement the JIT serviceLiam2022-04-134-9/+782
| |
* | Merge pull request #8165 from bunnei/ensure-session-port-cleanupbunnei2022-04-128-25/+53
|\ \ | | | | | | Kernel: Track open references to KServerPort and KServerSession.
| * | hle: kernel: Unify and integrate reference tracking for KServerPort/KServerSession.bunnei2022-04-086-13/+46
| | | | | | | | | | | | - These are not managed elsewhere, and need to be tracked and closed on emulation shutdown.
| * | hle: kernel: k_server_port: Release ref-counted host emulation members on Destroy.bunnei2022-04-081-0/+3
| | |
| * | hle: kernel: k_auto_object: Move unregister with kernel to after Destroy.bunnei2022-04-081-3/+2
| | | | | | | | | | | | - Destructor is no longer invoked, so our object counting was off.
| * | hle: service: sm: Remove manual tracking of KServerPorts.bunnei2022-04-082-8/+1
| | |
| * | hle: kernel: hle_ipc: HasSessionRequestHandler: Check if domain handler is expired rather than locking.bunnei2022-04-081-1/+1
| | |
* | | Merge pull request #8178 from tech-ticks/skyline-icache-fixbunnei2022-04-124-15/+34
|\ \ \ | |_|/ |/| | hle: kernel: Invalidate entire icache in UnmapProcessMemory and UnmapCodeMemory (fixes #8174)
| * | hle: kernel: Invalidate entire icache in UnmapProcessMemory and UnmapCodeMemory (fixes #8174)tech-ticks2022-04-094-15/+34
| | |
* | | Merge pull request #8157 from lat9nq/kernel-racesbunnei2022-04-127-13/+15
|\ \ \ | | | | | | | | kernel: Fix some data races
| * | | k_system_control: Fix data racelat9nq2022-04-061-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | `return distribution(gen)` is a data race between a read and a write in two threads, reported by TSan. Remove static random number generators so they aren't using the same generator.
| * | | k_auto_object: Fix data racelat9nq2022-04-041-1/+1
| | | | | | | | | | | | | | | | | | | | Change the memory order to acqure-release when we decrement the reference count. Prevents a race with line 89 reported by TSan.
| * | | k_thread: Fix data racelat9nq2022-04-042-3/+4
| | | | | | | | | | | | | | | | | | | | TSan reports a data race between writing at cpp:1162 and reading at h:262. Make the thread_state atomic to prevent this.
| * | | k_process: Fix data racelat9nq2022-04-041-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | TSan reported a race between thread 36 and thread 34, a read at :225 and a write at :225 respectively. Make total_proces_running_time_ticks atomic to avoid this race.
| * | | kernel: Fix current_process racelat9nq2022-04-041-4/+4
| | | | | | | | | | | | | | | | | | | | TSan reported a race at :258 and :803, so make current_process an atomic pointer.
| * | | k_scheduler_lock: Fix data racelat9nq2022-04-041-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | TSan reports a race between the main thread and T37 during IsLockedByCurrentThread and when it's set at the end of Lock(), respectively. Set owner_thread to an atomic pointer to fix it. Co-authored-by: bunnei <bunneidev@gmail.com>
* | | | service: sfdnsres: add missing includes for some BSDs after 82d46a974ad4Jan Beich2022-04-121-0/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | src/core/hle/service/sockets/sfdnsres.cpp: In function 'Service::Sockets::NetDbError Service::Sockets::AddrInfoErrorToNetDbError(s32)': src/core/hle/service/sockets/sfdnsres.cpp:66:10: error: 'EAI_NODATA' was not declared in this scope; did you mean 'EAI_NONAME'? 66 | case EAI_NODATA: | ^~~~~~~~~~ | EAI_NONAME src/core/hle/service/sockets/sfdnsres.cpp: In function 'std::vector<unsigned char> Service::Sockets::SerializeAddrInfo(const addrinfo*, s32, std::string_view)': src/core/hle/service/sockets/sfdnsres.cpp:127:53: error: 'sockaddr_in' does not name a type; did you mean 'SockAddrIn'? 127 | const auto addr = *reinterpret_cast<sockaddr_in*>(current->ai_addr); | ^~~~~~~~~~~ | SockAddrIn src/core/hle/service/sockets/sfdnsres.cpp:127:64: error: expected '>' before '*' token 127 | const auto addr = *reinterpret_cast<sockaddr_in*>(current->ai_addr); | ^ src/core/hle/service/sockets/sfdnsres.cpp:127:64: error: expected '(' before '*' token 127 | const auto addr = *reinterpret_cast<sockaddr_in*>(current->ai_addr); | ^ | ( src/core/hle/service/sockets/sfdnsres.cpp:127:65: error: expected primary-expression before '>' token 127 | const auto addr = *reinterpret_cast<sockaddr_in*>(current->ai_addr); | ^ src/core/hle/service/sockets/sfdnsres.cpp:127:84: error: expected ')' before ';' token 127 | const auto addr = *reinterpret_cast<sockaddr_in*>(current->ai_addr); | ^ | ) src/core/hle/service/sockets/sfdnsres.cpp:148:53: error: 'sockaddr_in6' does not name a type; did you mean 'SockAddrIn6'? 148 | const auto addr = *reinterpret_cast<sockaddr_in6*>(current->ai_addr); | ^~~~~~~~~~~~ | SockAddrIn6 src/core/hle/service/sockets/sfdnsres.cpp:148:65: error: expected '>' before '*' token 148 | const auto addr = *reinterpret_cast<sockaddr_in6*>(current->ai_addr); | ^ src/core/hle/service/sockets/sfdnsres.cpp:148:65: error: expected '(' before '*' token 148 | const auto addr = *reinterpret_cast<sockaddr_in6*>(current->ai_addr); | ^ | ( src/core/hle/service/sockets/sfdnsres.cpp:148:66: error: expected primary-expression before '>' token 148 | const auto addr = *reinterpret_cast<sockaddr_in6*>(current->ai_addr); | ^ src/core/hle/service/sockets/sfdnsres.cpp:148:85: error: expected ')' before ';' token 148 | const auto addr = *reinterpret_cast<sockaddr_in6*>(current->ai_addr); | ^ | )
* | | | Merge pull request #8171 from tech-ticks/skyline-improvementsFernando S2022-04-104-5/+201
|\ \ \ \ | |_|_|/ |/| | | Improvements for game modding with Skyline, DNS resolution
| * | | service: sfdnsres: Implement DNS address resolutiontech-ticks2022-04-082-5/+197
| | | |
| * | | service: bsd: Add keepalive socket optiontech-ticks2022-04-072-0/+4
| | |/ | |/|
* | | Merge pull request #8169 from merryhime/scoped_lockbunnei2022-04-089-36/+36
|\ \ \ | | | | | | | | Replace lock_guard with scoped_lock
| * | | core/hle: Standardize scoped_lock initializersMerry2022-04-075-23/+23
| | | |
| * | | core/hle: Replace lock_guard with scoped_lockMerry2022-04-074-13/+13
| | | |
* | | | Merge pull request #8167 from Tachi107/patch-1merry2022-04-071-2/+0
|\ \ \ \ | |/ / / |/| | | fix: remove #pragma once in .cpp file
| * | | fix: remove #pragma once in .cpp fileAndrea Pappacoda2022-04-071-2/+0
| | | |
* | | | Merge pull request #8148 from merryhime/interruptsFernando S2022-04-071-0/+1
|\ \ \ \ | |/ / / |/| | | dynarmic: Better interrupts
| * | | dynarmic: Better interruptsmerry2022-04-031-0/+1
| | | |
* | | | Merge pull request #8164 from liamwhite/jit-stubbunnei2022-04-075-1/+84
|\ \ \ \ | | | | | | | | | | service: jit: stub JIT service
| * | | | service: jit: stub JIT serviceLiam2022-04-075-1/+84
| | |/ / | |/| |
* | | | Merge pull request #8122 from bunnei/improve-thread-usagebunnei2022-04-0613-27/+74
|\ \ \ \ | |/ / / |/| | | Improve usage of service host threads
| * | | hle: service: nvdrv: Create a service thread where appropriate.Morph2022-04-021-1/+1
| | | |
| * | | hle: service: vi: Create a service thread where appropriate.bunnei2022-04-021-1/+2
| | | |
| * | | hle: service: bsd: Create a service thread where appropriate.bunnei2022-04-021-1/+2
| | | |
| * | | hle: service: filesystem: Create a service thread where appropriate.bunnei2022-04-021-5/+8
| | | |
| * | | hle: service: audio: Create a service thread where appropriate.bunnei2022-04-022-4/+6
| | | |
| * | | hle: service: Add option for service interfaces to create or use the default thread.bunnei2022-04-025-11/+29
| | | |
| * | | hle: kernel: Create a default thread for services that do not need their own host thread.bunnei2022-04-022-4/+26
| |/ /
* | | service: hid: Partially revert #8123german772022-04-061-0/+4
| | |
* | | Merge pull request #8137 from bunnei/improve-nvflinger-2bunnei2022-04-069-91/+99
|\ \ \ | |_|/ |/| | Follow-up fixes for NVFlinger rewrite (Part 2)
| * | hle: service: nvflinger: buffer_queue_producer: Cleanup & fixes.bunnei2022-04-022-61/+42
| | |
| * | hle: service: nvflinger: consumer_base: Cleanup & fixes.bunnei2022-04-022-15/+17
| | |
| * | hle: service: nvflinger: buffer_queue_producer: Cleanup & add GetReleasedBuffers.bunnei2022-04-022-10/+38
| | |
| * | hle: service: nvflinger: buffer_queue_core: Cleanup & fixes.bunnei2022-04-022-3/+0
| | |
| * | hle: service: nvflinger: Use correct logger namespace.bunnei2022-04-021-2/+2
| |/
* | Merge pull request #8135 from Morph1984/websession-hackbunnei2022-04-031-0/+8
|\ \ | | | | | | applets/web: Keep foreground (websession) web applet open
| * | applets/web: Keep foreground (websession) web applet openMorph2022-04-021-0/+8
| |/ | | | | | | This is a hack to keep the foreground (websession) web applet open in games using these such as Super Mario 3D All-Stars.
* | Merge pull request #8123 from german77/bombslingerbunnei2022-04-033-66/+69
|\ \ | | | | | | service: hid: Remove inaccurate behavior on initialization
| * | service: npad: Default initialize shared memorygerman772022-04-031-48/+48
| | |
| * | service: hid: Remove inaccurate behavior on initializationgerman772022-03-313-18/+21
| | |
* | | fix: typosAndrea Pappacoda2022-04-022-7/+7
| |/ |/|
* | Merge pull request #8116 from ameerj/nvhost_ctrl_bad_paramFernando S2022-04-011-1/+1
|\ \ | | | | | | nvhost_ctrl: Only mark EventState::Busy as BadParameter
| * | nvhost_ctrl: Only mark EventState::Busy as BadParameterameerj2022-03-291-1/+1
| |/ | | | | | | Fixes an svc break in Kirby and the Forgotten Land with async GPU enabled.
* | Merge pull request #8120 from german77/signalbunnei2022-03-311-0/+4
|\ \ | | | | | | service: hid: Signal event on AcquireNpadStyleSetUpdateEventHandle
| * | service: hid: Signal event on AcquireNpadStyleSetUpdateEventHandleNarr the Reg2022-03-311-0/+4
| | |
* | | Merge pull request #8090 from bunnei/fix-skylinebunnei2022-03-315-54/+241
|\ \ \ | |_|/ |/| | Kernel Memory Updates (Part 7): Various fixes to code memory (Skyline support)
| * | hle: kernel: k_page_table: Fix implementations of LockForCodeMemory & UnlockForCodeMemory.bunnei2022-03-261-48/+12
| | |
| * | hle: kernel: k_page_table: Implement LockMemoryAndOpen & UnlockMemory.bunnei2022-03-262-0/+124
| | |
| * | hle: kernel: svc: MapProcessMemory: Fix usage of KPageLinkedList to use physical address space.bunnei2022-03-261-2/+5
| | |
| * | hle: kernel: svc: CreateCodeMemory: Remove log of 'out' host pointer.bunnei2022-03-261-2/+2
| | | | | | | | | | | | - This does not seem terribly useful and is inconsistent with other usage.
| * | hle: kernel: k_code_memory: Fix usage of KPageLinkedList to use physical address space.bunnei2022-03-261-1/+2
| | |
| * | hle: kernel: k_page_table: Implement MakeAndOpenPageGroup & MakePageGroup.bunnei2022-03-262-0/+83
| | |
| * | hle: kernel: k_page_table: Add IsHeapPhysicalAddress method.bunnei2022-03-261-0/+8
| | |
| * | hle: kernel: k_page_linked_list: Add Empty method.bunnei2022-03-261-0/+4
| | |
| * | hle: kernel: svc: UnmapProcessCodeMemory: Fix inverted alignment check.bunnei2022-03-261-1/+1
| | |
* | | Merge pull request #8088 from bunnei/fixup-nvflingerFernando S2022-03-279-547/+136
|\ \ \ | |/ / |/| | Follow-up fixes for NVFlinger rewrite
| * | hle: service: nvflinger: buffer_queue: Remove AutoLock and fix free buffer tracking.bunnei2022-03-265-181/+130
| | |
| * | hle: service: nvflinger: buffer_queue_consumer: Use scoped_lock instead of unique_lock.bunnei2022-03-261-2/+2
| | |
| * | hle: service: nvflinger: consumer_base: Use scoped_lock instead of unique_lock.bunnei2022-03-261-4/+4
| | |
| * | hle: service: nvflinger: Remove unused BufferQueue.bunnei2022-03-262-360/+0
| | |
* | | Merge pull request #8041 from Morph1984/inline-swkbdbunnei2022-03-263-166/+415
|\ \ \ | |/ / |/| | applets/swkbd: Add support for an updated inline software keyboard
| * | applets/swkbd: Split software keyboard initializationMorph2022-03-222-160/+349
| | | | | | | | | | | | | | | Since the CalcArg struct has been updated with a new size and fields, we have to split the initialization of the keyboard into multiple functions. This also adds support for parsing the new CalcArg struct used by updated versions of Monster Hunter Rise.
| * | applets/swkbd: Add new inline software keyboard typesMorph2022-03-221-6/+66
| |/ | | | | | | These were added in newer firmware versions.
* | hle: nvflinger: ConsumerBase: Mark ctor as explicit.bunnei2022-03-251-1/+1
| |
* | hle: vi: NativeWindow: Fix trivially copyable issues.bunnei2022-03-251-4/+4
| |
* | hle: nvdrv: nvdata: buffer_queue_producer: Minor cleanup.bunnei2022-03-251-11/+11
| |
* | hle: nvdrv: nvdata: Cleanup NvFence static assert.bunnei2022-03-251-1/+1
| |
* | hle: nvflinger: Remove unused unordered_map include.bunnei2022-03-251-1/+0
| |
* | hle: nvflinger: buffer_queue_consumer: AcquireBuffer: Fix typo.bunnei2022-03-251-1/+1
| |
* | hle: nvflinger: Merge Rect with Common::Rectangle.bunnei2022-03-254-84/+9
| |
* | hle: nvflinger: buffer_queue_core: Declare default dtor.bunnei2022-03-252-0/+3
| |
* | hle: nvflinger: buffer_queue_producer: DequeueBuffer: Remove unnecessary lock.bunnei2022-03-251-3/+1
| |
* | hle: nvflinger: consumer_base: StillTracking: Should be const.bunnei2022-03-252-2/+3
| |
* | hle: nvflinger: graphic_buffer_producer: Remove unnecessary pragma pack.bunnei2022-03-251-2/+0
| |
* | hle: nvflinger: parcel: Reserve token size.bunnei2022-03-251-1/+2
| |
* | hle: nvflinger: buffer_queue_core: StillTracking: Take const reference.bunnei2022-03-254-7/+7
| |
* | hle: nvflinger: buffer_queue_core: Cleanup locking.bunnei2022-03-251-2/+2
| |
* | hle: nvflinger: Use std::chrono for present_ns.bunnei2022-03-257-25/+30
| |
* | hle: nvflinger: Migrate android namespace -> Service::android.bunnei2022-03-2529-61/+58
| |
* | hle: nvflinger: BufferQueueProducer: Handle SetPreallocatedBuffer with empty buffer.bunnei2022-03-251-7/+10
| | | | | | | | - Used by Naruto Ultimate Ninja Storm.
* | hle: vi: Integrate new NVFlinger and HosBinderDriverServer service.bunnei2022-03-2516-723/+285
| |
* | hle: nvflinger: Add implementation for HosBinderDriverServer service.bunnei2022-03-252-0/+73
| |
* | hle: nvflinger: Add implementation for BufferQueueProducer class.bunnei2022-03-252-0/+1019
| |
* | hle: nvflinger: Add implementation for BufferQueueCore class.bunnei2022-03-252-0/+233
| |
* | hle: nvflinger: Add implementation for BufferQueueConsumer class.bunnei2022-03-252-0/+261
| |
* | hle: nvflinger: Add implementation for QueueBufferInput and QueueBufferOutput structs.bunnei2022-03-252-0/+98
| |
* | hle: nvflinger: Add implementation for BufferItemConsumer class.bunnei2022-03-252-0/+85
| |
* | hle: nvflinger: Add implementation for ConsumerBase class.bunnei2022-03-252-0/+188
| |
* | hle: nvflinger: Add implementation for BufferSlot class.bunnei2022-03-251-0/+39
| |
* | hle: nvflinger: Add implementation for BufferItem class.bunnei2022-03-251-0/+46
| |
* | hle: nvflinger: Move implementation for Parcel to its own header.bunnei2022-03-251-0/+171
| |
* | hle: nvflinger: Add android buffer queue definitions to its own header.bunnei2022-03-251-0/+21
| |
* | hle: nvflinger: Add IBinder interface.bunnei2022-03-251-0/+42
| |
* | hle: nvflinger: Add IConsumerListener interface.bunnei2022-03-251-0/+26
| |
* | hle: nvflinger: Add ProducerListener interface.bunnei2022-03-251-0/+16
| |
* | hle: nvflinger: Add android window enumerations to its own header.bunnei2022-03-251-0/+53
| |
* | hle: nvflinger: Add android Status flags to its own header.bunnei2022-03-251-0/+28
| |
* | hle: nvflinger: Move BufferTransformFlags to its own header.bunnei2022-03-252-1/+26
| |
* | hle: nvdrv: Rename Fence to NvFence to avoid naming conflicts.bunnei2022-03-254-17/+13
| |
* | hle: nvflinger: Move PixelFormat to its own header.bunnei2022-03-254-10/+30
| |
* | hle: nvflinger: Add implementation for GraphicBuffer class.bunnei2022-03-251-0/+100
| |
* | hle: nvflinger: Add implementation for Fence class.bunnei2022-03-251-0/+32
| |
* | hle: nvflinger: Add implementation for Rect class.bunnei2022-03-251-0/+75
| |
* | applets/mii: Remove unused includeMorph2022-03-221-1/+0
| |
* | applets/mii: Cleanup MiiEdit applet implementationMorph2022-03-222-44/+85
| | | | | | | | This also enables proper support for MiiEdit applets which are used in games with firmware versions prior to 10.2.0 by handling the 2 different versions of applet inputs and outputs.
* | applets/mii: Cleanup MiiEdit applet typesMorph2022-03-221-23/+44
| |
* | applets/mii: Move MiiEdit applet types into its own fileMorph2022-03-223-54/+69
| |
* | service: Move mii enums and structs into its own fileMorph2022-03-226-307/+311
| | | | | | | | Moves these into types.h, since other files also make use of these types.
* | applets: Rename Mii to MiiEditMorph2022-03-224-34/+35
|/
* Merge pull request #8048 from ameerj/include-purgebunnei2022-03-2233-45/+8
|\ | | | | general: Reduce unused includes across the project
| * common: Reduce unused includesameerj2022-03-193-0/+4
| |
| * core: Reduce unused includesameerj2022-03-1930-45/+4
| |
* | Merge pull request #8040 from Morph1984/handle-tablebunnei2022-03-202-30/+12
|\ \ | |/ |/| KHandleTable: Optimize table entry layout
| * KHandleTable: Optimize table entry layoutMorph2022-03-182-30/+12
| | | | | | | | Since the handle type is not being used, we can reduce the amount of space each entry takes up by 4 bytes.
* | Merge pull request #8028 from v1993/patch-9bunnei2022-03-191-2/+2
|\ \ | | | | | | bsd: Allow inexact match for address length in AcceptImpl
| * | bsd: Allow inexact match for address length in AcceptImplValeri2022-03-151-2/+2
| |/ | | | | Minecraft passes in zero for length, but this should account for all possible cases
* | general: Reduce core.h includesameerj2022-03-183-7/+22
| |
* | Merge pull request #7964 from german77/miiiibunnei2022-03-174-5/+212
|\ \ | | | | | | applet: mii: Simple implementation of mii applet
| * | applet: mii: Simple implementation of mii appletgerman772022-03-014-5/+212
| | |
* | | core: hle: kernel: init_slab_setup: Move CalculateSlabHeapGapSize to global namespace.bunnei2022-03-151-6/+6
| | |
* | | core: hle: kernel: Allocate dummy threads on host thread storage.bunnei2022-03-152-8/+6
| | | | | | | | | | | | - Fixes a crash where on subsequent boots, long-lived host threads would have their dummy threads freed.
* | | core: hle: kernel: Downgrade dangling objects warning to debug.bunnei2022-03-151-2/+2
| | | | | | | | | | | | - It is not impossible to leak kernel objects, so this is not really any issue anymore (albeit, still interesting).
* | | core: hle: kernel: Make object list container global and ensure it is reset on each emulation session.bunnei2022-03-151-7/+9
| | |
* | | core: hle: kernel: Remove server session tracking.bunnei2022-03-154-37/+1
| | | | | | | | | | | | - These are now allocated/managed by emulated memory, so we do not need to track and free them on shutdown.
* | | core: hle: kernel: k_process: Remove handle table finalize, reset page table.bunnei2022-03-151-3/+3
| | |
* | | core: hle: kernel: k_process: Implement thread local storage accurately.bunnei2022-03-153-111/+99
| | |
* | | core: hle: kernel: k_page_table: Add implementations of MapPages, UnmapPages, and FindFreeArea for TLS.bunnei2022-03-152-2/+141
| | |
* | | core: hle: kernel: k_slab_heap: Refresh to use guest allocations.bunnei2022-03-152-125/+107
| | |
* | | core: hle: kernel: Update init_slab_heap, use device memory, and add KThreadLocalPage and KPageBuffer.bunnei2022-03-154-55/+92
| | | | | | | | | | | | | | | | | | - Refreshes our slab initialization code to latest known behavior. - Moves all guest kernel slabs into emulated device memory. - Adds KThreadLocalPage and KPageBuffer, which we will use for accurate TLS management.
* | | core: hle: kernel: k_page_buffer: Add KThreadLocalPage primitive.bunnei2022-03-152-0/+177
| | |
* | | core: hle: kernel: k_page_buffer: Add KPageBuffer primitive.bunnei2022-03-151-0/+34
| | |
* | | core: hle: kernel: k_thread: Ensure host Fiber is freed.bunnei2022-03-151-0/+3
| | |
* | | core: hle: kernel: k_server_session: Ensure SessionRequestManager is freed.bunnei2022-03-151-0/+3
| | |
* | | core: hle: service: kernel_helpers: Use system resource limit.bunnei2022-03-151-10/+1
| | |
* | | core: hle: service: sm: Fix KPort reference count.bunnei2022-03-151-0/+2
| | |
* | | core: hle: kernel: k_thread: Update to reflect tree changes.bunnei2022-03-151-3/+3
| | |
* | | core: hle: kernel: Use weak_ptr where possible for SessionRequestHandler and SessionRequestManager.bunnei2022-03-157-14/+25
| | |
* | | core: hle: kernel: k_memory_layout: Update kernel slab memory sizes.bunnei2022-03-151-3/+3
| | |
* | | core: hle: kernel: svc_types: Add ThreadLocalRegionSize.bunnei2022-03-151-0/+2
| | |
* | | core: hle: kernel: k_condition_variable: Update to reflect tree changes.bunnei2022-03-151-1/+1
| | |
* | | core: hle: kernel: k_address_arbiter: Update to reflect tree changes.bunnei2022-03-151-3/+3
| |/ |/|
* | hle: service: ldr: Use deterministic addresses when mapping NROs.bunnei2022-03-092-24/+62
| | | | | | | | | | - Instead of randomization, choose in-order addresses for where to map NROs into memory. - This results in predictable behavior when debugging and consistent behavior when reproducing issues.
* | hle: kernel: KPageTable: Improve implementations of MapCodeMemory and UnmapCodeMemory.bunnei2022-03-082-47/+116
| | | | | | | | | | - This makes these functions more accurate to the real HOS implementations. - Fixes memory access issues in Super Smash Bros. Ultimate that occur when un/mapping NROs.
* | Merge pull request #7956 from bunnei/improve-mem-managerbunnei2022-03-0314-376/+846
|\ \ | | | | | | Kernel Memory Updates (Part 4): Revamp KMemoryManager & other fixes
| * | hle: kernel: Re-create memory layout at initialization.bunnei2022-02-281-41/+43
| | | | | | | | | | | | - As this can only be derived once.
| * | hle: kernel: Remove unused pool locals.bunnei2022-02-281-2/+0
| | |
| * | hle: kernel: k_memory_manager: Rework for latest kernel behavior.bunnei2022-02-286-173/+548
| | | | | | | | | | | | | | | | | | - Updates the KMemoryManager implementation against latest documentation. - Reworks KMemoryLayout to be accessed throughout the kernel. - Fixes an issue with pool sizes being incorrectly reported.
| * | hle: kernel: k_page_heap: GetPhysicalAddr can be const.bunnei2022-02-271-2/+1
| | |
| * | hle: kernel: k_page_heap: Remove superfluous consexpr.bunnei2022-02-272-4/+4
| | |
| * | hle: kernel: k_page_heap: Various updates and improvements.bunnei2022-02-272-155/+192
| | | | | | | | | | | | | | | - KPageHeap tracks physical addresses, not virtual addresses. - Various updates and improvements to match latest documentation for this type.
| * | hle: kernel: Add initial_process.h header.bunnei2022-02-271-0/+23
| | |
| * | hle: kernel: board: nx: Add k_memory_layout.h header.bunnei2022-02-271-0/+13
| | |
| * | hle: kernel: k_system_control: Add GetRealMemorySize and update GetKernelPhysicalBaseAddress.bunnei2022-02-272-1/+12
| | |
| * | hle: kernel: k_memory_layout: Add GetPhysicalLinearRegion.bunnei2022-02-271-0/+4
| | |
| * | hle: kernel: k_memory_region_types: Update for new regions.bunnei2022-02-271-1/+9
| |/
* / dynarmic: Inline exclusive memory accessesmerry2022-02-271-2/+2
|/ | | | | | | | | | | | | | | Inlines implementation of exclusive instructions into JITted code, improving performance of applications relying heavily on these instructions. We also fastmem these instructions for additional speed, with support for appropriate recompilation on fastmem failure. An unsafe optimization to disable the intercore global_monitor is also provided, should one wish to rely solely on cmpxchg semantics for safety. See also: merryhime/dynarmic#664
* Merge pull request #7932 from bunnei/extended-mem-layoutbunnei2022-02-2610-47/+54
|\ | | | | Add extended memory layout (6GB) support and improve KResourceLimit management
| * hle: kernel: KSystemControl: Use 6GB memory layout when "use_extended_memory_layout" setting is enabled.bunnei2022-02-211-20/+4
| | | | | | | | - This uses a larger 6GB DRAM memory layout, which is useful for some mods that require more memory.
| * core: hle: kernel: Remove resource limit hack for PhysicalMemory.bunnei2022-02-211-7/+0
| | | | | | | | - With prior changes, we now report the correct amount of physical memory available to the emulated process.
| * core: hle: kernel: KProcess: Pass in KResourceLimit on process creation.bunnei2022-02-213-8/+20
| | | | | | | | - This allows us to have a resource limit per process, rather than use the global system resource limit.
| * core: hle: kernel: KEvent: Pass in owner KProcess on event creation.bunnei2022-02-214-12/+8
| | | | | | | | - This is necessary to ensure resource limits are freed from the right process.
| * core: hle: kernel: KResourceLimit: Add a helper function for creating a KResourceLimit for a process.bunnei2022-02-212-0/+22
| |
* | service: am: Update enum names to match documentationNarr the Reg2022-02-224-16/+51
|/
* Merge pull request #7919 from bunnei/phys-mem-updatesbunnei2022-02-211-125/+430
|\ | | | | core: hle: kernel: KPageTable: Improve Un/MapPhysicalMemory.
| * fixup! core: hle: kernel: KPageTable: Improve Un/MapPhysicalMemory.bunnei2022-02-191-22/+2
| |
| * core: hle: kernel: KPageTable: Improve Un/MapPhysicalMemory.bunnei2022-02-191-107/+432
| | | | | | | | - Improves the implementations of MapPhysicalMemory and UnmapPhysicalMemory to more closely reflect latest HOS.
* | Merge pull request #7920 from bunnei/fix-unmap-pagesbunnei2022-02-211-3/+2
|\ \ | | | | | | core: hle: kernel: KPageTable: Fix UnmapPages.
| * | core: hle: kernel: KPageTable: Fix UnmapPages.bunnei2022-02-191-3/+2
| |/ | | | | | | - Fixes a logic bug in KPageTable::UnmapPages.
* | Merge pull request #7867 from german77/amiibobunnei2022-02-192-247/+911
|\ \ | |/ |/| nfp: Improve amiibo support
| * nfp: Allow files without password datagerman772022-02-132-9/+24
| |
| * nfp: Separate nfc tag from amiibo dataNarr the Reg2022-02-102-42/+69
| |
| * nfp: Address compiler issuesgerman772022-02-091-25/+26
| |
| * nfp: Validate amiibo filesNarr the Reg2022-02-082-41/+145
| |
| * nfp: Improve implementationgerman772022-02-082-189/+664
| |
| * nfp: Move IUser class to header and add missing enum and structsgerman772022-02-072-257/+299
| |
| * nfp: Sort functions by command numbergerman772022-02-071-79/+79
| |
* | Merge pull request #7866 from xerpi/svc-OutputDebugString32-CreateCodeMemory32-ControlCodeMemory32Mai M2022-02-172-4/+40
|\ \ | | | | | | kernel: svc: Add OutputDebugString32, CreateCodeMemory32, ControlCodeMemory32
| * | kernel: svc: Add OutputDebugString32, CreateCodeMemory32, ControlCodeMemory32Sergi Granell2022-02-152-4/+40
| | | | | | | | | | | | | | | Very straightforward, they are just wrappers to the 64-bit version of the SVC.
* | | Merge pull request #7878 from german77/mnppbunnei2022-02-173-0/+67
|\ \ \ | |/ / |/| | service/mnpp: Stub mnpp_app
| * | service/mnpp: Stub mnpp_appNarr the Reg2022-02-113-0/+67
| |/ | | | | | | Used in Super Nintendo Entertainment System™ - Nintendo Switch Online
* | Merge pull request #7871 from german77/svc2bunnei2022-02-151-77/+77
|\ \ | | | | | | svc: Set unique names for function tables
| * | svc: Set unique names for function tablesNarr the Reg2022-02-091-77/+77
| |/
* | hid: Stub IsUsbFullKeyControllerEnabledlat9nq2022-02-122-1/+12
| | | | | | | | | | | | Used by Splatoon 2, when opening the inventory from a LAN battle lobby. Reference: https://switchbrew.org/wiki/HID_services
* | Merge pull request #7852 from Morph1984/new-uuidbunnei2022-02-1114-59/+58
|\ \ | | | | | | common: Revise and fix the UUID implementation
| * | general: Rename NewUUID to UUID, and remove the previous UUID implMorph2022-02-0516-108/+105
| | | | | | | | | | | | This completes the removal of the old UUID implementation.
| * | profile: Migrate to the new UUID implementationMorph2022-02-057-102/+105
| | |
| * | hle: ipc_helpers: Ignore -Wclass-memaccessMorph2022-02-051-0/+8
| | | | | | | | | | | | This warning is triggered by GCC when copying into non-trivially default constructible types, as it uses the more restrictive std::is_trivial (which includes std::is_trivially_default_constructible) to determine whether memcpy is safe instead of std::is_trivially_copyable.
| * | service: Migrate to the new UUID implementationMorph2022-02-059-45/+36
| | |
* | | hle: kernel: KCodeMemory: Remove unused QueryMemory.bunnei2022-02-091-1/+0
| | |
* | | hle: kernel: KCodeMemory: Correct m_page_group number of pages.bunnei2022-02-091-2/+3
| |/ |/| | | Credits to @xerpi for finding this issue and pointing it out on #7519.
* | service: pm: Implement AtmosphereGetProcessInfotech-ticks2022-02-042-1/+46
|/
* Merge pull request #7835 from bunnei/page-table-lockbunnei2022-02-032-34/+46
|\ | | | | hle: kernel: KPageTable: Migrate locks to KScopedLightLock.
| * hle: kernel: KPageTable: Migrate locks to KScopedLightLock.bunnei2022-02-022-34/+46
| | | | | | | | - More accurately reflects real kernel behavior by using guest locks.
* | general: Replace NonCopyable struct with equivalentsLioncash2022-02-026-100/+134
| |
* | general: Move deleted copy/move constructor/assignment operators to public interfaceLioncash2022-02-024-9/+7
|/ | | | | | | | This allows for better compiler errors, where the compiler will state a copy or move couldn't occur due to the relevant function being deleted. Previously a compiler would warn about the relevant function not being accessible (which, while true, isn't as informative as it could be).
* svc: Add 32 bit SynchronizePreemptionStateNarr the Reg2022-02-011-1/+1
| | | | Used by Espgaluda II
* hle: kernel: KScheduler: Fix deadlock with core waiting for a thread lock that has migrated.bunnei2022-01-272-23/+24
| | | | | | | | - Previously, it was possible for a thread migration to occur from core A to core B. - Next, core B waits on a guest lock that must be released by a thread queued for core A. - Meanwhile, core A is still waiting on the core B's current thread lock - resulting in a deadlock. - Fix this by try-locking the thread lock. - Fixes softlocks in FF8 and Pokemon Legends Arceus.
* Merge pull request #7762 from bunnei/un-map-improvebunnei2022-01-273-111/+108
|\ | | | | Kernel Memory Updates (Part 4): Improve Un/MapPages, and more.
| * core: hle: kernel: KPageTable: Various improvements to MapPages and UnmapPages.bunnei2022-01-231-22/+25
| |
| * core: hle: kernel: KPageTable: MapProcessCode: Various cleanup.bunnei2022-01-231-11/+12
| |
| * core: hle: kernel: KPageTable: ReserveTransferMemory: Various cleanup.bunnei2022-01-231-6/+6
| |
| * core: hle: kernel: KPageTable: ResetTransferMemory: Various cleanup.bunnei2022-01-231-6/+5
| |
| * core: hle: kernel: KPageTable: SetMemoryAttribute: Various cleanup.bunnei2022-01-231-2/+3
| |
| * core: hle: kernel: KPageTable: Assert valid address on GetPhysicalAddr.bunnei2022-01-221-1/+3
| |
| * core: hle: kernel: KPageTable: Operate: Assert lock ownership.bunnei2022-01-221-2/+2
| |
| * core: hle: kernel: KPageTable: SetHeapSize: Cleanup & take physical memory lock.bunnei2022-01-221-4/+7
| |
| * core: hle: kernel: Refactor Un/MapPhysicalMemory to remove unnecessary methods.bunnei2022-01-222-50/+39
| |
| * core: hle: kernel: Rename Un/Map to Un/MapMeory.bunnei2022-01-223-7/+6
| |
* | Merge pull request #7771 from lioncash/assertMorph2022-01-251-2/+0
|\ \ | | | | | | kernel/k_affinity_mask: Remove duplicated assert
| * | kernel/k_affinity_mask: Remove duplicated assertLioncash2022-01-241-2/+0
| |/ | | | | | | This is already checked inside GetCoreBit()
* / hle: kernel: KThread: Improve Increment/Decrement RunningThreadCount.bunnei2022-01-233-24/+21
|/ | | | - Previously implementation was incorrect, and would occasionally underflow.
* Merge pull request #7737 from bunnei/fix-dummy-thread-leakbunnei2022-01-228-38/+118
|\ | | | | Various fixes to HLE service thread management
| * hle: kernel: KThread: Ensure host (dummy) threads block on locking.bunnei2022-01-224-0/+89
| | | | | | | | | | - But do not enter the priority queue, as otherwise they will be scheduled. - Allows dummy threads to use guest synchronization primitives.
| * hle: kernel: Remove redundant tracking of dummy threads.bunnei2022-01-211-9/+3
| | | | | | | | - These are already tracked by kernel's registered_objects member.
| * hle: kernel: KThread: DummyThread can be waited, ensure wait_queue is not nullptr.bunnei2022-01-211-6/+6
| |
| * hle: kernel: KThread: Decrease DummyThread priority to ensure it is never scheduled.bunnei2022-01-213-2/+5
| |
| * hle: kernel: service_thread: Ensure dummy thread is closed & destroyed on thread exit.bunnei2022-01-211-0/+5
| |
| * hle: kernel: KServerSession: Remove hack for CompleteSyncRequest.bunnei2022-01-211-11/+0
| | | | | | | | - This does not appear to be necessary anymore.
| * hle: kernel: KServerSession: Simplify CompleteSyncRequest EndWait.bunnei2022-01-212-12/+2
| | | | | | | | | | - Considering is_thread_waiting is never set, so we can remove IsThreadWaiting. - KThread::EndWait will take the scheduler lock, so we can remove the redundant lock.
| * hle: kernel: KThread: Ensure dummy threads never call EndWait.bunnei2022-01-211-0/+5
| | | | | | | | - These are only used by host threads for locking and will never have a wait_queue.
| * hle: kernel: KScheduler: Ensure dummy threads are never scheduled.bunnei2022-01-211-0/+5
| | | | | | | | - These are only used by host threads for locking.
| * hle: kernel: KThread: Rename thread_type_for_debugging -> thread_type.bunnei2022-01-212-4/+4
| | | | | | | | - This will be used to ensure that we do not schedule dummy threads.
* | Merge pull request #7752 from Morph1984/SetCpuOverclockEnabledbunnei2022-01-221-1/+13
|\ \ | | | | | | service: apm: Stub ISession SetCpuOverclockEnabled
| * | service: apm: Stub ISession SetCpuOverclockEnabledMorph2022-01-211-1/+13
| |/ | | | | | | | | | | Since we don't currently support CPU overclocking within the emulated system, this can be stubbed for now, like APM IsCpuOverclockEnabled. - Used by Gravity Rider Zero
* | service/wlan: Update function tablesLioncash2022-01-211-1/+1
| |
* | service/usb: Update function tablesLioncash2022-01-211-27/+15
| |
* | service/set: Update function tablesLioncash2022-01-211-0/+2
| |
* | service/ns: Update function tablesLioncash2022-01-211-0/+6
| |
* | service/nim: Update unknown function table entriesLioncash2022-01-211-0/+6
| |
* | service/friend: Update unknown function table entriesLioncash2022-01-211-6/+6
| |
* | service/filsystem: Update fsp-srv function tableLioncash2022-01-211-0/+3
| |
* | service/btm: Update function tablesLioncash2022-01-211-0/+30
| |
* | service/audio: Update audctl unknown function namesLioncash2022-01-211-8/+8
| |
* | service/am: Update omm function tablesLioncash2022-01-211-0/+1
| |
* | service/acc: Update unknown function namesLioncash2022-01-212-4/+4
|/ | | | Switchbrew has the function names now.
* Merge pull request #7726 from german77/clampMorph2022-01-191-1/+2
|\ | | | | service/hid: Initialize applet_resource on SetNpadAnalogStickUseCenterClamp
| * service/hid: Initialize applet_resource on SetNpadAnalogStickUseCenterClampgerman772022-01-191-1/+2
| |
* | Merge pull request #7701 from bunnei/clear-mem-pagesbunnei2022-01-195-16/+34
|\ \ | |/ |/| Kernel Memory Updates (Part 3): Clear KMemoryManager pages & other fixes
| * hle: kernel: k_memory_manager: Clear pages on allocation & free.bunnei2022-01-155-16/+34
| | | | | | | | | | - Heap pages should be zero'd. - Also explicitly passed along heap allocation option.
* | Merge pull request #7712 from bunnei/fix-thread-exitbunnei2022-01-189-38/+174
|\ \ | | | | | | Accurately implement thread exit
| * | core: hle: kernel: KThread: Integrate with KWorkerTask and implement DoWorkerTaskImpl.bunnei2022-01-152-2/+28
| | | | | | | | | | | | | | | | | | - This is used to terminate a thread asynchronously after it has been exited. - This fixes a crash that can occur in Pokemon Sword/Shield because a thread is incorrectly closed on svcExitThread, then, the thread is destroyed on svcCloseHandle while it is still scheduled. - Instead, we now wait for the thread to no longer be scheduled on all cores before destroying it from KWorkerTaskManager, which is accurate to HOS behavior.
| * | core: hle: kernel: KProcess: Integrate with KWorkerTask and add unimplemented DoWorkerTaskImpl.bunnei2022-01-152-3/+9
| | |
| * | core: hle: kernel: KThread: Replace Suspend with UpdateState & various updates.bunnei2022-01-152-33/+26
| | | | | | | | | | | | - This makes our implementations of these more closely match HOS.
| * | core: hle: kernel: Instantiate a kernel instance of KWorkerTaskManager.bunnei2022-01-152-0/+18
| | |
| * | core: hle: kernel: Add KWorkerTask and KWorkerTaskManager.bunnei2022-01-153-0/+93
| | | | | | | | | | | | - These primitives are used to dispatch asynchronous kernel tasks from KThread and KProcess.
* | | hle: remove no-op codeValeri2022-01-171-2/+0
| | | | | | | | | Found by static analysis with PVS-Studio. Nobody seems to really know what was it doing there.
* | | Merge pull request #7711 from bunnei/fix-service-thread-race-v2bunnei2022-01-151-12/+11
|\ \ \ | |_|/ |/| | hle: kernel: Fix service_threads access to be thread safe V2.
| * | hle: kernel: Fix service_threads access to be thread safe V2.bunnei2022-01-151-12/+11
| |/ | | | | | | | | | | - PR #7699 attempted to fix CreateServiceThread and ReleaseServiceThread to be thread safe, but inadvertently introduced a possible dead-lock. - With this PR, we use a worker thread to manage the service thread list, allowing it only to be accessed by a single thread, and guaranteeing threads will not destroy themselves. - Fixes a rare crash in Pokemon Sword/Shield, I've now run this game for ~12 hours non-stop and am quite confident this is a good solution for this issue.
* | Merge pull request #7707 from german77/slow-updatebunnei2022-01-151-1/+2
|\ \ | |/ |/| service/hid: Decrease motion update rate
| * service/hid: Decrease motion update rateNarr the Reg2022-01-131-1/+2
| | | | | | Motion stops working in Mario Tennis in swing mode if the update rate is too fast even when HW it updates at the same speed. 10ms it's the minimum period that the game needs to start working again.
* | Merge pull request #7699 from bunnei/fix-service-thread-raceMai M2022-01-141-7/+27
|\ \ | | | | | | hle: kernel: Fix service_threads access to be thread safe.
| * | hle: kernel: Fix service_threads access to be thread safe.bunnei2022-01-141-7/+27
| |/ | | | | | | | | - CreateServiceThread and ReleaseServiceThread can be accessed by different threads, uses a lock to make this thread safe. - Fixes a rare crash in Pokemon Sword/Shield that can occur when a new service thread is being created while an old one is being destroyed.
* | hle: kernel: k_page_table: Update SetProcessMemoryPermission.bunnei2022-01-126-45/+68
| |
* | hle: service: ldr: UnmapCodeMemory BSS only when set.bunnei2022-01-121-3/+7
| |
* | hle: kernel: k_page_table: ReadAndWrite -> UserReadWrite.bunnei2022-01-123-18/+18
| |
* | hle: kernel: k_page_table: Rename *ProcessCodeMemory -> *CodeMemory.bunnei2022-01-124-20/+19
|/
* core: hle: kernel: svc: Updates to SetMemoryAttribute and SetMemoryPermission.bunnei2022-01-083-45/+46
|
* core: hle: kernel: k_page_table: Update CheckMemoryState.bunnei2022-01-084-116/+166
|
* Merge pull request #7636 from vonchenplus/buffer_queue_querybunnei2022-01-043-3/+9
|\ | | | | core:hle:service:nvflinger Implement few type in bufferqueue query method
| * Remove invalid assertion statementFeng Chen2021-12-281-3/+0
| |
| * Implement few type in bufferqueue query methodFeng Chen2021-12-282-0/+9
| |
* | Revert "Merge pull request #7668 from ameerj/fence-stop-token"ameerj2022-01-041-2/+1
| | | | | | | | | | This reverts commit e7733544779f2706d108682dd027d44e7fa5ff4b, reversing changes made to abbbdc2bc027ed7af236625ae8427a46df63f7e7.
* | gpu: Use std::stop_token in WaitFence for VSync threadameerj2022-01-031-1/+2
| | | | | | | | Fixes a hang that may occur when stopping emulation and the VSync thread is blocked on the syncpoint condition variable.
* | core: hle: kernel: Implement thread pinning.bunnei2021-12-319-14/+138
| | | | | | | | | | - We largely had the mechanics in place for thread pinning, this change hooks these up. - Validated with tests https://github.com/Atmosphere-NX/Atmosphere/blob/master/tests/TestSvc/source/test_thread_pinning.cpp.
* | core: hle: kernel: Updated implementation of svcSetHeapSize.bunnei2021-12-286-83/+141
|/ | | | | - Updates our svcSetHeapSize with latest HOS, furthermore allowing heap size to properly be extended/shrunk. - Validated with tests https://github.com/Atmosphere-NX/Atmosphere/blob/master/tests/TestSvc/source/test_set_heap_size.cpp.
* Merge pull request #7621 from bunnei/set-mem-permbunnei2021-12-284-1/+67
|\ | | | | core: hle: kernel: Implement SetMemoryPermission.
| * core: hle: kernel: Implement SetMemoryPermission.bunnei2021-12-234-1/+67
| | | | | | | | - Not seen in any games yet, but validated with kernel tests.
* | core: hle: kernel: KThread: X18 should be a cryptographically random number.bunnei2021-12-231-0/+2
|/ | | | | - This was added with firmware 11.0.0 (https://switchbrew.org/wiki/11.0.0). - X18 is OR'd by kernel with 1, to make sure it is odd.
* hle: kernel: svc: GetInfo: Fix error checking with IdleTickCount.bunnei2021-12-221-14/+9
| | | | | - Enforce tha the supplied handle is invalid, not valid. - This gets Witcher 3 booting.
* Merge pull request #7481 from german77/gyro-biasbunnei2021-12-212-14/+16
|\ | | | | service/hid: Improve console motion accuracy
| * service/hid: Improve console motion accuracyNarr the Reg2021-12-132-14/+16
| |
* | Merge pull request #7597 from bunnei/remove-global-lockbunnei2021-12-207-56/+1
|\ \ | | | | | | core: hle: Remove global HLE lock.
| * | core: hle: Remove global HLE lock.bunnei2021-12-187-56/+1
| | | | | | | | | | | | | | | - This was added early on as a hack to protect against some concurrency issues. - It's not clear that this serves any purpose anymore, and if it does, individual components should be fixed rather than using a global recursive mutex.
* | | kernel: Manually destroy the current process during shut downameerj2021-12-191-1/+4
| | | | | | | | | | | | Avoids a memory leak.
* | | core/hid: Cancel any vibration after the testNarr the Reg2021-12-163-11/+5
|/ /
* | Remove erroneous #pragma onceValeri2021-12-131-2/+0
| |
* | Merge pull request #7462 from bunnei/kernel-improve-schedulingbunnei2021-12-1328-612/+883
|\ \ | | | | | | Kernel: Improve threading & scheduling V3
| * | hle: kernel k_scheduler: EnableScheduling: Remove redundant GetCurrentThreadPointer calls.bunnei2021-12-071-3/+5
| | |
| * | hle: kernel k_process: Remove unnecessary .at usage with thread pinning methods.bunnei2021-12-071-3/+3
| | |
| * | hle: kernel: Remove unnecessary virtual specifier on NotifyAvailable.bunnei2021-12-071-2/+2
| | |
| * | hle: kernel: Remove unnecessary virtual specifier on EndWait.bunnei2021-12-071-1/+1
| | |
| * | hle: kernel: k_light_condition_variable: Revert unnecessary license comment changes.bunnei2021-12-071-1/+1
| | |
| * | hle: kernel: k_condition_variable: Revert unnecessary style changes.bunnei2021-12-071-2/+2
| | |
| * | hle: kernel: Remove unnecessary virtual specifier on CancelWait.bunnei2021-12-076-14/+14
| | |
| * | hle: kernel: service_thread: Force stop threads on destruction.bunnei2021-12-071-1/+7
| | |
| * | hle: kernel: k_light_lock: Implement CancelWait.bunnei2021-12-071-5/+10
| | | | | | | | | | | | - Fixes a crash in Megadimension Neptunia VII.
| * | hle: kernel: service_thread: Use std::jthread.bunnei2021-12-071-18/+19
| | | | | | | | | | | | - Fixes a potential deadlock on service thread shutdown.
| * | hle: kernel: k_thread: Skip reschedule on DisableDispatch with SC.bunnei2021-12-071-0/+5
| | |
| * | hle: kernel: k_thread: Rename sleeping_queue -> wait_queue.bunnei2021-12-072-17/+13
| | |
| * | hle: kernel: svc: Fix deadlock that can occur with single core.bunnei2021-12-071-10/+8
| | |
| * | hle: kernel: k_thread: Treat dummy threads as a special type.bunnei2021-12-072-1/+4
| | |
| * | hle: kernel: fix timing on thread preemptionFernandoS272021-12-071-4/+2
| | |
| * | hle: kernel: fix scheduling ops from HLE host thread.FernandoS272021-12-071-3/+3
| | |
| * | hle: kernel: Add a flag for indicating that the kernel is currently shutting down.bunnei2021-12-076-0/+49
| | |
| * | hle: kernel: KSynchronizationObject: Fix variable shadowing.bunnei2021-12-071-8/+8
| | |
| * | hle: kernel: Cleanup to match coding style.bunnei2021-12-076-26/+21
| | |
| * | hle: kernel: KProcess: Improvements for thread pinning.bunnei2021-12-072-8/+26
| | |
| * | hle: kernel: KThreadQueue: Remove deprecated code.bunnei2021-12-071-63/+0
| | |
| * | hle: kernel: KConditionVariable: Various updates & simplifications.bunnei2021-12-072-121/+65
| | |
| * | hle: kernel: KThread: Migrate to updated KThreadQueue (part 2).bunnei2021-12-071-29/+19
| | |
| * | hle: kernel: KThread: Migrate to updated KThreadQueue (part 1).bunnei2021-12-073-60/+71
| | |
| * | hle: kernel: KConditionVariable: Migrate to updated KThreadQueue.bunnei2021-12-071-12/+55
| | |
| * | hle: kernel: KServerSession: Migrate to updated KThreadQueue.bunnei2021-12-072-5/+11
| | |
| * | hle: kernel: KLightConditionVariable: Migrate to updated KThreadQueue.bunnei2021-12-072-54/+86
| | |
| * | hle: kernel: KLightLock: Migrate to updated KThreadQueue.bunnei2021-12-072-35/+36
| | |
| * | hle: kernel: KAddressArbiter: Migrate to updated KThreadQueue.bunnei2021-12-071-43/+39
| | |
| * | hle: kernel: KThread: Remove tracking of sync object from threads.bunnei2021-12-076-41/+21
| | |
| * | hle: kernel: Update KThreadQueue and migrate KSynchronizationObject.bunnei2021-12-077-75/+250
| | |
| * | core: hle: kernel: Disable dispatch count tracking on single core.bunnei2021-12-072-4/+13
| | | | | | | | | | | | - This would have limited value, and would be a mess to handle properly.
| * | core: hle: kernel: k_thread: Mark KScopedDisableDispatch as nodiscard.bunnei2021-12-071-1/+1
| | |
| * | core: hle: kernel: k_auto_object: Add GetName method.bunnei2021-12-071-0/+4
| | | | | | | | | | | | - Useful purely for debugging.
| * | core: hle: kernel: DisableDispatch on suspend threads.bunnei2021-12-071-0/+3
| | |
| * | core: hle: kernel: k_scheduler: Improve DisableScheduling and EnableScheduling.bunnei2021-12-071-14/+9
| | |
| * | core: hle: kernel: Use CurrentPhysicalCoreIndex as appropriate.bunnei2021-12-071-6/+2
| | |
| * | core: hle: kernel: k_scheduler: Remove unnecessary MakeCurrentProcess.bunnei2021-12-071-5/+0
| | |
| * | core: hle: kernel: k_scheduler: Improve ScheduleImpl.bunnei2021-12-071-6/+7
| | |
| * | core: hle: kernel: k_scheduler: Improve Unload.bunnei2021-12-071-17/+29
| | |
| * | core: hle: kernel: k_process: DisableDispatch on main thread.bunnei2021-12-071-0/+1
| | |
| * | core: hle: kernel: k_handle_table: Use KScopedDisableDispatch as necessary.bunnei2021-12-072-0/+8
| | |
| * | core: hle: kernel: k_thread: Add KScopedDisableDispatch.bunnei2021-12-072-1/+47
| | |
| * | core: hle: kernel: Ensure idle threads are closed before destroying scheduler.bunnei2021-12-073-24/+22
| | |
| * | core: hle: kernel: Reflect non-emulated threads as core 3.bunnei2021-12-075-5/+17
| | |
* | | Merge pull request #7519 from itsmeft24/masterbunnei2021-12-0911-6/+609
|\ \ \ | | | | | | | | kernel: svc: Implement ProcessMemory and CodeMemory SVCs
| * | | Update k_code_memory.hitsmeft242021-12-071-6/+6
| | | |
| * | | make KCodeMemory::GetSourceAddress constitsmeft242021-12-071-1/+1
| | | | | | | | | | | | Co-authored-by: Mai M. <mathew1800@gmail.com>
| * | | fix formattingitsmeft242021-12-061-1/+6
| | | |
| * | | move private members below public membersitsmeft242021-12-061-10/+11
| | | |
| * | | fix formattingitsmeft242021-12-061-4/+1
| | | |
| * | | fix formattingitsmeft242021-12-061-1/+1
| | | | | | | | | | | | Co-authored-by: Mai M. <mathew1800@gmail.com>
| * | | fix formattingitsmeft242021-12-062-2/+2
| | | |
| * | | Remove unnecessary includesitsmeft242021-12-062-50/+13
| | | |
| * | | Add copyright noticeitsmeft242021-12-052-0/+8
| | | |
| * | | kernel: svc: Implement Map/UnmapProcessMemory and Create/ControlCodeMemoryitsmeft242021-12-0511-7/+636
| | | | | | | | | | | | | | | | Used by Skyline modding framework
* | | | Merge pull request #7525 from german77/notifabunnei2021-12-083-0/+73
|\ \ \ \ | | | | | | | | | | service/notif: Add notif:a and stub ListAlarmSettings, Initialize
| * | | | service/notif: Add notif:a and stub ListAlarmSettings,Initializegerman772021-12-063-0/+73
| |/ / / | | | | | | | | | | | | Used by ring fit adventure 1.2.0
* | | | Merge pull request #7521 from german77/dual_single_joyconsbunnei2021-12-083-38/+161
|\ \ \ \ | |_|_|/ |/| | | service/hid: Implement SetNpadJoyAssignmentMode
| * | | service/hid: Implement SetNpadJoyAssignmentModegerman772021-12-053-38/+161
| |/ /
* | | Merge pull request #7488 from vonchenplus/support_multiple_videos_playingbunnei2021-12-086-8/+29
|\ \ \ | |_|/ |/| | Support multiple videos playing
| * | Address feedbackFeng Chen2021-12-044-13/+22
| | |
| * | Support multiple videos playingFeng Chen2021-12-024-9/+21
| | |
* | | Merge pull request #7524 from german77/hid_stubbunnei2021-12-062-2/+35
|\ \ \ | | | | | | | | service/hid: Stub SetNpadCaptureButtonAssignment and ClearNpadCaptureButtonAssignment
| * | | service/hid: Stub SetNpadCaptureButtonAssignment and ClearNpadCaptureButtonAssignmentgerman772021-12-062-2/+35
| | |/ | |/| | | | | | | Used by ring fit adventure 1.2.0
* / | general: Add missing copyright noticesameerj2021-12-051-0/+4
|/ /
* | core/hid: Ensure only valid npad are connectedgerman772021-12-051-17/+13
| |
* | Merge pull request #7489 from Morph1984/steady-clockbunnei2021-12-041-2/+2
|\ \ | | | | | | general: Replace high_resolution_clock with steady_clock
| * | general: Replace high_resolution_clock with steady_clockMorph2021-12-021-2/+2
| |/ | | | | | | On some OSes, high_resolution_clock is an alias to system_clock and is not monotonic in nature. Replace this with steady_clock.
* / service: am: ISelfController: Stub SaveCurrentScreenshotMorph2021-12-033-2/+15
|/ | | | - Used by Disney Magical World 2: Enchanted Edition
* service: friend: Implement GetCompletionEventMorph2021-11-301-2/+21
| | | | - Used by Super Bomberman R Online
* npad: Return NpadButton in GetAndResetPressStateMorph2021-11-302-5/+5
| | | | We were previously truncating this to a u32 as there were no known buttons that used the full 64 bits of this type. Fix this now that we know they are used.
* general: Fix handheld typoMorph2021-11-291-1/+1
|
* Merge pull request #7438 from german77/homebrew2bunnei2021-11-285-2/+144
|\ | | | | Core: Stub services and functions needed for checkpoint
| * core/ns: Implement GetReadOnlyApplicationControlDataInterfaceNarr the Reg2021-11-282-1/+26
| | | | | | | | Used in checkpoint homebrew
| * core/pdm: Stub QueryPlayStatisticsByApplicationIdAndUserAccountIdNarr the Reg2021-11-283-0/+105
| | | | | | | | Used in checkpoint homebrew
| * core/hid: Stub GetUniquePadsFromNpadNarr the Reg2021-11-271-1/+13
| | | | | | | | Used in checkpoint homebrew
* | settings: Add debug setting to enable all controllersgerman772021-11-281-0/+4
|/
* service/hid: Finish converting LIFO objects and address some nitsNarr the Reg2021-11-2512-91/+46
|
* kraken: Address comments from reviewgerman772021-11-252-5/+4
| | | | Fix compiler bug
* core/hid: Improve accuary of mouse implementationgerman772021-11-256-18/+28
|
* core/hid: Fully implement native mousegerman772021-11-251-4/+5
|
* core/hid: Improve accuracy of the keyboard implementationgerman772021-11-253-4/+34
|
* core/hid: Fix keyboard alignmentgerman772021-11-251-0/+1
|
* core/hid: Remove usage of native types, fix a couple of errors with motiongerman772021-11-255-411/+544
|
* service/hid: Remove includes of core.h and settings.hgerman772021-11-2522-51/+56
|
* service/hid: Add support for new controllersgerman772021-11-251-1/+30
|
* core/hid: Rename NpadType to NpadStyleIndexgerman772021-11-253-75/+79
|
* second commit lion reviewgerman772021-11-259-5/+15
|
* kraken: Address comments from reviewgerman772021-11-254-8/+5
| | | | start lion review
* core/hid: Update structs to 13.1.0german772021-11-259-42/+89
|
* core/hid: Rework battery mappingsgerman772021-11-251-2/+9
|
* service/hid: Fix memory allocated incorrectlygerman772021-11-255-7/+7
|
* Morph review first wavegerman772021-11-2512-74/+56
|
* service/hid: Match shared memory closer to HWgerman772021-11-252-26/+75
|
* kraken: Address comments from reviewgerman772021-11-254-9/+8
| | | | review fixes
* service/hid: Use ring buffer for gesturesgerman772021-11-252-79/+52
|
* service/hid: Fix gesture inputgerman772021-11-252-61/+92
|
* configuration: Migrate controller settings to emulated controllergerman772021-11-251-11/+3
|
* core/hid: Only signal when neededgerman772021-11-251-2/+4
|
* hid: Fix controller connection/disconnectiongerman772021-11-253-26/+56
|
* kraken: Fix errors from rebase and format filesgerman772021-11-251-1/+0
|
* core/hid: Add output devicesgerman772021-11-252-40/+5
|
* core/frontend: Update appletsgerman772021-11-251-1/+1
|
* service/hid: Rewrite npad to use ring lifo and the emulated controllergerman772021-11-252-890/+605
|
* service/hid: Update console sixaxis to the emulated consolegerman772021-11-252-28/+26
|
* service/hid: Update mouse and keyboard to use ring lifo and the emulated devicegerman772021-11-254-158/+71
|
* service/hid: Update touch and gestures to use ring lifo and the emulated consolegerman772021-11-254-370/+191
|
* service/hid: Update debug pad, xpad, stubbed and controller base to use ring lifo and the emulated controllergerman772021-11-257-166/+80
|
* service/hid: Use remove duplicated code, update namesgerman772021-11-252-64/+30
|
* service/hid: Create ring LIFOgerman772021-11-251-0/+54
|
* settings: Cleanup settingsgerman772021-11-254-5/+4
|
* Merge pull request #7394 from Morph1984/svc-SetMemoryPermissionbunnei2021-11-225-12/+64
|\ | | | | kernel: svc: Implement SetProcessMemoryPermission
| * kernel: svc: Move all IsValid functions to an anonymous namespaceMorph2021-11-211-3/+15
| |
| * kernel: svc: Implement SetProcessMemoryPermissionMorph2021-11-211-1/+41
| | | | | | | | - Used by Skyline modding framework
| * kernel: KPageTable: Rename SetCodeMemoryPermission to SetProcessMemoryPermissionMorph2021-11-214-8/+8
| |
* | Merge pull request #7359 from heinermann/kthread_crashbunnei2021-11-211-8/+14
|\ \ | | | | | | Fix crash on exit due to static scoped dummy threads
| * | Fix crash on exit due to static scoped dummy threadsAdam Heinermann2021-11-181-8/+14
| |/
* | service: pm: Implement AtmosphereGetProcessIdMorph2021-11-211-0/+24
| | | | | | | | - Used by Skyline modding framework
* | service: pm: Add all relevant result codesMorph2021-11-211-3/+8
| |
* | service: pm: Rename title id to program idMorph2021-11-211-6/+6
|/
* Settings: eliminate rescaling_factor.Fernando Sahmkow2021-11-162-27/+12
|
* applets/swkbd: Fix text check message encodingMorph2021-11-081-7/+15
| | | | The text check message can be encoded in UTF-8.
* applets/swkbd: Skip text checking if the text has been confirmedMorph2021-11-082-8/+15
| | | | | | | Confirm means that the text has already been checked by the application to be correct, but is asking the user for confirmation. The confirmation text itself seems to be corrupted though, this needs to be investigated. Fixes the software keyboard in Famicom Detective Club: The Missing Heir
* service/pctl: Stub EndFreeCommunicationNarr the Reg2021-11-051-1/+8
| | | - Used by Just Dance 2022
* Merge pull request #7279 from Morph1984/system-get-program-idMorph2021-11-0517-45/+31
|\ | | | | general: Get the current process program id directly from the system
| * general: Get the current process program id directly from the systemMorph2021-11-0413-43/+26
| | | | | | | | This allows us to avoid including KProcess' header file in files that only need to get the current process' program id.
| * general: Rename GetTitleID to GetProgramIDMorph2021-11-0417-32/+35
| |
* | Merge pull request #7287 from Morph1984/stub-aocFernando S2021-11-052-0/+29
|\ \ | |/ |/| service: aoc: Stub more 13.x functions used by Animal Crossing
| * service: aoc: Stub NotifyUnmountAddOnContentMorph2021-11-042-1/+9
| | | | | | | | Used by Animal Crossing: New Horizons v2.0.0 DLC
| * service: aoc: Stub NotifyMountAddOnContent and NotifyMountAddOnContentMorph2021-11-042-0/+21
| | | | | | | | Used by Animal Crossing: New Horizons v2.0.0 DLC
* | Merge pull request #7282 from ameerj/core-includesbunnei2021-11-0489-163/+6
|\ \ | |/ |/| core: Reduce unused header includes
| * core: Fix transitive include build errorsameerj2021-11-043-0/+6
| |
| * core: Remove unused includesameerj2021-11-0488-164/+1
| |
* | service/acc: Rename Unknown160 to InitializeApplicationInfoV2german772021-11-043-3/+3
| |
* | service: acc: Stub acc:u0 '160'Morph2021-11-043-0/+9
|/ | | | | | - Used by Animal Crossing: New Horizons v2.0.0 Since the name is currently unknown, '160' is used as a placeholder.
* svc: Correct WaitSynchronization num_handles param typeMorph2021-11-032-4/+4
| | | | num_handles is a s32
* general: Remove MakeResult helpersMorph2021-11-0210-60/+41
| | | | This is made obsolete by the presence of implicit constructors.
* hle/result: Amend ResultVal documentationMorph2021-11-021-12/+10
| | | | This amends the documentation slightly to reflect the updated interface.
* hle/result: Reimplement ResultVal using Common::ExpectedMorph2021-11-021-117/+63
| | | | | Common::Expected effectively provides the same functions as ResultVal, so we can implement it with this. This can be replaced with std::expected with minimal effort should it be standardized in the C++ Standard Template Library.
* Merge pull request #7227 from vonchenplus/fix_memory_leak_v2bunnei2021-11-025-11/+51
|\ | | | | Fix memory leak v2
| * Fix dangling kernel objects when exitingFeng Chen2021-10-272-11/+13
| |
| * Revert PR7009Feng Chen2021-10-271-2/+2
| |
| * Fix memory leakFeng Chen2021-10-274-0/+38
| |
* | Merge pull request #7244 from Morph1984/application-lang-pt-brbunnei2021-10-302-1/+26
|\ \ | | | | | | file_sys/ns: Add Brazilian Portuguese to the list of ApplicationLanguage
| * | ns: language: Add BrazilianPortuguese to ApplicationLanguageMorph2021-10-292-1/+26
| | | | | | | | | | | | It seems that Nintendo finally filled that last empty spot in ApplicationLanguage for a total of 16 supported languages.
* | | Merge pull request #7240 from Morph1984/resultval-remove-cvbunnei2021-10-301-2/+2
|\ \ \ | | | | | | | | hle/result: Remove cv-qualifiers from Arg in MakeResult
| * | | hle/result: Remove cv-qualifiers from Arg in MakeResultMorph2021-10-281-2/+2
| | |/ | |/| | | | | | | This removes the const qualification for types when MakeResult(arg) is used in a const member function, allowing for automatic deduction and removing the need to manually specify the non-const type as the template argument.
* | | hle/result: Declare copy/move constructor/assignment as noexceptMorph2021-10-281-3/+3
| | | | | | | | | | | | While we're at it, we can also declare these copy/move constructor/assignment as noexcept.
* | | hle/result: Add move assignment operator in ResultValMorph2021-10-281-0/+20
| |/ |/| | | | | ResultVal was missing a move assignment operator, add it.
* | Merge pull request #7193 from FernandoS27/idleMorph2021-10-252-0/+22
|\ \ | |/ |/| SVC: Implement svcInfo:IdleTickCount
| * SVC: Implement svcInfo:IdleTickCountFernando Sahmkow2021-10-162-0/+22
| | | | | | | | Used by the Witcher 3
* | Fixup channel submit IOCTL syncpoint parametersBilly Laws2021-10-242-21/+9
| | | | | | | | | | | | The current arguments worked by happenstance as games only ever submit one syncpoint and request one fence back, if a game were to do something other than this then the arguments would've been parsed entirely wrong.
* | Merge pull request #7198 from ameerj/settings-chronobunnei2021-10-191-6/+7
|\ \ | | | | | | settings: Remove std::chrono usage
| * | settings: Remove std::chrono usageameerj2021-10-171-6/+7
| |/ | | | | | | Alleviates the dependency on chrono for all files that include settings.h
* | Merge pull request #7173 from Morph1984/invalidate-unmapbunnei2021-10-171-0/+2
|\ \ | |/ |/| KPageTable: Perform ranged invalidation when unmapping code memory
| * KPageTable: Perform ranged invalidation when unmapping code memoryMorph2021-10-131-0/+2
| | | | | | | | Co-Authored-By: Fernando S. <1731197+FernandoS27@users.noreply.github.com>
* | Merge pull request #7187 from FernandoS27/boy-i-say-boybunnei2021-10-162-0/+16
|\ \ | | | | | | NVHost_Ctrl: Force wait if the gpu falls behind too long.
| * | NvHost/Core: Address Feedback.Fernando Sahmkow2021-10-161-3/+5
| | |
| * | Suspend temporallyFernandoS272021-10-161-1/+2
| | |
| * | NVHost_Ctrl: Force wait if the gpu falls behind too long.FernandoS272021-10-162-0/+13
| |/
* / service/vi: Stub IHOSBinderDriver::TransactParcel GetBufferHistory (#7184)Feng Chen2021-10-161-1/+11
|/
* Merge pull request #7110 from vonchenplus/fix_extract_offline_romefs_errorMorph2021-10-111-0/+10
|\ | | | | applets/web: Fallback to loader to get the manual romfs if none is found
| * applets/web: Fallback to loader to get the manual romfs if none is foundFeng Chen2021-10-111-0/+10
| |
* | kernel: hle_ipc: Foward declare KAutoObjectMorph2021-10-072-1/+2
| |
* | service: Reduce header include overheadMorph2021-10-0730-38/+10
| |
* | Merge pull request #7118 from ameerj/vc-gpu-implFernando S2021-10-065-52/+36
|\ \ | | | | | | gpu: Migrate implementation to the cpp file
| * | nvflinger: Use jthread and stop_token for VSync threadameerj2021-10-032-32/+8
| | | | | | | | | | | | Avoids a destruction data race that may occur on the vsync thread
| * | nvhost_ctrl: Refactor usage of gpu.LockSync()ameerj2021-10-031-15/+15
| | | | | | | | | | | | This seems to only be used to protect a later gpu function call. So we can move the lock into that call instead.
| * | gpu: Migrate implementation to the cpp fileameerj2021-10-032-5/+13
| | |
* | | Merge pull request #7115 from ameerj/log-compilebunnei2021-10-054-0/+6
|\ \ \ | | | | | | | | common/logging: Reduce dependent header include overhead
| * | | common/logging: Reduce scope of fmt includeameerj2021-10-022-0/+3
| | | |
| * | | common/logging: Move Log::Entry declaration to a separate headerameerj2021-10-022-0/+3
| |/ / | | | | | | | | | This reduces the load of requiring to include std::chrono in all files which include log.h
* | | Merge pull request #7103 from Morph1984/service-ctx-eventbunnei2021-10-0526-271/+367
|\ \ \ | | | | | | | | service: Replace all service event creation with ServiceContext::CreateEvent
| * | | service: Replace service event creation with ServiceContext::CreateEventMorph2021-10-0226-271/+367
| | | | | | | | | | | | | | | | The service context helps to manage all created events and allows us to close them upon destruction.
* | | | Merge pull request #7091 from vonchenplus/fix_memroy_leakAmeer J2021-10-045-9/+113
|\ \ \ \ | | | | | | | | | | core: Fix memory leak
| * | | | Fix KShareMemory object leakFeng Chen2021-09-294-3/+105
| | | | |
| * | | | Fix KScopedAutoObject object leak when SendSyncRequestFeng Chen2021-09-251-6/+8
| | |_|/ | |/| |
* | | | service: am: Make use of Exit to exit the currently running applicationMorph2021-10-021-2/+2
| |/ / |/| | | | | | | | This also moves the call to the end to ensure services are properly destructed on exit.
* | | Merge pull request #7102 from Morph1984/remove-boxcatbunnei2021-10-023-619/+0
|\ \ \ | |_|/ |/| | Remove Boxcat BCAT backend
| * | service: bcat: Remove BoxCat BCAT implementationMorph2021-09-293-619/+0
| | | | | | | | | | | | | | | The current implementation of BoxCat as it stands is non-functional due to the reliance on a server providing BCAT files. This implementation will eventually be replaced with one that allows the use of local BCAT files dumped from a Nintendo Switch.
* | | style: Remove extra space preceding the :: operatorMorph2021-09-295-6/+6
|/ /
* | Merge pull request #7018 from lat9nq/splat-stubsMorph2021-09-292-26/+67
|\ \ | | | | | | audin_u: stub Start, RegisterBufferEvent, AppendAudioInBufferAuto
| * | audin_u: Return a buffer event in RegisterBufferEventlat9nq2021-09-152-2/+12
| | | | | | | | | | | | Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com>
| * | audin_u: stub Start, RegisterBufferEvent, AppendAudioInBufferAutolat9nq2021-09-152-26/+57
| | | | | | | | | | | | | | | | | | This also moves IAudioIn's definition to the header. Required for Splatoon 2 LAN play.
* | | service/es: Update to 13.0.0german772021-09-271-0/+6
| | |
* | | service/npns: Update to 13.0.0german772021-09-271-0/+1
| | |
* | | service/vi: Update to 13.0.0german772021-09-272-0/+2
| | |
* | | service/am: Update to 13.0.0german772021-09-271-0/+4
| | |
* | | service/audio: Update to 13.0.0german772021-09-272-1/+10
| | |
* | | service/hid: Update to 13.0.0german772021-09-272-0/+10
| | |
* | | service/btdrv: Update to 13.0.0german772021-09-271-0/+4
| | |
* | | service/usb: Update to 13.0.0german772021-09-271-3/+3
| | |
* | | service: bsd: Stub ReadMorph2021-09-251-6/+5
| | | | | | | | | | | | - Used by Diablo II: Resurrected
* | | service: bsd: Implement ReadMorph2021-09-242-1/+15
| | | | | | | | | | | | - Used by Diablo II: Resurrected
* | | general: Update style to clang-format-12ameerj2021-09-244-27/+19
| | |
* | | common/uuid: Add validity checking functions to interfaceLioncash2021-09-223-7/+7
| |/ |/| | | | | | | Given we have a function to invalidate, we should also have ones to query the validity. Also makes the code more straightforward to read.
* | Merge pull request #7015 from german77/NotGoodForTerrabunnei2021-09-171-1/+14
|\ \ | | | | | | ngct: Stub Match
| * | ngct: Stub MatchNarr the Reg2021-09-151-1/+14
| |/ | | | | Needed for Cruis'n Blast
* / vfs: Partially implement GetFileTimeStampRawMorph2021-09-143-1/+37
|/ | | | Gets rid of homebrew warnings using this func
* FS: Mark recursive CreateDirectory as inaccurate and temporaryMorph2021-09-121-0/+5
|
* Merge pull request #6975 from ogniK5377/acc-async-ctxMorph2021-09-123-19/+152
|\ | | | | account: EnsureTokenIdCacheAsync
| * Mark is_complete as atomicChloe Marcec2021-09-082-4/+5
| |
| * Addressed issuesChloe Marcec2021-09-083-15/+14
| |
| * address name shadowing with systemChloe Marcec2021-09-061-2/+2
| |
| * account: EnsureTokenIdCacheAsyncChloe Marcec2021-09-063-19/+152
| | | | | | | | Closes #2547, #6946
* | Merge pull request #6974 from ogniK5377/fs-recursive-createdirMorph2021-09-121-8/+13
|\ \ | | | | | | FS: Recursively create directories for CreateDirectory
| * | Addressed issuesChloe2021-09-081-1/+1
| | | | | | | | | Co-authored-by: Mai M. <mathew1800@gmail.com>
| * | FS: Recursively create directories for CreateDirectoryChloe Marcec2021-09-061-8/+13
| | | | | | | | | | | | | | | | | | Originally we only created the parent directory, this caused issues for creating directories which also contained subdirectories, eg `/Folder1/Folder2` This allows the ultimate mod manager homebrew to at least boot
* | | Merge pull request #6992 from german77/brainsMorph2021-09-125-3/+44
|\ \ \ | | | | | | | | hid/am: Stub SetTouchScreenConfiguration and implement GetNotificationStorageChannelEvent
| * | | am: Implement GetNotificationStorageChannelEventgerman772021-09-102-2/+16
| | | |
| * | | hid: Stub SetTouchScreenConfigurationgerman772021-09-103-1/+28
| | | |
* | | | Merge pull request #6987 from Morph1984/common-errorMorph2021-09-121-0/+1
|\ \ \ \ | | | | | | | | | | common: Move error handling functions out of common_funcs
| * | | | kernel: Add missing <functional> includeMorph2021-09-111-0/+1
| | | | |
* | | | | Merge pull request #6986 from Morph1984/version-updateMorph2021-09-121-5/+12
|\ \ \ \ \ | |/ / / / |/| | | | api_version: Update and add AtmosphereTargetFirmware
| * | | | api_version: Update and add AtmosphereTargetFirmwareMorph2021-09-101-5/+12
| |/ / /
* | | | Merge pull request #6981 from ameerj/nvflinger-hb-formatFernando S2021-09-113-7/+8
|\ \ \ \ | |/ / / |/| | | nvflinger: Use external surface format for framebuffer creation
| * | | nvflinger: Use external surface format for framebuffer creationameerj2021-09-073-7/+8
| | |/ | |/| | | | | | | | | | | | | The format member the IGBPBuffer may not always specify the correct desired format. Using the external format member ensures a valid format is provided when creating the framebuffer. Fixes homebrew using the wrong framebuffer format.
* / | core: hle: service: buffer_queue: Improve management of KEvent.bunnei2021-09-053-14/+24
|/ /
* / core: hle: service: nvflinger/vi: Improve management of KEvent.bunnei2021-09-044-16/+30
|/
* Merge pull request #6905 from Morph1984/nifm-miscbunnei2021-08-291-55/+58
|\ | | | | nifm/network_interface: Cleanup and populate fields in GetCurrentNetworkProfile
| * service: nifm: Populate fields in GetCurrentNetworkProfileMorph2021-08-271-29/+37
| | | | | | | | Populates the current_address, subnet_mask, and gateway fields from the selected network interface.
| * service: nifm: Cleanup GetCurrentIpConfigInfoMorph2021-08-271-26/+21
| |
* | ngct: Stub NGCT:U servicegerman772021-08-273-0/+68
|/
* Revert "kernel: Various improvements to scheduler"bunnei2021-08-2619-205/+104
|
* Merge pull request #6878 from BreadFish64/optimize-GetHostThreadIDAmeer J2021-08-241-10/+13
|\ | | | | kernel: Optimize GetHostThreadID
| * kernel: Optimize GetHostThreadIDBreadFish642021-08-161-10/+13
| |
* | applet_error: Fix 64-bit error code conversionMorph2021-08-191-6/+25
| |
* | Fix crash in logging in CreateStrayLayerValeri2021-08-191-1/+1
| | | | | | It was trying to log value of layer_id which is specifically known not to exist, potentially leading to segfault. Log display_id instead.
* | Fix check is thread current in GetThreadContextValeri2021-08-191-1/+1
| | | | | | Misplaced break made it only check for the first core.
* | Merge pull request #6832 from bunnei/scheduler-improvementsbunnei2021-08-1919-104/+205
|\ \ | | | | | | kernel: Various improvements to scheduler
| * | core: hle: kernel: Disable dispatch count tracking on single core.bunnei2021-08-142-4/+11
| | | | | | | | | | | | - This would have limited value, and would be a mess to handle properly.
| * | core: hle: kernel: k_thread: Mark KScopedDisableDispatch as nodiscard.bunnei2021-08-071-1/+1
| | |
| * | core: hle: service: buffer_queue: Improve management of KEvent.bunnei2021-08-073-14/+24
| | |
| * | core: hle: kernel: k_auto_object: Add GetName method.bunnei2021-08-071-0/+4
| | | | | | | | | | | | - Useful purely for debugging.
| * | core: hle: service: nvflinger/vi: Improve management of KEvent.bunnei2021-08-074-16/+30
| | |
| * | core: hle: kernel: DisableDispatch on suspend threads.bunnei2021-08-071-0/+3
| | |
| * | core: hle: kernel: k_scheduler: Improve DisableScheduling and EnableScheduling.bunnei2021-08-071-14/+9
| | |
| * | core: hle: kernel: Use CurrentPhysicalCoreIndex as appropriate.bunnei2021-08-071-6/+2
| | |
| * | core: hle: kernel: k_scheduler: Remove unnecessary MakeCurrentProcess.bunnei2021-08-071-5/+0
| | |
| * | core: hle: kernel: k_scheduler: Improve ScheduleImpl.bunnei2021-08-071-6/+7
| | |
| * | core: hle: kernel: k_scheduler: Improve Unload.bunnei2021-08-071-17/+29
| | |
| * | core: hle: kernel: k_process: DisableDispatch on main thread.bunnei2021-08-071-0/+1
| | |
| * | core: hle: kernel: k_handle_table: Use KScopedDisableDispatch as necessary.bunnei2021-08-072-0/+8
| | |
| * | core: hle: kernel: k_thread: Add KScopedDisableDispatch.bunnei2021-08-072-1/+47
| | |
| * | core: hle: kernel: Ensure idle threads are closed before destroying scheduler.bunnei2021-08-073-24/+22
| | |
| * | core: hle: kernel: Reflect non-emulated threads as core 3.bunnei2021-08-075-4/+15
| |/
* | network: retrieve subnet mask and gateway infoSönke Holz2021-08-161-8/+16
| |
* | nifm: use operator*() instead of .value() to get value of std::optionalSönke Holz2021-08-131-2/+2
| |
* | nifm: treat a missing host IP address as a non-critical errorSönke Holz2021-08-131-2/+2
| |
* | configuration: add option to select network interfacespholz2021-08-121-15/+21
| | | | | | | | This commit renames the "Services" tab to "Network" and adds a combobox that allows the user to select the network interface that yuzu should use. This new setting is now used to get the local IP address in Network::GetHostIPv4Address. This prevents yuzu from selecting the wrong network interface and thus using the wrong IP address. The return type of Network::GetHostIPv4Adress has also been changed.
* | Merge branch 'yuzu-emu:master' into fix-lan-playspholz2021-08-072-99/+4
|\|
| * Merge pull request #6799 from ameerj/vp9-fixesbunnei2021-08-072-99/+4
| |\ | | | | | | nvdec: Fix VP9 reference frame refreshes
| | * nvhost_nvdec_common: Remove BufferMapameerj2021-08-072-76/+0
| | | | | | | | | | | | This was mainly used to keep track of mapped buffers for later unmapping. Since unmap is no longer implemented, this no longer seves a valuable purpose.
| | * nvhost_nvdec_common: Stub UnmapBuffer Ioctlameerj2021-08-071-23/+4
| | | | | | | | | | | | Skip unmapping nvdec buffers to avoid breaking the continuity of the VP9 reference frame addresses, and the risk of invalidating data before the async GPU thread is done with it.
* | | network: GetCurrentIpConfigInfo: return host IP addressSönke Holz2021-08-071-1/+4
|/ / | | | | | | Service::NIFM::IGeneralService::GetCurrentIpConfigInfo currently hardcodes 192.168.1.100 as the IP address, which prevents LAN play from working correctly.
* | applet_swkbd: Include the null terminator in the buffer size calculationMorph2021-08-051-2/+4
| | | | | | | | Some games may interpret the read string as a null-terminated string instead of just reading the string up to buffer_size.
* | service: set: Correct copy amount in GetAvailableLanguageCodesMorph2021-08-011-1/+2
|/
* hle: api_version: Update HOS version to 12.1.0Morph2021-07-311-7/+7
| | | | Keeps us up to date with reporting the system version.
* Merge pull request #6752 from Morph1984/pt-brbunnei2021-07-303-10/+14
|\ | | | | service: ns, set: Add PT_BR (Brazilian Portuguese)
| * service: set: Correct 4.0.0 max_entries to 0x40 (64) instead of 17Morph2021-07-301-8/+8
| |
| * service: ns, set: Add PT_BR (Brazilian Portuguese)Morph2021-07-303-2/+6
| |
* | applet_swkbd: Correct string buffer size calculationMorph2021-07-301-2/+2
|/ | | | The buffer size here does not include the initial 8 bytes.
* Merge pull request #6751 from Morph1984/languagecodeAmeer J2021-07-292-42/+2
|\ | | | | service: ns: Map ZH_TW and ZH_CN to Traditional/Simplified Chinese
| * service: ns: Remove unused ns_language headerMorph2021-07-271-42/+0
| |
| * service: ns: Map ZH_TW and ZH_CN to Traditional/Simplified ChineseMorph2021-07-271-0/+2
| |
* | Merge pull request #6742 from Morph1984/uuidbunnei2021-07-292-14/+14
|\ \ | |/ |/| common: uuid: Return a lower-case hex string in Format
| * common: uuid: Return a lower-case hex string in FormatMorph2021-07-272-14/+14
| |
* | Merge pull request #6696 from ameerj/speed-limit-renamebunnei2021-07-271-1/+1
|\ \ | | | | | | general: Rename "Frame Limit" references to "Speed Limit"
| * | general: Rename "Frame Limit" references to "Speed Limit"ameerj2021-07-241-1/+1
| | | | | | | | | | | | | | | This setting is best referred to as a speed limit, as it involves the limits of all timing based aspects of the emulator, not only framerate. This allows us to differentiate it from the fps unlocker setting.
* | | Merge pull request #6697 from ameerj/fps-capbunnei2021-07-261-5/+6
|\ \ \ | |_|/ |/| | config, nvflinger: Add FPS cap setting
| * | config, nvflinger: Add FPS cap settingameerj2021-07-241-5/+6
| |/ | | | | | | Allows finer tuning of the FPS limit.
* | Merge pull request #6551 from bunnei/improve-kernel-objbunnei2021-07-2420-88/+325
|\ \ | |/ |/| Improve management of kernel objects
| * hle: service: kernel_helpers: Remove unnecessary pragma once.bunnei2021-07-211-2/+0
| |
| * hle: kernel: svc: Remove part of ExitProcess.bunnei2021-07-211-5/+0
| | | | | | | | - ExitProcess is not actually implemented either way, and this needs more work before we implement.
| * hle: service: nvdrv: Remove unused kernel reference.bunnei2021-07-211-1/+0
| |
| * hle: service: hid: npad: Remove unused kernel reference.bunnei2021-07-211-1/+0
| |
| * hle: kernel: Track and release server sessions, and protect methods with locks.bunnei2021-07-214-13/+82
| |
| * hle: kernel: KProcess: Change process termination assert to a warning.bunnei2021-07-211-1/+1
| | | | | | | | - Since we do not implement multiprocess right now, this should not be a crashing assert.
| * hle: kernel: Ensure current running process is closed.bunnei2021-07-211-5/+6
| |
| * hle: kernel: Ensure global handle table is finalized before closing.bunnei2021-07-211-0/+1
| |
| * kernel: svc: ConnectToNamedPort: Close extra reference to port.bunnei2021-07-211-0/+1
| |
| * hle: service: sm: Refactor to better manage ports.bunnei2021-07-214-45/+47
| |
| * hle: kernel: k_process: Close the handle table on shutdown.bunnei2021-07-211-0/+3
| |
| * hle: kernel: k_process: Close main thread reference after it is inserted into handle table.bunnei2021-07-211-0/+3
| |
| * hle: kernel: Ensure global handle table is initialized.bunnei2021-07-211-0/+1
| |
| * hle: service: Add a helper module for managing kernel objects.bunnei2021-07-219-20/+144
| |
| * hle: kernel: Provide methods for tracking dangling kernel objects.bunnei2021-07-214-2/+43
| |
* | applet_controller: Add preliminary support for version 8Morph2021-07-202-3/+33
|/ | | | Version 8 adds support for key remapping introduced in FW 11.0, we will not be implementing this for now.
* Merge pull request #6525 from ameerj/nvdec-fixesFernando S2021-07-151-45/+40
|\ | | | | nvdec: Fix Submit Ioctl data source, vic frame dimension computations
| * nvhost_nvdec_common: Read Submit ioctl data from object addrameerj2021-07-151-8/+2
| | | | | | | | Fixes Mario Golf intro video decoding.
| * nvhost_nvdec_common: Fix {Slice/Write}Vectors returnameerj2021-07-151-37/+38
| | | | | | | | Plus some minor cleanup for consistency.
* | applets/web: Resolve Nintendo CDN URLsMorph2021-07-151-0/+13
| | | | | | | | This fixes the hint videos in New Super Mario Bros. U Deluxe
* | service: Append service name prefix to common filenamesMorph2021-07-1438-31/+31
| |
* | applets: Append applet_ prefix to backend appletsMorph2021-07-1416-17/+17
| |
* | Merge pull request #6599 from german77/disable_rumbleAmeer J2021-07-131-0/+5
|\ \ | | | | | | npad: Disable vibration check if disabled
| * | npad: Disable vibration check if disabledgerman772021-07-111-0/+5
| | |
* | | boxcat: Silence -Wmaybe-uninitialized in httplib.hReinUsesLisp2021-07-121-0/+3
|/ /
* | Merge pull request #6539 from lat9nq/default-settingAmeer J2021-07-085-7/+8
|\ \ | | | | | | general: Move most settings' defaults and labels into their definition
| * | core, input_common: Miscellaneous fixeslat9nq2021-06-291-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | bcat: Fix settings access telemetry_session: Fix settings accesses So this is what I get for testing with the web service disabled. touch_from_button: Fix settings access for clang
| * | general: Make most settings a BasicSettinglat9nq2021-06-284-6/+7
| |/ | | | | | | | | | | | | | | | | | | | | Creates a new BasicSettings class in common/settings, and forces setting a default and label for each setting that uses it in common/settings. Moves defaults and labels from both frontends into common settings. Creates a helper function in each frontend to facillitate reading the settings now with the new default and label properties. Settings::Setting is also now a subclass of Settings::BasicSetting. Also adds documentation for both Setting and BasicSetting.
* | Report 2 channels active. Fixes Tales of Vesperia's mono channel audio.Kelebek12021-07-061-1/+1
| |
* | service: mii: Retrieve the correct default miis.Morph2021-07-041-2/+3
| | | | | | | | We were including the first 2 default miis which are not meant to be shown in games. With this change, we properly retrieve the 6 default miis shown in games, with 3 of each gender.
* | Merge pull request #6498 from Kelebek1/Audiobunnei2021-07-031-5/+7
|\ \ | | | | | | [audio_core] Decouple audio update and processing, and process at variable rate
| * | Fix XC2/VOEZ crashing, add audio looping and a few misc fixesKelebek12021-07-011-1/+1
| | |
| * | Decouple audio processing and run at variable rateKelebek12021-06-271-4/+6
| | | | | | | | | | | | | | | | | | Currently, processing of audio samples is called from AudioRenderer's Update method, using a fixed 4 buffers to process the given samples. Games call Update at variable rates, depending on framerate and/or sample count, which causes inconsistency in audio processing. From what I've seen, 60 FPS games update every ~0.004s, but 30 FPS/160 sample games update somewhere between 0.02 and 0.04, 5-10x slower. Not enough samples get fed to the backend, leading to a lot of audio skipping. This PR seeks to address this by de-coupling the audio consumption and the audio update. Update remains the same without calling for buffer queuing, and the consume now schedules itself to run based on the sample rate and count.
* | | filesystem: Open a read-only directory for SDMC modsMorph2021-06-281-5/+9
| | | | | | | | | | | | This prevents mod files from being locked due to the read-only share flag in Windows.
* | | core: Simplify SDMC mod loadinglat9nq2021-06-281-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If someone else wants to support other mod formats in the SDMC directory, that can be added later. For now, just allow RomFS modding here and force people to do other types of mods the old way. Addresses review comments. Co-authored-by: LC <mathew1800@gmail.com>
* | | core: Support LayeredFS mod from SDMC directorylat9nq2021-06-282-0/+10
|/ / | | | | | | | | | | Enables loading a mod directly from `[yuzu data directory]/sdmc/atmosphere/contents/[title_id]`. For use with some homebrew mod managers.
* | Merge pull request #6526 from bunnei/doom-updatebunnei2021-06-265-8/+60
|\ \ | |/ |/| services: Misc. minor changes for latest SDK update.
| * hle: service: hwopus: OpenHardwareOpusDecoderEx: Remove unused buffer size.bunnei2021-06-261-1/+30
| |
| * hle: hle_helpers: Skip data payload offset checks on TIPC requests.bunnei2021-06-251-2/+6
| | | | | | | | - TIPC does not use this.
| * hle: service: hwopus: Implement GetWorkBufferSizeEx and OpenHardwareOpusDecoderEx.bunnei2021-06-252-5/+15
| | | | | | | | - This is used by the latest update of Doom Eternal.
| * hle: service: aoc: Stub GetAddOnContentListChangedEventWithProcessId.bunnei2021-06-252-1/+10
| | | | | | | | - This is used by the latest update of Doom Eternal.
* | Merge pull request #6519 from Wunkolo/mem-size-literalbunnei2021-06-257-58/+74
|\ \ | |/ |/| common: Replace common_sizes into user-literals
| * common: Replace common_sizes into user-literalsWunkolo2021-06-247-58/+74
| | | | | | | | | | | | | | | | | | | | | | | | | | Removes common_sizes.h in favor of having `_KiB`, `_MiB`, `_GiB`, etc user-literals within literals.h. To keep the global namespace clean, users will have to use: ``` using namespace Common::Literals; ``` to access these literals.
* | Merge pull request #6522 from Morph1984/pragmabunnei2021-06-243-0/+6
|\ \ | | | | | | general: Add missing #pragma once directives
| * | general: Add missing #pragma once directivesMorph2021-06-243-0/+6
| | |
* | | Add missing includes (#6521)Chloe2021-06-241-0/+2
|/ / | | | | | | | | * Add missing includes * Add array
* | Merge pull request #6517 from lioncash/fmtlibbunnei2021-06-241-3/+3
|\ \ | |/ |/| externals: Update fmt to 8.0.0
| * General: Resolve fmt specifiers to adhere to 8.0.0 API where applicableLioncash2021-06-231-3/+3
| | | | | | | | Also removes some deprecated API usages.
* | Merge pull request #6504 from Kelebek1/samples-playedbunnei2021-06-231-1/+9
|\ \ | |/ |/| [audout] Implement GetAudioOutPlayedSampleCount
| * Implement audout GetAudioOutPlayedSampleCountKelebek12021-06-221-1/+9
| | | | | | | | Used in Ninja Gaiden games.
* | Merge pull request #6510 from ReinUsesLisp/npad-data-raceMai M2021-06-232-0/+8
|\ \ | | | | | | npad: Fix data race when updating devices
| * | npad: Fix data race when updating devicesRodrigo Locatti2021-06-222-0/+8
| | | | | | | | | | | | | | | Add a lock to avoid data races. This reduces the number of -fsanitize=thread errors significantly.
* | | Merge pull request #6493 from Morph1984/fs-nodiscardbunnei2021-06-231-2/+2
|\ \ \ | | | | | | | | common: fs: Miscellaneous changes
| * | | common: fs: Remove [[nodiscard]] attribute on Remove* functionsMorph2021-06-221-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | There are a lot of scenarios where we don't particularly care whether or not the removal operation and just simply attempt a removal. As such, removing the [[nodiscard]] attribute is best for these functions.
* | | | Merge pull request #6472 from Morph1984/splbunnei2021-06-237-45/+475
|\ \ \ \ | | | | | | | | | | service: spl: Implement general SPL service
| * | | | spl: Mark the other functions as unimplementedMorph2021-06-161-5/+30
| | | | |
| * | | | spl: Implement spl::GetConfigMorph2021-06-162-1/+90
| | | | |
| * | | | hle: api_version: Add HLE API version constantsMorph2021-06-161-0/+38
| | | | |
| * | | | spl: Add the general SPL interfaceMorph2021-06-164-45/+64
| | | | |
| * | | | spl: Add SPL typesMorph2021-06-161-0/+230
| | | | |
| * | | | spl: Add SPL result codesMorph2021-06-161-0/+29
| | | | |
* | | | | Merge pull request #6483 from Morph1984/get-tz-filebunnei2021-06-221-1/+1
|\ \ \ \ \ | |_|/ / / |/| | | | service: time: Use GetFileRelative to get files within subdirectories
| * | | | service: time: Use GetFileRelative to get files within subdirectoriesMorph2021-06-181-1/+1
| | |_|/ | |/| | | | | | | | | | The timezone info file can be within subdirectories (such as Asia/Tokyo), use GetFileRelative instead of GetFile to get files within subdirectories.
* | | | Merge pull request #6481 from Morph1984/missing-peak-setbunnei2021-06-221-0/+1
|\ \ \ \ | |_|_|/ |/| | | kernel: Fix missing peak set in KResourceLimit::SetLimitValue
| * | | kernel: Fix missing peak set in KResourceLimit::SetLimitValueMorph2021-06-181-0/+1
| |/ /
* / / nvflinger: Add toggle to disable buffer swap interval limitsameerj2021-06-171-0/+3
|/ / | | | | | | | | Enabling this setting will allow some titles to present more frames to the screen as they become available in the nvflinger buffer queue.
* / fsp_srv: Fix filesystem access loggingMorph2021-06-162-12/+15
|/ | | | | | | | This introduces a new setting Enable FS Access Log which saves the filesystem access log to sdmc:/FsAccessLog.txt If this setting is not enabled, this will indicate to FS to not call OutputAccessLogToSdCard. Fixes softlocks during loading in Xenoblade Chronicles 2 when certain DLC is enabled.
* lm: Demote guest logs to LOG_DEBUGameerj2021-06-151-27/+20
| | | | Guest logs are not very useful, as they are intended for use by the game developers during development. As such, they provide little meaning to be logged by yuzu and tend to overwhelm the log output at times.
* general: Remove extraneous includesMorph2021-06-131-1/+0
|
* hid: Stub IsFirmwareUpdateAvailableForSixAxisSensorgerman772021-06-112-1/+23
|
* kernel: Unconditionally set thread state when appropriateMorph2021-06-112-23/+12
|
* kernel: KLightConditionVariable: Update implementation to 12.xMorph2021-06-112-14/+31
| | | | Updates the implementation of KLightConditionVariable to FW 12.x
* hle: service: sm: Remove redundant session reservation, etc.bunnei2021-06-102-18/+13
| | | | - We were double-reserving, causing us to run out of sessions in Pokemon Sword & Shield.
* hle: service: Increase arbitrary max sessions limit.bunnei2021-06-101-4/+1
| | | - Pokemon Sword/Shield are still hitting this for some reason, causing an svcBreak.
* hle: kernel: KClientPort: Add an assert for session count.bunnei2021-06-101-0/+3
| | | | - Prevents us from over decrementing num_sessions.
* hle: service: sm: Fix GetService setup of session & port.bunnei2021-06-102-5/+5
|
* hle: service: Use correct size for ServerSessionCountMax.bunnei2021-06-101-4/+6
|
* hle: kernel: KServerSession: Fix client disconnected.bunnei2021-06-103-9/+8
| | | | | - Prevents a cloned session's handler from being overwritten by another disconnected session. - Fixes session handler nullptr asserts with Pokemon Sword & Shield.
* kernel: svc: Add missing error check to CancelSynchronization.bunnei2021-06-101-2/+2
| | | | - Avoids a potential crash if the handle is invalid, and also makes this code accurate to real kernel behavior.
* hle: service: Increase arbitrary max sessions limit.bunnei2021-06-091-1/+1
| | | - Pokemon Sword/Shield are still hitting this for some reason, causing an svcBreak.
* hle: kernel: KServerSession: Work-around scenario where session is closed too early.bunnei2021-06-081-7/+24
|
* hle: kernel: hle_ipc: Ensure SessionRequestHandler is valid.bunnei2021-06-083-5/+26
|
* hle: kernel: Remove service thread manager and use weak_ptr.bunnei2021-06-083-18/+8
| | | | | - We no longer need to queue up service threads to be destroyed. - Fixes a race condition where a thread could be destroyed too early, which caused a crash in Pokemon Sword/Shield.
* Merge pull request #6414 from bunnei/fix-service-threadsbunnei2021-06-0721-87/+101
|\ | | | | hle: kernel: Refactor to allocate a ServiceThread per service handler.
| * hle: kernel: KServerSession: Use ASSERT_MSG where appropriate.bunnei2021-06-071-1/+1
| |
| * hle: kernel: k_server_session: Return service thread by strong pointer.bunnei2021-06-072-4/+4
| |
| * hle: kernel: k_server_session: Ensure service thread is valid before dereference.bunnei2021-06-071-1/+3
| |
| * hle: kernel: hle_ipc: Use default destructor for SessionRequestManager.bunnei2021-06-071-1/+1
| |
| * hle: kernel: KAutoObjectWithListContainer: Use boost::instrusive::rbtree.bunnei2021-06-0711-22/+26
| | | | | | | | - Fixes some crashes introduced by our common intrusive red/black tree impl.
| * hle: kernel: Refactor to allocate a ServiceThread per service handler.bunnei2021-06-0513-67/+75
| | | | | | | | | | | | - Previously, we would allocate a thread per session, which adds new threads on CloneCurrentObject. - This results in race conditions with N sessions queuing requests to the same service interface. - Fixes Pokken Tournament DX crashes/softlocks, which were regressed by #6347.
* | result: Add [[nodiscard]] specifiers where applicableLioncash2021-06-051-20/+20
|/ | | | | | The result code classes are used quite extensively throughout both the kernel and service HLE code. We can mark these member functions as [[nodiscard]] to prevent a few logic bugs from slipping through.
* fsp-srv: Replace one last instance of RESULT_SUCCESSMorph2021-06-031-1/+1
|
* fspsrv: Implement DisableAutoSaveDataCreation (#6355)Chloe2021-06-034-1/+17
| | | - Used by Mii Edit
* general: Replace RESULT_UNKNOWN with ResultUnknownMorph2021-06-0211-40/+40
| | | | Transition to PascalCase for result names.
* general: Replace RESULT_SUCCESS with ResultSuccessMorph2021-06-02110-928/+925
| | | | Transition to PascalCase for result names.
* common_funcs: Move R_ macros to result.hLioncash2021-05-311-0/+25
| | | | | | These macros all interact with the result code type, so they should ideally be within this file as well, so all the common_funcs machinery doesn't need to be pulled in just to use them.
* Merge pull request #6377 from lioncash/pointbunnei2021-05-303-39/+17
|\ | | | | common: Extract Point struct into common
| * touchscreen: Make use of common point structLioncash2021-05-282-10/+10
| |
| * common: Extract point into a common structLioncash2021-05-281-29/+7
| | | | | | | | | | This is generic enough that it can be moved into the Common class for reuse.
* | Merge pull request #6387 from lioncash/class-tokenbunnei2021-05-301-43/+36
|\ \ | | | | | | k_class_token: Use variable templates where applicable
| * | k_class_token: Use variable templates where applicableLioncash2021-05-291-43/+36
| |/ | | | | | | Same behavior, less code.
* | Merge pull request #6374 from Morph1984/swkbd-textcheck-encodingMai M2021-05-301-10/+15
|\ \ | | | | | | applets/swkbd: Only read the text check message on Failure/Confirm
| * | applets/swkbd: Make use of std::move where applicableMorph2021-05-281-8/+8
| | | | | | | | | | | | Avoids redundant string copies
| * | applets/swkbd: Only read the text check message on Failure/ConfirmMorph2021-05-281-2/+7
| |/ | | | | | | | | | | Applications may leave this region of memory uninitialized when the text check result is not either Failure or Confirm. Attempting to read uninitialized memory may cause an exception within the UTF16 to UTF8 string converter. Fix this by only reading the text check message on Failure or Confirm.
* | Merge pull request #6364 from german77/stub-lp2pMai M2021-05-301-0/+141
|\ \ | | | | | | | | | | | | | | | | | | ldn: Add and stub lp2p:sys lp2p:app INetworkServiceMonitor INetworkService Mario Kart Live: Home Circuit needs lp2p:sys lp2p:app INetworkServiceMonitor INetworkService to be able to progress. Note: The game still fails to boot from unimplemented LDN and BSD services.
| * | ldn: Add and stub lp2p:sys lp2p:app INetworkServiceMonitor INetworkServicegerman772021-05-261-0/+141
| |/
* | Merge pull request #6384 from lioncash/virtualbunnei2021-05-2915-53/+48
|\ \ | | | | | | kernel: Add missing override specifiers
| * | kernel: Add missing override specifiersLioncash2021-05-2915-53/+48
| |/ | | | | | | | | | | | | | | Over the course of the kernel refactoring a tiny bit of missing overrides slipped through review, so we can add these. While we're at it, we can remove redundant virtual keywords where applicable as well.
* | Merge pull request #6382 from lioncash/nullbunnei2021-05-291-5/+5
|\ \ | | | | | | k_thread: Move dereference after null check in Initialize()
| * | k_thread: Move dereference after null check in Initialize()Lioncash2021-05-291-5/+5
| |/ | | | | | | Prevents a -Wnonnull warning on GCC.
* | Merge pull request #6373 from bunnei/use-slabheap-tlsbunnei2021-05-292-11/+191
|\ \ | | | | | | hle: kernel: KSlabHeap: Allow host or guest allocations.
| * | hle: kernel: KSlabHeap: Allow host or guest allocations.bunnei2021-05-292-11/+191
| | | | | | | | | | | | | | | - Use host allocations for kernel memory, as this is not properly emulated yet. - Use guest allocations for TLS, as this needs to be backed by DeviceMemory.
* | | Fix two GCC 11 warnings: Unneeded copies.Markus Wick2021-05-291-1/+1
| | | | | | | | | | | | | | | std::move created an unneeded copy. iterating without reference also created copies.
* | | Merge pull request #6371 from degasus/drop_ExceptionalExitbunnei2021-05-291-1/+0
|\ \ \ | |/ / |/| | core/arm_interface: Call SVC after end of dynarmic block.
| * | core/arm_interface: Call SVC after end of dynarmic block.Markus Wick2021-05-271-1/+0
| |/ | | | | | | | | | | So we can modify all of dynarmic states within SVC without ExceptionalExit. Especially as the ExceptionalExit hack is dropped on upstream dynarmic.
* | Merge pull request #6356 from ogniK5377/ApplyNpadSystemCommonPolicybunnei2021-05-281-1/+10
|\ \ | |/ |/| hid: ApplyNpadSystemCommonPolicy
| * hid: ApplyNpadSystemCommonPolicyChloe Marcec2021-05-241-1/+10
| | | | | | | | We already do this specifically for homebrew, so we can keep it stubbed out for the time being
* | Merge pull request #6331 from lioncash/gestureMorph2021-05-262-67/+79
|\ \ | | | | | | hid/gesture: Simplify point related code
| * | hid/gesture: Factor out last gesture retrieval into its own functionLioncash2021-05-182-14/+23
| | | | | | | | | | | | Deduplicates a commonly repeated expression.
| * | hid/gesture: Ensure all ID arrays are initializedLioncash2021-05-181-4/+4
| | | | | | | | | | | | Makes for deterministic initial state.
| * | hid/gesture: Make Point a templateLioncash2021-05-182-38/+46
| | | | | | | | | | | | | | | We can now use this in a generic context to reuse it with the finger position.
| * | hid/gesture: Replace x,y members of GestureState with a PointLioncash2021-05-182-6/+4
| | | | | | | | | | | | Simplifies assignments.
| * | hid/gesture: Add default comparators to PointLioncash2021-05-182-10/+7
| | | | | | | | | | | | Simplifies some comparisons.
| * | hid/gesture: Rename Points to PointLioncash2021-05-181-5/+5
| | | | | | | | | | | | This only represents a single point
* | | common: fs: Rework the Common Filesystem interface to make use of std::filesystem (#6270)Morph2021-05-269-95/+111
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * common: fs: fs_types: Create filesystem types Contains various filesystem types used by the Common::FS library * common: fs: fs_util: Add std::string to std::u8string conversion utility * common: fs: path_util: Add utlity functions for paths Contains various utility functions for getting or manipulating filesystem paths used by the Common::FS library * common: fs: file: Rewrite the IOFile implementation * common: fs: Reimplement Common::FS library using std::filesystem * common: fs: fs_paths: Add fs_paths to replace common_paths * common: fs: path_util: Add the rest of the path functions * common: Remove the previous Common::FS implementation * general: Remove unused fs includes * string_util: Remove unused function and include * nvidia_flags: Migrate to the new Common::FS library * settings: Migrate to the new Common::FS library * logging: backend: Migrate to the new Common::FS library * core: Migrate to the new Common::FS library * perf_stats: Migrate to the new Common::FS library * reporter: Migrate to the new Common::FS library * telemetry_session: Migrate to the new Common::FS library * key_manager: Migrate to the new Common::FS library * bis_factory: Migrate to the new Common::FS library * registered_cache: Migrate to the new Common::FS library * xts_archive: Migrate to the new Common::FS library * service: acc: Migrate to the new Common::FS library * applets/profile: Migrate to the new Common::FS library * applets/web: Migrate to the new Common::FS library * service: filesystem: Migrate to the new Common::FS library * loader: Migrate to the new Common::FS library * gl_shader_disk_cache: Migrate to the new Common::FS library * nsight_aftermath_tracker: Migrate to the new Common::FS library * vulkan_library: Migrate to the new Common::FS library * configure_debug: Migrate to the new Common::FS library * game_list_worker: Migrate to the new Common::FS library * config: Migrate to the new Common::FS library * configure_filesystem: Migrate to the new Common::FS library * configure_per_game_addons: Migrate to the new Common::FS library * configure_profile_manager: Migrate to the new Common::FS library * configure_ui: Migrate to the new Common::FS library * input_profiles: Migrate to the new Common::FS library * yuzu_cmd: config: Migrate to the new Common::FS library * yuzu_cmd: Migrate to the new Common::FS library * vfs_real: Migrate to the new Common::FS library * vfs: Migrate to the new Common::FS library * vfs_libzip: Migrate to the new Common::FS library * service: bcat: Migrate to the new Common::FS library * yuzu: main: Migrate to the new Common::FS library * vfs_real: Delete the contents of an existing file in CreateFile Current usages of CreateFile expect to delete the contents of an existing file, retain this behavior for now. * input_profiles: Don't iterate the input profile dir if it does not exist Silences an error produced in the log if the directory does not exist. * game_list_worker: Skip parsing file if the returned VfsFile is nullptr Prevents crashes in GetLoader when the virtual file is nullptr * common: fs: Validate paths for path length * service: filesystem: Open the mod load directory as read only
* | | kernel: process_capability: Add MapRegion capabilityMorph2021-05-252-0/+12
| |/ |/| | | | | - Used by nx-hbloader
* | hle: kernel: service_thread: Take reference to KServerSession on service request.bunnei2021-05-211-9/+5
| |
* | hle: kernel: k_port: Use AcceptSession to ensure SessionList state is correct.bunnei2021-05-211-1/+1
| | | | | | | | - Fixes a use-after-free, work-around until we fixup session/port management.
* | hle: kernel: Use host memory allocations for KSlabMemory.bunnei2021-05-212-144/+20
| | | | | | | | - There are some issues with the current workaround, we will just use host memory until we have a complete kernel memory implementation.
* | Revert "WORKAROUND: Do not use slab heap while we track down issues with resource management."bunnei2021-05-211-2/+2
| | | | | | | | This reverts commit f2c26443f85a3c3fd43137509368ba5c7ab80ee7.
* | hle: kernel: hle_ipc: Simplify incoming/outgoing move/copy/domain objects.bunnei2021-05-213-62/+17
| |
* | hle: kernel: Implement CloneCurrentObject and improve session management.bunnei2021-05-2113-99/+184
| |
* | Revert "WORKAROUND: temp. disable session resource limits while we work out issues"bunnei2021-05-214-11/+11
| | | | | | | | This reverts commit fc086f93b2165b5c210cb7dcd6c18ebe17f1fd7b.
* | Merge pull request #6320 from Morph1984/get-pidbunnei2021-05-212-9/+14
|\ \ | | | | | | hle_ipc: Add a getter for PID
| * | hle_ipc: unsigned -> u32Morph2021-05-161-7/+7
| | | | | | | | | | | | This is more concise and consistent with the rest of the codebase.
| * | hle_ipc: Add a getter for PIDMorph2021-05-162-2/+7
| | |
* | | Merge pull request #6317 from ameerj/fps-fixbunnei2021-05-191-1/+0
|\ \ \ | | | | | | | | perf_stats: Rework FPS counter to be more accurate
| * | | perf_stats: Rework FPS counter to be more accurateameerj2021-05-161-1/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The FPS counter was based on metrics in the nvdisp swapbuffers call. This metric would be accurate if the gpu thread/renderer were synchronous with the nvdisp service, but that's no longer the case. This commit moves the frame counting responsibility onto the concrete renderers after their frame draw calls. Resulting in more meaningful metrics. The displayed FPS is now made up of the average framerate between the previous and most recent update, in order to avoid distracting FPS counter updates when framerate is oscillating between close values. The status bar update frequency was also changed from 2 seconds to 500ms.
* | | | KTransferMemory: Return size instead of size * PageSize in GetSize()Morph2021-05-181-1/+1
| |_|/ |/| | | | | | | | size is already the size in bytes. We do not need to multiply it by the page size
* | | Merge pull request #6284 from ameerj/shantae-fixbunnei2021-05-162-5/+35
|\ \ \ | | | | | | | | nvflinger: Create layers when they are queried but not found
| * | | nvflinger: Create layers when they are queried but not foundameerj2021-05-062-5/+35
| | | | | | | | | | | | | | | | Fixes Shantae softlock on boot.
* | | | Merge pull request #6296 from lioncash/shadow-errorbunnei2021-05-1663-194/+212
|\ \ \ \ | | | | | | | | | | core: Make variable shadowing a compile-time error
| * | | | core: Make variable shadowing a compile-time errorLioncash2021-05-1663-194/+212
| | |_|/ | |/| | | | | | | | | | | | | | | | | | Now that we have most of core free of shadowing, we can enable the warning as an error to catch anything that may be remaining and also eliminate this class of logic bug entirely.
* | | | Merge pull request #6307 from Morph1984/fix-response-push-sizebunnei2021-05-162-2/+2
|\ \ \ \ | |/ / / |/| | | nifm, ssl: Fix incorrect response sizes
| * | | nifm, ssl: Fix incorrect response sizesMorph2021-05-162-2/+2
| | |/ | |/|
* | | Merge pull request #6299 from bunnei/ipc-improvementsbunnei2021-05-1618-219/+353
|\ \ \ | |/ / |/| | Various improvements to IPC and session management
| * | hle: kernel: hle_ipc: Fix outgoing IPC response size calculation.bunnei2021-05-113-1/+15
| | |
| * | WORKAROUND: temp. disable session resource limits while we work out issuesbunnei2021-05-114-11/+11
| | |
| * | WORKAROUND: Do not use slab heap while we track down issues with resource management.bunnei2021-05-111-2/+2
| | |
| * | audrenbunnei2021-05-112-25/+16
| | |
| * | core: hle: ipc_helpers: Fix cast on raw_data_size calculation.bunnei2021-05-111-1/+1
| | |
| * | hle: service: sm: Add TIPC support.bunnei2021-05-112-41/+66
| | | | | | | | | | | | - Fixes our error checking of names as well.
| * | hle: kernel: hle_ipc: Improve IPC code and add initial support for TIPC.bunnei2021-05-112-81/+57
| | | | | | | | | | | | | | | - Fixes our move handles implementation to actually move objects. - Simplifies the traditional IPC path.
| * | hle: service: sm: GetService: Reserve session resource when we create a KSession.bunnei2021-05-111-0/+7
| | |
| * | hle: service: Add support for dispatching TIPC requests.bunnei2021-05-112-1/+52
| | |
| * | hle: service: Implement IPC::CommandType::Close.bunnei2021-05-113-11/+15
| | | | | | | | | | | | - This was not actually closing sessions before.
| * | hle: service: sm: Use RegisterNamedService to register the service.bunnei2021-05-111-1/+1
| | |
| * | hle: service: sm: Improve Initialize implementation.bunnei2021-05-112-0/+3
| | |
| * | hle: kernel: svc: Update ConnectToNamedPort to use new CreateNamedServicePort interface.bunnei2021-05-111-4/+3
| | |
| * | hle: kernel: Implement named service ports using service interface factory.bunnei2021-05-114-22/+30
| | | | | | | | | | | | - This allows us to create a new interface each time ConnectToNamedPort is called, removing the assumption that these are static.
| * | hle: kernel: KSession: Improve implementation of CloneCurrentObject.bunnei2021-05-111-2/+10
| | |
| * | hle: service: sm: Increase point buffer size.bunnei2021-05-111-1/+1
| | |
| * | hle: ipc_helpers: Reserve session resource when we create a KSession.bunnei2021-05-111-0/+5
| | |
| * | hle: kernel: KClientPort: Cleanup comment format.bunnei2021-05-111-1/+1
| | |
| * | hle: ipc: Add declarations for TIPC.bunnei2021-05-111-1/+16
| | |
| * | hle: kernel: Further cleanup and add TIPC helpers.bunnei2021-05-112-4/+12
| | |
| * | hle: ipc_helpers: Update IPC response generation for TIPC.bunnei2021-05-112-19/+39
| | |
* | | ssl: Stub Import(Client/Server)PkiMorph2021-05-131-2/+40
| | | | | | | | | | | | - Used in JUMP FORCE Deluxe Edition
* | | Merge pull request #6267 from german77/gestureRewriteMorph2021-05-122-76/+340
|\ \ \ | |/ / |/| | hid: Improve hardware accuracy of gestures
| * | hid: Improve hardware accuracy of gesturesgerman772021-05-052-76/+340
| | |
* | | Merge pull request #6291 from lioncash/kern-shadowbunnei2021-05-1040-140/+138
|\ \ \ | | | | | | | | kernel: Eliminate variable shadowing
| * | | kernel: Eliminate variable shadowingLioncash2021-05-0840-140/+138
| | | | | | | | | | | | | | | | | | | | Now that the large kernel refactor is merged, we can eliminate the remaining variable shadowing cases.
* | | | kernel: Delete unused filesgerman772021-05-092-151/+0
|/ / /
* | | Merge pull request #6266 from bunnei/kautoobject-refactorbunnei2021-05-08140-2699/+4595
|\ \ \ | | | | | | | | Kernel Rework: Migrate kernel objects to KAutoObject
| * | | hle: kernel: KPageTable: CanContain should not be constexpr.bunnei2021-05-062-2/+2
| | | |
| * | | hle: kernel: Move slab resource counts to Kernel.bunnei2021-05-064-33/+52
| | | |
| * | | fixup! hle: kernel: Migrate KSharedMemory to KAutoObject.bunnei2021-05-061-2/+2
| | | |
| * | | fixup! hle: kernel: Migrate more of KThread to KAutoObject.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Ensure all kernel objects with KAutoObject are properly created.bunnei2021-05-061-2/+0
| | | |
| * | | fixup! hle: kernel: Ensure all kernel objects with KAutoObject are properly created.bunnei2021-05-061-2/+0
| | | |
| * | | kernel: svc: Remove unused RetrieveResourceLimitValue function.bunnei2021-05-061-32/+0
| | | |
| * | | hle: kernel: Fix un/sign mismatch errors with NUM_CPU_CORES.bunnei2021-05-061-3/+3
| | | |
| * | | fixup! hle: kernel: Add initial impl. of slab setup.bunnei2021-05-061-6/+2
| | | |
| * | | fixup! hle: kernel: Migrate to KHandleTable.bunnei2021-05-061-0/+3
| | | |
| * | | fixup! hle: kernel: Migrate more of KThread to KAutoObject.bunnei2021-05-061-7/+0
| | | |
| * | | fixup! hle: kernel: Migrate KReadableEvent and KWritableEvent to KAutoObject.bunnei2021-05-062-2/+2
| | | |
| * | | fixup! hle: kernel: Migrate to KHandleTable.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Add initial impl. of KLinkedList.bunnei2021-05-061-12/+12
| | | |
| * | | fixup! hle: kernel: Migrate to KHandleTable.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject.bunnei2021-05-063-22/+28
| | | |
| * | | fixup! hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Migrate to KHandleTable.bunnei2021-05-061-60/+58
| | | |
| * | | fixup! hle: kernel: Add initial impl. of KAutoObjectWithListContainer.bunnei2021-05-061-11/+9
| | | |
| * | | fixup! hle: kernel: Add initial impl. of KAutoObjectWithListContainer.bunnei2021-05-061-9/+2
| | | |
| * | | fixup! hle: kernel: Add initial impl. of KAutoObject.bunnei2021-05-061-46/+46
| | | |
| * | | fixup! hle: kernel: Add initial impl. of KAutoObject.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Add initial impl. of slab setup.bunnei2021-05-061-8/+8
| | | |
| * | | common: Rename NON_COPYABLE/NON_MOVABLE with YUZU_ prefix.bunnei2021-05-064-9/+9
| | | |
| * | | fixup! hle: kernel: Rename Process to KProcess.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Migrate to KHandleTable.bunnei2021-05-061-1/+1
| | | |
| * | | fixup! hle: kernel: Improve MapSharedMemory and implement UnmapSharedMemory.bunnei2021-05-061-3/+3
| | | |
| * | | hle: kernel: svc: ConnectToNamedPort: Use KHandleTable::Reserve.bunnei2021-05-061-3/+8
| | | |
| * | | hle: kernel: Migrate to KHandleTable.bunnei2021-05-0619-375/+496
| | | |
| * | | hle: kernel: KClassToken: Ensure class tokens are correct.bunnei2021-05-061-1/+127
| | | |
| * | | hle: kernel: Improve MapSharedMemory and implement UnmapSharedMemory.bunnei2021-05-0610-95/+210
| | | |
| * | | hle: kernel: Rename Process to KProcess.bunnei2021-05-0646-160/+162
| | | |
| * | | hle: kernel: Remove deprecated Object class.bunnei2021-05-0635-404/+15
| | | |
| * | | hle: kernel: Do not shutdown twice on emulator close.bunnei2021-05-061-3/+1
| | | |
| * | | hle: kernel: Cleanup shutdown of persistent kernel objects.bunnei2021-05-061-14/+12
| | | |
| * | | hle: kernel: Migrate KPort, KClientPort, and KServerPort to KAutoObject.bunnei2021-05-0621-166/+442
| | | |
| * | | hle: kernel: Migrate KServerPort to KAutoObject.bunnei2021-05-067-50/+65
| | | |
| * | | hle: kernel: Migrate KClientPort to KAutoObject.bunnei2021-05-0616-60/+89
| | | |
| * | | hle: kernel: HandleTable: Remove deprecated APIs.bunnei2021-05-065-106/+23
| | | |
| * | | hle: kernel: Migrate KResourceLimit to KAutoObject.bunnei2021-05-0613-122/+197
| | | |
| * | | hle: kernel: svc: Migrate WaitSynchronization.bunnei2021-05-062-47/+78
| | | |
| * | | hle: kernel: svc: Use new handle table API for Process.bunnei2021-05-062-16/+17
| | | |
| * | | hle: kernel: Migrate KTransferMemory to KAutoObject.bunnei2021-05-0611-66/+207
| | | |
| * | | hle: kernel: Migrate KSession, KClientSession, and KServerSession to KAutoObject.bunnei2021-05-0630-350/+406
| | | |
| * | | hle: kernel: svc: Migrate GetThreadContext, GetThreadCoreMask.bunnei2021-05-061-2/+59
| | | |
| * | | hle: kernel: svc: Migrate GetProcessId, CancelSynchronization, SetThreadActivity.bunnei2021-05-061-13/+67
| | | |
| * | | hle: kernel: KThread: Remove incorrect resource release.bunnei2021-05-061-2/+1
| | | |
| * | | hle: kernel: svc_results: Update naming..bunnei2021-05-068-42/+43
| | | |
| * | | hle: kernel: KThread: Add missing resource hint release.bunnei2021-05-061-1/+1
| | | |
| * | | hle: kernel: Migrate KReadableEvent and KWritableEvent to KAutoObject.bunnei2021-05-0635-200/+215
| | | |
| * | | hle: ipc_helpers: Add methods for copy/move references.bunnei2021-05-061-2/+24
| | | |
| * | | hle: kernel: Move slab heaps to their own container.bunnei2021-05-062-10/+16
| | | |
| * | | hle: kernel: Refactor several threads/events/sharedmemory to use slab heaps.bunnei2021-05-0610-58/+52
| | | |
| * | | hle: kernel: Move slab heap management to KernelCore.bunnei2021-05-067-64/+106
| | | |
| * | | hle: kernel: Ensure all kernel objects with KAutoObject are properly created.bunnei2021-05-0620-0/+55
| | | |
| * | | hle: kernel: Use unique_ptr for suspend and dummy threads.bunnei2021-05-061-8/+8
| | | |
| * | | hle: kernel: Migrate KEvent to KAutoObject.bunnei2021-05-0637-266/+269
| | | |
| * | | hle: kernel: Migrate KSharedMemory to KAutoObject.bunnei2021-05-0616-114/+128
| | | |
| * | | hle: kernel: Migrate KProcess to KAutoObject.bunnei2021-05-0612-54/+73
| | | |
| * | | hle: kernel: Refactor IPC interfaces to not use std::shared_ptr.bunnei2021-05-0628-59/+65
| | | |
| * | | hle: kernel: Migrate more of KThread to KAutoObject.bunnei2021-05-0616-289/+442
| | | |
| * | | hle: kernel: svc: Migrate GetThreadPriority, StartThread, and ExitThread.bunnei2021-05-061-21/+12
| | | |
| * | | hle: kernel: svc: Migrate CreateThread.bunnei2021-05-061-14/+21
| | | |
| * | | hle: kernel: Migrate idle threads.bunnei2021-05-062-13/+9
| | | |
| * | | hle: kernel: Migrate KThread to KAutoObject.bunnei2021-05-062-109/+91
| | | |
| * | | hle: kernel: Add initial impl. of slab setup.bunnei2021-05-062-0/+225
| | | |
| * | | hle: kernel: Refactor out various KThread std::shared_ptr usage.bunnei2021-05-0610-58/+30
| | | |
| * | | hle: kernel: Add initial impl. of KLinkedList.bunnei2021-05-061-0/+233
| | | |
| * | | hle: kernel: Add initial impl. of KSlabAllocated.bunnei2021-05-061-0/+152
| | | |
| * | | hle: kernel: Add initial impl. of KAutoObjectWithListContainer.bunnei2021-05-062-0/+107
| | | |
| * | | hle: kernel: Add initial impl. of KAutoObject.bunnei2021-05-062-0/+304
| | |/ | |/|
* | | Merge pull request #6287 from lioncash/ldr-copybunnei2021-05-071-5/+3
|\ \ \ | |/ / |/| | ldr: Simplify memory copy within LoadNro()
| * | ldr: Simplify memory copy within LoadNro()Lioncash2021-05-071-5/+3
| | | | | | | | | | | | | | | | | | | | | | | | We can use the dedicated memory function for performing copies instead of reading into a temporary buffer and then immediately writing it back out to memory. Eliminates a bit of heap memory churn.
* | | Merge pull request #6279 from ogniK5377/nvhost-profbunnei2021-05-061-3/+14
|\ \ \ | |/ / |/| | nvdrv: /dev/nvhost-prof-gpu for production
| * | Update src/core/hle/service/nvdrv/interface.cppbunnei2021-05-061-1/+1
| | | | | | | | | Co-authored-by: Ameer J <52414509+ameerj@users.noreply.github.com>
| * | nvdrv: /dev/nvhost-prof-gpu for productionChloe Marcec2021-05-031-3/+14
| | | | | | | | | | | | | | | While we're at it, we can fix the is_initialized error code. This fixes the crashes on Shante
* | | service: Remove unused class variablesLioncash2021-05-053-7/+4
| |/ |/| | | | | Prevents some warnings from occurring.
* | service: Resolve cases of member field shadowingLioncash2021-05-0456-101/+103
|/ | | | | Now all that remains is for kernel code to be 'shadow-free' and then -Wshadow can be turned into an error.
* hid: Fix touch not initializing properly if disabledgerman772021-05-032-2/+10
|
* Merge pull request #6265 from Morph1984/snap-save-fixbunnei2021-05-021-2/+7
|\ | | | | service: filesystem: Return proper error codes for CreateFile
| * service: filesystem: Return proper error codes for CreateFileMorph2021-05-011-2/+7
| | | | | | | | | | | | This improves the accuracy of CreateFile by returning the correct error codes on certain conditions (parent directory does not exist, path already exists). This fixes saving and the loading of existing saves in New Pokemon Snap
* | Disable touch if setting is not enabledgerman772021-05-012-2/+2
|/
* Merge pull request #6226 from german77/sevensixbunnei2021-04-307-12/+201
|\ | | | | hid: Implement SevenSixAxis and ConsoleSixAxisSensor
| * address commentsgerman772021-04-272-5/+5
| |
| * hid: Implement SevenSixAxis and ConsoleSixAxisSensorgerman772021-04-247-12/+201
| |
* | service: Eliminate cases of member shadowingLioncash2021-04-2615-76/+81
| | | | | | | | | | Resolves a few localized instances of member variable shadowing. Brings us a little closer to turning shadowing warnings into errors.
* | nvhost_vic: Fix device closureameerj2021-04-252-10/+8
| | | | | | | | | | | | Implements the OnClose method of the nvhost_vic device, and removes the remnants of an older implementation. Also cleans up some of the surrounding code.
* | Merge pull request #6234 from Morph1984/stub-amMat M2021-04-242-1/+10
|\ \ | | | | | | ICommonStateGetter: Stub SetRequestExitToLibraryAppletAtExecuteNextProgramEnabled
| * | ICommonStateGetter: Stub SetRequestExitToLibraryAppletAtExecuteNextProgramEnabledMorph2021-04-242-1/+10
| | | | | | | | | | | | - Used by Pixel Game Maker Series Werewolf Princess Kaguya
* | | Merge pull request #6235 from german77/ectx_awMat M2021-04-243-0/+47
|\ \ \ | | | | | | | | glue: Add ectx:aw service placeholder
| * | | glue: Add ectx:aw placeholdergerman772021-04-243-0/+47
| | |/ | |/|
* | | Merge pull request #6228 from lioncash/semibunnei2021-04-241-6/+7
|\ \ \ | |_|/ |/| | lm: Resolve -Wextra-semi warning
| * | lm: Make use of insert_or_assign() in Log()Lioncash2021-04-231-1/+1
| | | | | | | | | | | | | | | Avoids unnecessary default construction of an entry in cases where no entry exists before overwriting the created entry.
| * | lm: Prevent redundant map lookups in Log()Lioncash2021-04-231-4/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | We can perform the lookup and then do the contains check by checking the end iterator. The benefit of this is that if we *do* find an entry, then we aren't hashing into the map again to find it. We can also get rid of an unused std::vector temporary while we're at it.
| * | lm: Resolve -Wextra-semi warningLioncash2021-04-231-1/+1
| | | | | | | | | | | | Resolves a trivial warning with clang.
* | | Merge pull request #6229 from lioncash/unused-varbunnei2021-04-242-6/+0
|\ \ \ | |_|/ |/| | acc/lbl: Remove unused variables
| * | acc/lbl: Remove unused variablesLioncash2021-04-232-6/+0
| |/
* / service: hid: Get transfer memory for InitializeSevenSixAxisSensorMorph2021-04-221-1/+38
|/
* Merge pull request #6214 from Morph1984/time-fix-kirby-clashbunnei2021-04-211-3/+5
|\ | | | | time: Fix GetClockSnapshotFromSystemClockContext
| * time: Write buffer before pushing RESULT_SUCCESS in GetClockSnapshotMorph2021-04-191-1/+2
| |
| * time: Fix GetClockSnapshotFromSystemClockContextMorph2021-04-191-2/+3
| | | | | | | | | | | | This removes an incorrect alignment usage and corrects the positions of the popped parameters. - Fixes Super Kirby Clash crashing on boot
* | Merge pull request #6217 from Morph1984/consistent-writebuffersbunnei2021-04-203-5/+12
|\ \ | | | | | | general: Write buffers before pushing raw arguments
| * | general: Write buffers before pushing raw argumentsMorph2021-04-193-5/+12
| |/ | | | | | | For consistency with the rest of the service implementations
* | Merge pull request #6215 from lioncash/duplicatebunnei2021-04-202-2/+1
|\ \ | | | | | | npad: Remove duplicated class member variable
| * | npad: Remove duplicated class member variableLioncash2021-04-192-2/+1
| |/ | | | | | | | | | | ControllerBase already has a System reference that can be accessed from this class, so we can get rid of this to make the class layout a little more straightforward.
* | arp: Use type alias for issue functionLioncash2021-04-191-4/+4
| | | | | | | | Reduces some verbosity and centralizes the function details in one spot.
* | arp: Prevent uninitialized read of launch member variableLioncash2021-04-191-1/+1
|/ | | | | | | | | If anything happened to call arp functions in the wrong order and called IRegistrar's Issue function before SetApplicationLaunchProperty, we'd read from an uninitialized ApplicationLaunchProperty instance. Instead, we can always initialize it so if this does happen, then the outcome of doing such a thing is at least consistently reproducible.
* applets: Send focus state change message on applet state changeMorph2021-04-1710-22/+56
| | | | Fixes the softlock after the controller applet exits in Mario Kart 8 Deluxe.
* applets: Make the applet mode a protected property of AppletMorph2021-04-1714-22/+20
|
* Merge pull request #6125 from ogniK5377/nvdec-close-devbunnei2021-04-171-6/+4
|\ | | | | nvdrv: Cleanup CDMA Processor on device closure
| * nvdrv: Cleanup CDMA Processor on device closureChloe Marcec2021-03-301-6/+4
| | | | | | | | Brings us a step closer to unifying all channels to share a common interface.
* | applets/swkbd: Implement the Normal and Inline Software Keyboard AppletMorph2021-04-153-13/+1487
| |
* | ILibraryAppletCreator: Implement CreateHandleStorageMorph2021-04-152-6/+64
| | | | | | | | Used by Monster Hunter Generations Ultimate
* | hle_ipc: Add helper functions to get copy/move handlesMorph2021-04-152-2/+16
| |
* | ILibraryAppletAccessor: Demote from ERROR to DEBUG for null storage logsMorph2021-04-151-2/+2
| | | | | | | | Avoids unnecessary console spam when the inline software keyboard is used.
* | applets: Pass in the LibraryAppletMode each applet's constructorMorph2021-04-1513-33/+58
| |
* | applets: Remove the previous software keyboard applet implementationMorph2021-04-152-227/+6
| |
* | Merge pull request #6196 from bunnei/asserts-settingbunnei2021-04-1528-28/+28
|\ \ | | | | | | core: settings: Add setting for debug assertions and disable by default.
| * | common: Move settings to common from core.bunnei2021-04-1528-28/+28
| | | | | | | | | | | | - Removes a dependency on core and input_common from common.
* | | k_resource_limit: Minor cleanup of member variables/headersameerj2021-04-144-21/+13
| | |
* | | Merge pull request #6185 from ameerj/process-reslimitbunnei2021-04-142-38/+27
|\ \ \ | |/ / |/| | kernel/process: Replace process resource limit instance with the kernel's resource limit
| * | kernel/process: Replace process resource limit instance with the kernel's resource limitameerj2021-04-122-38/+27
| | | | | | | | | | | | This commit addresses the inaccurate behavior of kernel processes creating their own resource limit, rather than utilizing the kernel's system-wide resource limit instance.
* | | k_thread: Remove [[nodiscard]] attribute from ClearWaitCancelled()Lioncash2021-04-121-1/+1
|/ / | | | | | | | | This function has a void return value, so this attribute doesn't apply to it.
* | Merge pull request #6170 from Morph1984/more-time-fixesbunnei2021-04-116-21/+38
|\ \ | | | | | | service: time: Setup the network clock with the local clock context
| * | service: time: Setup the network clock with the local clock contextMorph2021-04-086-21/+38
| | | | | | | | | | | | Setting the network time allows some time based events using the network clock to not reset.
* | | Merge pull request #6167 from Morph1984/time-fixbunnei2021-04-111-3/+8
|\ \ \ | | | | | | | | service: time: Fix CalculateStandardUserSystemClockDifferenceByUser
| * | | service: time: Fix CalculateStandardUserSystemClockDifferenceByUserMorph2021-04-081-3/+8
| | | | | | | | | | | | | | | | CalculateStandardUserSystemClockDifferenceByUser passes in the ClockSnapshots through 2 input buffers and not as raw arguments. Fix this by reading the 2 input buffers instead of popping raw arguments.
* | | | Merge pull request #6112 from ogniK5377/pctlbunnei2021-04-114-31/+244
|\ \ \ \ | | | | | | | | | | pctl: Rework how pctl works to be more accurate
| * | | | Addressed issuesChloe Marcec2021-03-302-21/+22
| | | | |
| * | | | pctl: Rework how pctl works to be more accurateChloe Marcec2021-03-264-31/+243
| | | | | | | | | | | | | | | | | | | | Introduces the usage of compatibilities to allow it the module to be closer to how it works on hardware.
* | | | | Merge pull request #6099 from bunnei/derive-membunnei2021-04-1023-172/+2087
|\ \ \ \ \ | | | | | | | | | | | | Kernel Rework: Derive memory regions from board layout.
| * | | | | hle: kernel: Breakup InitializeMemoryLayout.bunnei2021-03-241-3/+7
| | | | | |
| * | | | | hle: kernel: k_memory_region_type: Minor code cleanup.bunnei2021-03-241-13/+12
| | | | | |
| * | | | | hle: kernel: k_memory_region: Minor code cleanup.bunnei2021-03-241-7/+5
| | | | | |
| * | | | | hle: kernel: k_memory_layout: Use pair instead of tuple.bunnei2021-03-241-2/+4
| | | | | |
| * | | | | hle: kernel: k_system_control: Remove unnecessary inline.bunnei2021-03-241-4/+4
| | | | | |
| * | | | | common: common_sizes: Move sizes to the Common namespace.bunnei2021-03-244-45/+46
| | | | | |
| * | | | | hle: kernel: Merge KMemoryRegionAttr and KMemoryRegionType.bunnei2021-03-212-11/+9
| | | | | | | | | | | | | | | | | | | | | | | | - Fixes clang errors with mixed enum arithmetic.
| * | | | | hle: kernel: Remove unused variable.bunnei2021-03-211-1/+0
| | | | | |
| * | | | | hle: kernel: k_memory_region_type: Remove extra ".bunnei2021-03-211-1/+1
| | | | | |
| * | | | | hle: kernel: k_memory_layout: Move KMemoryRegionAllocator out of global.bunnei2021-03-213-35/+47
| | | | | |
| * | | | | hle: kernel: k_memory_layout: Derive memory regions based on board layout.bunnei2021-03-215-56/+1031
| | | | | |
| * | | | | common: common_sizes: Move Invalid to Size_* prefix and add missing values.bunnei2021-03-211-14/+14
| | | | | |
| * | | | | hle: kernel: k_memory_region: Refactor to simplify code.bunnei2021-03-212-83/+89
| | | | | |
| * | | | | hle: kernel: board: k_system_control: Extend to include memory region sizes.bunnei2021-03-212-1/+125
| | | | | |
| * | | | | hle: kernel: board: Add secure_monitor module.bunnei2021-03-211-0/+26
| | | | | |
| * | | | | common: Move common sizes to their own header for code reuse.bunnei2021-03-211-13/+1
| | | | | |
| * | | | | hle: kernel: k_address_space_info: Cleanup.bunnei2021-03-211-9/+9
| | | | | |
| * | | | | hle: kernel: Add k_trace module.bunnei2021-03-211-0/+12
| | | | | |
| * | | | | hle: kernel: KSystemControl: Update to reflect board-specific behavior.bunnei2021-03-213-9/+39
| | | | | |
| * | | | | hle: kernel: KMemoryManager: Add CalculateManagementOverheadSize.bunnei2021-03-212-0/+26
| | | | | |
| * | | | | hle: kernel: KMemoryManager: Add aliases.bunnei2021-03-211-0/+4
| | | | | |
| * | | | | hle: kernel: Add architecture and board specific memory regions.bunnei2021-03-212-0/+72
| | | | | |
| * | | | | hle: kernel: KMemoryRegion: Derive region values.bunnei2021-03-211-0/+327
| | | | | |
| * | | | | hle: kernel: Migrate some code from Common::SpinLock to KSpinLock.bunnei2021-03-215-25/+25
| | | | | |
| * | | | | hle: kernel: Add initial KMemoryRegionType module.bunnei2021-03-212-18/+40
| | | | | |
| * | | | | hle: kernel: Move KMemoryRegion to its own module and update.bunnei2021-03-213-31/+321
| | | | | |
* | | | | | Merge pull request #6171 from german77/servicesbunnei2021-04-1030-97/+137
|\ \ \ \ \ \ | | | | | | | | | | | | | | service: Update service function tables and use proper names
| * | | | | | wlan: Update to 12.xgerman772021-04-091-0/+7
| | | | | | |
| * | | | | | usb: Use proper namesgerman772021-04-091-21/+21
| | | | | | |
| * | | | | | ITimeZoneService: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | spl: Update to 12.xgerman772021-04-091-0/+3
| | | | | | |
| * | | | | | sfdnsres: Use proper namesgerman772021-04-091-2/+2
| | | | | | |
| * | | | | | nsd: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | ethc: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | sm: Use proper names, update to 12.xgerman772021-04-091-4/+5
| | | | | | |
| * | | | | | set_sys: Update to 12.xgerman772021-04-091-0/+6
| | | | | | |
| * | | | | | pctl_module: Update to 12.xgerman772021-04-091-0/+3
| | | | | | |
| * | | | | | pcie: Use proper namesgerman772021-04-091-1/+1
| | | | | | |
| * | | | | | olsc: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | pl_u: Update to 12.xgerman772021-04-091-0/+4
| | | | | | |
| * | | | | | ldr: Use proper namesgerman772021-04-091-16/+16
| | | | | | |
| * | | | | | arp: Use proper names, update to 12.xgerman772021-04-092-3/+10
| | | | | | |
| * | | | | | caps_u: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | caps_a: Update to 12.xgerman772021-04-091-0/+1
| | | | | | |
| * | | | | | bpc: Use proper namesgerman772021-04-091-2/+2
| | | | | | |
| * | | | | | bcat_module: Update to 12.xgerman772021-04-091-0/+2
| | | | | | |
| * | | | | | codecctl: Use proper namesgerman772021-04-091-13/+13
| | | | | | |
| * | | | | | audren_u: Use proper namesgerman772021-04-092-4/+4
| | | | | | |
| * | | | | | audren_a: Use proper namesgerman772021-04-091-6/+6
| | | | | | |
| * | | | | | audrec_u: Use proper names, update to 12.xgerman772021-04-091-3/+4
| | | | | | |
| * | | | | | audrec_a: Use proper namesgerman772021-04-091-2/+2
| | | | | | |
| * | | | | | audout_u: Use proper namesgerman772021-04-091-3/+3
| | | | | | |
| * | | | | | audout_a: Use proper namesgerman772021-04-091-6/+6
| | | | | | |
| * | | | | | audin_u: Use proper namesgerman772021-04-091-7/+7
| | | | | | |
| * | | | | | audin_a: Use proper namesgerman772021-04-091-4/+4
| | | | | | |
* | | | | | | Merge pull request #6156 from lioncash/lock-discardbunnei2021-04-103-9/+12
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | kernel: Mark lock helper classes as [[nodiscard]]
| * | | | | | | Amend bizarre clang-format suggestionsLioncash2021-04-073-5/+5
| | | | | | | |
| * | | | | | | k_scoped_scheduler_lock_and_sleep: Mark class as [[nodiscard]]Lioncash2021-04-071-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents logic bugs from slipping through.
| * | | | | | | k_scoped_lock: delete copy and move assignment operatorsLioncash2021-04-071-2/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If we delete the copy and move constructor, we should also be deleting the copy and move assignment operators (and even if this were intended, it would be pretty odd to not document why it's done this way).
| * | | | | | | k_scoped_lock: Mark class as [[nodiscard]]Lioncash2021-04-071-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents logic bugs of the kind described in the previous commit from slipping through.
| * | | | | | | k_scheduler: Mark KScopedSchedulerLock as [[nodiscard]]Lioncash2021-04-071-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents logic bugs like: KScopedSchedulerLock{kernel}; instead of: KScopedSchedulerLock lk{kernel}; from slipping through.
* | | | | | | | Merge pull request #6113 from german77/playhistorybunnei2021-04-101-1/+13
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | Friend: Stub GetPlayHistoryRegistrationKey
| * | | | | | | | Friend: Stub GetPlayHistoryRegistrationKeygerman772021-03-271-1/+13
| | |_|_|/ / / / | |/| | | | | |
* | | | | | | | Merge pull request #6158 from german77/hidServiceTablesbunnei2021-04-102-0/+85
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | hid: Update service function tables
| * | | | | | | | hid: Update service function tablesgerman772021-04-072-0/+85
| | |/ / / / / / | |/| | | | | |
* | | | | | | | ns: Update to 12.xMorph2021-04-091-3/+38
| | | | | | | |
* | | | | | | | aoc_u: Update to 12.xMorph2021-04-091-0/+2
| | | | | | | |
* | | | | | | | nim: Update to 12.xMorph2021-04-091-44/+55
| | | | | | | |
* | | | | | | | npns: Update to 12.xMorph2021-04-091-0/+3
| | | | | | | |
* | | | | | | | bgtc: Update to 12.x and implement OpenTaskServiceMorph2021-04-092-1/+34
| | | | | | | |
* | | | | | | | vi: Update to 12.xMorph2021-04-091-0/+8
| | | | | | | |
* | | | | | | | erpt: Update to 12.xMorph2021-04-091-1/+6
| | | | | | | |
* | | | | | | | btm: Update to 12.xMorph2021-04-091-0/+1
| | | | | | | |
* | | | | | | | btdrv: Update to 12.xMorph2021-04-091-0/+19
| | | | | | | |
* | | | | | | | Merge pull request #6168 from Morph1984/stub-SetNpadAnalogStickUseCenterClampbunnei2021-04-094-1/+29
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | service: hid: Stub SetAnalogStickUseCenterClamp
| * | | | | | | | service: hid: Stub SetAnalogStickUseCenterClampMorph2021-04-084-1/+29
| | |_|_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | - Used by eBASEBALLパワフルプロ野球2020
* | | | | | | | Merge pull request #6155 from ameerj/kernel-12-rescntbunnei2021-04-091-2/+2
|\ \ \ \ \ \ \ \ | |_|_|_|/ / / / |/| | | | | | | kernel: Increase event and session counts
| * | | | | | | kernel: Increase event and session countsameerj2021-04-071-2/+2
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | 12.x increased the number of available sessions and event resource counts
* | | | | | | Merge pull request #6157 from Morph1984/am-update-12.xbunnei2021-04-091-0/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service: am: Update service function tables
| * | | | | | | ISelfController: Update to 11.xMorph2021-04-071-0/+1
| | | | | | | |
| * | | | | | | IApplicationFunctions: Update to 11.xMorph2021-04-071-0/+6
| | | | | | | |
| * | | | | | | IDebugFunctions: Update to 12.xMorph2021-04-071-0/+2
| | | | | | | |
| * | | | | | | ICommonStateGetter: Update to 12.xMorph2021-04-071-0/+9
| | | | | | | |
| * | | | | | | IGlobalStateController: Update to 12.xMorph2021-04-071-0/+1
| | | | | | | |
| * | | | | | | IHomeMenuFunctions: Update to 12.xMorph2021-04-071-0/+3
| |/ / / / / /
* | | | | | | Merge pull request #6062 from ameerj/auto-stubbunnei2021-04-091-0/+6
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service: Add a toggle for auto stub fallback
| * | | | | | | configuration: Add auto stub toggle that resets on bootameerj2021-03-301-4/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Auto-stub is an experimental debugging feature that may cause unforseen bugs. This adds a toggle to only allow auto-stubbing unimplemented functions when explicitly enabled when yuzu is launched.
| * | | | | | | service: Auto stub fallbackameerj2021-03-301-0/+4
| | |_|_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | For simple services we can implement an automatic stub fallback to help with compatibility until a proper implementation is done. Co-Authored-By: Chloe <25727384+ognik5377@users.noreply.github.com>
* | | | | | | Merge pull request #6145 from lat9nq/nvhost_empty_memcpybunnei2021-04-081-6/+11
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | nvhost_nvdec_common: Avoid memcpy with null pointers
| * | | | | | | nvhost_nvdec_common: Avoid memcpy with null pointerslat9nq2021-04-051-6/+11
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoid sending null pointer to memcpy as reported by Undefined Behavious Sanitizer. Co-authored-by: LC <mathew1800@gmail.com>
* | | | | | | Merge pull request #6154 from lioncash/svcrange2bunnei2021-04-081-0/+132
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | svc: Expand SVC tables
| * | | | | | svc: Expand SVC tablesLioncash2021-04-071-0/+132
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | 12.x expanded the range of SVC entries from 0x7F to 0xBF (with all new entries being unused), so we can expand it to also match.
* | | | | | Merge pull request #6160 from Morph1984/fs-update-12.xbunnei2021-04-082-6/+15
|\ \ \ \ \ \ | |_|_|_|_|/ |/| | | | | service: fs: Update service function tables
| * | | | | IFile: Update to 12.xMorph2021-04-071-3/+7
| | | | | |
| * | | | | fsp-srv: Update to 12.xMorph2021-04-072-3/+8
| |/ / / /
* | | | | Merge pull request #6143 from lat9nq/nvhost_null_memcpybunnei2021-04-081-1/+7
|\ \ \ \ \ | | | | | | | | | | | | nvhost_ctrl_gpu: Avoid sending null pointer to memcpy
| * | | | | nvhost_ctrl_gpu: Avoid sending null pointer to memcpylat9nq2021-04-051-1/+7
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | Undefined Behaviour Sanitizer reports a null pointer is being sent to memcpy, thought it's "guaranteed to never be null". Guard it with an if statement, and log when the action has been averted.
* | | | | Merge pull request #6159 from Morph1984/acc-update-12.xbunnei2021-04-073-36/+45
|\ \ \ \ \ | | | | | | | | | | | | service: acc: Update service function tables
| * | | | | dauth_o: Update to 11.xMorph2021-04-071-6/+11
| | | | | |
| * | | | | acc_u1: Update to 12.xMorph2021-04-071-13/+15
| | | | | |
| * | | | | acc_su: Update to 12.xMorph2021-04-071-17/+19
| |/ / / /
* | | | | Merge pull request #6153 from lioncash/svcrangebunnei2021-04-072-6/+1
|\ \ \ \ \ | | | | | | | | | | | | process_capability: Handle extended SVC range
| * | | | | process_capability: Handle extended SVC rangeLioncash2021-04-072-6/+1
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 12.x extended the range of SVC IDs, so we need to expand the range of bits that need to be tested. The upside of this is that we can eliminate a range check, given the whole range is used.
* / / / / hwopus: Update to 12.xMorph2021-04-071-0/+4
|/ / / /
* | | | Merge pull request #6131 from german77/rightjoyconSLSRMorph2021-04-021-2/+6
|\ \ \ \ | | | | | | | | | | HID: Fix SL and SR buttons for right joycon
| * | | | HID: Fix SL and SR buttons for right joycongerman772021-04-021-2/+6
| | |/ / | |/| |
* | | | ISelfController: Stub SetAlbumImageTakenNotificationEnabledMorph2021-03-302-1/+17
| |/ / |/| | | | | | | | | | | This service call sets an internal flag whether a notification is shown when an image is captured. Currently we do not support capturing images via the capture button, so this can be stubbed for now.
* | | Merge pull request #6109 from german77/gestureIDbunnei2021-03-302-3/+13
|\ \ \ | | | | | | | | HID: Initialize correctly the gesture finger_id and filter invalid inputs
| * | | HID: Initialize correctly the gesture finger_id and filter invalid resultsNarr the Reg2021-03-262-3/+13
| |/ /
* | | Merge pull request #6102 from ogniK5377/fd-passbunnei2021-03-2920-78/+161
|\ \ \ | | | | | | | | nvdrv: Pass device fd and handle device create methods for device opening and closing
| * | | nvdrv: Pass device fd and handle device create methods for device opening and closingChloe Marcec2021-03-2520-78/+161
| |/ / | | | | | | | | | We pass the fd to the ioctl as well as alert the device when it's opened or closed to allow for fd unique actions to take place
* | | Merge pull request #6115 from bunnei/fix-kernel-initbunnei2021-03-281-1/+1
|\ \ \ | | | | | | | | hle: kernel: Initialize preemption task after schedulers.
| * | | hle: kernel: Initialize preemption task after schedulers.bunnei2021-03-271-1/+1
| |/ / | | | | | | | | | - Fixes a startup crash that occurs if CoreTiming tries to preempt before kernel initialization completes.
* / / service: friend: Change logging class from ACC to FriendMorph2021-03-271-11/+12
|/ /
* / nvdrv: Change InitializeEx to AllocAsExChloe Marcec2021-03-222-27/+49
|/ | | | Wee also report the correct "big page size" now in GetVARegions & fix up the struct for IoctlAllocAsEx
* Merge pull request #6052 from Morph1984/vi-getindirectlayerimagemapbunnei2021-03-201-1/+27
|\ | | | | IApplicationDisplayService: Stub GetIndirectLayerImageMap
| * IApplicationDisplayService: Stub GetIndirectLayerImageMapMorph2021-03-171-1/+27
| | | | | | | | Used by games invoking the inline software keyboard such as GNOSIA
* | Merge pull request #6056 from zkitX/spl-updatesbunnei2021-03-183-9/+178
|\ \ | |/ |/| service: Refactor spl
| * Fix casing on DeallocateAesKeySlotzkitx2021-03-111-3/+3
| |
| * Update SPL to fit N's service refactor (4.0.0+) which split into new services.zkitx2021-03-113-9/+178
| |
* | bsd: Avoid writing empty buffersMorph2021-03-161-2/+6
| | | | | | | | Silences log spam on empty buffer writes
* | Merge pull request #6054 from Morph1984/time-GetClockSnapshotbunnei2021-03-141-0/+2
|\ \ | | | | | | time: Assign the current time point to the ClockSnapshot
| * | time: Assign the current time point to the ClockSnapshotMorph2021-03-101-0/+2
| |/ | | | | | | Fixes the timer in Super Smash Bros Ultimate's Spirit Board.
* / time: Fix CalculateSpanBetween implementationMorph2021-03-101-3/+9
|/ | | | | | CalculateSpanBetween passes in the ClockSnapshots through 2 input buffers and not as raw arguments. Fix this by reading the 2 input buffers instead of popping raw arguments. Partially fixes Super Smash Bros. Ultimate's Spirit Board
* common: Fiber: use a reference for YieldTo.bunnei2021-03-071-8/+3
| | | | - Fixes another small leak.
* hle: kernel: KThread: Rework dummy threads & fix memory leak.bunnei2021-03-066-36/+65
| | | | | - Dummy threads are created on thread local storage for all host threads. - Fixes a leak by removing creation of fibers, which are not applicable here.
* Revert "core: Switch to unique_ptr for usage of Common::Fiber."bunnei2021-03-065-24/+23
|
* Merge pull request #6006 from bunnei/fiber-unique-ptrbunnei2021-03-055-23/+24
|\ | | | | core: Switch to unique_ptr for usage of Common::Fiber.
| * core: Switch to unique_ptr for usage of Common::Fiber.bunnei2021-02-275-23/+24
| | | | | | | | | | - With using unique_ptr instead of shared_ptr, we have more explicit ownership of the context. - Fixes a memory leak due to circular reference of the shared pointer.
* | Merge pull request #6007 from bunnei/ldn-errorbunnei2021-02-281-1/+1
|\ \ | | | | | | core: hle: ldn: Error out on call to Initialization.
| * | core: hle: ldn: Error out on call to Initialization.bunnei2021-02-271-1/+1
| |/ | | | | | | - Since we do not emulate LDN, returning an error here makes more sense.
* | Merge pull request #5276 from german77/gesturesMorph2021-02-282-11/+240
|\ \ | |/ |/| HID: Implement gestures
| * Implements touch, pan, pinch and rotation gesturesgerman2021-02-282-11/+240
| |
* | Merge pull request #5953 from bunnei/memory-refactor-1bunnei2021-02-2742-1184/+1393
|\ \ | | | | | | Kernel Rework: Memory updates and refactoring (Part 1)
| * | hle: kernel: Migrate PageHeap/PageTable to KPageHeap/KPageTable.bunnei2021-02-1914-134/+118
| | |
| * | hle: kernel: Migrate MemoryManager to KMemoryManager.bunnei2021-02-197-45/+46
| | |
| * | hle: kernel: Migrate PageLinkedList to KPageLinkedList.bunnei2021-02-197-37/+40
| | |
| * | hle: kernel: Migrate to KMemoryBlock, KMemoryBlockManager, and others.bunnei2021-02-1917-472/+475
| | |
| * | hle: kernel: Migrate SlabHeap to KSlabHeap.bunnei2021-02-193-21/+20
| | |
| * | hle: kernel: Migrate MemoryLayout to KMemoryLayout.bunnei2021-02-194-30/+29
| | |
| * | hle: kernel: Migrate AddressSpaceInfo to KAddressSpaceInfo.bunnei2021-02-193-57/+52
| | |
| * | hle: kernel: memory_manager: Rename AllocateContinuous to AllocateContinuous.bunnei2021-02-192-4/+28
| | |
| * | hle: kernel: KSystemControl does not belong in Memory namespace.bunnei2021-02-196-29/+36
| | |
| * | hle: kernel: memory: PageHeap: Migrate to KPageBitmap class.bunnei2021-02-194-197/+23
| | |
| * | hle: kernel: Add KPageBitmap class.bunnei2021-02-191-0/+279
| | |
| * | hle: kernel: system_control: Add function GenerateRandomU64.bunnei2021-02-192-3/+5
| | |
| * | hle: kernel: Add KSpinLock implementation.bunnei2021-02-192-0/+87
| | |
| * | hle: kernel: Rename SharedMemory to KSharedMemory.bunnei2021-02-1912-52/+52
| | |
* | | Merge pull request #5944 from Morph1984/gc-vibrationsbunnei2021-02-272-3/+130
|\ \ \ | | | | | | | | hid: Implement GameCube Controller Vibrations
| * | | hid: Implement GameCube Controller VibrationsMorph2021-02-212-3/+130
| | | | | | | | | | | | | | | | Implements both SendVibrationGcErmCommand and GetActualVibrationGcErmCommand, and modifies GetVibrationDeviceInfo to account for additional controllers.
* | | | acc: Stub GetNintendoAccountUserResourceCacheForApplicationMorph2021-02-211-1/+17
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | This command returns a Nintendo Account ID and writes 2 output buffers. The first output buffer is a NasUserBaseForApplication and the second output buffer is currently empty. Used by: - Pokken Tournament DX - Super Smash Bros. Ultimate - Super Nintendo Entertainment System - Nintendo Switch Online - Mario Kart 8 Deluxe
* / / kernel: Fix resource release exception on exitameerj2021-02-213-2/+13
|/ / | | | | | | | | After rewriting the resource limit, objects releasing reserved resources require a live kernel instance. This commit fixes exceptions that occur due to the kernel being destroyed before some objects released their resources, allowing for a graceful exit.
* | Merge pull request #4973 from ameerj/nvdec-optbunnei2021-02-192-3/+7
|\ \ | | | | | | nvdec: Reuse allocated buffers and general cleanup
| * | Address PR feedbackameerj2021-02-132-4/+2
| | | | | | | | | | | | Co-Authored-By: LC <712067+lioncash@users.noreply.github.com>
| * | nvdec cleanupameerj2021-02-131-1/+7
| | |
* | | Merge pull request #4940 from german77/nativeGCbunnei2021-02-152-1/+88
|\ \ \ | | | | | | | | HID: Implement GC controller in game
| * | | hid: Implement GC controllergerman2021-02-082-1/+88
| | |/ | |/|
* | | hle: service: ldn: IUserLocalCommunicationService: Improve the stub.bunnei2021-02-141-5/+29
| | |
* | | hle: service: ldn: IUserLocalCommunicationService: Indicate that LDN is disabled.bunnei2021-02-142-3/+18
| | | | | | | | | | | | - Fixes crash on Pokemon Sword/Shield when pressing 'Y'.
* | | hle: service: am: IStorageAccessor: Fix out of bounds error handling.bunnei2021-02-141-6/+7
| |/ |/|
* | kernel: More accurately reserve and release resourcesameerj2021-02-136-14/+42
| |
* | kernel: KScopedReservation implementationameerj2021-02-135-26/+151
| | | | | | | | This implements KScopedReservation, allowing resource limit reservations to be more HW accurate, and release upon failure without requiring too many conditionals.
* | kernel: Unify result codes (#5890)Chloe2021-02-1320-254/+222
| | | | | | | | | | | | | | | | | | * kernel: Unify result codes Drop the usage of ERR_NAME convention in kernel for ResultName. Removed seperation between svc_results.h & errors.h as we mainly include both most of the time anyways. * oops * rename errors to svc_results
* | Merge pull request #5902 from lioncash/core-warnbunnei2021-02-123-4/+7
|\ \ | | | | | | core: Silence various warnings on Clang 12
| * | bsd: Remove usage of optional emplace() with no argumentsLioncash2021-02-091-2/+4
| | | | | | | | | | | | Clang 12 currently falls over in the face of this.
| * | am/controller: Remove [[fallthrough]] from unreachable pathLioncash2021-02-091-1/+2
| | | | | | | | | | | | | | | Prevents warnings on clang 12. This path is reachable on other variations of the build that disable the unreachable macro.
| * | nfp: Correct uninitialized size being used within GetTagInfo()Lioncash2021-02-091-1/+1
| |/ | | | | | | | | We were previously the name of the object being initialized within its own initializer, which results in uninitialized data being read.
* | software_keyboard: Implement Finalize request commandMorph2021-02-111-0/+4
| |
* | Merge pull request #5892 from german77/backupbunnei2021-02-091-1/+12
|\ \ | | | | | | olsc: Stub GetSaveDataBackupSetting
| * | olsc: Stub GetSaveDataBackupSettinggerman2021-02-081-1/+12
| |/
* | Merge pull request #5868 from german77/HandheldFixbunnei2021-02-081-0/+1
|\ \ | |/ |/| Prevent over scheduling audio events and add motion update unschedule event
| * Prevent over scheduling audio events and terminate properly the motion update eventgerman2021-02-021-0/+1
| |
* | Merge pull request #5872 from lioncash/svc-errorChloe2021-02-081-59/+188
|\ \ | | | | | | svc: Provide more detailed error logs for svc functions
| * | svc: Provide more detailed error logs for svc functionsLioncash2021-02-061-59/+188
| | | | | | | | | | | | | | | Allows SVC calls to have much more informative information during error cases. This also doesn't hide control flow returns from the reader.
* | | Merge pull request #5887 from ogniK5377/lm-fixbunnei2021-02-071-7/+9
|\ \ \ | | | | | | | | lm: Fix ReadLeb128
| * | | lm: Fix ReadLeb128Chloe Marcec2021-02-071-7/+9
| | | | | | | | | | | | | | | | | | | | | | | | Fixes assertion on Bloodstained Ritual of the Night. We would over read sometimes, this is fixed by checking if the top bit is set in the first iteration. We also lock the loop off to be only the max size of the type we can fit. Finally we changed an incorrect print of "DEBUG" to "TRACE" to reflect the proper log severity
* | | | Merge pull request #5878 from aleasto/masterMorph2021-02-071-2/+7
|\ \ \ \ | |/ / / |/| | | pl_u: Fix read out of bounds
| * | | pl_u: Fix read out of boundsAlessandro Astone2021-02-061-2/+7
| | | |
* | | | Merge pull request #5871 from lioncash/address-arbbunnei2021-02-061-54/+30
|\ \ \ \ | | | | | | | | | | k_address_arbiter: Minor cleanup
| * | | | k_address_arbiter: Unfold R_UNLESS macrosLioncash2021-02-061-5/+8
| | | | | | | | | | | | | | | | | | | | | | | | | Allows for more descriptive error messages and also doesn't hide control-path exit returns from the reader.
| * | | | k_address_arbiter: Remove unnecessary usages of std::addressofLioncash2021-02-061-10/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is a useful function in a generic context or with types that overload unary operator&. However, primitives and pointers will never do this, so we can opt for a more straightforward syntax.
| * | | | k_address_arbiter: Remove dead codeLioncash2021-02-061-40/+13
| | |/ / | |/| | | | | | | | | | | | | | This code is never used, so we can remove it. It's in version control, so it can always be brought back when needed.
* | | | Merge pull request #5326 from german77/hidUpdate1bunnei2021-02-0610-168/+406
|\ \ \ \ | |/ / / |/| | | HID: Update the HID service to match more closely to switchbrew part 1
| * | | Add footer types and address commentsgerman2021-02-047-58/+106
| | | |
| * | | Fix npad struct to match switchbrewgerman2021-02-043-105/+134
| | | |
| * | | Adds missing controller types and propertiesgerman2021-02-049-30/+191
| | | |
* | | | Merge pull request #5862 from bunnei/keventbunnei2021-02-0659-559/+720
|\ \ \ \ | | | | | | | | | | Kernel Rework: Refactor KEvent/KReadableEvent/KWritableEvent
| * | | | hle: kernel: Drop R_UNLESS_NOLOG in favor of expanded if-statement.bunnei2021-02-052-3/+11
| | | | |
| * | | | hle: kernel: KAddressArbiter: Remove noisy error log.bunnei2021-02-051-1/+1
| | | | |
| * | | | hle: kernel: svc: Cleanup KEvent/KReadableEvent/KWritableEvent SVCs.bunnei2021-02-055-69/+89
| | | | |
| * | | | hle: kernel: Reimplement KReadableEvent and KWritableEvent.bunnei2021-02-0538-298/+341
| | | | |
| * | | | hle: kernel: Implement KEvent.bunnei2021-02-052-0/+89
| | | | |
| * | | | hle: kernel: KAddressArbiter: Use R_UNLESS_NOLOG where applicable.bunnei2021-02-051-1/+1
| | | | |
| * | | | hle: kernel: Rename WritableEvent to KWritableEvent.bunnei2021-02-0543-99/+99
| | | | |
| * | | | hle: kernel: Rename ReadableEvent to KReadableEvent.bunnei2021-02-0539-74/+75
| | | | |
* | | | | Merge pull request #5875 from lioncash/identifierbunnei2021-02-061-9/+9
|\ \ \ \ \ | |/ / / / |/| | | | k_priority_queue: Minor cleanup
| * | | | k_priority_queue: Unfold several declval usagesLioncash2021-02-041-5/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given these are only used as function existence checks, we can simplify some usages of declval, given they aren't particularly useful here. Reduces a few template instantiations, which at most reduces compile times a tiny bit.
| * | | | k_priority_queue: Simplify affinity mask type aliasLioncash2021-02-041-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | We can make use of the _t variants of the templates to cut down on a little bit of verbosity.
| * | | | k_priority_queue: Resolved reserved identifierLioncash2021-02-041-2/+2
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | An identifier containing a starting underscore followed by a capital letter is reserved by the standard. It's trivial to avoid this by moving the underscore to the end of the identifier. While the likelihood of clashing here being minimal, we can turn a "should not break" scenario into a definitive "will not break" one, so why not?.
* | | | Merge pull request #5867 from Morph1984/am-GetHealthWarningDisappearedSystemEventbunnei2021-02-052-1/+14
|\ \ \ \ | |_|/ / |/| | | IApplicationFunctions: Implement GetHealthWarningDisappearedSystemEvent
| * | | IApplicationFunctions: Implement GetHealthWarningDisappearedSystemEventMorph2021-02-022-1/+14
| | | |
* | | | k_affinity_mask: Avoid implicit truncation to boolLioncash2021-02-041-1/+1
| |/ / |/| | | | | | | | | | | This can cause compiler warnings. Instead, we can explicitly add a boolean expression around it to naturally turn the result into a bool.
* | | Merge pull request #5848 from ogniK5377/k-resourcelimitbunnei2021-02-0312-228/+340
|\ \ \ | | | | | | | | kernel: Rewrite resource limit to be more accurate
| * | | Simplify limitableresource namesChloe Marcec2021-02-036-36/+29
| | | |
| * | | Compile errorChloe Marcec2021-02-021-1/+1
| | | |
| * | | Address issuesChloe Marcec2021-02-023-19/+15
| | | |
| * | | fix compile errorChloe Marcec2021-01-301-1/+1
| | | |
| * | | cleanup commentingChloe Marcec2021-01-301-2/+2
| | | |
| * | | Drop m_ from lockChloe Marcec2021-01-302-9/+9
| | | |
| * | | Move to GetGlobalTimeNs, fix GetTotalPhysicalMemoryAvailableChloe Marcec2021-01-303-9/+7
| | | |
| * | | kernel: Rewrite resource limit to be more accurateChloe Marcec2021-01-3012-229/+354
| | | | | | | | | | | | | | | | Matches closer to hardware
* | | | Merge pull request #5842 from german77/userfixbunnei2021-02-031-2/+8
|\ \ \ \ | |_|/ / |/| | | acc: Fix error when second user is selected
| * | | Fix user changing to 0 if validgerman2021-01-291-2/+8
| | | |
* | | | Merge pull request #5861 from german77/HandheldFixbunnei2021-02-021-2/+11
|\ \ \ \ | | |_|/ | |/| | hid: Only update motion for npad and prevent over scheduling events
| * | | Only update motion for npad and prevent over scheduling eventsgerman2021-02-011-2/+11
| | | |
* | | | Merge pull request #5859 from Morph1984/nifmbunnei2021-02-011-2/+157
|\ \ \ \ | | | | | | | | | | nifm: Stub GetCurrentNetworkProfile and GetCurrentIpConfigInfo
| * | | | nifm: Stub GetCurrentIpConfigInfoMorph2021-01-311-1/+29
| | | | | | | | | | | | | | | | | | | | - Used by Lets Sing 12
| * | | | nifm: Stub GetCurrentNetworkProfileMorph2021-01-311-1/+41
| | | | | | | | | | | | | | | | | | | | | | | | | - Used by Minecraft Bedrock Edition - Used by Bloons TD 5
| * | | | nifm: Add several structsMorph2021-01-311-0/+87
| | | | |
* | | | | Merge pull request #5856 from Morph1984/nifm-fix-getappletinfo-stubAmeer J2021-02-011-1/+5
|\ \ \ \ \ | | | | | | | | | | | | nifm: Fix GetAppletInfo stub
| * | | | | nifm: Fix GetAppletInfo stubMorph2021-01-311-1/+5
| | | | | |
* | | | | | Merge pull request #5858 from Morph1984/IsGamePlayRecordingSupported-stubbunnei2021-02-012-1/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | am/IApplicationFunctions: Stub IsGamePlayRecordingSupported
| * | | | | | am/IApplicationFunctions: Stub IsGamePlayRecordingSupportedMorph2021-01-312-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Used by RetroArch
* | | | | | | prepo: Stub GetTransmissionStatusMorph2021-01-311-1/+11
| | | | | | |
* | | | | | | prepo: Stub RequestImmediateTransmissionMorph2021-01-311-1/+8
| |_|/ / / / |/| | | | | | | | | | | | | | | | | - Used by Animal Crossing: New Horizons
* | | | | | bsd: Fix EventFd stubMorph2021-01-311-3/+3
|/ / / / /
* | | | | Merge pull request #5855 from Morph1984/bsd-fix-getsockopt-stubbunnei2021-01-311-1/+5
|\ \ \ \ \ | |/ / / / |/| | | | bsd: Fix GetSockOpt stub
| * | | | bsd: Fix GetSockOpt stubMorph2021-01-311-1/+5
| | | | |
* | | | | Merge pull request #5851 from ameerj/pop-inv-stubMorph2021-01-312-1/+10
|\ \ \ \ \ | |/ / / / |/| | | | am: Stub TryPopFromFriendInvitationStorageChannel
| * | | | am: Stub TryPopFromFriendInvitationStorageChannelameerj2021-01-312-1/+10
| | |_|/ | |/| | | | | | | | | | Used by Family Feud
* / | | bsd: Stub EventFdameerj2021-01-312-1/+12
|/ / / | | | | | | | | | Used by Family Feud
* | | Merge pull request #5779 from bunnei/kthread-rewritebunnei2021-01-3056-1859/+2889
|\ \ \ | | | | | | | | Rewrite KThread to be more accurate
| * | | hle: kernel: KLightLock: Fix several bugs.bunnei2021-01-291-3/+3
| | | |
| * | | hle: kernel: KThread: Release thread resource on thread exit.bunnei2021-01-291-0/+1
| | | |
| * | | yuzu: debugger: Ignore HLE threads.bunnei2021-01-292-7/+13
| | | |
| * | | hle: kernel: process: Add state lock.bunnei2021-01-293-6/+15
| | | |
| * | | hle: kernel: threading: Fix bug with host thread naming.bunnei2021-01-291-3/+2
| | | |
| * | | hle: kernel: k_scheduler_lock: Cleanup.bunnei2021-01-291-3/+3
| | | |
| * | | hle: kernel: Allocate a dummy KThread for each host thread, and use it for scheduling.bunnei2021-01-297-41/+45
| | | |
| * | | hle: kernel: k_scheduler: Use atomics for current_thread, etc.bunnei2021-01-292-26/+28
| | | |
| * | | hle: kernel: k_scheduler: Fix for single core mode.bunnei2021-01-291-1/+2
| | | |
| * | | kernel: Fix build errors.bunnei2021-01-292-4/+9
| | | |
| * | | hle: kernel: KScheduler: Introduce thread context_guard.bunnei2021-01-292-3/+16
| | | |
| * | | hle: kernel: Recode implementation of KThread to be more accurate.bunnei2021-01-2912-767/+1553
| | | |
| * | | kernel: svc_types: Add ThreadActivity.bunnei2021-01-291-0/+5
| | | |
| * | | kernel: KSchedulerPriorityQueue: Lowest priority should be LowestThreadPriority.bunnei2021-01-291-1/+1
| | | |
| * | | kernel: k_light_lock: Simplify EmuThreadHandle implementation.bunnei2021-01-294-23/+25
| | | |
| * | | hle: kernel: TimeManager: Simplify to not rely on previous EmuThreadHandle implementation.bunnei2021-01-296-69/+25
| | | |
| * | | core: hle: kernel: object: Implement Finalize() virtual method.bunnei2021-01-2915-6/+29
| | | |
| * | | core: hle: kernel: svc_results: Populate with several missing error codes.bunnei2021-01-291-0/+3
| | | |
| * | | core: hle: kernel: Implement KLightLock.bunnei2021-01-292-0/+171
| | | |
| * | | core: hle: kernel: Implement KThreadQueue.bunnei2021-01-291-0/+81
| | | |
| * | | hle: kernel: KThread: Clean up thread priorities.bunnei2021-01-299-75/+41
| | | |
| * | | hle: kernel: KThread: Reorganize thread priority defaults.bunnei2021-01-297-27/+27
| | | |
| * | | hle: kernel: KThread: Fix ThreadType definition.bunnei2021-01-295-11/+12
| | | |
| * | | hle: kernel: Move single core "phantom mode" out of KThread.bunnei2021-01-293-10/+24
| | | | | | | | | | | | | | | | - This is a workaround that does not belong in a kernel primitive.
| * | | hle: kernel: KThread: Remove thread types that do not exist.bunnei2021-01-294-44/+27
| | | |
| * | | core: hle: kernel: Rename Thread to KThread.bunnei2021-01-2938-246/+245
| | | |
* | | | Merge pull request #5838 from german77/prepostubMorph2021-01-301-1/+10
|\ \ \ \ | | | | | | | | | | prepo: Stub GetSystemSessionId
| * | | | Stub GetSystemSessionIdgerman2021-01-301-1/+10
| | |_|/ | |/| |
* | | | Merge pull request #5809 from ogniK5377/FlushAudioOutBuffersbunnei2021-01-291-1/+9
|\ \ \ \ | |_|/ / |/| | | audout: FlushAudioOutBuffers
| * | | audout: FlushAudioOutBuffersChloe Marcec2021-01-241-1/+9
| | | | | | | | | | | | | | | | Fixes Devil May Cry
* | | | Merge pull request #5837 from german77/socketstubbunnei2021-01-292-1/+17
|\ \ \ \ | | | | | | | | | | sockets: Stub GetSockOpt
| * | | | Stub GetSockOptgerman2021-01-282-1/+17
| | |/ / | |/| |
* | | | Merge pull request #5840 from Morph1984/prepo-fixLC2021-01-283-24/+70
|\ \ \ \ | | | | | | | | | | prepo: Fix BufferDescriptorX invalid buffer index errors and add New variants of SaveReport
| * | | | prepo: Fix BufferDescriptorX invalid buffer errors and add "New" variants of SaveReportMorph2021-01-281-24/+42
| | | | | | | | | | | | | | | | | | | | The second input buffer could be optional when prepo/srepo is called, test for the availability of the second buffer prior to reading from it.
| * | | | hle_ipc: Add Can(Read, Write)BufferMorph2021-01-282-0/+28
| |/ / / | | | | | | | | | | | | Allows us to test whether a buffer can be read from or written to memory
* | | | hid: Add static_assert for Parameter sizeMorph2021-01-281-15/+19
| | | |
* | | | npad: Remove unused device handle parameterMorph2021-01-273-11/+9
|/ / /
* | | Merge pull request #5812 from german77/StubSixaxisFusionbunnei2021-01-274-3/+104
|\ \ \ | | | | | | | | HID: Stub Set/Get/Reset SixaxisSensorFusionParameters
| * | | Stub Set/Get/Reset SixaxisSensorFusionParametersgerman2021-01-244-3/+104
| |/ /
* | | Merge pull request #5810 from ogniK5377/stereo-visionbunnei2021-01-273-7/+60
|\ \ \ | | | | | | | | hle: Implement remaining services for Stereo Vision
| * | | hle: Implement remaining services for Stereo VisionChloe Marcec2021-01-243-7/+60
| |/ / | | | | | | | | | Used by Zelda Breath of the Wild, Super Mario Odyssey and Nintendo Labo
* | | Merge pull request #5824 from ogniK5377/IPsmSessionbunnei2021-01-261-1/+112
|\ \ \ | | | | | | | | psm: IPsmSession
| * | | Omit system referenceChloe Marcec2021-01-251-2/+1
| | | |
| * | | psm: IPsmSessionChloe Marcec2021-01-251-2/+114
| | | | | | | | | | | | | | | | Used by homebrew menu
* | | | Merge pull request #5774 from ogniK5377/mii-raw-randombunnei2021-01-264-2274/+1657
|\ \ \ \ | | | | | | | | | | mii: Fix BuildRandomStoreData & Cleanup raw_data
| * | | | mii: Fix BuildRandomStoreData & Cleanup raw_dataChloe Marcec2021-01-204-2274/+1657
| | | | | | | | | | | | | | | | | | | | | | | | | Cleaned up mii raw data to reflect the underlying values instead of just a chunk of bytes. Fixed BuildRandomStoreData not actually generating random miis properly. "values" should be a u32, not a u8.
* | | | | Merge pull request #5771 from ogniK5377/lm-reworkbunnei2021-01-253-271/+288
|\ \ \ \ \ | |_|/ / / |/| | | | lm: Recode LM service
| * | | | Print Process ID and Thread ID as hexChloe Marcec2021-01-241-2/+2
| | | | |
| * | | | Clamp string reads to buffer sizeChloe Marcec2021-01-231-3/+5
| | | | |
| * | | | Mark DestinationToString as staticChloe Marcec2021-01-201-1/+1
| | | | |
| * | | | Mark LogPacketHeaderEntry hash as noexceptChloe Marcec2021-01-201-1/+1
| | | | |
| * | | | lm: Recode LM serviceChloe Marcec2021-01-203-271/+286
| |/ / / | | | | | | | | | | | | Rework the service to spit out to logs instead of a seperate file as well as fix any crashes caused by lm.
* | | | Merge pull request #5799 from ogniK5377/event-register-unregisterbunnei2021-01-251-1/+7
|\ \ \ \ | |_|/ / |/| | | nvdrv: Unregister already registered events
| * | | Simplify conditionChloe Marcec2021-01-231-2/+1
| | | |
| * | | nvdrv: Unregister already registered eventsChloe Marcec2021-01-231-1/+8
| | | |
* | | | Merge pull request #5806 from bunnei/am-stubbunnei2021-01-241-1/+8
|\ \ \ \ | |/ / / |/| | | hle: service: am: Stub ILibraryAppletAccessor::PresetLibraryAppletGpuTimeSliceZero.
| * | | hle: service: am: Stub ILibraryAppletAccessor::PresetLibraryAppletGpuTimeSliceZero.bunnei2021-01-211-1/+8
| |/ / | | | | | | | | | - Used by Monster Hunter Rise demo.
* | | Merge pull request #5776 from ogniK5377/lblbunnei2021-01-231-22/+261
|\ \ \ | | | | | | | | lbl: Implement most of lbl
| * | | lbl: Implement most of lblChloe Marcec2021-01-201-22/+261
| |/ / | | | | | | | | | Pretty basic service, only thing left to do is handle setting applying once set:sys is implemented
* | | Merge pull request #5765 from ogniK5377/StoreSaveDataThumbnail-stubbunnei2021-01-235-6/+66
|\ \ \ | | | | | | | | acc: Stub StoreSaveDataThumbnail
| * | | acc: Stub StoreSaveDataThumbnailChloe Marcec2021-01-195-6/+66
| |/ / | | | | | | | | | Fixes ACA NEOGEO METAL SLUG hanging on boot.
* | | Merge pull request #5270 from german77/multiTouchbunnei2021-01-212-29/+130
|\ \ \ | |/ / |/| | HID: Add multitouch support
| * | Always initialize keyboard inputgerman2021-01-151-5/+1
| | |
| * | Add mutitouch support for touch screensgerman2021-01-152-19/+25
| | |
| * | Allow to return up to 16 touch inputs per enginegerman2021-01-152-55/+75
| | |
| * | Allow all touch inputs at the same time and remove config options that are not longer necesarygerman2021-01-152-11/+20
| | |
| * | Add multitouch supportgerman2021-01-152-23/+93
| | |
* | | npad: Add check for HANDHELD_INDEX in UpdateControllerAt()Morph2021-01-181-1/+1
| | |
* | | Merge pull request #5360 from ReinUsesLisp/enforce-memclass-accessbunnei2021-01-1712-179/+189
|\ \ \ | |_|/ |/| | core: Silence Wclass-memaccess warnings and enforce it
| * | core: Silence Wclass-memaccess warningsReinUsesLisp2021-01-1512-179/+189
| | | | | | | | | | | | | | | This requires making several types trivial and properly initialize them whenever they are called.
* | | Merge pull request #5358 from ReinUsesLisp/rename-insert-paddingLC2021-01-152-7/+7
|\| | | |/ |/| common/common_funcs: Rename INSERT_UNION_PADDING_{BYTES,WORDS} to _NOINIT
| * common/common_funcs: Rename INSERT_UNION_PADDING_{BYTES,WORDS} to _NOINITReinUsesLisp2021-01-152-7/+7
| | | | | | | | INSERT_PADDING_BYTES_NOINIT is more descriptive of the underlying behavior.
* | common/bit_util: Replace CLZ/CTZ operations with standardized onesLioncash2021-01-154-8/+12
|/ | | | Makes for less code that we need to maintain.
* hle: kernel: thread: Preserve thread wait reason for debugging only.bunnei2021-01-117-1/+34
| | | | - This is decoupled from core functionality and used for debugging only.
* hle: kernel: k_scheduler_lock: Fix shadowing errors.bunnei2021-01-111-1/+1
|
* core: hle: Add missing calls to MicroProfileOnThreadExit.bunnei2021-01-111-0/+4
|
* core: hle: Integrate new KConditionVariable and KAddressArbiter implementations.bunnei2021-01-1113-1173/+503
|
* core: hle: kernel: Update KAddressArbiter.bunnei2021-01-112-0/+435
|
* core: hle: kernel: Update KConditionVariable.bunnei2021-01-113-0/+411
|
* core: hle: kernel: Begin moving common SVC defintions to its own header.bunnei2021-01-111-0/+13
|
* hle: kernel: Remove unnecessary AddressArbiter definition.bunnei2021-01-111-1/+0
|
* hle: kernel: k_scheduler: Cleanup OnThreadPriorityChanged.bunnei2021-01-112-6/+3
|
* hle: kernel: Rename thread "status" to "state".bunnei2021-01-111-2/+2
|
* hle: kernel: thread: Replace ThreadStatus/ThreadSchedStatus with a single ThreadState.bunnei2021-01-1111-127/+97
| | | | - This is how the real kernel works, and is more accurate and simpler.
* core: hle: kernel: Add some useful functions for checking kernel addresses.bunnei2021-01-111-0/+19
|
* core: hle: kernel: svc_types: Add type definitions for KAddressArbiter.bunnei2021-01-111-0/+12
|
* core: hle: kernel: Update KSynchronizationObject.bunnei2021-01-1130-599/+377
|
* core: hle: kernel: Begin moving common SVC results to its own header.bunnei2021-01-111-0/+20
|
* hle: service: nfp: Remove incorrect signaling behavior in GetDeviceState.bunnei2021-01-111-6/+0
|
* Merge pull request #5312 from german77/overclockenabledbunnei2021-01-102-1/+10
|\ | | | | apm: Stub IsCpuOverclockEnabled
| * Stub IsCpuOverclockEnabledgerman2021-01-082-1/+10
| |
* | core: Silence unhandled enum in switch warningsReinUsesLisp2021-01-091-2/+4
|/
* fix for nvdec disabled, cleanup host1xameerj2021-01-071-11/+14
|
* nvdec syncpt incorporationameerj2021-01-077-20/+43
| | | | laying the groundwork for async gpu, although this does not fully implement async nvdec operations
* core: Silence warnings when compiling without assertsReinUsesLisp2021-01-052-0/+3
|
* buffer_queue: Protect queue_sequence list access with a mutexameerj2021-01-042-13/+21
| | | | fixes a data race as this is an unprotected variable manipulated by multiple threads
* hle: service: nvflinger: buffer_queue: Do not reset id/layer_id on Connect.bunnei2021-01-031-2/+0
| | | | - This behavior is a mistake, fixes Katana Zero.
* general: Fix various spelling errorsMorph2021-01-025-19/+19
|
* Merge pull request #5249 from ReinUsesLisp/lock-free-pagesbunnei2021-01-011-1/+1
|\ | | | | core/memory: Read and write page table atomically
| * core/memory: Read and write page table atomicallyReinUsesLisp2020-12-301-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Squash attributes into the pointer's integer, making them an uintptr_t pair containing 2 bits at the bottom and then the pointer. These bits are currently unused thanks to alignment requirements. Configure Dynarmic to mask out these bits on pointer reads. While we are at it, remove some unused attributes carried over from Citra. Read/Write and other hot functions use a two step unpacking process that is less readable to stop MSVC from emitting an extra AND instruction in the hot path: mov rdi,rcx shr rdx,0Ch mov r8,qword ptr [rax+8] mov rax,qword ptr [r8+rdx*8] mov rdx,rax -and al,3 and rdx,0FFFFFFFFFFFFFFFCh je Core::Memory::Memory::Impl::Read<unsigned char> mov rax,qword ptr [vaddr] movzx eax,byte ptr [rdx+rax]
* | Merge pull request #5208 from bunnei/service-threadsbunnei2020-12-3144-666/+496
|\ \ | | | | | | Service threads
| * | hle: kernel: service_thread: Make thread naming more consistent.bunnei2020-12-301-1/+1
| | |
| * | hle: kernel: Manage service threads on another thread.bunnei2020-12-301-9/+20
| | | | | | | | | | | | - This is to allow service threads to defer destruction of themselves.
| * | hle: kernel: Manage host thread IDs using TLS.bunnei2020-12-301-46/+31
| | | | | | | | | | | | - Avoids the need to have a large map of host to guest thread IDs.
| * | hle: kernel: Move ServiceThread ownership to KernelCore.bunnei2020-12-294-5/+48
| | | | | | | | | | | | - Fixes a circular dependency which prevented threads from being released on shutdown.
| * | hle: kernel: service_thread: Add thread name and take weak_ptr of ServerSession.bunnei2020-12-293-11/+22
| | |
| * | hle: service: Acquire and release a lock on requests.bunnei2020-12-295-25/+35
| | | | | | | | | | | | - This makes it such that we can safely access service members from CoreTiming thread.
| * | core: hle: kernel: Clear process list on boot.bunnei2020-12-291-2/+2
| | |
| * | hle: service: vi: Refactor to grab buffer only once.bunnei2020-12-291-15/+4
| | |
| * | service: nvflinger: Improve synchronization for BufferQueue.bunnei2020-12-295-19/+72
| | | | | | | | | | | | | | | - Use proper mechanisms for blocking on DequeueBuffer. - Ensure service thread terminates on emulation Shutdown.
| * | hle: service: Ensure system is powered on before writing IPC result.bunnei2020-12-291-1/+5
| | |
| * | core: kernel: Clear process list earlier.bunnei2020-12-291-2/+2
| | |
| * | hle: kernel: hle_ipc: Remove SleepClientThread.bunnei2020-12-292-54/+0
| | | | | | | | | | | | - This was kind of hacky, and no longer is necessary with service threads.
| * | hle: service: bsd: Update to work with service threads, removing SleepClientThread.bunnei2020-12-293-249/+45
| | |
| * | hle: service: nvdrv: Revert #4981 to remove usage of SleepClientThread.bunnei2020-12-2923-211/+83
| | | | | | | | | | | | - Note, this always processes the ioctl right away, which fixes BotW 1.0.0 issues.
| * | hle: kernel: service_thread: Add parameter for thread pool size.bunnei2020-12-293-7/+7
| | |
| * | hle: service: nvflinger: Refactor locking and interfaces.bunnei2020-12-293-45/+31
| | |
| * | hle: service: vi: Remove usage of SleepClientThread.bunnei2020-12-291-34/+43
| | |
| * | core: hle: server_session: Use separate threads for each service connection.bunnei2020-12-295-23/+138
| | |
* | | service/pcie: Fix invalid initialization argumentReinUsesLisp2020-12-301-1/+1
| | |
* | | Merge pull request #5247 from comex/xx-conceptsbunnei2020-12-301-3/+5
|\ \ \ | | | | | | | | k_priority_queue: Fix concepts use
| * | | k_priority_queue: Fix concepts usecomex2020-12-291-3/+5
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - For `std::same_as`, add missing include of `<concepts>`. - For `std::convertible_to`, create a replacement in `common/concepts.h` and use that instead. This would also be found in `<concepts>`, but unlike `std::same_as`, `std::convertible_to` is not yet implemented in libc++, LLVM's STL implementation - not even in master. (In fact, `std::same_as` is the *only* concept currently implemented. For some reason.)
* | | Merge pull request #5246 from comex/xx-includebunnei2020-12-301-0/+1
|\ \ \ | |_|/ |/| | Add missing include of "core/hle/kernel/kernel.h"
| * | Add missing include of "core/hle/kernel/kernel.h"comex2020-12-291-0/+1
| |/ | | | | | | This is needed as the header invokes methods on KernelCore.
* / svc: demote SleepThread log to LOG_TRACEameerj2020-12-291-1/+1
|/ | | | This log is called often, and introduces a lot of noise when debug logging is enabled, making it difficult to see other debug logs.
* Merge pull request #5042 from Morph1984/project-aetherbunnei2020-12-2210-527/+643
|\ | | | | Project Aether: Reimplementation of the Web Browser Applet
| * applets/web: Implement the online web browser appletMorph2020-12-182-3/+11
| |
| * main, applets/web: Re-add progress dialog for RomFS extractionMorph2020-12-182-32/+44
| |
| * pl_u, applets/web: Decrypt shared fonts to TTF filesMorph2020-12-183-18/+117
| |
| * ns_vm: Stub NeedsUpdateVulnerabilityMorph2020-12-181-1/+10
| | | | | | | | This is used to force system updates on launching the web browser. We do not care about system updates so this can be set to false.
| * controllers/npad: Make press_state atomicMorph2020-12-182-2/+3
| |
| * applets/web: Implement the default web browser applet frontendMorph2020-12-181-1/+4
| |
| * applets/web: Implement the offline browser applet backendMorph2020-12-182-13/+143
| |
| * applets/web: Initial implementation of the web browser appletMorph2020-12-183-2/+428
| |
| * applets: Remove the previous web browser applet implementationMorph2020-12-184-609/+37
| |
* | Merge pull request #5131 from bunnei/scheduler-rewritebunnei2020-12-2129-1372/+2041
|\ \ | | | | | | Rewrite Kernel scheduler based on Atmosphere
| * | hle: kernel: Process: Various style fixes based on code review feedback.bunnei2020-12-061-2/+2
| | |
| * | hle: kernel: Thread: Various style fixes based on code review feedback.bunnei2020-12-061-22/+25
| | |
| * | hle: kernel: KScopedSchedulerLockAndSleep: Various style fixes based on code review feedback.bunnei2020-12-061-6/+6
| | |
| * | hle: kernel: KScopedLock: Various style fixes based on code review feedback.bunnei2020-12-061-6/+8
| | |
| * | hle: kernel: KAbstractSchedulerLock: Various style fixes based on code review feedback.bunnei2020-12-061-9/+7
| | |
| * | hle: kernel: KScheduler: Various style fixes based on code review feedback.bunnei2020-12-062-50/+41
| | |
| * | hle: kernel: KPriorityQueue: Various style fixes based on code review feedback.bunnei2020-12-061-29/+36
| | |
| * | hle: kernel: KAffinityMask: Various style fixes based on code review feedback.bunnei2020-12-061-17/+13
| | |
| * | hle: kernel: GlobalSchedulerContext: Various style fixes based on code review feedback.bunnei2020-12-062-5/+10
| | |
| * | hle: kernel: Use C++ style comments in KScheduler, etc.bunnei2020-12-064-152/+136
| | |
| * | kernel: KScopedSchedulerLockAndSleep: Remove unused ctor.bunnei2020-12-061-13/+7
| | |
| * | kernel: time_manager: Add missing lock guards.bunnei2020-12-061-3/+10
| | |
| * | hle: kernel: Migrate to KScopedSchedulerLock.bunnei2020-12-0614-48/+91
| | |
| * | hle: kernel: Separate KScopedSchedulerLockAndSleep from k_scheduler.bunnei2020-12-0610-69/+71
| | |
| * | hle: kernel: Separate KScheduler from GlobalSchedulerContext class.bunnei2020-12-064-118/+138
| | |
| * | hle: kernel: Rewrite scheduler implementation based on Mesopshere.bunnei2020-12-0620-1146/+1179
| | |
| * | hle: kernel: physical_core: Clear exclusive state after each run.bunnei2020-12-061-0/+1
| | | | | | | | | | | | - This is closer to pre-multicore behavior, and works a bit better.
| * | hle: kernel: Port KAbstractSchedulerLock from Mesosphere.bunnei2020-12-061-0/+76
| | |
| * | hle: kernel: svc: Remove reschedule on svcBreak.bunnei2020-12-061-5/+0
| | | | | | | | | | | | - This breaks things, and is unnecessary, since emulation will be done at this point.
| * | hle: kernel: process: Add schedule count tracking, to be used for yield impl.bunnei2020-12-061-0/+13
| | |
| * | hle: kernel: svc: Remove unnecessary hack in svcSleep.bunnei2020-12-061-7/+0
| | |
| * | common: Port KPriorityQueue from Mesosphere.bunnei2020-12-061-0/+443
| | |
| * | hle: kernel: Port KAffinityMask from Mesosphere.bunnei2020-12-065-14/+77
| | |
* | | buffer_queue: better use of std::arrayameerj2020-12-181-59/+46
| | |
* | | Overwrite slots instead of queuing them, add disconnect signalameerj2020-12-173-27/+33
| |/ |/| | | | | Fix for Katana Zero and Yoshi's Crafted World
* | Merge pull request #5190 from Morph1984/validate_device_handlebunnei2020-12-162-0/+45
|\ \ | | | | | | controllers/npad: Validate device handles before use
| * | controllers/npad: Validate device handles before useMorph2020-12-122-0/+45
| | | | | | | | | | | | Some games such as NEKOPARA Vol. 3 send invalid device handles when calling InitializeVibrationDevice. Introduce a check to validate the device handle before use.
* | | Merge pull request #5119 from Morph1984/fs-opendatastoragewithprogramindexbunnei2020-12-155-8/+62
|\ \ \ | | | | | | | | fsp_srv: Implement OpenDataStorageWithProgramIndex
| * | | fsp_srv: Implement OpenDataStorageWithProgramIndexMorph2020-12-084-1/+57
| | | | | | | | | | | | | | | | - Used by RollerCoaster Tycoon 3: Complete Edition
| * | | file_sys: Consolidate common Title ID operationsMorph2020-12-081-7/+5
| | | |
* | | | Merge pull request #5168 from Morph1984/aoc-PurchaseEventManagerbunnei2020-12-152-2/+76
|\ \ \ \ | |_|/ / |/| | | aoc_u: Stub IPurchaseEventManager and its service commands
| * | | IPurchaseEventManager: Implement GetPurchasedEventReadableHandleMorph2020-12-081-1/+14
| | | | | | | | | | | | | | | | | | | | - Used by Pokémon Café Mix - Used by DOOM: Eternal
| * | | IPurchaseEventManager: Stub Set(Default)DeliveryTargetMorph2020-12-081-2/+27
| | | | | | | | | | | | | | | | | | | | - Used by Pokémon Café Mix - Used by DOOM: Eternal
| * | | aoc_u: Stub Create(Permanent)EcPurchasedEventManagerMorph2020-12-082-2/+38
| |/ / | | | | | | | | | | | | - Used by Pokémon Café Mix - Used by DOOM: Eternal
* | | Merge pull request #5172 from lioncash/svc-widebunnei2020-12-121-35/+25
|\ \ \ | | | | | | | | svc: Remove unnecessary casts
| * | | svc: Remove unnecessary castsLioncash2020-12-081-35/+25
| |/ / | | | | | | | | | | | | | | | Simplifies and removes some casts. In all cases, these were generally widening from a 32-bit unsigned type to a 64-bit unsigned type, so no information would be lost from the conversion.
* | | Merge pull request #5123 from Morph1984/nim-IsLargeResourceAvailablebunnei2020-12-101-1/+13
|\ \ \ | | | | | | | | nim: Stub IsLargeResourceAvailable
| * | | nim: Stub IsLargeResourceAvailableMorph2020-12-041-1/+13
| | |/ | |/| | | | | | | - Used by Immortals Fenyx Rising
* | | Merge pull request #5142 from comex/xx-poll-eventsRodrigo Locatti2020-12-094-40/+45
|\ \ \ | | | | | | | | network, sockets: Replace `POLL_IN`, `POLL_OUT`, etc. constants with an `enum class PollEvents`
| * | | network, sockets: Replace `POLL_IN`, `POLL_OUT`, etc. constants with an `enum class PollEvents`comex2020-12-074-40/+45
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Actually, two enum classes, since for some reason there are two separate yet identical `PollFD` types used in the codebase. I get that one is ABI-compatible with the Switch while the other is an abstract type used for the host, but why not use `WSAPOLLFD` directly for the latter? Anyway, why make this change? Because on Apple platforms, `POLL_IN`, `POLL_OUT`, etc. (with an underscore) are defined as macros in <sys/signal.h>. (This is inherited from FreeBSD.) So defining a variable with the same name causes a compile error. I could just rename the variables, but while I was at it I thought I might as well switch to an enum for stronger typing. Also, change the type used for values copied directly to/from the `events` and `revents` fields of the host *native* `pollfd`/`WSASPOLLFD`, from `u32` to `short`, as `short` is the correct canonical type on both Unix and Windows.
* | | | Merge pull request #5166 from lioncash/log-castbunnei2020-12-0921-76/+67
|\ \ \ \ | | | | | | | | | | core: Remove unnecessary enum casts in log calls
| * | | | core: Remove unnecessary enum casts in log callsLioncash2020-12-0821-76/+67
| | | | | | | | | | | | | | | | | | | | | | | | | Follows the video core PR. fmt doesn't require casts for enum classes anymore, so we can remove quite a few casts.
* | | | | Merge pull request #5135 from Morph1984/applets-shadowbunnei2020-12-091-1/+1
|\ \ \ \ \ | |_|_|_|/ |/| | | | applets: Resolve variable shadowing
| * | | | applets: Resolve variable shadowingMorph2020-12-051-1/+1
| | |_|/ | |/| |
* | | | controller: Use std::move within ConvertToFrontendParameters()Lioncash2020-12-081-3/+3
| | | | | | | | | | | | | | | | Avoids unnecessary copies.
* | | | controller: Avoid unnecessary copies in ConfigurationComplete()Lioncash2020-12-081-9/+8
| |/ / |/| | | | | | | | | | | Avoids unnecessary 1072 byte copies when querying info about controllers.
* | | Merge pull request #5148 from comex/xx-unused-fieldsbunnei2020-12-072-3/+3
|\ \ \ | | | | | | | | core: Mark unused fields as [[maybe_unused]]
| * | | core: Mark unused fields as [[maybe_unused]]comex2020-12-072-3/+3
| |/ /
* | | Merge pull request #5154 from comex/xx-ipcbunnei2020-12-072-34/+37
|\ \ \ | | | | | | | | hle: Type check ResponseBuilder::Push arguments, and fix use in vi.cpp
| * | | hle: Type check ResponseBuilder::Push arguments, and fix use in vi.cppcomex2020-12-072-34/+37
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - Add a type check so that calling Push with an invalid type produces a compile error rather than a linker error. - vi.cpp was calling Push with a variable of type `std::size_t`. There's no explicit overload for `size_t`, but there is one for `u64`, which on most platforms is the same type as `size_t`. On macOS, however, it isn't: both types are 64 bits, but `size_t` is `unsigned long` and `u64` is `unsigned long long`. Regardless, it makes more sense to explicitly use `u64` here instead of `size_t`.
* | | Merge pull request #5147 from comex/xx-purevirtLC2020-12-071-33/+0
|\ \ \ | | | | | | | | nvdrv: Remove useless re-declaration of pure virtual methods that were already declared in the superclass
| * | | nvdrv: Remove useless re-declaration of pure virtual methods that were already declared in the superclasscomex2020-12-071-33/+0
| |/ /
* | | Merge pull request #5150 from comex/xx-boxcatLC2020-12-071-1/+1
|\ \ \ | | | | | | | | boxcat: Avoid unnecessary object copy
| * | | boxcat: Avoid unnecessary object copycomex2020-12-071-1/+1
| |/ /
* | | Merge pull request #5136 from lioncash/video-shadow3LC2020-12-071-3/+3
|\ \ \ | |_|/ |/| | video_core: Resolve more variable shadowing scenarios pt.3
| * | video_core: Resolve more variable shadowing scenarios pt.3Lioncash2020-12-051-3/+3
| |/ | | | | | | | | Cleans out the rest of the occurrences of variable shadowing and makes any further occurrences of shadowing compiler errors.
* / Fix "explicitly defaulted but implicitly deleted" warningcomex2020-12-071-1/+1
|/ | | | | | | | | | `PhysicalCore`'s move assignment operator was declared as `= default`, but was implicitly deleted because `PhysicalCore` has fields of reference type. Switch to explicitly deleting it to avoid a Clang warning. The move *constructor* is still defaulted, and is required to exist due to the use of `std::vector<PhysicalCore>`.
* Merge pull request #4996 from bunnei/use-4jitsbunnei2020-12-0416-120/+132
|\ | | | | Kernel: Refactor to use 4-instances of Dynarmic & various cleanups and improvements
| * kernel: scheduler: Minor cleanup to remove duplicated code.bunnei2020-11-292-46/+14
| |
| * kernel: time_manager: Protect access with a mutex.bunnei2020-11-292-1/+5
| |
| * hle: kernel: thread: Remove unused "Running" state.bunnei2020-11-292-6/+0
| |
| * core: arm: Implement InvalidateCacheRange for CPU cache invalidation.bunnei2020-11-295-10/+21
| |
| * hle: kernel: time_manager: Avoid a crash on process exit.bunnei2020-11-291-1/+4
| |
| * hle: kernel: AddressArbiter: Remove unused code.bunnei2020-11-292-9/+0
| |
| * hle: kernel: SynchronizationObject: Use atomic_bool for is_signaled.bunnei2020-11-291-1/+2
| |
| * common: fiber: Use boost::context instead of native fibers on Windows.bunnei2020-11-291-1/+1
| |
| * hle: kernel: multicore: Replace n-JITs impl. with 4 JITs.bunnei2020-11-298-57/+97
| |
* | Merge pull request #5000 from lioncash/audio-errorbunnei2020-12-031-1/+1
|\ \ | |/ |/| audio_core: Make shadowing and unused parameters errors
| * audio_core: Make shadowing and unused parameters errorsLioncash2020-12-031-1/+1
| | | | | | | | Moves the audio code closer to enabling warnings as errors in general.
* | Merge pull request #4998 from Morph1984/bioshock-patchbunnei2020-11-291-2/+4
|\ \ | | | | | | hid: Check if applet_resource exists in InitializeVibrationDevice
| * | hid: Check if applet_resource exists in InitializeVibrationDeviceMorph2020-11-251-2/+4
| |/
* | Add missing types to NpadCommunicationModegerman2020-11-291-0/+2
| |
* | Merge pull request #5021 from german77/StubCommunicationModebunnei2020-11-294-2/+50
|\ \ | | | | | | HID: Stub set and get NpadCommunicationMode
| * | Stub set and get NpadCommunicationModegerman2020-11-274-2/+50
| | |
* | | savedata_factory: Eliminate usage of the global system instanceLioncash2020-11-271-1/+2
| | | | | | | | | | | | Now there's only two meaningful instances left in core.
* | | service: Eliminate usages of the global system instanceLioncash2020-11-27219-897/+1207
|/ / | | | | | | | | Completely removes all usages of the global system instance within the services code by passing in the using system instance to the services.
* | Merge pull request #4975 from comex/invalid-syncpoint-idbunnei2020-11-261-2/+2
|\ \ | | | | | | nvdrv, video_core: Don't index out of bounds when given invalid syncpoint ID
| * | nvdrv, video_core: Don't index out of bounds when given invalid syncpoint IDcomex2020-11-241-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | - Use .at() instead of raw indexing when dealing with untrusted indices. - For the special case of WaitFence with syncpoint id UINT32_MAX, instead of crashing, log an error and ignore. This is what I get when running Super Mario Maker 2.
* | | Merge pull request #4981 from ogniK5377/ioctl-ctrlbunnei2020-11-2624-91/+214
|\ \ \ | |_|/ |/| | nvservices: Reintroducee IoctlCtrl
| * | nvservices: Reintroducee IoctlCtrlChloe Marcec2020-11-2424-91/+214
| |/ | | | | | | Fixes regression caused by #4907 which caused games like Breath of the Wild 1.0.0 not to boot.
* | service: am: Implement ExecuteProgram and required stubs.bunnei2020-11-252-3/+34
| | | | | | | | - This is used by Super Mario 3D All-Stars.
* | hle: services: Fix a crash with improper NVFlinger lifetime management. (#4977)bunnei2020-11-2416-97/+98
| | | | | | | | | | | | * hle: services: Fix a crash with improper NVFlinger lifetime management. - This crash would happen when attempting to shutdown yuzu early on in boot.
* | Merge pull request #4972 from lioncash/unused4Rodrigo Locatti2020-11-241-1/+1
|\ \ | |/ |/| svc: Remove unnecessary [[maybe_unused]] tag
| * svc: Remove unnecessary [[maybe_unused]] tagLioncash2020-11-231-1/+1
| | | | | | | | | | The parameter is used in this function, so this suppression isn't necessary.
* | Merge pull request #4944 from lioncash/system-rembunnei2020-11-228-31/+66
|\ \ | | | | | | patch_manager: Remove usages of the global system instance
| * | patch_manager: Remove usages of the global system instanceLioncash2020-11-188-31/+66
| |/ | | | | | | | | | | | | With this, only 19 usages of the global system instance remain within the core library. We're almost there.
* | Merge pull request #4907 from ogniK5377/nvdrv-cleanupbunnei2020-11-2126-898/+1220
|\ \ | | | | | | core: Make nvservices more standardized
| * | Addressed issuesChloe Marcec2020-11-1010-17/+86
| | |
| * | core: Make nvservices more standardizedChloe Marcec2020-11-1026-903/+1156
| | |
* | | olsc: Move member initialization to after member functions.bunnei2020-11-201-2/+2
| | |
* | | hle: service: Stub OLSC Initialize and SetSaveDataBackupSettingEnabled functions.bunnei2020-11-193-0/+87
| |/ |/| | | | | - Used by Animal Cross: New Horizons v1.6.0 update, minimal stub gets this update working.
* | hid: Reimplement Begin/EndPermitVibrationSessionMorph2020-11-163-5/+17
| | | | | | | | Upon further investigation, these commands allow temporary vibrations even when the "Controller Vibration" system setting is disabled. As a result, vibrations are allowed when either the system setting or this flag is set to true. Therefore, we can only block vibrations when both flags are set to false.
* | controllers/npad: Load input devices on initMorph2020-11-161-0/+2
| |
* | general: Fix compiler warnings on linux and miscellaneous changesMorph2020-11-162-8/+11
| |
* | controllers/npad: Remove the old vibration filterMorph2020-11-163-50/+64
| | | | | | | | Previously we used a vibration filter that filters out amplitudes close to each other. It turns out there are cases where this results into vibrations that are too inaccurate. Remove this and move the 100Hz vibration filter (Only allowing a maximum of 100 vibrations per second) from sdl_impl to npad when enable_accurate_vibrations is set to false.
* | hid: Implement InitializeVibrationDevice and IsVibrationDeviceMountedMorph2020-11-163-12/+66
| |
* | input_common: Add VibrationDevice and VibrationDeviceFactoryMorph2020-11-163-33/+27
| | | | | | | | | | | | A vibration device is an input device that returns an unsigned byte as status. It represents whether the vibration device supports vibration or not. If the status returns 1, it supports vibration. Otherwise, it does not support vibration.
* | configure_input: Add per-player vibrationMorph2020-11-161-2/+11
| | | | | | | | | | | | | | Allows for enabling and modifying vibration and vibration strength per player. Also adds a toggle for enabling/disabling accurate vibrations. Co-authored-by: Its-Rei <kupfel@gmail.com>
* | settings: Remove global vibration strength modifierMorph2020-11-161-3/+1
| | | | | | | | This will be replaced in favor of per-player vibration strength modifiers.
* | hid: Mark Begin/EndPermitVibrationSession as stubsMorph2020-11-163-18/+4
| | | | | | | | The implementation of these commands seem incomplete and causes rumble in Super Mario Party to stop working since only EndPermitVibrationSession is called. Thus, these are better off being marked as a stub until this can be investigated more thoroughly.
* | controllers/npad: Send an empty vibration on destruction/deactivationMorph2020-11-163-22/+38
| | | | | | | | This stops all controllers from continuously vibrating when emulation is stopped.
* | hid: Stub IsVibrationDeviceMountedMorph2020-11-162-1/+23
| | | | | | | | - Used in Super Mario Odyssey
* | controllers/npad: Add heuristics to reduce rumble state changesMorph2020-11-161-5/+46
| | | | | | | | | | Sending too many state changes in a short period of time can cause massive performance issues. As a result, we have to use several heuristics to reduce the number of state changes to minimize/eliminate this performance impact while maintaining the quality of these vibrations as much as possible.
* | configure_input: Hook up the vibration percentage spinboxMorph2020-11-161-1/+2
| | | | | | | | | | This allows setting the vibration strength percentage anywhere from 1% to 100%. Also hooks up the remaining motion button and checkbox in the Controller Applet.
* | controllers/npad: Stop games from vibrating incorrect controllersMorph2020-11-161-0/+10
| | | | | | | | Fixes vibration in 1-2 Switch and potentially other games where they would vibrate both players' joycons at the same time.
* | hid: Fix controller rumble based on new researchMorph2020-11-163-43/+69
| | | | | | | | | | This fixes the issue where rumble is only sent to the first controller. Now, individual controllers can receive their own rumble commands.
* | hid: Pop a struct of parameters instead of popping individual parametersMorph2020-11-161-103/+237
| | | | | | | | | | Some parameters need to be doubleword aligned due to the presence of the applet_resource_user_id. Previously, this value was invalid in many commands where it was not doubleword aligned when popped.
* | hid: Reorder all HID commandsMorph2020-11-164-215/+230
| | | | | | | | Reorders all HID commands in command id order.
* | hid: Implement GetVibrationDeviceInfoMorph2020-11-162-3/+39
| | | | | | | | | | | | | | | | | | | | The first u32 describes the vibration device type which is a Linear Resonant Actuator used in Nintendo Switch controller hardware. The second u32 describes the vibration device position, in this case distinguishing between left and right vibration actuators. Pro Controllers have 2 LRAs each that can vibrate independently of each other, which means they have 2 distinct vibration device handles to distinguish between the two actuators. Similarly for joycons, the left joycon can be distinguished from the right joycon through the vibration device handle since each joycon has 1 LRA.
* | hid: Stub InitializeVibrationDeviceMorph2020-11-161-3/+11
| |
* | controllers/npad: Rename NPadType to NpadStyleSetMorph2020-11-163-9/+9
| | | | | | | | This more accurately represents the underlying type and avoids confusion with NpadType
* | controllers/npad: Add DeviceHandle structMorph2020-11-161-27/+50
| | | | | | | | A DeviceHandle describes a vibration device or six-axis sensor based on the npad type, npad id, and device index/position
* | settings: Preparation for per-game input settingsMorph2020-11-166-25/+32
| |
* | controllers/npad: Connect a controller on init if none are connectedMorph2020-11-161-0/+13
| |
* | Merge pull request #4895 from Morph1984/cave-story-plus-applet-fixbunnei2020-11-132-26/+80
|\ \ | | | | | | applets/controller: Introduce additional checks for mode and caller
| * | applets: Rename LibraryAppletVersion to ControllerAppletVersionMorph2020-11-082-15/+15
| | |
| * | applets/controller: Pop normal data for StrapGuide and FirmwareUpdateMorph2020-11-082-6/+19
| | |
| * | applets/controller: Introduce additional checks for mode and callerMorph2020-11-082-5/+39
| | | | | | | | | | | | | | | Some games like Cave Story+ set invalid values in the ControllerPrivateArg's mode and caller fields. Use other fields to determine the appropriate mode and caller should either or both fields be invalid.
| * | applets/controller: Add ControllerUpdateFirmwareArg structMorph2020-11-081-0/+7
| | |
* | | Merge pull request #4901 from bunnei/caps-stubbunnei2020-11-102-9/+17
|\ \ \ | |_|/ |/| | hle: service: caps_u: Stub GetAlbumFileList3AaeAruid.
| * | hle: service: caps_u: Stub GetAlbumFileList3AaeAruid.bunnei2020-11-072-9/+17
| | | | | | | | | | | | | | | | | | - This works similiar to GetAlbumContentsFileListForApplication. - Since we do not implement the album, this should be safe to stub for now. - Used by Super Smash Bros. Ultimate (newer updates) in World of Light.
* | | ipc_helpers: Remove usage of the global system instanceLioncash2020-11-0816-7/+23
| |/ |/| | | | | | | | | | | | | | | Resolves numerous deprecation warnings throughout the codebase due to inclusion of this header. Now building core should be significantly less noisy (and also relying on less global state). This also uncovered quite a few modules that were relying on indirect includes, which have also been fixed.
* | video_core: dma_pusher: Remove integrity check on command lists.bunnei2020-11-071-1/+0
| | | | | | | | - This seems to cause softlocks in Breath of the Wild.
* | Merge pull request #4888 from lioncash/unicorn-removebunnei2020-11-072-28/+5
|\ \ | |/ |/| core: Remove usage of unicorn
| * core: Remove usage of unicornLioncash2020-11-042-28/+5
| | | | | | | | | | | | | | | | Unicorn long-since lost most of its use, due to dynarmic gaining support for handling most instructions. At this point any further issues encountered should be used to make dynarmic better. This also allows us to remove our dependency on Python.
* | Merge pull request #4858 from lioncash/initializerbunnei2020-11-041-0/+4
|\ \ | | | | | | General: Resolve a few missing initializer warnings
| * | General: Resolve a few missing initializer warningsLioncash2020-10-301-0/+4
| | | | | | | | | | | | Resolves a few -Wmissing-initializer warnings.
* | | Merge pull request #4869 from bunnei/improve-gpu-syncChloe2020-11-049-60/+291
|\ \ \ | |_|/ |/| | Improvements to GPU synchronization & various refactoring
| * | fixup! hle service: nvdrv: nvhost_gpu: Update to use SyncpointManager and other improvements.bunnei2020-11-012-3/+11
| | |
| * | hle service: nvdrv: nvhost_gpu: Update to use SyncpointManager and other improvements.bunnei2020-11-013-46/+106
| | | | | | | | | | | | | | | - Refactor so that SubmitGPFIFO and KickoffPB use shared functionality. - Implement add_wait and add_increment flags.
| * | service: hle: nvflinger: Fix potential shutdown crash when GPU is destroyed.bunnei2020-11-011-0/+4
| | |
| * | hle service: nvdrv: nvhost_ctrl: Update to use SyncpointManager.bunnei2020-11-013-9/+31
| | |
| * | hle service: nvdrv: Update to instantiate SyncpointManager.bunnei2020-11-012-5/+18
| | |
| * | hle: service: nvdrv: Implement SyncpointManager, to manage syncpoints.bunnei2020-11-013-1/+125
| | |
* | | Merge pull request #4878 from bunnei/unload-nrrbunnei2020-11-031-1/+15
|\ \ \ | |/ / |/| | hle: service: ldr: Implement UnloadNrr.
| * | hle: service: ldr: Implement UnloadNrr.bunnei2020-10-311-1/+15
| | | | | | | | | | | | - Used by Final Fantasy X/X-2 HD Remaster.
* | | Rename to align with switchbrew and remove gpu function (#4714)Levi Behunin2020-11-012-16/+10
|/ / | | | | | | | | * Rename to align with switchbrew * Rename to align with switchbrew and remove gpu function that checks if clearing should be done.
* | video_core: unbreak -Werror in NVDEC with ClangJan Beich2020-10-301-1/+1
| | | | | | | | | | | | src/core/hle/service/nvdrv/devices/nvhost_nvdec_common.cpp:41:15: error: unused variable 'OutOfMemory' [-Werror,-Wunused-const-variable] constexpr u32 OutOfMemory{static_cast<u32>(-12)}; ^
* | kernel/process: Add missing <ctime> includeMorph2020-10-291-0/+1
| | | | | | | | Fixes compilation on MSVC
* | Merge pull request #4835 from lat9nq/rng-default-timebunnei2020-10-291-1/+1
|\ \ | |/ |/| kernel: Use the current time as the default RNG seed
| * kernel: Use the current time as the default RNG seedlat9nq2020-10-271-1/+1
| | | | | | | | Use the current time, not zero, as the default RNG seed.
* | Merge pull request #4846 from lioncash/service-fnbunnei2020-10-285-1/+7
|\ \ | | | | | | service: Update function tables
| * | service: Update function tablesLioncash2020-10-285-1/+7
| | | | | | | | | | | | Updates function tables according to info on SwitchBrew.
* | | hle/kernel: Remove unused registered_core_threads to fix data racesReinUsesLisp2020-10-271-5/+0
|/ / | | | | | | | | This member was only used on asserts and it triggered data races. Remove it to fix them.
* | Merge pull request #4729 from ameerj/nvdec-prodbunnei2020-10-278-288/+468
|\ \ | | | | | | video_core: NVDEC Implementation
| * | video_core: NVDEC Implementationameerj2020-10-278-288/+468
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | This commit aims to implement the NVDEC (Nvidia Decoder) functionality, with video frame decoding being handled by the FFmpeg library. The process begins with Ioctl commands being sent to the NVDEC and VIC (Video Image Composer) emulated devices. These allocate the necessary GPU buffers for the frame data, along with providing information on the incoming video data. A Submit command then signals the GPU to process and decode the frame data. To decode the frame, the respective codec's header must be manually composed from the information provided by NVDEC, then sent with the raw frame data to the ffmpeg library. Currently, H264 and VP9 are supported, with VP9 having some minor artifacting issues related mainly to the reference frame composition in its uncompressed header. Async GPU is not properly implemented at the moment. Co-Authored-By: David <25727384+ogniK5377@users.noreply.github.com>
* / hle: services: TimeZoneContentManager: This can be made explicit.bunnei2020-10-271-1/+1
|/
* Merge pull request #4828 from lioncash/lockguardRodrigo Locatti2020-10-251-1/+1
|\ | | | | general: Use template deduction guides for lock_guard
| * general: Use template deduction guides for lock_guardLioncash2020-10-251-1/+1
| | | | | | | | Same behavior, less code.
* | Merge pull request #4792 from bunnei/rtc-fixbunnei2020-10-236-188/+302
|\ \ | |/ |/| service: time: Update current time with changes to RTC setting.
| * service: time: Update current time with changes to RTC setting.bunnei2020-10-136-188/+302
| | | | | | | | - This can be used to advance time, e.g. for Pokemon Sword/Shield pokejobs.
* | core: Fix clang build pt.3Lioncash2020-10-222-13/+3
| | | | | | | | Should finally resolve building with clang.
* | Revert "core: Fix clang build"bunnei2020-10-2154-433/+322
| |
* | kernel: Fix build with recent compiler flag changesLioncash2020-10-211-4/+8
| | | | | | | | | | This slipped through the cracks due to another change being merged before the compiler flag changes.
* | Merge pull request #4796 from lioncash/clangLC2020-10-2154-322/+433
|\ \ | | | | | | core: Fix clang build
| * | core: Fix clang buildLioncash2020-10-1854-322/+433
| | | | | | | | | | | | | | | | | | | | | Recent changes to the build system that made more warnings be flagged as errors caused building via clang to break. Fixes #4795
* | | Merge pull request #4390 from ogniK5377/get-applet-inf-stubbunnei2020-10-211-1/+11
|\ \ \ | | | | | | | | nifm: GetAppletInfo stub
| * | | Added remaining paramsDavid Marcec2020-10-201-1/+4
| | | |
| * | | nifm: GetAppletInfo stubDavid Marcec2020-10-201-1/+8
| | | | | | | | | | | | | | | | Fixes crash for Catherine Full Body
* | | | Merge pull request #4788 from ReinUsesLisp/lockfree-host-threadbunnei2020-10-201-28/+38
|\ \ \ \ | |/ / / |/| | | kernel: Implement host thread register methods without locking
| * | | kernel: Implement host thread register methods without lockingReinUsesLisp2020-10-131-28/+38
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Locks on GetCurrentHostThreadID were causing performance issues according to Visual Studio's profiler. It was consuming twice the time as arm_interface.Run(). The cost was not in the function itself but in the lockinig it required. Reimplement these functions using atomics and static storage instead of an unordered_map. This is a side effect to avoid locking and using linked lists for reads. Replace unordered_map with a linear search.
* | | Merge pull request #4785 from Morph1984/fs-hadesbunnei2020-10-201-2/+3
|\ \ \ | | | | | | | | filesystem: Fix CreateDirectory and DeleteFile
| * | | filesystem: Fix CreateDirectory and DeleteFileMorph2020-10-131-2/+3
| |/ / | | | | | | | | | | | | | | | Add a check if dir is nullptr (does not exist) Fixes save game creation in Hades
* | | Merge pull request #4783 from bunnei/nvdrv-freespacebunnei2020-10-182-0/+25
|\ \ \ | | | | | | | | hle: service: nvdrv: Implement nvhost_as_gpu::FreeSpace.
| * | | hle: service: nvdrv: Implement nvhost_as_gpu::FreeSpace.bunnei2020-10-132-0/+25
| |/ / | | | | | | | | | - This is used by Super Mario 3D All-Stars.
* | | Merge pull request #4801 from lioncash/missing-boundbunnei2020-10-181-1/+1
|\ \ \ | | | | | | | | mii/manager: Make use of unused lower bound in GetRandomValue()
| * | | mii/manager: Make use of unused lower bound in GetRandomValue()Lioncash2020-10-171-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, the lower bound wasn't being used and zero was being used as the lower bound every time this function was called. This affects the outcome of some of the randomized entries a little bit, for example, the lower-bound for beard and mustache flags was supposed to be 1, not 0. Aside from these cases, the bug didn't affect anything else.
* | | | service: bcat: Check client connection before interacting with socket.bunnei2020-10-171-0/+10
|/ / / | | | | | | | | | - Fixes a crash when BCAT service is offline.
* | | Merge pull request #4784 from bunnei/cancelbufferbunnei2020-10-163-14/+53
|\ \ \ | | | | | | | | hle: service: vi: Implement BufferQueue::CancelBuffer.
| * | | hle: service: vi: Implement BufferQueue::CancelBuffer.bunnei2020-10-143-14/+53
| | |/ | |/| | | | | | | - This is used by Super Mario 3D All-Stars.
* / | service: acc: Stub IManagerForApplication::StoreOpenContext.bunnei2020-10-151-1/+7
|/ / | | | | | | - Used by Super Mario 3D All-Stars.
* / core/CMakeLists: Make some warnings errorsLioncash2020-10-1312-67/+52
|/ | | | | | | | | Makes our error coverage a little more consistent across the board by applying it to Linux side of things as well. This also makes it more consistent with the warning settings in other libraries in the project. This also updates httplib to 0.7.9, as there are several warning cleanups made that allow us to enable several warnings as errors.
* Merge pull request #4736 from Morph1984/home-button-input-protection-stubbunnei2020-10-074-2/+50
|\ | | | | hid: Stub HomeButtonInputProtection service commands
| * hid: Stub HomeButtonInputProtection service commandsMorph2020-09-304-2/+50
| | | | | | | | - Used in 1-2 Switch. Given that we do not emulate the functionality of the home button yet, we can stub this for now.
* | Merge pull request #4737 from Morph1984/setshimlibraryversion-stubbunnei2020-10-075-4/+38
|\ \ | | | | | | capsrv: Stub 3 variants of SetShimLibraryVersion
| * | caps_c: Stub SetShimLibraryVersionMorph2020-09-302-1/+18
| | | | | | | | | | | | - Used by caps_su SetShimLibraryVersion
| * | caps_u: Stub SetShimLibraryVersionMorph2020-09-302-2/+14
| | | | | | | | | | | | - Used in Super Smash Bros. Ultimate
| * | caps_su: Properly stub SetShimLibraryVersionMorph2020-09-301-1/+6
| |/
* | Merge pull request #4742 from german77/InputFilterbunnei2020-10-061-49/+58
|\ \ | | | | | | HID: Only use inputs corresponding to controller type
| * | Only use inputs corresponding to controller typegerman2020-10-021-49/+58
| | |
* | | Merge pull request #4734 from german77/motionfusionbunnei2020-10-022-1/+15
|\ \ \ | |/ / |/| | HID: Add Stub for EnableSixAxisSensorFusion
| * | Stubbed EnableSixAxisSensorFusiongerman2020-09-302-1/+15
| | |
* | | Merge pull request #4291 from german77/ImplementControllerRumbleDavid2020-09-303-13/+22
|\ \ \ | | | | | | | | input_common: First implementation of controller rumble
| * | | First implementation of controller rumblegerman2020-09-293-13/+22
| | | |
* | | | Merge pull request #4726 from lioncash/appletDavid2020-09-301-1/+2
|\ \ \ \ | |_|_|/ |/| | | frontend/controller: Eliminate dependency on the global system instance
| * | | frontend/controller: Eliminate dependency on the global system instanceLioncash2020-09-261-1/+2
| |/ /
* | | Merge pull request #4705 from german77/SplitMotionPollerbunnei2020-09-305-76/+157
|\ \ \ | |_|/ |/| | HID: Use different timing for motion
| * | Use different timing for motiongerman2020-09-245-76/+157
| | |
* | | Merge pull request #1703 from DarkLordZach/nvdec-ioctlbunnei2020-09-304-3/+256
|\ \ \ | |_|/ |/| | nvdrv: Stub nvdec/vic ioctls to bypass nvdec movies
| * | service: nvhost_vic: Ignore Submit commands.bunnei2020-06-052-1/+18
| | |
| * | nvdrv: Stub nvdec/vic ioctls to bypass nvdec moviesZach Hilman2020-06-054-3/+239
| | |
* | | Merge pull request #4717 from lioncash/debugLC2020-09-251-0/+17
|\ \ \ | | | | | | | | service: Restore "unused" function
| * | | service: Restore "unused" functionLioncash2020-09-251-0/+17
| | |/ | |/| | | | | | | Turns out this function is actually used, but within a trace log.
* | | Merge pull request #4678 from Morph1984/LoadOpenContext-partial-implbunnei2020-09-243-1/+13
|\ \ \ | |/ / |/| | acc: Partially implement LoadOpenContext
| * | acc: Stub LoadOpenContextMorph2020-09-213-1/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is used in multiple games such as: - Clubhouse Games: 51 Worldwide Classics - Grandia HD Collection - XCOM 2 Collection - Baldur's Gate 1/2 - Dr Kawashima's Brain Training - Super Mario 3D All-Stars
* | | General: Make use of std::nullopt where applicableLioncash2020-09-224-7/+7
|/ / | | | | | | | | | | | | | | Allows some implementations to avoid completely zeroing out the internal buffer of the optional, and instead only set the validity byte within the structure. This also makes it consistent how we return empty optionals.
* | Merge pull request #4683 from Morph1984/NpadHandheldActivationMode-implbunnei2020-09-203-5/+28
|\ \ | | | | | | hid: Implement Get/SetNpadHandheldActivationMode
| * | hid: Implement Get/SetNpadHandheldActivationModeMorph2020-09-183-5/+28
| | | | | | | | | | | | - Used in Clubhouse Games: 51 Worldwide Classics
* | | Merge pull request #4643 from FearlessTobi/decrease-pad-update-intervalbunnei2020-09-191-1/+1
|\ \ \ | | | | | | | | Test: Decrease pad_update_ns
| * | | Test: Decrease pad_update_nsFearlessTobi2020-09-101-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | There have been reports of quite heavy input lag in the past. Compared to Citra for example, our pad_update_ns value is very high. So let's decrease it and see if it helps with this problem.
* | | | am: Stub GetPreviousProgramIndexMorph2020-09-182-1/+11
| | | | | | | | | | | | | | | | - Used in Super Mario 3D All-Stars
* | | | Merge pull request #4665 from lioncash/sm-kernelRodrigo Locatti2020-09-172-8/+10
|\ \ \ \ | | | | | | | | | | service/sm: Eliminate dependency on the global system instance
| * | | | service/sm: Slightly more efficient string name validationLioncash2020-09-171-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | We can check the end of the string first for null-termination, rather than the beginning of the string.
| * | | | service/sm: Eliminate dependency on the global system instanceLioncash2020-09-172-6/+8
| | | | |
* | | | | Merge pull request #4666 from lioncash/unused-funcRodrigo Locatti2020-09-171-22/+0
|\ \ \ \ \ | | | | | | | | | | | | service: Remove unused funcation
| * | | | | service: Remove unused funcationLioncash2020-09-171-22/+0
| |/ / / / | | | | | | | | | | | | | | | This is now completely unused, so it can be removed.
* | | | | Merge pull request #4671 from lioncash/nfp-copyRodrigo Locatti2020-09-171-10/+13
|\ \ \ \ \ | | | | | | | | | | | | command_generator/nfp: Eliminate unnecessary copies
| * | | | | nfp: Eliminate two unnecessary copiesLioncash2020-09-171-10/+13
| |/ / / / | | | | | | | | | | | | | | | | | | | | GetAmiiboBuffer() returns by const reference, so we can use a reference instead of taking the returned buffer by value.
* | | | | Merge pull request #4594 from german77/MotionHIDbunnei2020-09-174-15/+184
|\ \ \ \ \ | |/ / / / |/| | | | hid/configuration: Implement motion controls to HID
| * | | | configure_input: Hook up the motion button and checkboxMorph2020-09-051-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | This allows toggling motion on or off, and allows access to the motion configuration. Also changes the [waiting] text for motion buttons to Shake! as this is how motion is connected to a player.
| * | | | Add cemu hook changes related to PR #4609german2020-09-051-2/+1
| | | | |
| * | | | Remove RealMotionDevicegerman2020-09-052-7/+8
| | | | |
| * | | | controllers/npad: Simplify motion entry assignmentMorph2020-09-051-29/+18
| | | | | | | | | | | | | | | | | | | | Simplifies the motion assignment in the Dual Joycon entry and assigns index 1 of the motion entry (Motion 2) for the right joycon.
| * | | | Include HID and configuration changes related to motiongerman2020-09-054-15/+195
| | | | |
* | | | | file_sys/bis_factory: Eliminate usage of the global system accessorLioncash2020-09-171-1/+1
| | | | |
* | | | | kernel: Remove all dependencies on the global system instanceLioncash2020-09-145-11/+20
| | | | | | | | | | | | | | | | | | | | | | | | | With this, the kernel finally doesn't depend directly on the global system instance anymore.
* | | | | Merge pull request #4636 from lioncash/kernel-hlebunnei2020-09-143-7/+5
|\ \ \ \ \ | |_|_|/ / |/| | | | service: Remove two usages of the global system accessor
| * | | | service: Remove two usages of the global system accessorLioncash2020-09-073-7/+5
| | |/ / | |/| | | | | | | | | | Removes more instances of reliance on global state.
* | | | Merge pull request #4323 from ReinUsesLisp/no-spinbunnei2020-09-121-1/+1
|\ \ \ \ | | | | | | | | | | kernel/scheduler: Use std::mutex instead of spin lock
| * | | | kernel/scheduler: Use std::mutex instead of spin lockReinUsesLisp2020-07-131-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Profiling shows that this is a highly contested mutex, causing dimishing results compared to a OS lock. std::mutex implementations can spin for a while before falling back to an OS lock. This avoids wasting precious CPU cycles in a no-op.
* | | | | Merge pull request #4634 from lioncash/blockingbunnei2020-09-123-19/+19
|\ \ \ \ \ | | | | | | | | | | | | bsd: Resolve a few warnings
| * | | | | bsd: Resolve unused value within SendToImplLioncash2020-09-071-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously the address provided to SendToImpl would never be propagated to SendTo(). This fixes that.
| * | | | | bsd: Resolve sign comparison warningsLioncash2020-09-071-3/+3
| | | | | |
| * | | | | sockets_translate: Make use of designated initializersLioncash2020-09-071-12/+12
| | | | | | | | | | | | | | | | | | | | | | | | Same behavior, less typing.
| * | | | | blocking_worker: Make use of templated lambdaLioncash2020-09-071-3/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can simplify this a little by explicitly specifying the typename for the lambda function.
| * | | | | blocking_worker: Resolve -Wdocumentation warningLioncash2020-09-071-1/+1
| | |/ / / | |/| | |
* | | | | Merge pull request #4310 from ogniK5377/apollo-1-prodbunnei2020-09-111-72/+77
|\ \ \ \ \ | | | | | | | | | | | | audio_core: Apollo Part 1, AudioRenderer refactor
| * | | | | audio_core: Apollo Part 1, AudioRenderer refactorDavid Marcec2020-07-251-72/+77
| | | | | |
* | | | | | Merge pull request #4597 from Morph1984/mjolnir-p2bunnei2020-09-116-131/+415
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | Project Mjölnir: Part 2 - Controller Applet
| * | | | | Address feedbackMorph2020-09-042-0/+7
| | | | | |
| * | | | | applets/controller: Set min_players to have a minimum value of 1.Morph2020-09-041-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | - Some games like Shipped have a minimum requirement of 0 connected players and is undesired behavior. We must require a minimum of 1 player connected regardless of what games may ask.
| * | | | | applets/controller: Implement fallback applet for the SDL frontendMorph2020-09-042-89/+0
| | | | | | | | | | | | | | | | | | | | | | | | Implement the fallback applet for the SDL frontend, connecting only the minimum amount of players required.
| * | | | | applets/controller: Implement "Explain Text"Morph2020-09-042-16/+26
| | | | | | | | | | | | | | | | | | | | | | | | "Explain Text" is additional text that is shown for each player in the controller applet.
| * | | | | Project Mjölnir: Part 2 - Controller AppletMorph2020-09-046-42/+398
| | | | | | | | | | | | | | | | | | | | | | | | Co-authored-by: Its-Rei <kupfel@gmail.com>
* | | | | | Merge pull request #4397 from ReinUsesLisp/bsdbunnei2020-09-069-56/+1384
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | services: Implement most of bsd:s and GetCurrentIpAddress from nifm
| * | | | | service/bsd: Handle Poll with no entries accuratelyReinUsesLisp2020-07-281-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Testing shows that Poll called with zero entries returns -1 and signals an errno of zero.
| * | | | | services/bsd: Implement most of bsd:sReinUsesLisp2020-07-285-55/+911
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This implements: Socket, Poll, Accept, Bind, Connect, GetPeerName, GetSockName, Listen, Fcntl, SetSockOpt, Shutdown, Recv, RecvFrom, Send, SendTo, Write, and Close The implementation was done referencing: SwIPC, switchbrew, testing with libnx and inspecting its code, general information about bsd sockets online, and analysing official software. Not everything from these service calls is implemented, but everything that is not implemented will be logged in some way.
| * | | | | service/sockets: Add worker pool abstractionReinUsesLisp2020-07-281-0/+30
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Manage worker threads with an easy to use abstraction. We can expand this to support thread deletion in the future.
| * | | | | service/sockets: Add worker abstraction to execute blocking calls asynchronouslyReinUsesLisp2020-07-281-0/+132
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This abstraction allows executing blocking functions (like recvfrom on a socket configured for blocking) without blocking the service thread. It is intended to be used with SleepClientThread.
| * | | | | service/sockets: Add translate functionsReinUsesLisp2020-07-282-0/+213
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These functions translate from Network enumerations/structures to guest enumerations/structures and viceversa.
| * | | | | service/sockets: Add enumerations and structuresReinUsesLisp2020-07-282-0/+81
| | | | | | | | | | | | | | | | | | | | | | | | Add guest enumerations and structures used in socket services
| * | | | | services/nifm: Implement GetCurrentIpAddressReinUsesLisp2020-07-281-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is trivially implemented using the Network abstraction - Used by ftpd
* | | | | | hid: Implement MergeSingleJoyasDualJoyMorph2020-09-043-5/+24
| |/ / / / |/| | | | | | | | | | | | | | - Used in multiple games such as Super Mario Odyssey.
* | | | | Merge pull request #4590 from ReinUsesLisp/tsan-schedbunnei2020-09-031-2/+6
|\ \ \ \ \ | | | | | | | | | | | | hle/scheduler: Fix data race in is_context_switch_pending
| * | | | | hle/scheduler: Fix data race in is_context_switch_pendingReinUsesLisp2020-08-261-2/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | As reported by tsan, SelectThreads could write to is_context_switch_pending holding a mutex while SwitchToCurrent reads it without holding any. It is assumed that the author didn't want an atomic here, so the code is reordered so that whenever is_context_switch_pending is read inside SwitchToContext, the mutex is locked.
* | | | | | Merge pull request #4568 from lioncash/fspbunnei2020-09-031-3/+13
|\ \ \ \ \ \ | | | | | | | | | | | | | | fsp_srv: Resolve -Wmaybe_uninitialized warning in OpenSaveDataFileSystem()
| * | | | | | fsp_srv: Resolve -Wunused-but-set-variable warningLioncash2020-08-231-1/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just log out the parameters in the meantime.
| * | | | | | fsp_srv: Resolve -Wmaybe_uninitialized warning in OpenSaveDataFileSystem()Lioncash2020-08-231-2/+5
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | Initialize id to a deterministic value and also mark the unreachable cases in the switch with UNREACHABLE().
* | | | | | Merge pull request #4564 from lioncash/file-includebunnei2020-09-031-0/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | file_sys: Replace inclusions with forward declarations where applicable
| * | | | | | file_sys: Replace inclusions with forward declarations where applicableLioncash2020-08-231-0/+1
| |/ / / / / | | | | | | | | | | | | | | | | | | Same behavior, minus unnecessary inclusions where not necessary.
* | | | | | Merge pull request #4382 from FearlessTobi/port-udp-configbunnei2020-09-012-1/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | yuzu: Add motion and touch configuration from Citra
| * | | | | | yuzu: Add motion and touch configurationFearlessTobi2020-08-292-1/+12
| | | | | | |
* | | | | | | Merge pull request #4589 from ReinUsesLisp/tsan-hostbunnei2020-09-011-1/+2
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | hle/kernel: Fix data race in GetCurrentHostThreadID
| * | | | | | hle/kernel: Fix data race in GetCurrentHostThreadIDReinUsesLisp2020-08-261-1/+2
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | As reported by tsan, host_thread_ids could be read while any of the RegisterHostThread variants were called. To fix this, lock the register mutex when yuzu is running in multicore mode and GetCurrentHostThreadID is called.
* | | | | | controllers/npad: Fix inconsistencies with controller connection statusesMorph2020-08-261-1/+7
| | | | | |
* | | | | | controllers/npad: Fix LibNX controller connection statusesMorph2020-08-261-1/+9
| | | | | | | | | | | | | | | | | | | | | | | | This allows homebrew applications to be able to properly detect connected controllers.
* | | | | | controllers/npad: Fix LedPattern for P1-4Morph2020-08-261-3/+3
| | | | | |
* | | | | | Project Mjölnir: Part 1Morph2020-08-263-127/+111
|/ / / / / | | | | | | | | | | | | | | | | | | | | Co-authored-by: James Rowe <jroweboy@gmail.com> Co-authored-by: Its-Rei <kupfel@gmail.com>
* | | | | common/fileutil: Convert namespace to Common::FSLioncash2020-08-165-73/+73
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Migrates a remaining common file over to the Common namespace, making it consistent with the rest of common files. This also allows for high-traffic FS related code to alias the filesystem function namespace as namespace FS = Common::FS; for more concise typing.
* | | | | Merge pull request #4526 from lioncash/core-semibunnei2020-08-153-7/+12
|\ \ \ \ \ | | | | | | | | | | | | core: Resolve several -Wextra-semi warnings
| * | | | | core: Resolve several -Wextra-semi warningsLioncash2020-08-143-7/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can amend one of the cascade macros to require semicolons in order to compile. In other cases, we can just remove the superfluous semicolons.
* | | | | | Merge pull request #4527 from lioncash/pessimizing2bunnei2020-08-151-2/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | software_keyboard: Resolve a pessimizing move warning
| * | | | | | software_keyboard: Resolve a pessimizing move warningLioncash2020-08-141-2/+1
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | A std::vector created in place like this is already an rvalue and doesn't need to be moved.
* | | | | | Merge pull request #4492 from lioncash/linkagebunnei2020-08-152-15/+11
|\ \ \ \ \ \ | | | | | | | | | | | | | | system_control: Make functions internally linked where applicable
| * | | | | | system_control: Make functions internally linked where applicableLioncash2020-08-052-15/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These functions are only ever used internally as implementation details for GenerateRandomRange(), so these can be given internal linkage.
* | | | | | | Merge pull request #4463 from lioncash/lockdiscardbunnei2020-08-151-1/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | kernel/scheduler: Mark SchedulerLock constructor as nodiscard
| * | | | | | | kernel/scheduler: Mark SchedulerLock constructor as nodiscardLioncash2020-08-141-1/+1
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows the compiler to warn about cases where the constructor is used but then immediately discarded, which is a potential cause of locking/unlocking bugs.
* / | | | | | time_zone_content_manager: Collapse auto and default caseLioncash2020-08-141-3/+1
|/ / / / / / | | | | | | | | | | | | | | | | | | Prevents a useless self-assignment from occurring.
* | | | | | General: Tidy up clang-format warnings part 2Lioncash2020-08-136-40/+49
| | | | | |
* | | | | | Merge pull request #4491 from lioncash/unused-varsbunnei2020-08-102-18/+11
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel: Remove unused variables
| * | | | | | kernel: Remove unused variablesLioncash2020-08-052-18/+11
| |/ / / / / | | | | | | | | | | | | | | | | | | Resolves a few compiler warnings.
* | | | | | Merge pull request #4457 from ogniK5377/SetScreenShotPermissionbunnei2020-08-072-1/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | am: Unstub SetScreenShotPermission
| * | | | | | am: Unstub SetScreenShotPermissionDavid Marcec2020-07-312-1/+12
| | |/ / / / | |/| | | |
* | | | | | common/concepts: Rename IsBaseOf to DerivedFromLioncash2020-08-071-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This makes it more inline with its currently unavailable standardized analogue std::derived_from. While we're at it, we can also make the template match the requirements of the standardized variant as well.
* | | | | | Merge pull request #4490 from lioncash/arbiterbunnei2020-08-072-2/+3
|\ \ \ \ \ \ | | | | | | | | | | | | | | address_arbiter/scheduler: Resolve sign conversion warnings
| * | | | | | scheduler: Resolve sign conversion warningLioncash2020-08-051-1/+2
| | | | | | |
| * | | | | | address_arbiter: Resolve sign conversion warningLioncash2020-08-051-1/+1
| | |/ / / / | |/| | | | | | | | | | | | | | | | Makes our type conversion explicit.
* | | | | | Merge pull request #4489 from lioncash/typesafebunnei2020-08-061-0/+4
|\ \ \ \ \ \ | | | | | | | | | | | | | | ipc_helpers: Only allow trivially copyable objects with PushRaw() and PopRaw()
| * | | | | | ipc_helpers: Only allow trivially copyable objects with PushRaw() and PopRaw()Lioncash2020-08-051-0/+4
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | It's undefined behavior to use non-trivially copyable objects with std::memcpy, so we can add asserts to catch usages of these at compile-time.
* | | | | | Merge pull request #4475 from lioncash/bqueuebunnei2020-08-051-10/+11
|\ \ \ \ \ \ | |/ / / / / |/| | | | | buffer_queue: Make use of designated initializers/std::nullopt where applicable
| * | | | | buffer_queue: Make use of std::nulloptLioncash2020-08-031-5/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows compilers to eliminate unnecessary zeroing out of the optional's buffer.
| * | | | | buffer_queue: Make use of designated initializersLioncash2020-08-031-5/+5
| |/ / / /
* | | | | Merge pull request #4401 from ogniK5377/GetIndirectLayerImageRequiredMemoryInfobunnei2020-08-051-1/+19
|\ \ \ \ \ | | | | | | | | | | | | vi: IApplicationDisplayService:GetIndirectLayerImageRequiredMemoryInfo
| * | | | | vi: IApplicationDisplayService:GetIndirectLayerImageRequiredMemoryInfoDavid Marcec2020-07-211-1/+19
| | |/ / / | |/| | | | | | | | | | | | | Needed for dark souls and monster hunter
* | | | | Merge pull request #4430 from bunnei/new-gpu-vmmbunnei2020-08-054-93/+227
|\ \ \ \ \ | | | | | | | | | | | | hle: nvdrv: Rewrite of GPU memory management.
| * | | | | Update src/core/hle/service/nvdrv/devices/nvmap.cppbunnei2020-07-281-1/+1
| | | | | | | | | | | | | | | | | | Co-authored-by: LC <mathew1800@gmail.com>
| * | | | | hle: nvdrv: Rewrite of GPU memory management.bunnei2020-07-264-93/+227
| | | | | |
* | | | | | Merge pull request #4481 from lioncash/cpp-depDavid2020-08-043-21/+21
|\ \ \ \ \ \ | | | | | | | | | | | | | | yuzu: Resolve C++20 deprecation warnings related to lambda captures
| * | | | | | yuzu: Resolve C++20 deprecation warnings related to lambda capturesLioncash2020-08-033-21/+21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | C++20 deprecates capturing the this pointer via the '=' capture. Instead, we replace it or extend the capture specification.
* | | | | | | Merge pull request #4474 from lioncash/hle-profileDavid2020-08-041-17/+26
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | profile_manager: Make use of designated initializers
| * | | | | | | profile_manager: Make use of std::nulloptLioncash2020-08-031-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows some implementations to completely avoid unnecessarily zeroing out the internal buffer.
| * | | | | | | profile_manager: Make use of designated initializersLioncash2020-08-031-13/+22
| | |_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | More compact code.
* | | | | | | Merge pull request #4456 from Morph1984/stub-really-long-fs-funcbunnei2020-08-045-34/+69
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | fsp-srv: Stub Read/WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttribute
| * | | | | | | minor nitsMorph2020-07-311-1/+3
| | | | | | | |
| * | | | | | | fsp-srv: Stub Read/WriteSaveDataFileSystemExtraDataWithMaskBySaveDataAttributeMorph2020-07-302-23/+56
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Stub these 2 service commands required for Animal Crossing: New Horizons Update 1.4.0
| * | | | | | | fs: Rename SaveDataDescriptor to SaveDataAttributeMorph2020-07-303-12/+12
| |/ / / / / /
* | | | | | | Merge pull request #4482 from lioncash/ldr-signbunnei2020-08-031-3/+2
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service/ldr: Resolve sign mismatch warnings
| * | | | | | | service/ldr: Resolve sign mismatch warningsLioncash2020-08-031-3/+2
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | We were performing an int < size_t comparison. We can just correct the type of the induction variable.
* / | | | | | sm: Make use of IsBaseOf for GetServiceDavid Marcec2020-08-031-3/+2
|/ / / / / /
* / / / / / ipc: Allow all trivially copyable objects to be passed directly into WriteBuffer (#4465)David2020-08-039-30/+30
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * ipc: Allow all trivially copyable objects to be passed directly into WriteBuffer With the support of C++20, we can use concepts to deduce if a type is an STL container or not. * More agressive concept for stl containers * Add -fconcepts * Move to common namespace * Add Common::IsBaseOf
* | | | | core_timing: Make use of uintptr_t to represent user_dataLioncash2020-07-286-13/+17
| | | | | | | | | | | | | | | | | | | | Makes the interface future-proofed for supporting other platforms in the event we ever support platforms with differing pointer sizes. This way, we have a type in place that is always guaranteed to be able to represent a pointer exactly.
* | | | | remove unused variable;CrazyMax2020-07-271-1/+0
| | | | |
* | | | | nvflinger: Mark interface functions with return values as [[nodiscard]]Lioncash2020-07-261-16/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Not using the return value of these functions are undeniably the source of a bug. This way we allow compilers to loudly make any future misuses evident.
* | | | | nvflinger: Use return value of Lock()Lioncash2020-07-263-4/+4
|/ / / / | | | | | | | | | | | | | | | | comex reported in #4424 that we were incorrectly discarding the return value of Lock() which is correct.
* | | | Merge pull request #4350 from ogniK5377/hid-update-connectedbunnei2020-07-252-33/+37
|\ \ \ \ | | | | | | | | | | hid: Only update keyboard & debug pad inputs if enabled
| * | | | hid: Only update keyboard & debug pad inputs if enabledDavid Marcec2020-07-162-33/+37
| | | | | | | | | | | | | | | | | | | | Previously we would ignore this setting and would update the states regardless of the user setting
* | | | | Address issuesDavid Marcec2020-07-201-2/+2
| | | | |
* | | | | swkbd: Return result for Calc request for inlined swkbdDavid Marcec2020-07-192-13/+49
| |/ / / |/| | | | | | | | | | | Fixes random swkbd popups in monster hunter
* | | | Merge pull request #4348 from lioncash/nanobunnei2020-07-186-28/+34
|\ \ \ \ | | | | | | | | | | core_timing: Make usage of nanoseconds more consistent in the interface
| * | | | core_timing: Make TimedCallback take std::chrono::nanosecondsLioncash2020-07-166-15/+13
| | | | | | | | | | | | | | | | | | | | Enforces our desired time units directly with a concrete type.
| * | | | core_timing: Make use of std::chrono with ScheduleEventLioncash2020-07-165-16/+24
| | |/ / | |/| |
* | | | Merge pull request #4345 from Morph1984/fix-createfilebunnei2020-07-181-0/+4
|\ \ \ \ | | | | | | | | | | filesystem: Create subdirectories prior to creating a file
| * | | | Add comment to clarify the nullptr checkMorph2020-07-161-0/+1
| | | | |
| * | | | filesystem: Create subdirectories prior to creating a fileMorph2020-07-161-0/+3
| | |/ / | |/| | | | | | | | | | | | | | If subdirectories exist in the given path parameter and don't exist in the real filesystem create them prior to creating the files within. This fixes the softlocks upon save creation in The Legend of Zelda: Breath of the Wild
* | | | Merge pull request #4365 from lioncash/miibunnei2020-07-181-53/+54
|\ \ \ \ | | | | | | | | | | mii/manager: Make use of designated initializers
| * | | | mii/manager: Make use of designated initializersLioncash2020-07-171-53/+54
| | | | | | | | | | | | | | | | | | | | Allows returning the structure in a more concise manner.
* | | | | Merge pull request #4366 from lioncash/mii-signbunnei2020-07-181-3/+3
|\ \ \ \ \ | | | | | | | | | | | | mii/manager: Resolve sign mismatch warnings
| * | | | | mii/manager: Resolve sign mismatch warningsLioncash2020-07-171-3/+3
| |/ / / / | | | | | | | | | | | | | | | | | | | | Previously the loop termination condition was testing variables of different signedness.
* | | | | Merge pull request #4357 from lioncash/unused4David2020-07-173-7/+2
|\ \ \ \ \ | | | | | | | | | | | | kernel: Remove unused variables
| * | | | | kernel: Remove unused variablesLioncash2020-07-163-7/+2
| | | | | | | | | | | | | | | | | | | | | | | | Resolves some compiler warnings in the Linux build.
* | | | | | Merge pull request #4358 from lioncash/unused5David2020-07-171-2/+0
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | kernel/thread: Remove unimplemented function prototype
| * | | | | kernel/thread: Remove unimplemented function prototypeLioncash2020-07-161-2/+0
| |/ / / / | | | | | | | | | | | | | | | This isn't used, so it can be removed.
* | | | | Merge pull request #4292 from bunnei/mii-rewritebunnei2020-07-178-912/+3265
|\ \ \ \ \ | | | | | | | | | | | | hle: service: mii: Rewrite service to properly support creation of random and default miis.
| * | | | | hle: service: mii: Rewrite service to properly support creation of random and default miis.bunnei2020-07-128-912/+3265
| | | | | |
* | | | | | Merge pull request #4327 from lioncash/desig2Rodrigo Locatti2020-07-162-58/+38
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | address_space_info: Make use of designated initializers
| * | | | | address_space_info: Use type alias to simplify codeLioncash2020-07-131-14/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can define an alias for the index arrays and then just reuse it to make the code nicer to read.
| * | | | | address_space_info: Make use of designated initializersLioncash2020-07-132-46/+27
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | We can alter the structure so that we can use designated initializers in the array, eliminating the comments that indicate their field names.
* | | | | kernel: Add missing includeLioncash2020-07-161-0/+1
| | | | |
* | | | | cpu_manager: Mark function getters as staticLioncash2020-07-163-7/+8
| | | | | | | | | | | | | | | | | | | | | | | | | All these do are return std::function instances of static functions, so these can be used without an instance of the CPU manager.
* | | | | Merge pull request #4346 from lioncash/threadDavid2020-07-167-35/+26
|\ \ \ \ \ | |_|_|/ / |/| | | | kernel/handle_table: Remove usages of the global system instance
| * | | | kernel/process: Move name and system context to the bottom of the member listLioncash2020-07-151-6/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These aren't directly important or commonly used within the process, so we can move these to the bottom to allow everything else to be more likely to be within a cache line.
| * | | | kernel/handle_table: Remove usages of the global system instanceLioncash2020-07-154-8/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Removes even more usages of the global system instance, trimming away more dependencies on global variables and making them explicit in the interface.
| * | | | kernel/thread: Remove global GetCurrentThread()Lioncash2020-07-153-23/+7
| |/ / / | | | | | | | | | | | | | | | | This is only used in one place, so we can fold it into the calling code, eliminating a place for the global system instance to be used.
* / / / memory_layout: Remove unused data memberLioncash2020-07-131-2/+0
|/ / / | | | | | | | | | | | | This isn't used, so it can be removed entirely, shrinking the structure size by 8 bytes.
* | | Merge pull request #4275 from CrazyMax/desired_languagebunnei2020-07-121-1/+13
|\ \ \ | | | | | | | | AM: fix GetDesiredLanguage:
| * | | AM: fix GetDesiredLanguage:CrazyMax2020-07-081-1/+13
| | | | | | | | | | | | | | | | | | | | | | | | try to get a control metadata from application update when is failed to get from the basic version. Tested on Kirby Star Allies
* | | | Merge pull request #4203 from VolcaEM/servicesbunnei2020-07-1126-154/+282
|\ \ \ \ | |_|/ / |/| | | service: Update function tables
| * | | Rename two functions in NSVolcaEM2020-07-021-2/+2
| | | | | | | | | | | | | | | | - Rename "GetShellEvent" to "GetShellEventHandle" - Rename "LaunchApplicationFromHost" to "LaunchApplication"
| * | | Rename GetApplicationArea2 to GetApplicationAreaSizeVolcaEM2020-07-021-2/+2
| | | |
| * | | Remove duplicate functionsVolcaEM2020-06-291-2/+0
| | | |
| * | | Use decimal instead of hexadecimalVolcaEM2020-06-291-3/+5
| | | | | | | | | | | | Co-authored-by: David <25727384+ogniK5377@users.noreply.github.com>
| * | | Fix typoVolcaEM2020-06-291-1/+1
| | | |
| * | | Clang-formatVolcaEM2020-06-291-1/+1
| | | |
| * | | service: Update function tablesVolcaEM2020-06-2927-157/+285
| | | |
* | | | configuration: implement per-game configurations (#4098)lat9nq2020-07-106-22/+23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Switch game settings to use a pointer In order to add full per-game settings, we need to be able to tell yuzu to switch to using either the global or game configuration. Using a pointer makes it easier to switch. * configuration: add new UI without changing existing funcitonality The new UI also adds General, System, Graphics, Advanced Graphics, and Audio tabs, but as yet they do nothing. This commit keeps yuzu to the same functionality as originally branched. * configuration: Rename files These weren't included in the last commit. Now they are. * configuration: setup global configuration checkbox Global config checkbox now enables/disables the appropriate tabs in the game properties dialog. The use global configuration setting is now saved to the config, defaulting to true. This also addresses some changes requested in the PR. * configuration: swap to per-game config memory for properties dialog Does not set memory going in-game. Swaps to game values when opening the properties dialog, then swaps back when closing it. Uses a `memcpy` to swap. Also implements saving config files, limited to certain groups of configurations so as to not risk setting unsafe configurations. * configuration: change config interfaces to use config-specific pointers When a game is booted, we need to be able to open the configuration dialogs without changing the settings pointer in the game's emualtion. A new pointer specific to just the configuration dialogs can be used to separate changes to just those config dialogs without affecting the emulation. * configuration: boot a game using per-game settings Swaps values where needed to boot a game. * configuration: user correct config during emulation Creates a new pointer specifically for modifying the configuration while emulation is in progress. Both the regular configuration dialog and the game properties dialog now use the pointer Settings::config_values to focus edits to the correct struct. * settings: split Settings::values into two different structs By splitting the settings into two mutually exclusive structs, it becomes easier, as a developer, to determine how to use the Settings structs after per-game configurations is merged. Other benefits include only duplicating the required settings in memory. * settings: move use_docked_mode to Controls group `use_docked_mode` is set in the input settings and cannot be accessed from the system settings. Grouping it with system settings causes it to be saved with per-game settings, which may make transferring configs more difficult later on, especially since docked mode cannot be set from within the game properties dialog. * configuration: Fix the other yuzu executables and a regression In main.cpp, we have to get the title ID before the ROM is loaded, else the renderer will reflect only the global settings and now the user's game specific settings. * settings: use a template to duplicate memory for each setting Replaces the type of each variable in the Settings::Values struct with a new class that allows basic data reading and writing. The new struct Settings::Setting duplicates the data in memory and can manage global overrides per each setting. * configuration: correct add-ons config and swap settings when apropriate Any add-ons interaction happens directly through the global values struct. Swapping bewteen structs now also includes copying the necessary global configs that cannot be changed nor saved in per-game settings. General and System config menus now update based on whether it is viewing the global or per-game settings. * settings: restore old values struct No longer needed with the Settings::Setting class template. * configuration: implement hierarchical game properties dialog This sets the apropriate global or local data in each setting. * clang format * clang format take 2 can the docker container save this? * address comments and style issues * config: read and write settings with global awareness Adds new functions to read and write settings while keeping the global state in focus. Files now generated per-game are much smaller since often they only need address the global state. * settings: restore global state when necessary Upon closing a game or the game properties dialog, we need to restore all global settings to the original global state so that we can properly open the configuration dialog or boot a different game. * configuration: guard setting values incorrectly This disables setting values while a game is running if the setting is overwritten by a per game setting. * config: don't write local settings in the global config Simple guards to prevent writing the wrong settings in the wrong files. * configuration: add comments, assume less, and clang format No longer assumes that a disabled UI element means the global state is turned off, instead opting to directly answer that question. Still however assumes a game is running if it is in that state. * configuration: fix a logic error Should not be negated * restore settings' global state regardless of accept/cancel Fixes loading a properties dialog and causing the global config dialog to show local settings. * fix more logic errors Fixed the frame limit would set the global setting from the game properties dialog. Also strengthened the Settings::Setting member variables and simplified the logic in config reading (ReadSettingGlobal). * fix another logic error In my efforts to guard RestoreGlobalState, I accidentally negated the IsPowered condition. * configure_audio: set toggle_stretched_audio to tristate * fixed custom rtc and rng seed overwriting the global value * clang format * rebased * clang format take 4 * address my own review Basically revert unintended changes * settings: literal instead of casting "No need to cast, use 1U instead" Thanks, Morph! Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> * Revert "settings: literal instead of casting " This reverts commit 95e992a87c898f3e882ffdb415bb0ef9f80f613f. * main: fix status buttons reporting wrong settings after stop emulation * settings: Log UseDockedMode in the Controls group This should have happened when use_docked_mode was moved over to the controls group internally. This just reflects this in the log. * main: load settings if the file has a title id In other words, don't exit if the loader has trouble getting a title id. * use a zero * settings: initalize resolution factor with constructor instead of casting * Revert "settings: initalize resolution factor with constructor instead of casting" This reverts commit 54c35ecb46a29953842614620f9b7de1aa9d5dc8. * configure_graphics: guard device selector when Vulkan is global Prevents the user from editing the device selector if Vulkan is the global renderer backend. Also resets the vulkan_device variable when the users switches back-and-forth between global and Vulkan. * address reviewer concerns Changes function variables to const wherever they don't need to be changed. Sets Settings::Setting to final as it should not be inherited from. Sets ConfigurationShared::use_global_text to static. Co-Authored-By: VolcaEM <volcaem@users.noreply.github.com> * main: load per-game settings after LoadROM This prevents `Restart Emulation` from restoring the global settings *after* the per-game settings were applied. Thanks to BSoDGamingYT for finding this bug. * Revert "main: load per-game settings after LoadROM" This reverts commit 9d0d48c52d2dcf3bfb1806cc8fa7d5a271a8a804. * main: only restore global settings when necessary Loading the per-game settings cannot happen after the ROM is loaded, so we have to specify when to restore the global state. Again thanks to BSoD for finding the bug. * configuration_shared: address reviewer concerns except operator overrides Dropping operator override usage in next commit. Co-Authored-By: LC <lioncash@users.noreply.github.com> * settings: Drop operator overrides from Setting template Requires using GetValue and SetValue explicitly. Also reverts a change that broke title ID formatting in the game properties dialog. * complete rebase * configuration_shared: translate "Use global configuration" Uses ConfigurePerGame to do so, since its usage, at least as of now, corresponds with ConfigurationShared. * configure_per_game: address reviewer concern As far as I understand, it prevents the program from unnecessarily copying strings. Co-Authored-By: LC <lioncash@users.noreply.github.com> Co-authored-by: Morph <39850852+Morph1984@users.noreply.github.com> Co-authored-by: VolcaEM <volcaem@users.noreply.github.com> Co-authored-by: LC <lioncash@users.noreply.github.com>
* | | | Merge pull request #4248 from Morph1984/CreateManagedDisplaySeparableLayerbunnei2020-07-102-1/+20
|\ \ \ \ | | | | | | | | | | AM/ISelfController: Stub CreateManagedDisplaySeparableLayer
| * | | | AM/ISelfController: Stub CreateManagedDisplaySeparableLayerMorph2020-07-052-1/+20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Stub this by sending 1 layer id instead of 2 as yuzu does not support multiple layers per display. No adverse side effects have been observed. - Used by Animal Crossing: New Horizons Update 1.3.0
* | | | | Merge pull request #4202 from ReinUsesLisp/scoped-lockbunnei2020-07-091-11/+10
|\ \ \ \ \ | |_|_|/ / |/| | | | core_timing,scheduler: Use std::scoped_lock when possible
| * | | | core_timing,scheduler: Use std::scoped_lock when possibleReinUsesLisp2020-06-291-11/+10
| | | | | | | | | | | | | | | | | | | | | | | | | Simplifies the cognitive load of procedures using locks and makes locks safe against exceptions.
* | | | | GetDisplayVersion should return a null-terminated version string.CrazyMax2020-07-071-4/+16
| |/ / / |/| | | | | | | | | | | also, in case of failed to get of the basic version, we will try get it from application update.
* | | | Merge pull request #3924 from ogniK5377/GetKeyCodeMapbunnei2020-07-032-2/+72
|\ \ \ \ | | | | | | | | | | Implement GetKeyCodeMap & GetKeyCodeMap2
| * | | | Move GetKeyCodeMapImpl to an anonymous namespaceDavid Marcec2020-06-241-19/+19
| | | | |
| * | | | Fixed logging outputDavid Marcec2020-06-241-1/+1
| | | | |
| * | | | Implement GetKeyCodeMap & GetKeyCodeMap2David Marcec2020-06-242-2/+72
| | | | | | | | | | | | | | | | | | | | Closes #3919
* | | | | Merge pull request #4193 from ogniK5377/GetIndirectLayerConsumerHandle-stubbunnei2020-07-031-1/+13
|\ \ \ \ \ | | | | | | | | | | | | am: Stub GetIndirectLayerConsumerHandle
| * | | | | am: Stub GetIndirectLayerConsumerHandleDavid Marcec2020-06-281-1/+13
| | | | | | | | | | | | | | | | | | | | | | | | Needed by Monster Hunter Generations Ultimate
* | | | | | Merge pull request #4192 from ogniK5377/acc-ListOpenContextStoredUsers-stubbunnei2020-07-035-4/+14
|\ \ \ \ \ \ | | | | | | | | | | | | | | acc: ListOpenContextStoredUsers partial stub
| * | | | | | acc: ListOpenContextStoredUsers partial stubDavid Marcec2020-06-285-4/+14
| |/ / / / / | | | | | | | | | | | | | | | | | | Needed by Baldur's Gate 1/2
* | | | | | key_manager: Correct casing of instance()Lioncash2020-07-011-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | Our codebase uppercases member function names.
* | | | | | Merge pull request #3967 from FearlessTobi/keys-singletonDavid2020-07-011-1/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | crypto: Make KeyManager a singleton class
| * | | | | | crypto: Make KeyManager a singleton classFearlessTobi2020-05-201-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, we were reading the keys everytime a KeyManager object was created, causing yuzu to reread the keys file multiple hundreds of times when loading the game list. With this change, it is only loaded once. On my system, this decreased game list loading times by a factor of 20.
* | | | | | | Merge pull request #4153 from ogniK5377/prepo-multibufbunnei2020-07-011-1/+6
|\ \ \ \ \ \ \ | |_|_|_|/ / / |/| | | | | | prepo: : Don't read extra buffer from report unless passed
| * | | | | | prepo: : Don't read extra buffer from report unless passedDavid Marcec2020-06-241-1/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Prepo doesn't always pass a secondary buffer, we assume it always does which leads to a bad read.
* | | | | | | Merge pull request #3955 from FernandoS27/prometheus-2bbunnei2020-06-2844-1071/+2134
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Remake Kernel Scheduling, CPU Management & Boot Management (Prometheus)
| * | | | | | | Core/Common: Address Feedback.Fernando Sahmkow2020-06-285-16/+17
| | | | | | | |
| * | | | | | | NvFlinger: Clang Format.Fernando Sahmkow2020-06-271-1/+1
| | | | | | | |
| * | | | | | | SVC: Implement 32-bits wrappers and update Dynarmic.Fernando Sahmkow2020-06-272-30/+273
| | | | | | | |
| * | | | | | | SVC: Add GetCurrentProcessorNumber32, CreateTransferMemory32, SetMemoryAttribute32Fernando Sahmkow2020-06-272-6/+39
| | | | | | | |
| * | | | | | | SVC: Add GetThreadPriority32 & SetThreadPriority32Fernando Sahmkow2020-06-272-2/+30
| | | | | | | |
| * | | | | | | Common/Kernel: Corrections and small bug fixing.Fernando Sahmkow2020-06-271-2/+2
| | | | | | | |
| * | | | | | | Services/NvFlinger: Do vSync in a sepparate thread on Multicore.Fernando Sahmkow2020-06-272-3/+60
| | | | | | | |
| * | | | | | | Kernel: Correct Host Context on Threads and Scheduler.Fernando Sahmkow2020-06-274-11/+11
| | | | | | | |
| * | | | | | | Clang Format.Fernando Sahmkow2020-06-274-12/+11
| | | | | | | |
| * | | | | | | General: Cleanup legacy code.Fernando Sahmkow2020-06-279-254/+6
| | | | | | | |
| * | | | | | | Kernel/svcBreak: Implement CacheInvalidation for Singlecore and correct svcBreak.Fernando Sahmkow2020-06-272-3/+13
| | | | | | | |
| * | | | | | | HLE_IPC: Correct HLE Event behavior on timeout.Fernando Sahmkow2020-06-273-1/+19
| | | | | | | |
| * | | | | | | SingleCore: Improve Cycle timing Behavior and replace mutex in global scheduler for spinlock.Fernando Sahmkow2020-06-272-2/+3
| | | | | | | |
| * | | | | | | FrameLimiting: Enable frame limiting for single core.Fernando Sahmkow2020-06-271-0/+1
| | | | | | | |
| * | | | | | | SingleCore: Use Cycle Timing instead of Host Timing.Fernando Sahmkow2020-06-272-4/+13
| | | | | | | |
| * | | | | | | Scheduler: Correct Reload/UnloadFernando Sahmkow2020-06-272-3/+5
| | | | | | | |
| * | | | | | | Thread: Release the ARM Interface on exitting.Fernando Sahmkow2020-06-273-1/+8
| | | | | | | |
| * | | | | | | General: Move ARM_Interface into Threads.Fernando Sahmkow2020-06-278-119/+88
| | | | | | | |
| * | | | | | | Core: Refactor ARM Interface.Fernando Sahmkow2020-06-273-24/+43
| | | | | | | |
| * | | | | | | SVC/ARM: Correct svcSendSyncRequest and cache ticks on arm interface.Fernando Sahmkow2020-06-271-1/+1
| | | | | | | |
| * | | | | | | SingleCore: Move Host Timing from a sepparate thread to main cpu thread.Fernando Sahmkow2020-06-272-1/+10
| | | | | | | |
| * | | | | | | ARM: Addapt to new Exclusive Monitor Interface.Fernando Sahmkow2020-06-272-9/+4
| | | | | | | |
| * | | | | | | Scheduler: Correct yielding interaction with SetThreadActivity.Fernando Sahmkow2020-06-271-0/+15
| | | | | | | |
| * | | | | | | General: Fix microprofile on dynarmic/svc, fix wait tree showing which threads were running.Fernando Sahmkow2020-06-275-3/+51
| | | | | | | |
| * | | | | | | General: Fix Stop functionFernando Sahmkow2020-06-272-3/+20
| | | | | | | |
| * | | | | | | Kernel: Rewind on SVC change.Fernando Sahmkow2020-06-273-5/+16
| | | | | | | |
| * | | | | | | Kernel: Preempt Single core on redudant yields.Fernando Sahmkow2020-06-275-19/+40
| | | | | | | |
| * | | | | | | CPU_Manager: Unload/Reload threads on preemption on SingleCoreFernando Sahmkow2020-06-272-0/+52
| | | | | | | |
| * | | | | | | Synchronization: Correct wide Assertion.Fernando Sahmkow2020-06-271-2/+4
| | | | | | | |
| * | | | | | | General: Initial Setup for Single Core.Fernando Sahmkow2020-06-272-0/+22
| | | | | | | |
| * | | | | | | Scheduler: Set last running time on thread.Fernando Sahmkow2020-06-272-4/+2
| | | | | | | |
| * | | | | | | Kernel: Corrections to TimeManager, Scheduler and Mutex.Fernando Sahmkow2020-06-273-5/+5
| | | | | | | |
| * | | | | | | Kernel: Fixes, corrections and asserts to scheduler and different svcs.Fernando Sahmkow2020-06-278-38/+38
| | | | | | | |
| * | | | | | | Scheduler: Correct yields.Fernando Sahmkow2020-06-272-7/+25
| | | | | | | |
| * | | | | | | Mutex: Revert workaround due to poor exclusive memory.Fernando Sahmkow2020-06-271-9/+2
| | | | | | | |
| * | | | | | | ARM/Memory: Correct Exclusive Monitor and Implement Exclusive Memory Writes.Fernando Sahmkow2020-06-274-9/+10
| | | | | | | |
| * | | | | | | SVC: WaitSynchronization add Termination Pending Result.Fernando Sahmkow2020-06-272-1/+5
| | | | | | | |
| * | | | | | | Scheduler: Remove arm_interface lock and a few corrections.Fernando Sahmkow2020-06-271-7/+3
| | | | | | | |
| * | | | | | | SVC: Correct SetThreadActivity.Fernando Sahmkow2020-06-274-38/+59
| | | | | | | |
| * | | | | | | SCC: Small corrections to CancelSynchronizationFernando Sahmkow2020-06-273-2/+14
| | | | | | | |
| * | | | | | | Scheduler: Correct locking for hle threads.Fernando Sahmkow2020-06-271-1/+2
| | | | | | | |
| * | | | | | | Scheduler: Fix HLE Threads on guardFernando Sahmkow2020-06-271-4/+6
| | | | | | | |
| * | | | | | | Scheduler: Protect on closed threads.Fernando Sahmkow2020-06-271-7/+17
| | | | | | | |
| * | | | | | | Scheduler: Correct assert.Fernando Sahmkow2020-06-271-4/+2
| | | | | | | |
| * | | | | | | Core: Correct rebase.Fernando Sahmkow2020-06-271-6/+5
| | | | | | | |
| * | | | | | | Scheduler: Release old thread fiber before trying to switch to the next thread fiber.Fernando Sahmkow2020-06-272-11/+35
| | | | | | | |
| * | | | | | | NVDRV: Remove frame limiting as Host Timing already takes care.Fernando Sahmkow2020-06-271-1/+0
| | | | | | | |
| * | | | | | | Mutex: Correct Result writting to clear exclusivity.Fernando Sahmkow2020-06-271-3/+11
| | | | | | | |
| * | | | | | | SVC: Correct svcWaitForAddress and svcSignalToAddress.Fernando Sahmkow2020-06-274-68/+161
| | | | | | | |
| * | | | | | | Scheduler: Correct Select Threads Step 2.Fernando Sahmkow2020-06-271-0/+1
| | | | | | | |
| * | | | | | | Kernel: Corrections to Scheduling.Fernando Sahmkow2020-06-273-14/+15
| | | | | | | |
| * | | | | | | Kernel: Correct Signal on Thread Death and Setup Sync Objects on Thread for DebuggingFernando Sahmkow2020-06-273-15/+17
| | | | | | | |
| * | | | | | | Core: Correct HLE Event Callbacks and other issues.Fernando Sahmkow2020-06-275-37/+39
| | | | | | | |
| * | | | | | | Process: Protect TLS region and Modules.Fernando Sahmkow2020-06-271-0/+4
| | | | | | | |
| * | | | | | | General: Add AssertsFernando Sahmkow2020-06-273-0/+20
| | | | | | | |
| * | | | | | | General: Add better safety for JIT use.Fernando Sahmkow2020-06-272-1/+8
| | | | | | | |
| * | | | | | | SVC: Correct races on physical core switching.Fernando Sahmkow2020-06-271-5/+4
| | | | | | | |
| * | | | | | | NVFlinger: Lock race condition between CPU, Host Timing, VSync.Fernando Sahmkow2020-06-273-0/+11
| | | | | | | |
| * | | | | | | SVC: Add locks to the memory management.Fernando Sahmkow2020-06-271-0/+21
| | | | | | | |
| * | | | | | | SVC: Correct WaitSynchronization, WaitProcessWideKey, SignalProcessWideKey.Fernando Sahmkow2020-06-279-33/+84
| | | | | | | |
| * | | | | | | SVC: Cleanup old methods.Fernando Sahmkow2020-06-271-13/+9
| | | | | | | |
| * | | | | | | CPU_Manager: Reconfigre guest threads for dynamrmic downsidesFernando Sahmkow2020-06-272-0/+5
| | | | | | | |
| * | | | | | | SVC: Correct SendSyncRequest.Fernando Sahmkow2020-06-277-52/+115
| | | | | | | |
| * | | | | | | SVC: Correct ArbitrateUnlockFernando Sahmkow2020-06-273-33/+37
| | | | | | | |
| * | | | | | | SVC: Correct SignalEvent, ClearEvent, ResetSignal, WaitSynchronization, CancelSynchronization, ArbitrateLockFernando Sahmkow2020-06-278-90/+134
| | | | | | | |
| * | | | | | | SVC: Remove global HLE Lock.Fernando Sahmkow2020-06-271-3/+0
| | | | | | | |
| * | | | | | | SVC: Correct GetThreadPriority, SetThreadPriority, GetThreadCoreMask, SetThreadCoreMask, GetCurrentProcessorNumberFernando Sahmkow2020-06-273-15/+11
| | | | | | | |
| * | | | | | | SVC: Correct CreateThread, StartThread, ExitThread, SleepThread.Fernando Sahmkow2020-06-273-37/+31
| | | | | | | |
| * | | | | | | General: Recover Prometheus project from harddrive failure Fernando Sahmkow2020-06-2727-383/+710
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit: Implements CPU Interrupts, Replaces Cycle Timing for Host Timing, Reworks the Kernel's Scheduler, Introduce Idle State and Suspended State, Recreates the bootmanager, Initializes Multicore system.
* | | | | | | ldr: Cleanup NRO & NRR structsDavid Marcec2020-06-281-8/+8
| | | | | | |
* | | | | | | Merge pull request #4026 from VolcaEM/ldrDavid2020-06-281-38/+73
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | ldr: Update NRR/NRO structs
| * | | | | | | Move SHA256Hash to its original positionVolcaEM2020-06-181-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | It's not needed to have it in its previous position anymore
| * | | | | | | Remove unnecessary pragmasVolcaEM2020-06-161-8/+0
| | | | | | | |
| * | | | | | | Revert IsValidNRO refactor but make it more readableVolcaEM2020-06-161-26/+13
| | | | | | | |
| * | | | | | | Update assert stringVolcaEM2020-06-161-1/+1
| | | | | | | |
| * | | | | | | Clang-format againVolcaEM2020-06-141-2/+2
| | | | | | | |
| * | | | | | | Use consistent variable namesVolcaEM2020-06-141-4/+4
| | | | | | | |
| * | | | | | | Clang-formatVolcaEM2020-06-141-1/+2
| | | | | | | |
| * | | | | | | Make assert strings consistentVolcaEM2020-06-141-3/+3
| | | | | | | |
| * | | | | | | Attempt to fix crashes in SSBU and refactor IsValidNROVolcaEM2020-06-141-36/+59
| | | | | | | |
| * | | | | | | Address review commentsVolcaEM2020-06-021-4/+4
| | | | | | | |
| * | | | | | | Add comment to nrr_kindVolcaEM2020-05-311-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | According to Atmosphére (https://github.com/Atmosphere-NX/Atmosphere/blob/c7026b90940a1d88f9c10a6d98263bf22e654fa5/libraries/libstratosphere/include/stratosphere/ro/ro_types.hpp), nrr_kind (Atmosphére calls it "type") is 7.0.0+
| * | | | | | | ldr: Update NRR/NRO structs VolcaEM2020-05-311-40/+72
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was based on Switchbrew pages: https://switchbrew.org/wiki/NRR https://switchbrew.org/wiki/NRO
* | | | | | | Merge pull request #4184 from VolcaEM/patch-9David2020-06-281-0/+3
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | grc: Update function table
| * | | | | | | Oops (fix typo)VolcaEM2020-06-271-1/+1
| | | | | | | |
| * | | | | | | grc: Update function tableVolcaEM2020-06-271-0/+3
| | |/ / / / / | |/| | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/GRC_services
* | | | | | | Merge pull request #4185 from VolcaEM/patch-10David2020-06-281-0/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | lbl: Update function table
| * | | | | | | lbl: Update function tableVolcaEM2020-06-271-0/+1
| |/ / / / / / | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/Backlight_services
* | | | | | | Merge pull request #4186 from VolcaEM/patch-11David2020-06-281-0/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | ldn: Update function table
| * | | | | | | ldn: Update function tableVolcaEM2020-06-271-0/+1
| |/ / / / / / | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/LDN_services
* | | | | | | Merge pull request #4187 from VolcaEM/patch-12David2020-06-281-0/+6
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | mig: Update function table
| * | | | | | | mig: Update function tableVolcaEM2020-06-271-0/+6
| |/ / / / / / | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/Migration_services
* | | | | | | Merge pull request #4188 from VolcaEM/patch-13David2020-06-281-16/+16
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | mm: Update function table
| * | | | | | | mm: Update function tableVolcaEM2020-06-271-16/+16
| |/ / / / / / | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/Display_services
* | | | | | | Merge pull request #4189 from VolcaEM/patch-14David2020-06-281-10/+10
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | ncm: Update function table
| * | | | | | | ncm: Update function tableVolcaEM2020-06-271-10/+10
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/NCM_services ILocationResolver's 16, 17, 18 and 19 have unofficial names
* | | | | | | Merge pull request #4190 from VolcaEM/patch-15David2020-06-281-3/+3
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | nfc: Update function table
| * | | | | | | nfc: Update function tableVolcaEM2020-06-271-3/+3
| |/ / / / / / | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/NFC_services
* / / / / / / friend: Update function tableVolcaEM2020-06-271-0/+6
|/ / / / / /
* | | | | | Merge pull request #4158 from Morph1984/capsbunnei2020-06-2714-57/+69
|\ \ \ \ \ \ | | | | | | | | | | | | | | caps: Use enum classes and check struct sizes on compile time
| * | | | | | caps_u: Fix GetAlbumContentsFileListForApplication stubMorph2020-06-261-9/+15
| | | | | | |
| * | | | | | caps: Use enum classes and check struct sizes on compile timeMorph2020-06-261-34/+40
| | | | | | |
| * | | | | | caps: Update copyright headersMorph2020-06-2614-14/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Updated to "yuzu Emulator Project"
* | | | | | | Merge pull request #4152 from ogniK5377/ipc-errbunnei2020-06-271-25/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Mark invalid IPC buffers as ASSERT_OR_EXECUTE_MSG
| * | | | | | | Mark invalid IPC buffers as ASSERT_OR_EXECUTE_MSGDavid Marcec2020-06-241-25/+22
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | Previously if applications would send faulty buffers(example homebrew) it would lead to us returning uninitalized data. Switching from ASSERT_MSG to ASSERT_OR_EXECUTE_MSG allows us to have a fail safe to prevent crashes but also continue execution without introducing undefined behavior
* | | | | | | Merge pull request #4154 from ogniK5377/swkbd-nullptrbunnei2020-06-271-1/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Prevent nullptr dereference on swkbd error case
| * | | | | | | Prevent nullptr dereference on swkbd error caseDavid Marcec2020-06-241-1/+1
| |/ / / / / /
* | | | | | | Merge pull request #4178 from VolcaEM/patch-6David2020-06-271-4/+43
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | es: Update function table
| * | | | | | | Use better names for "Unknown"sVolcaEM2020-06-271-39/+39
| | | | | | | |
| * | | | | | | Update function namesVolcaEM2020-06-271-4/+4
| | | | | | | |
| * | | | | | | es: Update function tableVolcaEM2020-06-271-2/+41
| | |/ / / / / | |/| | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/ETicket_services
* | | | | | | btm: Give better names for unknown functionsDavid Marcec2020-06-271-5/+5
| | | | | | |
* | | | | | | btdrv: Update function table (#4174)VolcaEM2020-06-271-83/+84
| | | | | | | | | | | | | | | | | | | | | * btdrv: Update function table
* | | | | | | bpc: Update function tables (#4173)VolcaEM2020-06-271-7/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * bpc: Update function tables This was based on Switchbrew page: https://switchbrew.org/wiki/PCV_services
* | | | | | | bcat: Update function tables and add missing classes (#4172)VolcaEM2020-06-272-0/+5
| | | | | | | | | | | | | | | | | | | | | * bcat: Update function tables and add missing classes
* | | | | | | am: Update function tables and add missing classes (#4169)VolcaEM2020-06-273-17/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * am: Update function tables and add missing classes * Remove comments (1/5) * Remove comments (2/5) * Remove comments (3/5) * Remove comments (4/5) * Remove comments (5/5) * Remove unused classes (1/2) * Remove unused classes (2/2)
* | | | | | | aoc: Update function table (#4170)VolcaEM2020-06-271-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * aoc: Update function table * Remove comments
* | | | | | | Merge pull request #4177 from VolcaEM/patch-5LC2020-06-271-71/+76
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | btm: Update function tables
| * | | | | | | btm: Update function tablesVolcaEM2020-06-271-71/+76
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/BTM_services "No comment" edition
* / / / / / / eupld: Update function tableVolcaEM2020-06-271-0/+1
|/ / / / / / | | | | | | | | | | | | This was based on Switchbrew page: https://switchbrew.org/wiki/Error_Upload_services
* | | | | | Merge pull request #4159 from ogniK5377/mem-manager-dumb-assertbunnei2020-06-261-1/+0
|\ \ \ \ \ \ | | | | | | | | | | | | | | memory_manager: Remove useless assertion
| * | | | | | memory_manager: Remove useless assertionDavid Marcec2020-06-251-1/+0
| |/ / / / / | | | | | | | | | | | | | | | | | | num_pages is an std::size_t. It will always be >= 0
* | | | | | Merge pull request #4141 from Morph1984/SevenSixAxisSensorDavid2020-06-252-21/+85
|\ \ \ \ \ \ | |/ / / / / |/| | | | | hid: Stub a series of "SevenSixAxisSensor" service commands
| * | | | | hid: Stub a series of "SevenSixAxisSensor" service commandsMorph2020-06-242-21/+85
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | - Used by Captain Toad: Treasure Tracker Update 1.3.0 While we're at it, fix the input parameters for SetIsPalmaAllConnectable and SetPalmaBoostMode
* | | | | Merge pull request #4138 from Morph1984/GyroscopeZeroDriftModebunnei2020-06-244-6/+56
|\ \ \ \ \ | | | | | | | | | | | | hid: Implement Get/ResetGyroscopeZeroDriftMode
| * | | | | hid: Implement Get/ResetGyroscopeZeroDriftModeMorph2020-06-214-6/+56
| |/ / / / | | | | | | | | | | | | | | | - Used by Captain Toad Treasure Tracker
* | | | | Merge pull request #4128 from lioncash/move2bunnei2020-06-241-2/+2
|\ \ \ \ \ | | | | | | | | | | | | software_keyboard: Eliminate trivial redundant copies
| * | | | | software_keyboard: Eliminate trivial redundant copiesLioncash2020-06-201-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | We can just make use of moves here to get rid of two redundant copies
* | | | | | lm: Silence no return value warningMorph2020-06-231-1/+2
| | | | | |
* | | | | | account: Update function tables and add missing classes (#4145)VolcaEM2020-06-225-42/+384
| |/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * account: Update function tables and add missing classes * clang-format * Add missing "public" * Add missing public again * Add missing final
* | | | | memory_manager: Explicitly specifcy std::min<size_t>MerryMage2020-06-181-2/+2
|/ / / /
* | | | Merge pull request #4070 from ogniK5377/GetTPCMasks-fixbunnei2020-06-152-21/+22
|\ \ \ \ | | | | | | | | | | nvdrv: Fix GetTPCMasks for ioctl3
| * | | | nvdrv: Fix GetTPCMasks for ioctl3David Marcec2020-06-102-21/+22
| | |_|/ | |/| | | | | | | | | | Fixes animal crossing svcBreak on launch
* | | | Merge pull request #4069 from ogniK5377/total-phys-membunnei2020-06-141-2/+4
|\ \ \ \ | | | | | | | | | | kernel: Account for system resource size for memory usage
| * | | | kernel: Account for system resource size for memory usageDavid Marcec2020-06-101-2/+4
| |/ / / | | | | | | | | | | | | GetTotalPhysicalMemoryAvailableWithoutSystemResource & GetTotalPhysicalMemoryUsedWithoutSystemResource seem to subtract the resource size from the usage.
* | | | Merge pull request #4010 from ogniK5377/reserve-always-breakbunnei2020-06-131-5/+1
|\ \ \ \ | |/ / / |/| | | kernel: ResourceLimit::Reserve remove useless while loop
| * | | kernel: ResourceLimit::Reserve remove useless while loopDavid Marcec2020-05-291-5/+1
| |/ / | | | | | | | | | Timeout is a u64, it will always be >= 0
* | | Downgrade "handle not signaled" error to traceDavid Marcec2020-06-041-1/+1
| | | | | | | | | | | | clogs logs quite a bit
* | | Clang-formatVolcaEM2020-06-011-2/+1
| | |
* | | hid: Stub GetXpadIDsVolcaEM2020-06-012-1/+14
|/ / | | | | Allows Minecraft: Nintendo Switch Edition (a.k.a. old Minecraft) to boot and go ingame
* | clang-formatVolcaEM2020-05-211-1/+2
| |
* | nifm: correct assert in CreateTemporaryNetworkProfileVolcaEM2020-05-211-1/+1
| | | | | | | | | | | | | | | | | | This has been wrong since https://github.com/yuzu-emu/yuzu/commit/0432af5ad1ec34f02071f6fdc5fc78149b059f18 I haven't found a game that called this function (and I haven't tried this on a real Switch), and because of this I haven't been able to check if the number in assert OR the string in the assert is wrong, but one of the two is wrong: NetworkProfileData is 0x18E, while SfNetworkProfileData is 0x17C, according to Switchbrew Switchbrew doesn't officially say that NetworkProfileData's size is 0x18E but it's possible to calculate its size since Switchbrew provides the size and the offset of all the components of NetworkProfileData (which isn't currently implemented in yuzu, alongside SfNetworkProfileData) NetworkProfileData documentation: https://switchbrew.org/wiki/Network_Interface_services#NetworkProfileData SfNetworkProfileData documentation: https://switchbrew.org/wiki/Network_Interface_services#SfNetworkProfileData Since I trust ogniK's work on reversing NIFM, I'd assume this was just a typo in the string
* | Merge pull request #3926 from ogniK5377/keyboard-statesbunnei2020-05-191-3/+4
|\ \ | | | | | | hid: Clear keyboard states & fix logic issue
| * | hid: Clear keyboard states & fix logic issueDavid Marcec2020-05-121-3/+4
| | | | | | | | | | | | Previously we never cleared the states of the entries and the key would stay held down, also looping over the key bytes for each key lead to setting every bit for the key state instead of the key we wanted
* | | Merge pull request #3665 from bunnei/device-savebunnei2020-05-162-1/+38
|\ \ \ | | | | | | | | FS: Improve emulation of device saves
| * | | service: fsp_srv: Stub implementation of OpenMultiCommitManager.bunnei2020-05-112-1/+38
| |/ /
* | | nv_flinger: Use enum for pixel format instead of u32David Marcec2020-05-162-3/+11
| | |
* | | time_zone: Use std::chrono::seconds for strong typing.bunnei2020-05-131-1/+1
| | |
* | | hle: service: time_zone_manager: Use current time zone setting.bunnei2020-05-112-3/+32
| | |
* | | Stub SendKeyboardLockKeyEventDavid Marcec2020-05-112-1/+11
|/ / | | | | | | Needed for Puchikon 4 SmileBASIC 1.0.0
* | Replace externals with Conan (#3735)James Rowe2020-05-081-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Remove git submodules that will be loaded through conan * Move custom Find modules to their own folder * Use conan for downloading missing external dependencies * CI: Change the yuzu source folder user to the user that the containers run on * Attempt to remove dirty mingw build hack * Install conan on the msvc build * Only set release build type when using not using multi config generator * Re-add qt bundled to workaround an issue with conan qt not downloading prebuilt binaries * Add workaround for submodules that use legacy CMAKE variables * Re-add USE_BUNDLED_QT on the msvc build bot
* | Merge pull request #3879 from lioncash/global2bunnei2020-05-083-10/+16
|\ \ | |/ |/| hle_ipc: Eliminate core memory globals
| * hle_ipc: Eliminate core memory globalsLioncash2020-05-033-10/+16
| | | | | | | | | | We can just pass the required instances into the constructor of the request, eliminating all usages of the global system accessor.
* | Merge pull request #3881 from lioncash/mem-warningbunnei2020-05-0511-23/+11
|\ \ | | | | | | kernel/memory: Resolve several compiler warnings
| * | kernel/memory: Remove #pragma once within cpp fileLioncash2020-05-031-2/+0
| | | | | | | | | | | | This isn't necessary in a cpp file and will cause warnings on clang.
| * | kernel/memory: Remove unused includesLioncash2020-05-037-8/+1
| | | | | | | | | | | | | | | Prevents header churn and needing to recompile these files if these headers are ever changed in the future.
| * | kernel/memory: Remove unused variables in memory_block_managerLioncash2020-05-031-3/+0
| | | | | | | | | | | | Prevents unused variable warnings.
| * | kernel/memory: Make use of std::array consistently in address_space_infoLioncash2020-05-031-6/+6
| | | | | | | | | | | | | | | This allows tuning standard library implementations to enable or disable range checks at runtime, which is nicer for debugging.
| * | kernel/memory: Resolve -Wshadow warningsLioncash2020-05-031-4/+4
| |/ | | | | | | Prevents variable name clashing.
* | Merge pull request #3880 from lioncash/encodingbunnei2020-05-056-12/+12
|\ \ | | | | | | kernel/memory: Amend potential encoding warnings
| * | kernel/memory: Amend potential encoding warningsLioncash2020-05-036-12/+12
| |/ | | | | | | | | | | | | While èis generally representable in some language encodings, in some it isn't and will result in compilation warnings occurring. To remain friendly with other language's codepages on Windows, we normalize it to an ASCII e.
* | Merge pull request #3843 from ogniK5377/GetPopFromGeneralChannelEventbunnei2020-05-043-4/+20
|\ \ | | | | | | am: IHomeMenuFunctions:GetPopFromGeneralChannelEvent
| * | am: IHomeMenuFunctions:GetPopFromGeneralChannelEventDavid Marcec2020-05-013-4/+20
| | | | | | | | | | | | QLaunch 1.0.0
* | | Merge pull request #3822 from ogniK5377/GetAccountIdbunnei2020-05-041-5/+8
|\ \ \ | |_|/ |/| | acc: Return a unique value per account for GetAccountId
| * | acc: Return a unique value per account for GetAccountIdDavid Marcec2020-04-291-5/+8
| | |
* | | Merge pull request #3871 from lioncash/semibunnei2020-05-031-4/+6
|\ \ \ | | | | | | | | readable_event: Remove unnecessary semicolon in Signal()
| * | | readable_event: Remove unnecessary semicolon in Signal()Lioncash2020-05-021-4/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Resolves a -Wextra-semi warning. While we're at it, we can invert the branch to form a guard clause, unindenting all of the contained code.
* | | | Merge pull request #3824 from ogniK5377/GetDisplayVersionbunnei2020-05-031-3/+14
|\ \ \ \ | |/ / / |/| | | am: Properly implement GetDisplayVersion
| * | | Update src/core/hle/service/am/am.cppbunnei2020-05-031-1/+1
| | | | | | | | | | | | Co-authored-by: Mat M. <mathew1800@gmail.com>
| * | | am: Properly implement GetDisplayVersionDavid Marcec2020-04-291-3/+14
| |/ / | | | | | | | | | Properly implement IApplicationFunctions::GetDisplayVersion
* | | Merge pull request #3811 from ogniK5377/audin-initbunnei2020-05-022-5/+94
|\ \ \ | | | | | | | | audin:u: ListAudioIns, OpenAudioIn, ListAudioInsAuto, OpenAudioInAuto, ListAudioInsAutoFiltered, OpenAudioInProtocolSpecified
| * | | marked stubsDavid Marcec2020-04-281-4/+5
| | | |
| * | | Audin:u ListAudioIns, OpenAudioIn, ListAudioInsAuto, OpenAudioInAuto, ListAudioInsAutoFiltered, OpenAudioInProtocolSpecifiedDavid Marcec2020-04-282-5/+93
| | | | | | | | | | | | | | | | Closes #2874
* | | | Merge pull request #3819 from ogniK5377/err-log2bunnei2020-05-027-0/+51
|\ \ \ \ | | | | | | | | | | kernel: Don't fail silently
| * | | | kernel: Don't fail silentlyDavid Marcec2020-04-297-0/+51
| | |/ / | |/| |
* | | | Merge pull request #3833 from qwell/caps_su-32-stubbunnei2020-05-022-1/+13
|\ \ \ \ | | | | | | | | | | Add stub for caps:su SetShimLibraryVersion
| * | | | caps:su Stub out SetShimLibraryVersionJason Parker2020-04-302-1/+13
| | | | | | | | | | | | | | | | | | | | Used by Animal Crossing: New Horizons when trying to take a picture.
* | | | | Merge pull request #3821 from ogniK5377/InitializeApplicationInfo-fixbunnei2020-05-022-22/+15
|\ \ \ \ \ | | | | | | | | | | | | acc: Fix InitializeApplicationInfo
| * | | | | acc: Fix InitializeApplicationInfoDavid Marcec2020-04-292-22/+15
| | |/ / / | |/| | | | | | | | | | | | | We're not suppose to pop a u64, should just read the sent pid and check that
* | | | | Merge pull request #3812 from ogniK5377/lisst-qualified-usersbunnei2020-05-025-3/+15
|\ \ \ \ \ | | | | | | | | | | | | account: ListQualifiedUsers
| * | | | | Updated comment to reflect ListQualifiedUsers betterDavid Marcec2020-04-281-1/+3
| | | | | |
| * | | | | account: ListQualifiedUsersDavid Marcec2020-04-285-3/+13
| | |_|/ / | |/| | | | | | | | | | | | | Closes #2844
* | | | | nvdrv: Fix GetGpuTime stack corruptionDavid Marcec2020-05-011-2/+3
| |_|_|/ |/| | | | | | | | | | | IoctlGetGpuTime should be 16 bytes, not 8.
* | | | Merge pull request #3823 from ogniK5377/setvrmodeMat M2020-04-302-16/+6
|\ \ \ \ | | | | | | | | | | am: IsVrModeEnabled & SetVrModeEnabled fixes
| * | | | am: IsVrModeEnabled & SetVrModeEnabled fixesDavid Marcec2020-04-292-16/+6
| | |/ / | |/| | | | | | | | | | | | | | Return the proper state of vr mode for IsVrModeEnabled We should not return an error for SetVrModeEnabled. When VR Mode is turned on, it signals to lbl to turn vr mode on, not return an error code
* | | | Merge pull request #3830 from ogniK5377/GetFriendInvitationStorageChannelEventMat M2020-04-302-1/+14
|\ \ \ \ | | | | | | | | | | am: GetFriendInvitationStorageChannelEvent
| * | | | am: GetFriendInvitationStorageChannelEventDavid Marcec2020-04-302-1/+14
| |/ / / | | | | | | | | | | | | Closes #3829
* | | | Merge pull request #3835 from ogniK5377/GetFreeSpaceSize-GetTotalSpaceSizeMat M2020-04-301-2/+2
|\ \ \ \ | | | | | | | | | | fs-srv: GetFreeSpaceSize & GetTotalSpaceSize
| * | | | fs-srv: GetFreeSpaceSize & GetTotalSpaceSizeDavid Marcec2020-04-301-2/+2
| |/ / / | | | | | | | | | | | | | | | | | | | | Closes #3533 Turns out the functions were already implemented but just never added
* | | | Merge pull request #3832 from ogniK5377/nim-eca-CreateServerInterfaceMat M2020-04-301-1/+69
|\ \ \ \ | | | | | | | | | | nim: CreateServerInterface, CreateAccessorInterface, CreateAsyncInterface
| * | | | nim: CreateServerInterface, CreateAccessorInterface, CreateAsyncInterfaceDavid Marcec2020-04-301-1/+69
| |/ / / | | | | | | | | | | | | Closes #3026
* | | | Merge pull request #3831 from ogniK5377/caps-su-namesMat M2020-04-301-0/+3
|\ \ \ \ | | |_|/ | |/| | caps: Add missing service names to caps:su
| * | | caps: Add missing service names to caps:suDavid Marcec2020-04-301-0/+3
| |/ / | | | | | | | | | SetShimLibraryVersion, SaveScreenShotEx1 & SaveScreenShotEx2 were missing
* / / psm: Mark as debug instead of warningDavid Marcec2020-04-291-7/+14
|/ / | | | | | | No point to emulate battery life. However options are broken out if we ever want to add a setting for it
* | Merge pull request #3818 from ogniK5377/err-logMat M2020-04-294-3/+27
|\ \ | | | | | | Don't fail silently for vi, sm, set and ns services
| * | Don't fail silently for vi, sm, set and ns servicesDavid Marcec2020-04-294-3/+27
| | |
* | | Merge pull request #3783 from lioncash/pointerMat M2020-04-291-1/+3
|\ \ \ | |/ / |/| | physical_core: Make use of std::make_unique instead of std::make_shared in ctor
| * | physical_core: Make use of std::make_unique instead of std::make_shared in ctorLioncash2020-04-241-1/+3
| | | | | | | | | | | | | | | | | | | | | We can also allow unicorn to be constructed in 32-bit mode or 64-bit mode to satisfy the need for both interpreter instances. Allows this code to compile successfully of non x86-64 architectures.
* | | kernel: Bad GetInfo ids should not be marked as stubsDavid Marcec2020-04-281-2/+2
| | | | | | | | | | | | As we currently match hardware and don't return a successful result, these should be marked as errors instead of warnings and as stubs.
* | | style: Change AMs & Glues error codes to be dec instead of hexDavid Marcec2020-04-282-7/+7
| |/ |/| | | | | Consistency for the rest of the error codes in the codebase
* | Merge pull request #3785 from ogniK5377/set-buffer-count-unitbunnei2020-04-271-1/+9
|\ \ | | | | | | vi: Don't let uninitialized data pass as a response for SetBufferCount
| * | vi: Don't let uninitialized data pass as a response for SetBufferCountDavid Marcec2020-04-241-1/+9
| | | | | | | | | | | | Currently SetBufferCount doesn't write to the out buffer which then contains uninitialized data. This leads to non-zero data which leads to responding with different error codes
* | | Merge pull request #3797 from slashiee/hid-stubMat M2020-04-272-1/+13
|\ \ \ | | | | | | | | services: hid: Stub StopSevenSixAxisSensor.
| * | | services: hid: Stub StopSevenSixAxisSensor.M&M2020-04-262-1/+13
| | | | | | | | | | | | | | | | - Used by The Legend of Zelda: Breath of the Wild v1.6.0
* | | | Merge pull request #3744 from lioncash/table2bunnei2020-04-2618-7/+107
|\ \ \ \ | |/ / / |/| | | service: Update function tables
| * | | service: Update function tablesLioncash2020-04-2018-7/+107
| | | | | | | | | | | | | | | | | | | | | | | | Keeps the service function tables up to date. Updated based off information on SwitchBrew.
* | | | Merge pull request #3780 from lioncash/processbunnei2020-04-251-2/+138
|\ \ \ \ | |_|/ / |/| | | svc: Re-add MapProcessCodeMemory/UnmapProcessCodeMemory
| * | | svc: Re-add MapProcessCodeMemory/UnmapProcessCodeMemoryLioncash2020-04-241-2/+138
| | |/ | |/| | | | | | | These were lost in the re-implementation of the virtual memory manager.
* | | Merge pull request #3777 from lioncash/warnRodrigo Locatti2020-04-241-2/+2
|\ \ \ | | | | | | | | page_table: Remove unused captures
| * | | page_table: Remove unused capturesLioncash2020-04-231-2/+2
| |/ / | | | | | | | | | | | | | | | Any time the lambda function is called, the permission being used in the capture would be passed in as an argument to the lambda, so the capture is unnecessary.
* | | Merge pull request #3778 from lioncash/unused-varRodrigo Locatti2020-04-241-3/+0
|\ \ \ | | | | | | | | svc: Remove unused variable
| * | | svc: Remove unused variableLioncash2020-04-231-3/+0
| |/ / | | | | | | | | | Since the VMM refactor, this is no longer used or needed.
* / / shared_memory: Amend doxygen referenceLioncash2020-04-242-5/+5
|/ / | | | | | | | | | | Amends the parameter to match the documentation reference. Resolves a -Wdocumentation warning with clang.
* | kernel: memory: Improve implementation of device shared memory. (#3707)bunnei2020-04-235-3/+105
| | | | | | | | | | | | | | * kernel: memory: Improve implementation of device shared memory. * fixup! kernel: memory: Improve implementation of device shared memory. * fixup! kernel: memory: Improve implementation of device shared memory.
* | Merge pull request #3730 from lioncash/timebunnei2020-04-231-24/+26
|\ \ | | | | | | service/time: Remove reliance on the global system accessor
| * | service/time: Remove reliance on the global system accessorLioncash2020-04-191-24/+26
| | | | | | | | | | | | | | | Eliminates usages of the global system accessor and instead passes the existing system instance into the interfaces.
* | | Merge pull request #3697 from lioncash/declarationsbunnei2020-04-232-6/+2
|\ \ \ | | | | | | | | CMakeLists: Enable -Wmissing-declarations on Linux builds
| * | | General: Resolve warnings related to missing declarationsLioncash2020-04-172-6/+2
| | | |
* | | | Merge pull request #3725 from MerryMage/fpcrbunnei2020-04-231-2/+1
|\ \ \ \ | | | | | | | | | | thread: FPCR.FZ is likely not 1 (and FPCR.RMode = TieAway and FPCR.DN = 0)
| * | | | thread: FPCR.FZ is likely not 1MerryMage2020-04-191-2/+1
| | | | |
* | | | | Merge pull request #3698 from lioncash/warningbunnei2020-04-211-2/+2
|\ \ \ \ \ | | | | | | | | | | | | General: Resolve minor assorted warnings
| * | | | | time_zone_manager: Resolve sign conversion warningsLioncash2020-04-171-2/+2
| | |/ / / | |/| | | | | | | | | | | | | | | | | | ttis and ats will never exceed the length of INT32_MAX in our case, so this is safe.
* | | | | audio_renderer: Preliminary BehaviorInfo (#3736)David2020-04-211-2/+7
| |_|_|/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * audio_renderer: Preliminary BehaviorInfo * clang format * Fixed IsRevisionSupported * fixed IsValidRevision * Fixed logic error & spelling errors & crash * Addressed issues
* | | | npad: Lower log level for VibrateController to DebugFearlessTobi2020-04-201-1/+1
| | | |
* | | | audren: Lower log level for RequestUpdateImpl to DebugFearlessTobi2020-04-201-1/+1
| | | |
* | | | Merge pull request #3712 from lioncash/removebunnei2020-04-202-3/+0
|\ \ \ \ | | | | | | | | | | service: Remove unused RequestParser instances
| * | | | service: Remove unused RequestParser instancesLioncash2020-04-182-3/+0
| | | | | | | | | | | | | | | | | | | | | | | | | These aren't used, so they should be removed to reduce compilation warnings.
* | | | | Merge pull request #3709 from lioncash/ambunnei2020-04-201-2/+2
|\ \ \ \ \ | |_|_|_|/ |/| | | | am: Resolve ineffective moves
| * | | | am: Resolve ineffective movesLioncash2020-04-181-2/+2
| |/ / / | | | | | | | | | | | | | | | | Previously const objects were being std::moved, which results in no move actually occurring. This resolves that.
* | | | Merge pull request #3696 from lioncash/cast-sizebunnei2020-04-192-21/+23
|\ \ \ \ | | | | | | | | | | hle_ipc: Remove std::size_t casts where applicable
| * | | | hle_ipc: Remove std::size_t casts where applicableLioncash2020-04-172-21/+23
| | |/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These were added in the change that enabled -Wextra on linux builds so as not to introduce interface changes in the same change as a build-system flag addition. Now that the flags are enabled, we can freely change the interface to make these unnecessary.
* | | | Merge pull request #3715 from bunnei/fix-impl-fallthroughMat M2020-04-181-0/+2
|\ \ \ \ | | | | | | | | | | service: hid: npad: Fix implicit fallthrough errors.
| * | | | service: hid: npad: Fix implicit fallthrough errors.bunnei2020-04-181-0/+2
| | |/ / | |/| |
* | | | Merge pull request #3713 from lioncash/timebunnei2020-04-185-4/+5
|\ \ \ \ | | | | | | | | | | service/time: Minor changes
| * | | | time/system_clock_core: Remove unnecessary initializerLioncash2020-04-181-1/+1
| | | | | | | | | | | | | | | | | | | | This is already initialized within the class body.
| * | | | service/time: Mark IsStandardNetworkSystemClockAccuracySufficient as constLioncash2020-04-181-1/+1
| | | | | | | | | | | | | | | | | | | | This doesn't modify internal member state.
| * | | | service/time: Add virtual destructors where applicableLioncash2020-04-183-2/+3
| |/ / / | | | | | | | | | | | | | | | | | | | | Many of these implementations are used to implement a polymorphic interface. While not directly used polymorphically, this prevents virtual destruction from ever becoming an issue.
* / / / memory/slab_heap: Make use of static_cast over reinterpret_castLioncash2020-04-181-2/+2
|/ / / | | | | | | | | | | | | Casting from void* with static_cast is permitted by the standard, so we can just make use of that instead.
* | | core: hle: Address various feedback & code cleanup.bunnei2020-04-1710-244/+144
| | | | | | | | | | | | - Should be no functional changes.
* | | memory: Add copyright notice for Atmosphere where applicable.bunnei2020-04-176-0/+18
| | |
* | | kernel: Remove old VMManager class.bunnei2020-04-172-1971/+0
| | |
* | | service: ldr: Updates for new VMM.bunnei2020-04-171-150/+215
| | | | | | | | | | | | - Includes removing some service impls. that are untested.
* | | kernel: memory: page_table: Simplify GetPhysicalAddr impl.bunnei2020-04-172-5/+3
| | |
* | | kernel: svc: Updates for new VMM.bunnei2020-04-171-488/+116
| | | | | | | | | | | | - Includes removing some SVC impls. that are untested.
* | | kernel: process: Updates for new VMM.bunnei2020-04-172-79/+151
| | |
* | | service: pl_u: Update for new shared memory layout.bunnei2020-04-171-7/+5
| | |
* | | service: time: Update for new shared memory layout.bunnei2020-04-171-3/+2
| | |
* | | service: hid: Update for new shared memory layout.bunnei2020-04-171-3/+2
| | |
* | | service: irs: Update for new shared memory layout.bunnei2020-04-171-3/+3
| | |
* | | kernel: resource_limit: Reserve physical memory.bunnei2020-04-171-1/+6
| | |
* | | kernel: Initialize memory layout for new VMM.bunnei2020-04-172-0/+159
| | |
* | | core: system: Rename GetDeviceManager -> DeviceManager.bunnei2020-04-171-1/+1
| | | | | | | | | | | | - More consistent with other system components.
* | | kernel: transfer_memory: Refactor for new VMM.bunnei2020-04-172-130/+16
| | |
* | | kernel: shared_memory: Refactor for new VMM.bunnei2020-04-172-220/+58
| | |
* | | kernel: errors: Add ERR_OUT_OF_RESOURCES.bunnei2020-04-171-0/+1
| | |
* | | kernel: process_capability: Update to use Memory::PageTable.bunnei2020-04-172-23/+25
| | |
* | | kernel: memory: Add PageTable class, to manage process address space.bunnei2020-04-172-0/+1508
| | |
* | | kernel: memory: Add MemoryLayout class, to build physical memory layout.bunnei2020-04-171-0/+73
| | |
* | | kernel: memory: Add MemoryManager class, to manage page heaps.bunnei2020-04-172-0/+274
| | |
* | | kernel: memory: Add MemoryBlockManager class, to manage memory blocks.bunnei2020-04-172-0/+254
| | |
* | | kernel: memory: Add PageHeap class, to manage a heap of pages.bunnei2020-04-172-0/+481
| | |
* | | kernel: memory: Add PageLinkedList class, to manage a list of pages.bunnei2020-04-171-0/+93
| | |
* | | kernel: memory: Add system_control code, which will be used for ASLR support.bunnei2020-04-172-0/+59
| | |
* | | physical_memory: Add missing include for <vector>.bunnei2020-04-171-0/+2
| | |
* | | kernel: memory: Add MemoryBlock class, for managing memory blocks and their state.bunnei2020-04-171-0/+315
| | |
* | | kernel: memory: Add memory_types.h, for things that are commonly used in memory code.bunnei2020-04-171-0/+18
| | |
* | | kernel: memory: Add SlabHeap class, for managing memory heaps.bunnei2020-04-171-0/+161
| | | | | | | | | | | | - This will be used for TLS pages, among other things.
* | | kernel: memory: Add AddressSpaceInfo class, for managing the memory address space.bunnei2020-04-172-0/+164
| | |
* | | core: memory: Move to Core::Memory namespace.bunnei2020-04-1710-30/+34
| | | | | | | | | | | | - helpful to disambiguate Kernel::Memory namespace.
* | | core: kernel: Add svc_types header to include SVC-specific types.bunnei2020-04-172-0/+69
| | |
* | | core: kernel: Move SVC to its own namesapce.bunnei2020-04-172-6/+6
| | |
* | | kernel: resource_limit: Improvements to implementation.bunnei2020-04-172-12/+50
| | |
* | | process: SetupMainThread: Zero out argument on process start.bunnei2020-04-171-0/+2
| | |
* | | Merge pull request #3671 from lioncash/switchbunnei2020-04-171-0/+2
|\ \ \ | |/ / |/| | kernel/thread: Resolve -Wswitch warnings
| * | kernel/thread: Resolve -Wswitch warningsLioncash2020-04-151-0/+2
| | |
* | | Merge pull request #3673 from lioncash/extrabunnei2020-04-176-23/+27
|\ \ \ | | | | | | | | CMakeLists: Specify -Wextra on linux builds
| * | | CMakeLists: Specify -Wextra on linux buildsLioncash2020-04-166-23/+27
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows reporting more cases where logic errors may exist, such as implicit fallthrough cases, etc. We currently ignore unused parameters, since we currently have many cases where this is intentional (virtual interfaces). While we're at it, we can also tidy up any existing code that causes warnings. This also uncovered a few bugs as well.
* | | | Merge pull request #3659 from bunnei/time-calc-standard-userRodrigo Locatti2020-04-163-1/+25
|\ \ \ \ | |/ / / |/| | | service: time: Implement CalculateStandardUserSystemClockDifferenceByUser.
| * | | service: time: Implement CalculateStandardUserSystemClockDifferenceByUser.bunnei2020-04-153-1/+25
| | |/ | |/| | | | | | | - Used by Animal Crossing: New Horizons.
* | | CMakeLists: Make -Wreorder a compile-time errorLioncash2020-04-151-1/+1
| |/ |/| | | | | | | | | This can result in silent logic bugs within code, and given the amount of times these kind of warnings are caused, they should be flagged at compile-time so no new code is submitted with them.
* | service: friend: Stub IFriendService::GetBlockedUserListIds.bunnei2020-04-141-1/+10
|/ | | | - This is safe to stub, as there should be no adverse consequences from reporting no blocked users.
* Merge pull request #3606 from ReinUsesLisp/nvflingerbunnei2020-04-123-10/+44
|\ | | | | service/vi: Partially implement BufferQueue disconnect
| * service/vi: Partially implement BufferQueue disconnectReinUsesLisp2020-04-103-10/+44
| |
* | Buffer queue: Correct behavior of free buffer.Fernando Sahmkow2020-04-102-9/+33
|/ | | | | | This corrects the behavior of free buffer after witnessing it in an unrelated hardware test. I haven't found any games affected by it but in name of better accuracy we'll correct such behavior.
* Merge pull request #3563 from bunnei/fix-ldr-memstateFernando Sahmkow2020-04-031-5/+15
|\ | | | | services: ldr: Fix MemoryState for read/write regions of NROs.
| * services: ldr: Fix MemoryState for read/write regions of NROs.bunnei2020-03-261-5/+15
| | | | | | | | - Fixes #3541, used by Final Fantasy VIII Remastered.
* | capsrv: Split Capture services into individual files and stub GetAlbumContentsFileListForApplication (#3571)Morph2020-04-0114-151/+524
| | | | | | | | | | | | | | * Organize capture services into individual files * Stub GetAlbumContentsFileListForApplication * Address feedback
* | Merge pull request #3568 from bunnei/time-calcspanbunnei2020-03-293-1/+31
|\ \ | | | | | | services: time: Implement CalculateSpanBetween.
| * | services: time: Implement CalculateSpanBetween.bunnei2020-03-273-1/+31
| |/ | | | | | | - Used by Super Smash Bros. Ultimate.
* | Merge pull request #3562 from perillamint/vrsvcbunnei2020-03-282-3/+42
|\ \ | | | | | | am: Implement VR related APIs
| * | am: Implement VR related APIsperillamint2020-03-272-3/+42
| |/ | | | | | | | | | | Implement (and stub) VR related APIs in AM sysmodule. This fixes issue #2938
* / services: hid: Stub InitializeSevenSixAxisSensor.bunnei2020-03-272-1/+9
|/ | | | - Used by Super Smash Bros. Ultimate v7.0.0.
* sm/controller: Increase PointerBufferSizeFearlessTobi2020-03-231-1/+1
| | | | | | | This increases the PointerBufferSize as a lager one is required by some services. This change is still not hw-accurate, but it is proven to work in Ryujinx. Instead of using a hardcoded size, we should figure out the specific values for each service in the future. Some of them can be taken from Atmosphere: https://github.com/Atmosphere-NX/Atmosphere/search?q=PointerBufferSize.
* Merge pull request #3477 from FearlessTobi/webapplet-shitbunnei2020-03-221-0/+6
|\ | | | | core/web_browser: Allow WebApplet to exit gracefully when an error occurs
| * core/web_browser: Allow WebApplet to exit gracefully when an error occursFearlessTobi2020-03-221-0/+6
| | | | | | | | | | | | | | | | Currently, yuzu just freezes when an error occurs while Initializing the WebApplet. From a user perspective, this obviously isn't great as the game just softlocks. With this change, yuzu will call the Finalize method, so to the game it seems like as the user just exited the WebApplet normally. This works around https://github.com/yuzu-emu/yuzu/issues/2852.
* | set: implement GetRegionCodeDan2020-03-192-1/+10
| |
* | time_zone_content_manager: Fix out of bounds readReinUsesLisp2020-03-181-1/+1
| | | | | | | | | | | | | | There were cases where raw_data didn't contain enough space to hold the zero terminator. This was caught with -fsanitize=address.
* | NVFlinger: Do the microprofile Flip after processing a valid frame.Fernando Sahmkow2020-03-121-2/+2
| |
* | core: hle: Implement separate A32/A64 SVC interfaces.bunnei2020-03-032-107/+380
| |
* | core: Implement separate A32/A64 ARM interfaces.bunnei2020-03-038-36/+73
|/
* AM/ICommonStateGetter: Stub SetLcdBacklighOffEnabled (#3454)Morph2020-02-272-2/+14
| | | | | | | | | * Stub SetLcdBacklighOffEnabled Used by Super Smash Bros. Ultimate We require backlight services to be implemented to turn on/off the backlight. * Address feedback
* Merge pull request #3431 from CJBok/npad-fixbunnei2020-02-261-5/+5
|\ | | | | InputCommon: analog_from_button get direction implementation
| * analog_from_button get direction implementationCJBok2020-02-181-5/+5
| |
* | Scheduler: Inline global scheduler in Scheduler Lock.Fernando Sahmkow2020-02-221-4/+2
| |
* | Kernel: Correct pending feedback.Fernando Sahmkow2020-02-221-3/+4
| |
* | Kernel: Address Feedback.Fernando Sahmkow2020-02-226-30/+47
| |
* | Kernel: Implement Scheduler locksFernando Sahmkow2020-02-222-0/+89
| |
* | Kernel: Implement Time Manager.Fernando Sahmkow2020-02-224-1/+96
| |
* | Kernel: Rename ThreadCallbackHandleTable and Setup Thread Ids on Kernel.Fernando Sahmkow2020-02-224-24/+105
| |
* | Kernel: Make global scheduler depend on KernelCoreFernando Sahmkow2020-02-224-8/+24
| |
* | httplib compatibilityBrian Clinkenbeard2020-02-191-3/+4
|/
* Merge pull request #3420 from namkazt/master2bunnei2020-02-172-0/+20
|\ | | | | nvhost_gpu: implement ChannelSetTimeslice
| * nvhost_gpu: implement ChannelSetTimeslicenamkazy2020-02-162-0/+20
| |
* | IUserLocalCommunicationService: add function Initialize2Nguyen Dac Nam2020-02-161-1/+9
| |
* | HLE: correct function name of IUserLocalCommunicationServiceNguyen Dac Nam2020-02-161-1/+1
|/ | | | 402: function name should be Initialize2 (7.0.0+) not SetOperationMode Follow by: https://switchbrew.org/wiki/LDN_services#IUserLocalCommunicationService
* Merge pull request #3401 from FernandoS27/synchronizationbunnei2020-02-1431-176/+330
|\ | | | | Set of refactors for Kernel Synchronization and Hardware Constants
| * Core: Address FeedbackFernando Sahmkow2020-02-145-16/+27
| |
| * Core: Set all hardware emulation constants in a single file.Fernando Sahmkow2020-02-129-29/+37
| |
| * Kernel: Refactor synchronization to better match REFernando Sahmkow2020-02-1122-80/+210
| |
| * Kernel: Change WaitObject to Synchronization object. In order to better reflect RE.Fernando Sahmkow2020-02-1119-71/+76
| |
* | Merge pull request #3400 from makigumo/patch-1bunnei2020-02-141-2/+4
|\ \ | | | | | | update hwopus DecodeInterleaved for FW 7.0.0+
| * | update hwopus DecodeInterleaved for FW 7.0.0+makigumo2020-02-111-2/+4
| |/ | | | | | | trivial change, see https://switchbrew.org/wiki/Audio_services#IHardwareOpusDecoder
* | address_arbiter: Collapse loops in InsertThread() and RemoveThread()Lioncash2020-02-121-19/+17
| | | | | | | | | | Same behavior, but without the need to explicitly loop through everything manually.
* | address_arbiter: Simplify GetThreadsWaitingOnAddress()Lioncash2020-02-122-10/+9
| | | | | | | | | | Simplifies the overall function and also allows for it to become a const-qualified member function.
* | Merge pull request #3403 from lioncash/debugbunnei2020-02-121-2/+2
|\ \ | | | | | | bcat/backend: Prevent fmt exception in debug log within NullBackend::Clear()
| * | bcat/backend: Make formatting of passphrase consistent in NullBackend::SetPassphrase()Lioncash2020-02-121-1/+1
| | | | | | | | | | | | | | | Aligns the '=' to be consistent with the rest of the logs within this source file.
| * | bcat/backend: Prevent fmt exception in debug log within NullBackend::Clear()Lioncash2020-02-121-1/+1
| |/ | | | | | | | | A formatting specifier within Clear wasn't being used, which will cause fmt to throw an exception. This fixes that.
* / kernel/thread: Remove trivial usages of the global system accessorLioncash2020-02-121-2/+2
|/ | | | | We can just use the kernel member variable directly instead of going through the system to obtain the same thing.
* hle: services: Use std::shared_ptr instead of copy by value.bunnei2020-02-089-50/+52
|
* Merge pull request #3381 from bunnei/ipc-fixbunnei2020-02-072-23/+57
|\ | | | | hle: services: Fix prepo IPC, and add better error checking.
| * services: prepo: Fix IPC interface with SaveReport/SaveReportWithUser.bunnei2020-02-061-15/+15
| |
| * hle_ipc: Add error checking to read/write buffer access.bunnei2020-02-061-8/+42
| |
* | kernel: transfer_memory: Properly reserve and reset memory region.bunnei2020-02-065-40/+116
| |
* | wait_object: Make wait behavior only require one object to signal.Zach Hilman2020-02-061-11/+2
| | | | | | | | - This was holdover from citra.
* | am: Correct IPC object count mismatch.bunnei2020-02-061-6/+4
| |
* | services: am: Clear events on PopOutData and PopInteractiveOutData.bunnei2020-02-061-0/+2
| |
* | am: Refactor IStorage interface.bunnei2020-02-067-43/+81
| |
* | applets: software_keyboard: Signal state change on end of interactive session.bunnei2020-02-061-0/+1
| |
* | applets: software_keyboard: Minor cleanup.bunnei2020-02-061-2/+2
|/
* Merge pull request #3284 from CJBok/hid-fixbunnei2020-02-011-13/+26
|\ | | | | hid: Fix analog sticks directional states
| * Moved analog direction logic to sdl_implCJBok2020-01-151-9/+22
| |
| * Corrected directional states sensitivityCJBok2020-01-141-9/+9
| |
| * hid: Fix analog sticks directional statesCJBok2020-01-091-12/+12
| |
* | kernel/physical_core: Make use of std::unique_ptrLioncash2020-01-312-4/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | shared_ptr was used in 2d1984c20c75e03ec79eeb3806b12efa1679b977 due to a misunderstanding of how the language generates move constructors and move assignment operators. If a destructor is user-provided, then the compiler won't generate the move constructor and move assignment operators by default--they must be explicitly opted into. The reason for the compilation errors is due to the fact that the language will fall back to attempting to use the copy constructor/copy assignment operators if the respective move constructor or move assignment operator is unavailable. Given that we explicitly opt into them now, the the move constructor and move assignment operators will be generated as expected.
* | kernel/physical_core: Remove unused kernel reference member variableLioncash2020-01-313-11/+7
| | | | | | | | | | | | | | This isn't used within the class, so it can be removed to simplify the overall interface. While we're in the same area, we can simplify a unique_ptr reset() call.
* | Merge pull request #3353 from FernandoS27/ariesbunnei2020-01-319-9/+198
|\ \ | | | | | | System: Refactor CPU Core management and move ARMInterface and Schedulers to Kernel
| * | System: Address FeedbackFernando Sahmkow2020-01-274-10/+20
| | |
| * | Kernel: Remove a few global instances from the kernel.Fernando Sahmkow2020-01-262-2/+2
| | |
| * | Core: Refactor CpuCoreManager to CpuManager and Cpu to Core Manager.Fernando Sahmkow2020-01-265-6/+2
| | | | | | | | | | | | This commit instends on better naming the new purpose of this classes.
| * | ArmInterface: Delegate Exclusive monitor factory to exclusive monitor interfasce.Fernando Sahmkow2020-01-261-15/+2
| | |
| * | Core: Refactor CPU Management.Fernando Sahmkow2020-01-254-12/+127
| | | | | | | | | | | | This commit moves ARM Interface and Scheduler handling into the kernel.
| * | Kernel: Implement Physical Core.Fernando Sahmkow2020-01-242-0/+81
| | |
* | | bsd: Stub several more functions.bunnei2020-01-252-4/+48
|/ / | | | | | | - Required for Little Town Hero to boot further.
* | service: time: Implement ToPosixTimeWithMyRule.bunnei2020-01-234-1/+34
| | | | | | | | - Used by Pokemon Mystery Dungeon.
* | time: Fix month off-by-one error.bunnei2020-01-201-2/+2
| | | | | | | | - Fixes timestamp in ZLA and Astral Chain saves.
* | Merge pull request #3271 from bunnei/time-rewritebunnei2020-01-2039-533/+2962
|\ \ | | | | | | service: time: Rewrite implementation of glue services.
| * | service: time: Implement GetStandardLocalSystemClock.bunnei2020-01-053-1/+9
| | |
| * | time: Remove overflow error checking (currently breaks ADO builds).bunnei2020-01-042-18/+2
| | |
| * | service: time: Implement GetClockSnapshotFromSystemClockContext.bunnei2020-01-043-3/+27
| | |
| * | service: time: Implement IsStandardNetworkSystemClockAccuracySufficient.bunnei2020-01-045-1/+51
| | |
| * | service: time: Rewrite implementation of glue services.bunnei2020-01-0434-444/+2806
| | |
| * | core: Initialize several structs that make use of Common::UUID.bunnei2020-01-045-100/+101
| | |
* | | core/memory: Create a special MapMemoryRegion for physical memory.Markus Wick2020-01-182-3/+5
| | | | | | | | | | | | This allows us to create a fastmem arena within the memory.cpp helpers.
* | | core/hle: Simplify PhysicalMemory usage in vm_manager.Markus Wick2020-01-181-23/+11
| | |
* | | core/kernel: Fix GetTotalPhysicalMemoryUsed.Markus Wick2020-01-111-2/+2
| |/ |/| | | | | | | | | | | | | | | module._memory was already moved over to a new shared_ptr. So code_memory_size was not increased at all. This lowers the heap space and so saves a bit of memory, usually between 50 to 100 MB. This fixes a regression of c0a01f3adc466d07fc27020048e82cca60988970
* | Merge pull request #3272 from bunnei/vi-close-layerbunnei2020-01-075-11/+48
|\ \ | | | | | | service: vi: Implement CloseLayer.
| * | service: vi: Implement CloseLayer.bunnei2020-01-045-11/+48
| |/ | | | | | | - Needed for Undertale.
* | Merge pull request #3257 from degasus/no_busy_loopsbunnei2020-01-061-1/+1
|\ \ | | | | | | video_core: Block in WaitFence.
| * | video_core: Block in WaitFence.Markus Wick2019-12-301-1/+1
| | | | | | | | | | | | | | | | | | | | | This function is called rarely and blocks quite often for a long time. So don't waste power and let the CPU sleep. This might also increase the performance as the other cores might be allowed to clock higher.
* | | Merge pull request #2945 from FernandoS27/fix-bcatbunnei2020-01-051-3/+17
|\ \ \ | |_|/ |/| | nifm: Only return that there's an internet connection when there's a BCATServer
| * | nifm: Only return that there's an internet connection when there's a BCATServerFernando Sahmkow2019-11-071-3/+17
| | | | | | | | | | | | | | | This helps games that need internet for other purposes boot as the rest of our internet infrastructure is incomplete.
* | | NvServices: Correct Ioctl Remap.Fernando Sahmkow2019-12-252-3/+5
| |/ |/| | | | | | | This commit corrects a padding value in Ioctl Remap that was actually an offset to the mapping address.
* | Merge pull request #3214 from lioncash/svc-funcbunnei2019-12-132-9/+6
|\ \ | | | | | | kernel/svc: Amend function signature of SignalProcessWideKey
| * | kernel/svc: Correct function signature of SignalProcessWideKeyLioncash2019-12-112-9/+6
| | | | | | | | | | | | | | | This function doesn't actually return a result code, so we can amend the signature of it to match.
* | | Kernel: Correct behavior of Address Arbiter threads. (#3165)Fernando Sahmkow2019-12-113-24/+67
|/ / | | | | | | | | | | | | | | | | | | | | * Kernel: Correct behavior of Address Arbiter threads. This corrects arbitration threads to behave just like in Horizon OS. They are added into a container and released according to what priority they had when added. Horizon OS does not reorder them if their priority changes. * Kernel: Address Feedback.
* | Merge pull request #3201 from lioncash/dumpbunnei2019-12-112-2/+24
|\ \ | | | | | | kernel/svc: Provide implementations for svcDumpInfo/svcDumpInfoNew
| * | kernel/svc: Provide implementations for svcDumpInfo/svcDumpInfoNewLioncash2019-12-082-2/+24
| | | | | | | | | | | | | | | | | | | | | | | | | | | These are fairly trivial to implement, we can just do nothing. This also provides a spot for us to potentially dump out any relevant info in the future (e.g. for debugging purposes with homebrew, etc). While we're at it, we can also correct the names of both of these supervisor calls.
* | | kernel: Remove unnecessary includesLioncash2019-12-0815-11/+17
|/ / | | | | | | | | | | Over the course of the changes to the kernel code, a few includes are no longer necessary, particularly with the change over to std::shared_ptr from Boost's intrusive_ptr.
* | CpuCore: Clear exclusive state after doing a run in dynarmic.Fernando Sahmkow2019-12-051-1/+0
| | | | | | | | | | | | This commit corrects an error in which a Core could remain with an exclusive state after running, leaving space for possible race conditions between changing cores.
* | kernel: Implement a more accurate IPC dispatch.bunnei2019-11-2818-167/+245
| |
* | Merge pull request #3169 from lioncash/memorybunnei2019-11-2817-89/+133
|\ \ | | | | | | core/memory: Deglobalize memory management code
| * | core/memory; Migrate over SetCurrentPageTable() to the Memory classLioncash2019-11-271-7/+11
| | | | | | | | | | | | | | | | | | | | | Now that literally every other API function is converted over to the Memory class, we can just move the file-local page table into the Memory implementation class, finally getting rid of global state within the memory code.
| * | core/memory: Migrate over Write{8, 16, 32, 64, Block} to the Memory classLioncash2019-11-274-21/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | The Write functions are used slightly less than the Read functions, which make these a bit nicer to move over. The only adjustments we really need to make here are to Dynarmic's exclusive monitor instance. We need to keep a reference to the currently active memory instance to perform exclusive read/write operations.
| * | core/memory: Migrate over Read{8, 16, 32, 64, Block} to the Memory classLioncash2019-11-278-33/+50
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | With all of the trivial parts of the memory interface moved over, we can get right into moving over the bits that are used. Note that this does require the use of GetInstance from the global system instance to be used within hle_ipc.cpp and the gdbstub. This is fine for the time being, as they both already rely on the global system instance in other functions. These will be removed in a change directed at both of these respectively. For now, it's sufficient, as it still accomplishes the goal of de-globalizing the memory code.
| * | core/memory: Migrate over ReadCString() to the Memory classLioncash2019-11-271-2/+4
| | | | | | | | | | | | | | | This only had one usage spot, so this is fairly straightforward to convert over.
| * | core/memory: Migrate over GetPointer()Lioncash2019-11-271-1/+2
| | | | | | | | | | | | | | | With all of the interfaces ready for migration, it's trivial to migrate over GetPointer().
| * | core: Prepare various classes for memory read/write migrationLioncash2019-11-278-17/+32
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Amends a few interfaces to be able to handle the migration over to the new Memory class by passing the class by reference as a function parameter where necessary. Notably, within the filesystem services, this eliminates two ReadBlock() calls by using the helper functions of HLERequestContext to do that for us.
| * | core/memory: Migrate over address checking functions to the new Memory classLioncash2019-11-273-8/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | A fairly straightforward migration. These member functions can just be mostly moved verbatim with minor changes. We already have the necessary plumbing in places that they're used. IsKernelVirtualAddress() can remain a non-member function, since it doesn't rely on class state in any form.
| * | core/memory: Migrate over memory mapping functions to the new Memory classLioncash2019-11-271-6/+7
| | | | | | | | | | | | | | | | | | Migrates all of the direct mapping facilities over to the new memory class. In the process, this also obsoletes the need for memory_setup.h, so we can remove it entirely from the project.
* | | Merge pull request #3170 from lioncash/enumbunnei2019-11-281-2/+2
|\ \ \ | |/ / |/| | file_sys/directory: Make EntryType an enum class
| * | file_sys/directory: Make EntryType an enum classLioncash2019-11-271-2/+2
| | | | | | | | | | | | | | | This can trivially be an enum class rather than a regular enum, making it more strongly typed.
* | | core_timing: Use better reference tracking for EventType. (#3159)bunnei2019-11-276-14/+14
|/ / | | | | | | | | | | | | * core_timing: Use better reference tracking for EventType. - Moves ownership of the event to the caller, ensuring we don't fire events for destroyed objects. - Removes need for unique names - we won't be using this for save states anyways.
* | kernel: Fix reference management for client/server session.bunnei2019-11-263-20/+18
| | | | | | | | - Fixes shutdown crash and crash in Pokemon SwSh.
* | Merge pull request #3094 from lioncash/tablesbunnei2019-11-2533-7/+192
|\ \ | | | | | | service: Update function tables
| * | service: Update function tablesLioncash2019-11-1233-7/+192
| |/ | | | | | | | | | | Keeps the function tables up to date. Updated based off information from Switchbrew.
* | kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. (#3154)bunnei2019-11-2569-364/+364
| | | | | | | | | | | | * kernel: Replace usage of boost::intrusive_ptr with std::shared_ptr for kernel objects. - See https://github.com/citra-emu/citra/pull/4710 for details.
* | Update svc.cppbunnei2019-11-231-0/+1
| |
* | svc: GetSystemTick should return cntpct_el0, not core ticks.bunnei2019-11-231-1/+3
| |
* | Merge pull request #3114 from FernandoS27/cond-varbunnei2019-11-235-22/+74
|\ \ | | | | | | Kernel: Correct behavior of Condition Variables to be more similar to real hardware.
| * | Kernel: Optimize condition variable threads management.Fernando Sahmkow2019-11-214-24/+21
| | |
| * | Kernel: Correct SignalProcessWideKeyFernando Sahmkow2019-11-211-6/+2
| | | | | | | | | | | | When the target is 0, all threads must be processed.
| * | Kernel: Correct behavior of Condition Variables to be more similar to real hardware.Fernando Sahmkow2019-11-215-15/+74
| | | | | | | | | | | | | | | | | | | | | This commit ensures cond var threads act exactly as they do in the real console. The original implementation uses an RBTree and the behavior of cond var threads is that at the same priority level they act like a FIFO.
* | | Merge pull request #3130 from FernandoS27/cancel-syncbunnei2019-11-233-2/+19
|\ \ \ | | | | | | | | Kernel: Correct Cancel Synchronization.
| * | | Kernel: Correct Cancel Synchronization.Fernando Sahmkow2019-11-163-2/+19
| | | | | | | | | | | | | | | | | | | | | | | | This commit corrects the behavior of cancel synchronization when the thread is running/ready and ensures the next wait is cancelled as it's suppose to.
* | | | Merge pull request #3112 from lioncash/skipbunnei2019-11-211-8/+16
|\ \ \ \ | | | | | | | | | | service/am: Remove unnecessary Skip calls
| * | | | service/am: Remove unnecessary Skip callsLioncash2019-11-141-8/+16
| |/ / / | | | | | | | | | | | | | | | | We can simplify these by wrapping the necessary members in structs and then simply reading out the whole struct.
* | | | Merge pull request #3111 from lioncash/querybunnei2019-11-212-5/+14
|\ \ \ \ | |_|/ / |/| | | am: Stub QueryApplicationPlayStatistics
| * | | am: Stub QueryApplicationPlayStatisticsLioncash2019-11-142-5/+14
| |/ / | | | | | | | | | | | | | | | | | | | | | Maintains implementation parity between QueryApplicationPlayStatistics and QueryApplicationPlayStatisticsByUid. These function the same behaviorally underneath the hood, with the only difference being that one allows specifying a UID.
* | | Merge pull request #3091 from lioncash/core-conversionbunnei2019-11-1520-131/+124
|\ \ \ | |/ / |/| | core: Make most implicit type conversion warnings errors on MSVC
| * | service: Resolve sign conversion errorsLioncash2019-11-1215-58/+55
| | | | | | | | | | | | | | | These are fairly trivial to resolve and most of the changes entail using RESULT_UNKNOWN over ResultCode(-1).
| * | kernel: Resolve sign conversion warningsLioncash2019-11-124-72/+60
| | | | | | | | | | | | | | | | | | | | | | | | | | | Uncovered a bug within Thread's SetCoreAndAffinityMask() where an unsigned variable (ideal_core) was being compared against "< 0", which would always be a false condition. We can also get rid of an unused function (GetNextProcessorId) which contained a sign mismatch warning.
| * | result: Add default error code for the ResultCode(-1) caseLioncash2019-11-121-1/+9
| | | | | | | | | | | | | | | Will be used to reduce the overall duplication of the same magic value all over the codebase in following changes.
| * | result: Resolve sign-coversion warningsLioncash2019-11-121-1/+1
| |/ | | | | | | | | The constructor was implicitly using signed->unsigned conversions to produce 0xFFFFFFFF. We can just specify this explicitly with UINT32_MAX.
* | Merge pull request #3089 from SciresM/play_statisticsbunnei2019-11-142-0/+10
|\ \ | | | | | | Implement stub for IApplicationFunctions::QueryApplicationPlayStatisticsByUid
| * | Implement stub for QueryApplicationPlayStatisticsByUidMichael Scire2019-11-112-0/+10
| |/
* / core: Migrate off deprecated mbedtls functionsLioncash2019-11-123-3/+3
|/ | | | | These functions are marked for deprecation and it's recommended that the *_ret variants be used instead.
* Merge pull request #3062 from bunnei/event-improvebunnei2019-11-0623-87/+53
|\ | | | | kernel: Improve events
| * kernel: readable_event: Signal only once.bunnei2019-11-031-2/+4
| |
| * kernel: events: Remove ResetType::Automatic.bunnei2019-11-0323-84/+48
| | | | | | | | | | | | | | | | - This does not actually seem to exist in the real kernel - games reset these automatically. # Conflicts: # src/core/hle/service/am/applets/applets.cpp # src/core/hle/service/filesystem/fsp_srv.cpp
| * kernel: readable_event: Initialize members.bunnei2019-11-031-1/+1
| |
* | Merge pull request #2859 from Morph1984/hidDavid2019-11-062-92/+126
|\ \ | | | | | | hid: Stub SetNpadJoyAssignmentModeSingle and GetNpadHandheldActivationMode
| * | hid: Stub SetNpadJoyAssignmentModeSingle and reorganize service commandsMorph2019-10-072-92/+126
| | |
* | | common_func: Use std::array for INSERT_PADDING_* macros.bunnei2019-11-043-8/+11
| | | | | | | | | | | | - Zero initialization here is useful for determinism.
* | | core/am: Stub InitializeApplicationCopyrightFrameBuffer, SetApplicationCopyrightImage and SetApplicationCopyrightVisibilityFearlessTobi2019-11-032-3/+31
| |/ |/| | | | | These commands require Screenshots to be implemented anyway, so they are safe to stub for now.
* | scheduler: Mark parameter of AskForReselectionOrMarkRedundant() as constLioncash2019-10-282-5/+5
| | | | | | | | This is only compared against, so it can be made const.
* | scheduler: Silence sign conversion warningsLioncash2019-10-281-5/+5
| |
* | scheduler: Initialize class members directly where applicableLioncash2019-10-282-6/+4
| | | | | | | | Reduces the overall amount of code.
* | scheduler: Amend documentation commentsLioncash2019-10-282-75/+59
| | | | | | | | | | Adjusts the formatting of a few of the comments an ensures they get recognized as proper Doxygen comments.
* | Merge pull request #2971 from FernandoS27/new-scheduler-v2David2019-10-2811-398/+955
|\ \ | | | | | | Kernel: Implement a New Thread Scheduler V2
| * | Kernel Thread: Cleanup THREADPROCESSORID_DONT_UPDATE.Fernando Sahmkow2019-10-152-4/+1
| | |
| * | Kernel: Address Feedback 2Fernando Sahmkow2019-10-152-9/+6
| | |
| * | Kernel: Clang FormatFernando Sahmkow2019-10-152-5/+5
| | |
| * | Kernel: Reverse global accessor removal.Fernando Sahmkow2019-10-154-23/+9
| | |
| * | Kernel: Address Feedback.Fernando Sahmkow2019-10-156-67/+98
| | |
| * | Kernel Scheduler: Make sure the global scheduler shutdowns correctly.Fernando Sahmkow2019-10-153-0/+17
| | |
| * | Kernel_Thread: Eliminate most global accessors.Fernando Sahmkow2019-10-151-11/+11
| | |
| * | KernelSVC: Assert that condition variable address is aligned to 4 bytes.Fernando Sahmkow2019-10-151-0/+4
| | |
| * | Kernel: Correct Paused schedulingFernando Sahmkow2019-10-151-3/+1
| | |
| * | Kernel: Corrections to Wait Objects clearing in which a thread could still be signalled after a timeout or a cancel.Fernando Sahmkow2019-10-153-3/+4
| | |
| * | Kernel: Correct redundant yields to only advance time forward.Fernando Sahmkow2019-10-151-3/+5
| | |
| * | Kernel: Corrections to ModifyByWaitingCountAndSignalToAddressIfEqualFernando Sahmkow2019-10-151-5/+13
| | |
| * | Kernel: Correct Results in Condition Variables and MutexesFernando Sahmkow2019-10-153-24/+17
| | |
| * | Kernel: Clang FormatFernando Sahmkow2019-10-152-2/+3
| | |
| * | Kernel: Remove global system accessor from WaitObjectFernando Sahmkow2019-10-154-2/+17
| | |
| * | Scheduler: Implement Yield Count and Core migration on Thread Preemption.Fernando Sahmkow2019-10-152-5/+85
| | |
| * | Scheduler: Corrections to YieldAndBalanceLoad and Yield bombing protection.Fernando Sahmkow2019-10-152-8/+8
| | |
| * | Kernel: Initial implementation of thread preemption.Fernando Sahmkow2019-10-153-0/+30
| | |
| * | Scheduler: Add protections for Yield bombingFernando Sahmkow2019-10-155-24/+31
| | | | | | | | | | | | | | | | | | In case of redundant yields, the scheduler will now idle the core for it's timeslice, in order to avoid continuously yielding the same thing over and over.
| * | Kernel: Style and CorrectionsFernando Sahmkow2019-10-158-90/+130
| | |
| * | Correct PrepareRescheduleFernando Sahmkow2019-10-153-37/+20
| | |
| * | Comment and reorganize the schedulerFernando Sahmkow2019-10-152-98/+104
| | |
| * | Add PrepareReschedule where required.Fernando Sahmkow2019-10-153-16/+18
| | |
| * | Correct compiling errors and addapt to the new interface.Fernando Sahmkow2019-10-151-4/+1
| | |
| * | Correct Supervisor Calls to work with the new scheduler,Fernando Sahmkow2019-10-151-26/+41
| | |
| * | Add interfacing to the Global SchedulerFernando Sahmkow2019-10-152-0/+17
| | |
| * | Addapt thread class to the new SchedulerFernando Sahmkow2019-10-152-60/+237
| | |
| * | Implement a new Core SchedulerFernando Sahmkow2019-10-152-258/+411
| | |
* | | Merge pull request #2991 from lioncash/npadbunnei2019-10-232-51/+23
|\ \ \ | | | | | | | | hid/npad: Minor cleanup
| * | | hid/npad: Fix incorrect connection boolean value in ConnectAllDisconnectedControllers()Lioncash2019-10-181-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | We should be setting the connection state to true, otherwise we aren't actually making the controllers connected like the function name indicates.
| * | | hid/npad: Add missing break in default caseLioncash2019-10-181-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | While not an issue, it does prevent fallthrough from occurring if anything is ever added after this case (unlikely to occur, but this turns a trivial "should not cause issues" into a definite "won't cause issues).
| * | | hid/npad: Replace std::for_each with ranged for loopsLioncash2019-10-181-13/+12
| | | | | | | | | | | | | | | | | | | | | | | | Performs the same behavior, but is built into the core language itself. No functional change.
| * | | hid/npad: Remove redundant non-const variant of IsControllerSupported()Lioncash2019-10-182-34/+5
| | | | | | | | | | | | | | | | | | | | | | | | The const qualified variant can also be called in non-const contexts, so we can remove the non-const variant to eliminate a bit of code duplication.
| * | | hid/npad: Move function declarationsLioncash2019-10-181-5/+6
| | | | | | | | | | | | | | | | | | | | Clearly separate these from the variable declarations to make them more visible.
* | | | apm/controller: Make SetPerformanceConfiguration() use an array of pairs over a mapLioncash2019-10-171-14/+34
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While a map is an OK way to do lookups (and usually recommended in most cases), this is a map that lives for the entire duration of the program and only deallocates its contents when the program terminates. Given the total size of the map is quite small, we can simply use a std::array of pairs and utilize std::find_if to perform the same behavior without loss of performance. This eliminates a static constructor and places the data into the read-only segment. While we're at it, we can also handle malformed inputs instead of directly dereferencing the resulting iterator.
* | | | apm/controller: Make GetCurrentPerformanceMode() a const member functionLioncash2019-10-172-2/+2
|/ / / | | | | | | | | | This doesn't modify instance state, so it can be made const qualified.
* | | Merge pull request #2912 from FernandoS27/async-fixesbunnei2019-10-165-28/+27
|\ \ \ | | | | | | | | General fixes to Async GPU
| * | | NvFlinger: Remove leftover from corrections and clang format.Fernando Sahmkow2019-10-051-4/+0
| | | |
| * | | Nvdrv: Correct Event setup in NvdrvFernando Sahmkow2019-10-052-23/+14
| | | | | | | | | | | | | | | | Events are supposed to be cleared on quering. This fixes that issue.
| * | | NVFlinger: Reverse the change that only signaled events on buffer acquire.Fernando Sahmkow2019-10-052-20/+1
| | | | | | | | | | | | | | | | | | | | This has been hardware tested and it seems that NVFlinger will still signal even if there are no buffers to present.
| * | | Nvdrv: Do framelimiting only in the CPU ThreadFernando Sahmkow2019-10-051-0/+4
| | | |
| * | | NvFlinger: Don't swap buffers if a frame is missing and always trigger event in sync gpu.Fernando Sahmkow2019-10-051-1/+3
| | | |
| * | | GPU_Async: Correct fences, display events and more.Fernando Sahmkow2019-10-052-2/+21
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit uses guest fences on vSync event instead of an articial fake fence we had. It also corrects to keep signaling display events while loading the game as the OS is suppose to send buffers to vSync during that time.
| * | | Nvdrv: Correct Async regression and avoid signaling empty buffer vsyncsFernando Sahmkow2019-10-052-3/+9
| | | |
* | | | Merge pull request #2972 from lioncash/systembunnei2019-10-159-33/+63
|\ \ \ \ | |_|/ / |/| | | {bcat, gpu, nvflinger}: Remove trivial usages of the global system accessor
| * | | bcat: Remove use of global system accessorsLioncash2019-10-156-29/+55
| | | | | | | | | | | | | | | | | | | | Removes all uses of the global system accessor within the BCAT interface.
| * | | nvflinger/buffer_queue: Remove use of a global system accessorLioncash2019-10-123-4/+8
| | | |
* | | | pl_u: Fix mismatched rebase size error in font encryptionZach Hilman2019-10-132-11/+11
| | | |
* | | | pl_u: Use kernel physical memoryZach Hilman2019-10-131-0/+1
| | | |
* | | | pl_u: Remove excess static qualifierZach Hilman2019-10-131-1/+1
| | | |
* | | | pl_u: Use OSS system archives if real archives don't existZach Hilman2019-10-131-110/+47
|/ / /
* | | Merge pull request #2921 from FreddyFunk/compiler-warnings-corebunnei2019-10-091-6/+6
|\ \ \ | | | | | | | | Services::ES fix casting warnings
| * | | Services::ES fix casting warningsFreddyFunk2019-09-291-6/+6
| | | |
* | | | Merge pull request #2654 from DarkLordZach/lm-log-rewritebunnei2019-10-095-156/+278
|\ \ \ \ | | | | | | | | | | lm: Rewrite logger to use core reporting services
| * | | | lm: Flush manager output on core shutdownZach Hilman2019-09-222-5/+11
| | | | |
| * | | | lm: Rename Initialize to Log and implement with manager/reporterZach Hilman2019-09-221-140/+22
| | | | | | | | | | | | | | | Allows saving and clearer output of data.
| * | | | lm: Implement manager class to output to reporterZach Hilman2019-09-222-0/+233
| | | | |
| * | | | core: Add LM::Manager to systemZach Hilman2019-09-223-16/+17
| |/ / / | | | | | | | | Allows centralized control over logging mechanisms.
* | | / hid: Implement DeactivateNpadMorph2019-10-072-1/+13
| |_|/ |/| | | | | | | | Makes use of the already existing DeactivateController function.
* | | Merge pull request #2951 from lioncash/globalZach Hilman2019-10-0711-44/+66
|\ \ \ | | | | | | | | core: Remove Core::CurrentProcess()
| * | | core: Remove Core::CurrentProcess()Lioncash2019-10-061-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | This only encourages the use of the global system instance (which will be phased out long-term). Instead, we use the direct system function call directly to remove the appealing but discouraged short-hand.
| * | | hle/service: Replace global system instance calls with instance-based onesLioncash2019-10-0610-43/+65
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Migrates the HLE service code off the use of directly accessing the global system instance where trivially able to do so. This removes all usages of Core::CurrentProcess from the service code, only 8 occurrences of this function exist elsewhere. There's still quite a bit of "System::GetInstance()" being used, however this was able to replace a few instances.
* | | | bcat/module: Silence truncation warningsLioncash2019-10-061-3/+3
| | | | | | | | | | | | | | | | | | | | We need to perform explicit casts here, otherwise we're implicitly truncating a 64-bit type to a 32-bit one.
* | | | bcat: Take std::function instance by value in NullBackend's constructorLioncash2019-10-062-2/+2
| | | | | | | | | | | | | | | | | | | | Without this, the std::move within the constructor initializer list won't be able to actually perform a move.
* | | | bcat: In-class initialize ProgressServiceBackend's impl memberLioncash2019-10-062-2/+2
| | | | | | | | | | | | | | | | Allows us to remove a constructor initializer list.
* | | | bcat: Make ProgressServiceBackend's constructor take a std::string_viewLioncash2019-10-062-3/+7
| | | | | | | | | | | | | | | | | | | | Given the string is appended to another, we can make it a view so a redundant full copy of the string isn't made.
* | | | bcat: Make ProgressServiceBackend's GetEvent() constLioncash2019-10-062-2/+2
| | | | | | | | | | | | | | | | | | | | This member function doesn't modify internal member state, so it can be marked const.
* | | | boxcat: Silence an unused variable warningLioncash2019-10-061-1/+2
|/ / / | | | | | | | | | | | | | | | On parse errors, we can log out the explanatory string indicating what the parsing error was, rather than just ignoring the variable and returning an overly broad error code.
* | | audio/audout_u: Change formatting for old clang-format versionsReinUsesLisp2019-10-051-1/+1
| | |
* | | service/nvdrv: Silence -WswitchReinUsesLisp2019-10-054-4/+10
| | |
* | | service/nfp: Silence -Wunused and -WswitchReinUsesLisp2019-10-051-4/+5
| | |
* | | service/hid: Silence -Wunused and -WswitchReinUsesLisp2019-10-0515-23/+18
| | |
* | | service/am: Silence -WreorderReinUsesLisp2019-10-051-2/+1
| | |
* | | service/hid: Remove unused system referenceReinUsesLisp2019-10-052-2/+1
| | |
* | | service/friend: Remove unused fieldReinUsesLisp2019-10-051-1/+0
| | |
* | | service/filesystem: Silence -Wunused-variableReinUsesLisp2019-10-051-1/+1
| | |
* | | service/bcat: Silence -Wreorder and -WunusedReinUsesLisp2019-10-052-2/+2
| | |
* | | service/audio: Silence -WunusedReinUsesLisp2019-10-051-1/+1
| | |
* | | service/apm: Silence -Wunused and -WreorderReinUsesLisp2019-10-052-4/+5
| |/ |/|
* | Merge pull request #2539 from DarkLordZach/bcatDavid2019-10-0316-40/+1497
|\ \ | | | | | | bcat: Implement BCAT service and connect to yuzu Boxcat server
| * | qt: Add service dialogZach Hilman2019-10-021-6/+5
| | |
| * | boxcat: Use updated game-asset API URL and tagsZach Hilman2019-10-011-6/+6
| | |
| * | bcat: Add FSC accessors for BCAT dataZach Hilman2019-10-0110-31/+51
| | | | | | | | | Ports BCAT to use FSC interface
| * | boxcat: Implement events global fieldZach Hilman2019-09-303-12/+14
| | |
| * | bcat: Implement DeliveryCacheProgressImpl structureZach Hilman2019-09-305-84/+310
| | | | | | | | | Huge thanks to lioncash for re-ing this for me.
| * | boxcat: Use Etag header names for file digestZach Hilman2019-09-301-10/+11
| | |
| * | boxcat: Add downloading and client for launch parameter dataZach Hilman2019-09-302-16/+77
| | |
| * | bcat: Add backend function for BCAT Indirect (launch parameter)Zach Hilman2019-09-302-0/+11
| | | | | | | | | | | | Returns the data that should be returned by PopLaunchParameter kind=ApplicationSpecific.
| * | bcat: Expose CreateBackendFromSettings helper functionZach Hilman2019-09-302-2/+2
| | |
| * | am: Unstub PopLaunchParameter and add bcat connection for app-specific dataZach Hilman2019-09-302-16/+52
| | | | | | | | | | | | Previously we were simply returning the account-preselect structure all times but if passed with a different mode the game expects application-specific data. This also adds a hook for BCAT into this allowing us to send the launch parameter through bcat,
| * | bcat: Implement cmd 90201 ClearDeliveryCacheStorageZach Hilman2019-09-301-1/+23
| | | | | | | | | | | | Takes a title ID and simply deletes all the data for that title ID's bcat. Invokes the respective backend command.
| * | bcat: Implement cmd 30100 SetPassphraseZach Hilman2019-09-301-1/+33
| | | | | | | | | | | | Takes a title ID and passphrase (0x40 byte string) and passes it to the backend.
| * | bcat: Implement cmd RequestSyncDeliveryCache and variantZach Hilman2019-09-301-2/+70
| | | | | | | | | | | | Variant also supports only updating a single directory. These just both invoke backend commands.
| * | bcat: Implement IDeliveryCacheProgressService commandsZach Hilman2019-09-301-0/+131
| | | | | | | | | | | | Used to query completion status and events for the current delivery task.
| * | bcat: Implement IDeliveryCacheFileService commandsZach Hilman2019-09-301-0/+117
| | | | | | | | | | | | Used to read the contents of files and access their metadata.
| * | bcat: Implement IDeliveryCacheDirectoryService commandsZach Hilman2019-09-301-0/+99
| | | | | | | | | | | | Used to list and get directories at the root level.
| * | bcat: Implement IDeliveryCacheStorageService commandsZach Hilman2019-09-301-0/+58
| | | | | | | | | | | | Used to create subclasses to manage files and directories and to list directories.
| * | bcat: Add commands to create IDeliveryCacheStorageServiceZach Hilman2019-09-303-2/+32
| | | | | | | | | | | | Used to access contents of download.
| * | module: Create BCAT backend based upon Settings value on constructionZach Hilman2019-09-302-1/+16
| | |
| * | bcat: Add BCAT backend for Boxcat serviceZach Hilman2019-09-302-0/+407
| | | | | | | | | | | | Downloads content from yuzu servers and unpacks it into the temporary directory provided. Fully supports all Backend features except passphrase.
| * | bcat: Add backend class to generify the functions of BCATZach Hilman2019-09-302-0/+100
| | | | | | | | | | | | Provides the most abstract simplified functions of BCAT as functions. Also includes a NullBackend class which is just a no-op.
| * | nifm: Signal to applications that internet access is availableZach Hilman2019-09-301-3/+10
| | |
| * | applets: Add accessor for AppletFrontendSetZach Hilman2019-09-302-0/+6
| | | | | | | | | | | | Allows other services to call applets without using LLE.
| * | filesystem: Add getter for BCAT temporary directoryZach Hilman2019-09-301-0/+9
| |/
* / Signal styleset changes at a better timeDavid Marcec2019-09-241-8/+2
|/ | | | We should signal when a net controller is added and our event should be manual, not automatic.
* Merge pull request #2683 from DarkLordZach/lock-exitDavid2019-09-224-7/+33
|\ | | | | am: Implement exit locking and self exit commands
| * qt: Prompt user for confirmation if exit lock is activeZach Hilman2019-09-221-1/+1
| |
| * am: Implement ISelfController ExitLock commandsZach Hilman2019-09-221-2/+6
| |
| * am: Implement ISelfController ExitZach Hilman2019-09-224-4/+20
| | | | | | | | Closes the current application.
| * am: Add RequestExit event to AppletMessageQueueZach Hilman2019-09-222-0/+6
| | | | | | | | Tested against libnx, signals to games to begin cleanup.
* | Merge pull request #2876 from ogniK5377/AcquireNpadStyleSetUpdateEventHandle-fixZach Hilman2019-09-223-11/+18
|\ \ | | | | | | AcquireNpadStyleSetUpdateEventHandle should have a separate event for each controller type
| * | removed commentDavid Marcec2019-09-221-1/+0
| | |
| * | RebasedDavid Marcec2019-09-223-11/+19
| | |
* | | Merge pull request #2895 from FearlessTobi/debug-logsDavid2019-09-221-7/+7
|\ \ \ | | | | | | | | service/acc: Lower log severity from INFO to DEBUG
| * | | service/acc: Lower log severity from INFO to DEBUGFearlessTobi2019-09-221-7/+7
| | | | | | | | | | | | | | | | According to ogniK, this should have always been Debug and not Info.
* | | | Merge pull request #2873 from ogniK5377/new-ioctlsFernando Sahmkow2019-09-2224-73/+153
|\ \ \ \ | |_|/ / |/| | | Initial implementation of Ioctl2 & Ioctl3
| * | | server side clang format fix2David Marcec2019-09-221-18/+18
| | | |
| * | | Use clang-format provided by build serverDavid Marcec2019-09-221-20/+18
| | | |
| * | | disable clang-format tempDavid Marcec2019-09-201-0/+2
| | | |
| * | | Initial implementation of Ioctl2 & Ioctl3David Marcec2019-09-1924-63/+143
| | | | | | | | | | | | | | | | Purpose of Ioctl2 and Ioctl3 is to prevent the passing of raw pointers through ioctls
* | | | Merge pull request #2884 from ogniK5377/deglobal-sys-servicesFernando Sahmkow2019-09-2264-212/+291
|\ \ \ \ | | | | | | | | | | Remove usage of System::CurrentInterface() from most services
| * | | | removed unneeded semicolonDavid Marcec2019-09-221-1/+1
| | | | |
| * | | | Removed reference to core timing to nvflinger and used system insteadDavid Marcec2019-09-221-1/+1
| | | | |
| * | | | marked controller constructors as explicitDavid Marcec2019-09-228-8/+8
| | | | |
| * | | | RebaseDavid Marcec2019-09-2225-62/+75
| | | | |
| * | | | RebaseDavid Marcec2019-09-225-20/+21
| | | | |
| * | | | Deglobalize System: ViDavid Marcec2019-09-223-8/+8
| | | | |
| * | | | Deglobalize System: TimeDavid Marcec2019-09-224-14/+21
| | | | |
| * | | | RebaseDavid Marcec2019-09-222-8/+12
| | | | |
| * | | | Deglobalize System: NvFlingerDavid Marcec2019-09-222-6/+7
| | | | |
| * | | | RebaseDavid Marcec2019-09-224-8/+12
| | | | |
| * | | | Deglobalize System: NimDavid Marcec2019-09-222-7/+12
| | | | |
| * | | | Deglobalize System: NifmDavid Marcec2019-09-222-13/+23
| | | | |
| * | | | Deglobalize System: NFPDavid Marcec2019-09-224-14/+16
| | | | |
| * | | | Deglobalize System: LDRDavid Marcec2019-09-222-6/+7
| | | | |
| * | | | Deglobalize System: IRSDavid Marcec2019-09-223-5/+6
| | | | |
| * | | | Deglobalize System: HidDavid Marcec2019-09-2220-37/+44
| | | | |
| * | | | Deglobalize System: FriendDavid Marcec2019-09-224-22/+24
| | | | |
| * | | | Deglobalize System: FatalDavid Marcec2019-09-226-20/+29
| | | | |
| * | | | Deglobalize System: BtmDavid Marcec2019-09-222-7/+13
| | | | |
| * | | | Deglobalize System: BtdrvDavid Marcec2019-09-222-5/+9
| | | | |
| * | | | Deglobalize System: AocDavid Marcec2019-09-222-11/+13
| | | | |
| * | | | Deglobalize System: AmDavid Marcec2019-09-221-1/+1
| | | | |
* | | | | Revert "Merge pull request #2709 from DarkLordZach/oss-ext-fonts-1"David Marcec2019-09-222-50/+117
|/ / / / | | | | | | | | | | | | | | | | This reverts commit fa1c60c33ef88c6cd0b72da46842dc9098db712d, reversing changes made to e34899067b60a69bca02761bd1290c6824bb559a.
* | | | Merge pull request #2709 from DarkLordZach/oss-ext-fonts-1David2019-09-222-117/+50
|\ \ \ \ | |_|_|/ |/| | | system_archive: Move shared font data to system_archive and fix extended font data
| * | | pl_u: Use kernel physical memoryZach Hilman2019-09-221-0/+1
| | | |
| * | | pl_u: Remove excess static qualifierZach Hilman2019-09-221-1/+1
| | | |
| * | | pl_u: Use OSS system archives if real archives don't existZach Hilman2019-09-222-109/+41
| | | |
| * | | pl_u: Expose method to encrypt TTF to BFTTFZach Hilman2019-09-222-14/+14
| | |/ | |/|
* | | Merge pull request #2612 from DarkLordZach/prepo-newDavid2019-09-223-25/+84
|\ \ \ | | | | | | | | prepo: Implement New, System, and Non-User variants of SaveReport
| * | | prepo: Remove system global accessorsZach Hilman2019-09-223-15/+18
| | | |
| * | | prepo: Implement SaveReport New and System variantsZach Hilman2019-09-221-15/+71
| |/ /
* | | configure_debug: Move reporting option to loggingZach Hilman2019-09-228-14/+15
| | |
* | | filesystem: Add const qualification to various accessorsZach Hilman2019-09-213-68/+76
| | |
* | | yuzu: Port old usages of Filesystem namespace to FilesystemControllerZach Hilman2019-09-214-15/+38
| | |
* | | services: Pass FileSystemController as reference to services that need itZach Hilman2019-09-2111-20/+47
| | |
* | | am: Unstub IApplicationFunctions EnsureSaveData (20)Zach Hilman2019-09-211-8/+14
| | | | | | | | | Creates a default save data for the application given a user ID.
* | | filesystem: Pass Size Getter functions to IFileSystem for sizesZach Hilman2019-09-213-20/+31
| | |
* | | filesystem: Add FileSystemController to deglobalize FS servicesZach Hilman2019-09-212-58/+359
|/ /
* / Mark KickOffPb & SubmitGPFIFO as traceDavid Marcec2019-09-211-4/+4
|/ | | | These functions are not stubbed and are called fairly often. Due to the nature of how often they're called, we should keep them marked as LOG_TRACE instead of LOG_DEBUG or LOG_WARNING
* Merge pull request #2667 from DarkLordZach/profile-editorbunnei2019-09-145-10/+130
|\ | | | | acc: Implement IProfileEditor interface and 'Store'/'StoreWithImage' commands
| * acc_su: Implement GetProfileEditor (205)Zach Hilman2019-07-033-1/+13
| | | | | | Takes a UUID of a user and provides and interface that allows RW access to user data/settings.
| * acc: Implement IProfileEditor-specific commands 'Store' and 'StoreWithImage'Zach Hilman2019-07-031-1/+73
| | | | | | Verified with IDA
| * profile_manager: Add setter for ProfileBase and ProfileDataZach Hilman2019-07-032-0/+13
| | | | | | Needed by IProfileEditor 'Store' and 'StoreWithImage'
| * acc: Add IProfileCommon for IProfile and IProfileEditorZach Hilman2019-07-031-8/+31
| | | | | | Since 2/3 of the commands are shared, this is likely how its done on HW.
* | Merge pull request #2716 from lioncash/hle-globalDavid2019-09-0916-96/+141
|\ \ | | | | | | service/am: Remove usages of global system accessors
| * | service/am: Remove usages of global system accessorsLioncash2019-09-0516-96/+141
| | | | | | | | | | | | | | | | | | Avoids the use of global accessors, removing the reliance on global state. This also makes dependencies explicit in the interface, as opposed to being hidden
* | | Merge pull request #2763 from lioncash/map-physDavid2019-09-092-39/+41
|\ \ \ | | | | | | | | kernel/vm_manager: Minor cleanup
| * | | kernel/vm_manager: Correct doxygen comment parameter tags for MapPhysicalMemory/UnmapPhysicalMemoryLioncash2019-09-051-4/+4
| | | | | | | | | | | | | | | | | | | | Corrects the parameter names within the doxygen comments so that they resolve properly.
| * | | kernel/vm_manager: Move variables closer to usage spots in MapPhysicalMemory/UnmapPhysicalMemoryLioncash2019-09-051-16/+10
| | | | | | | | | | | | | | | | Narrows the scope of variables down to where they're only necessary.
| * | | kernel/vm_manager: Correct behavior in failure case of UnmapPhysicalMemory()Lioncash2019-08-301-0/+2
| | | | | | | | | | | | | | | | | | | | | | | | If an unmapping operation fails, we shouldn't be decrementing the amount of memory mapped and returning that the operation was successful. We should actually be returning the error code in this case.
| * | | kernel/vm_manager: Reserve memory ahead of time for slow path in MergeAdjacentVMALioncash2019-08-301-1/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids potentially expensive (depending on the size of the memory block) allocations by reserving the necessary memory before performing both insertions. This avoids scenarios where the second insert may cause a reallocation to occur.
| * | | kernel/vm_manager: std::move shared_ptr instance in MergeAdjacentVMALioncash2019-08-301-1/+1
| | | | | | | | | | | | | | | | Avoids an unnecessary atomic reference count increment and decrement.
| * | | kernel/vm_manager: Deduplicate iterator creation in MergeAdjacentVMALioncash2019-08-301-7/+10
| | | | | | | | | | | | | | | | | | | | | | | | Avoids needing to read the same long sequence of code in both code paths. Also makes it slightly nicer to read and debug, as the locals will be able to be shown in the debugger.
| * | | kernel/vm_manager: Simplify some std::vector constructor callsLioncash2019-08-301-2/+2
| | | | | | | | | | | | | | | | Same behavior, one less magic constant to read.
| * | | kernel/vm_manager: Simplify some assertion messagesLioncash2019-08-301-10/+10
| | | | | | | | | | | | | | | | | | | | Assertions already log out the function name, so there's no need to manually include the function name in the assertion strings.
* | | | Merge pull request #2418 from DarkLordZach/srv-esDavid2019-09-051-10/+220
|\ \ \ \ | |_|/ / |/| | | es: Implement various ticket accessor commands from IEticketService
| * | | key_manager: Convert Ticket union to std::variantZach Hilman2019-07-081-2/+2
| | | |
| * | | es: Populate/synthesize tickets on constructionZach Hilman2019-07-081-2/+3
| | | |
| * | | key_manager: Add structure for Ticket parsingZach Hilman2019-07-081-9/+9
| | | |
| * | | es: Implement ETicket GetPersonalizedTicketData (17)Zach Hilman2019-07-081-1/+21
| | | | | | | | | | | | Copies the raw personal ticket data into the buffer provided.
| * | | es: Implement ETicket GetCommonTicketData (16)Zach Hilman2019-07-081-1/+20
| | | | | | | | | | | | Copies the raw common ticket data for the specified rights ID into the buffer provided.
| * | | es: Implement ETicket GetPersonalizedTicketSize (15)Zach Hilman2019-07-081-1/+17
| | | | | | | | | | | | Returns the size of the buffer needed to hold the personal ticket associated with the rights ID.
| * | | es: Implement ETicket GetCommonTicketSize (14)Zach Hilman2019-07-081-1/+17
| | | | | | | | | | | | Returns the size of the buffer needed to hold the common ticket associated with the rights ID.
| * | | es: Implement ETicket ListPersonalizedTicket (12)Zach Hilman2019-07-081-1/+24
| | | | | | | | | | | | Returns an application-specific number of entries of personal tickets, starting at offset 0.
| * | | es: Implement ETicket ListCommonTicket (11)Zach Hilman2019-07-081-1/+24
| | | | | | | | | | | | Returns an application specified count of entries of common tickets, starting at offset 0.
| * | | es: Implement ETicket CountPersonalizedTicket (10)Zach Hilman2019-07-081-1/+12
| | | | | | | | | | | | Returns the number of personalized (console/user-unique) tickets in the KeyManager.
| * | | es: Implement ETicket CountCommonTicket (9)Zach Hilman2019-07-081-1/+12
| | | | | | | | | | | | Returns the number of common (non-console-unique) tickets in the KeyManager.
| * | | es: Implement ETicket GetTitleKey (8)Zach Hilman2019-07-081-1/+27
| | | | | | | | | | | | Takes a rights ID as input and returns the associated title key, if it exists.
| * | | es: Implement ETicket ImportTicket (1)Zach Hilman2019-07-081-1/+45
| | | | | | | | | | | | Takes a ticket and certificate and installs it to the KeyManager.
* | | | Merge pull request #2834 from Morph1984/audrenu_QueryAudioDeviceInputEventDavid2019-09-051-1/+15
|\ \ \ \ | | | | | | | | | | audren_u: Stub IAudioDevice::QueryAudioDeviceInputEvent
| * | | | Add Kernel::EventPair audio_input_device_switch_event;Morph19842019-09-041-0/+1
| | | | |
| * | | | audren_u: Stub IAudioDevice::QueryAudioDeviceInputEventMorph19842019-09-041-1/+14
| | |/ / | |/| |
* | | | Merge pull request #2836 from Morph1984/hid_vibrationDavid2019-09-054-2/+32
|\ \ \ \ | | | | | | | | | | hid: Implement PermitVibration and IsVibrationPermitted
| * | | | dittoMorph19842019-09-041-1/+1
| | | | | | | | | | | | | | | Co-Authored-By: David <25727384+ogniK5377@users.noreply.github.com>
| * | | | IsVibrationEnabled() as a const member funcMorph19842019-09-041-1/+1
| | | | |
| * | | | clang-formatMorph19842019-09-041-2/+2
| | | | |
| * | | | Update npad.hMorph19842019-09-041-0/+1
| | | | |
| * | | | Update npad.cppMorph19842019-09-041-0/+6
| | | | |
| * | | | Update hid.hMorph19842019-09-041-0/+2
| | | | |
| * | | | Update hid.cppMorph19842019-09-041-2/+23
| |/ / /
* | | | Merge pull request #2818 from MysticExile/fmtDavid2019-09-051-1/+1
|\ \ \ \ | | | | | | | | | | externals: update fmt to 6.0.0
| * | | | accommodate for fmt updateEthan2019-08-291-1/+1
| |/ / /
* | | | AM: Stub IApplicationFunctions::GetGpuErrorDetectedSystemEvent (#2827)mailwl2019-09-042-0/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * AM: Implement IApplicationFunctions::GetGpuErrorDetectedSystemEvent * Remove unneeded event clear * Fix event name
* | | | Merge pull request #2829 from Morph1984/audiobunnei2019-09-041-2/+15
|\ \ \ \ | | | | | | | | | | service/audio/audren_u: Stub IAudioDevice::GetAudioDeviceOutputVolume
| * | | | remove <f32>Morph19842019-09-041-1/+1
| | | | | | | | | | | | | | | We can remove this since its already a f32 value
| * | | | explicitly represent 1 as a float (1.0f instead of 1)Morph19842019-09-041-1/+1
| | | | |
| * | | | Change u32 -> f32Morph19842019-09-041-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Volume is a f32 value. (SwIPC describes it as a u32, but it is actually f32 as corroborated by switchbrew docs and SetAudioDeviceOutputVolume) ```cpp const f32 volume = rp.Pop<f32>(); ```
| * | | | service/audio/audren_u: Stub IAudioDevice::GetAudioDeviceOutputVolumeMorph19842019-09-031-2/+15
| |/ / /
* | | | Merge pull request #2708 from DarkLordZach/mii-db-source-crashDavid2019-09-041-0/+4
|\ \ \ \ | | | | | | | | | | mii: Handle logging of unknown database source
| * | | | mii: Handle logging of unknown database sourceZach Hilman2019-07-101-0/+4
| | | | |
* | | | | Merge pull request #2793 from ReinUsesLisp/bgr565bunnei2019-09-041-1/+1
|\ \ \ \ \ | |_|/ / / |/| | | | renderer_opengl: Implement RGB565 framebuffer format
| * | | | gpu: Change optional<reference_wrapper<T>> to T* for FramebufferConfigReinUsesLisp2019-08-211-1/+1
| | | | |
* | | | | Merge pull request #2748 from FernandoS27/align-memorybunnei2019-08-2110-33/+55
|\ \ \ \ \ | |/ / / / |/| | | | VM_Manager: Align allocated host physical memory to 256bytes
| * | | | Kernel: Address FeedbackFernando Sahmkow2019-07-192-3/+9
| | | | |
| * | | | VM_Manager: Align allocated memory to 256bytesFernando Sahmkow2019-07-1910-32/+48
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit ensures that all backing memory allocated for the Guest CPU is aligned to 256 bytes. This due to how gpu memory works and the heavy constraints it has in the alignment of physical memory.
* | | | | Merge pull request #2747 from lioncash/audiobunnei2019-08-187-108/+179
|\ \ \ \ \ | | | | | | | | | | | | service/audren_u: Unstub ListAudioDeviceName
| * | | | | service/audren_u: Handle audio USB output revision queries in ListAudioDeviceName()Lioncash2019-07-192-16/+45
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Audio devices use the supplied revision information in order to determine if USB audio output is able to be supported. In this case, we can only really handle using this revision information in ListAudioDeviceName(), where it checks if USB audio output is supported before supplying it as a device name. A few other scenarios exist where the revision info is checked, such as: - Early exiting from SetAudioDeviceOutputVolume if USB audio is attempted to be set when that device is unsupported. - Early exiting and returning 0.0f in GetAudioDeviceOutputVolume when USB output volume is queried and it's an unsupported device. - Falling back to AHUB headphones in GetActiveAudioDeviceName when the device type is USB output, but is unsupported based off the revision info. In order for these changes to also be implemented, a few other changes to the interface need to be made. Given we now properly handle everything about ListAudioDeviceName(), we no longer need to describe it as a stubbed function.
| * | | | | service/audren_u: Move revision testing code out of AudRenULioncash2019-07-192-63/+63
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The revision querying facilities are used by more than just audren. e.g. audio devices can use this to test whether or not USB audio output is supported. This will be used within the following change.
| * | | | | service/audio: Remove global system accessorsLioncash2019-07-197-34/+54
| | | | | | | | | | | | | | | | | | | | | | | | Trims out the lingering reliance on global state out of the audio code.
| * | | | | service/audren_u: Remove unnecessary return value from GetActiveAudioDeviceName()Lioncash2019-07-191-2/+1
| | | | | | | | | | | | | | | | | | | | | | | | This service function only ever returns a result and nothing more.
| * | | | | service/audren_u: Report proper device namesLioncash2019-07-191-6/+29
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | AudioDevice and AudioInterface aren't valid device names on the Switch. We should also be returning consistent names in GetActiveAudioDeviceName(). While we're at it, we can also handle proper name output in ListAudioDeviceName, by returning all the available devices on the Switch.
* | | | | Merge pull request #2592 from FernandoS27/sync1bunnei2019-07-2630-169/+542
|\ \ \ \ \ | |/ / / / |/| | | | Implement GPU Synchronization Mechanisms & Correct NVFlinger
| * | | | NVServices: Correct delayed responses.Fernando Sahmkow2019-07-051-24/+19
| | | | |
| * | | | Nv_Host_Ctrl: Correct difference calculationFernando Sahmkow2019-07-051-5/+7
| | | | |
| * | | | NVServices: Address FeedbackFernando Sahmkow2019-07-058-21/+38
| | | | |
| * | | | NVServices: Styling, define constructors as explicit and correctionsFernando Sahmkow2019-07-0518-36/+31
| | | | |
| * | | | NVFlinger: Correct GCC compile errorFernando Sahmkow2019-07-056-17/+16
| | | | |
| * | | | NVServices: Make NVEvents Automatic according to documentation.Fernando Sahmkow2019-07-052-4/+7
| | | | |
| * | | | NVServices: Correct CtrlEventWaitSync to block the ipc until timeout.Fernando Sahmkow2019-07-0523-31/+104
| | | | |
| * | | | GPU: Correct Interrupts to interrupt on syncpt/value instead of event, mirroring hardwareFernando Sahmkow2019-07-055-14/+14
| | | | |
| * | | | nvflinger: Make the force 30 fps still force 30 fpsFernando Sahmkow2019-07-051-1/+1
| | | | |
| * | | | nv_services: Fixes to event liberation.Fernando Sahmkow2019-07-051-6/+14
| | | | |
| * | | | nvflinger: Acquire buffers in the same order as they were queued.Fernando Sahmkow2019-07-052-3/+11
| | | | |
| * | | | nv_services: Deglobalize NvServicesFernando Sahmkow2019-07-0523-51/+65
| | | | |
| * | | | nv_host_ctrl: Make Sync GPU variant always return synced result.Fernando Sahmkow2019-07-051-0/+5
| | | | |
| * | | | nvhost_ctrl: Corrections to event handlingFernando Sahmkow2019-07-052-8/+12
| | | | |
| * | | | Gpu: Mark areas as protected.Fernando Sahmkow2019-07-051-0/+6
| | | | |
| * | | | nv_services: Stub CtrlEventSignalFernando Sahmkow2019-07-052-12/+34
| | | | |
| * | | | Gpu: Implement Hardware Interrupt Manager and manage GPU interruptsFernando Sahmkow2019-07-053-8/+1
| | | | |
| * | | | nv_services: Implement NvQueryEvent, NvCtrlEventWait, NvEventRegister, NvEventUnregisterFernando Sahmkow2019-07-057-17/+192
| | | | |
| * | | | nv_services: Create GPU channels correctlyFernando Sahmkow2019-07-052-2/+5
| | | | |
| * | | | video_core: Implement GPU side SyncpointsFernando Sahmkow2019-07-053-7/+33
| | | | |
| * | | | nv_services: Correct buffer queue fencing and GPFifo fencingFernando Sahmkow2019-07-057-57/+69
| | | | |
| * | | | nvflinger: Implement swap intervalsFernando Sahmkow2019-07-055-8/+21
| | | | |
* | | | | Merge pull request #2687 from lioncash/tls-processbunnei2019-07-183-14/+30
|\ \ \ \ \ | | | | | | | | | | | | kernel/process: Allocate the process' TLS region during initialization
| * | | | | kernel/process: Allocate the process' TLS region during initializationLioncash2019-07-073-3/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prior to execution within a process beginning, the process establishes its own TLS region for uses (as far as I can tell) related to exception handling. Now that TLS creation was decoupled from threads themselves, we can add this behavior to our Process class. This is also good, as it allows us to remove a stub within svcGetInfo, namely querying the address of that region.
| * | | | | kernel/process: Move main thread stack allocation to its own functionLioncash2019-07-072-12/+17
| | |_|/ / | |/| | | | | | | | | | | | | Keeps this particular set of behavior isolated to its own function.
* | | | | Kernel: Downgrade WaitForAddress and SignalToAddress messages to Trace.Fernando Sahmkow2019-07-181-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | This messages were originally set as warnning since few games used these svcs and it was needed for debugging. This is no longer the case.
* | | | | Merge pull request #2690 from SciresM/physmem_fixesFernando Sahmkow2019-07-146-40/+470
|\ \ \ \ \ | | | | | | | | | | | | Implement MapPhysicalMemory/UnmapPhysicalMemory
| * | | | | Remove unicorn mappings/unmappingsMichael Scire2019-07-121-19/+0
| | | | | |
| * | | | | Prevent merging of device mapped memory blocks.Michael Scire2019-07-091-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This sets the DeviceMapped attribute for GPU-mapped memory blocks, and prevents merging device mapped blocks. This prevents memory mapped from the gpu from having its backing address changed by block coalesce.
| * | | | | Remove unused member function declarationMichael Scire2019-07-071-9/+0
| | | | | |
| * | | | | physmem: add helpers, cleanup logic.Michael Scire2019-07-072-171/+170
| | | | | |
| * | | | | clang-format fixesMichael Scire2019-07-072-3/+3
| | | | | |
| * | | | | address review commentaryMichael Scire2019-07-075-36/+42
| | | | | |
| * | | | | Implement MapPhysicalMemory/UnmapPhysicalMemoryMichael Scire2019-07-076-20/+468
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This implements svcMapPhysicalMemory/svcUnmapPhysicalMemory for Yuzu, which can be used to map memory at a desired address by games since 3.0.0. It also properly parses SystemResourceSize from NPDM, and makes information available via svcGetInfo. This is needed for games like Super Smash Bros. and Diablo 3 -- this PR's implementation does not run into the "ASCII reads" issue mentioned in the comments of #2626, which was caused by the following bugs in Yuzu's memory management that this PR also addresses: * Yuzu's memory coalescing does not properly merge blocks. This results in a polluted address space/svcQueryMemory results that would be impossible to replicate on hardware, which can lead to game code making the wrong assumptions about memory layout. * This implements better merging for AllocatedMemoryBlocks. * Yuzu's implementation of svcMirrorMemory unprotected the entire virtual memory range containing the range being mirrored. This could lead to games attempting to map data at that unprotected range/attempting to access that range after yuzu improperly unmapped it. * This PR fixes it by simply calling ReprotectRange instead of Reprotect.
* | | | | Clang formatDavid Marcec2019-07-121-2/+4
| | | | |
* | | | | "AudioRenderer" thread should have a unique nameDavid Marcec2019-07-122-4/+4
| | | | | | | | | | | | | | | | | | | | Creating multiple "AudioRenderer" threads cause the previous thread to be overwritten. The thread will name be renamed to AudioRenderer-InstanceX, where X is the current instance number.
* | | | | Merge pull request #2717 from SciresM/unmirror_memorybunnei2019-07-112-7/+34
|\ \ \ \ \ | | | | | | | | | | | | Restore memory perms on svcUnmapMemory/UnloadNro
| * | | | | Restore memory perms on svcUnmapMemory/UnloadNroMichael Scire2019-07-112-7/+34
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prior to PR, Yuzu did not restore memory to RW- on unmap of mirrored memory or unloading of NRO. (In fact, in the NRO case, the memory was unmapped instead of reprotected to --- on Load, so it was actually lost entirely...) This PR addresses that, and restores memory to RW- as it should. This fixes a crash in Super Smash Bros when creating a World of Light save for the first time, and possibly other games/circumstances.
* | | | | | Merge pull request #2723 from lioncash/membunnei2019-07-111-20/+0
|\ \ \ \ \ \ | | | | | | | | | | | | | | core/arm: Remove obsolete Unicorn memory mapping
| * | | | | | core/arm: Remove obsolete Unicorn memory mappingLioncash2019-07-111-20/+0
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was initially necessary when AArch64 JIT emulation was in its infancy and all memory-related instructions weren't implemented. Given the JIT now has all of these facilities implemented, we can remove these functions from the CPU interface.
* | | | | | service/am: Implement IsAutoSleepDisabledLioncash2019-07-112-1/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This simply queries whether or not auto-sleep facilities are disabled and has no special handling. It's a basic getter function.
* | | | | | service/am: Implement SetAutoSleepDisabledLioncash2019-07-112-1/+23
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Provides a basic implementation of SetAutoSleepDisabled. Until idle handling is implemented, this is about the best we can do. In the meantime, provide a rough documenting of specifics that occur when this function is called on actual hardware.
* | | | | Merge pull request #2700 from ogniK5377/GetFriendListbunnei2019-07-101-1/+34
|\ \ \ \ \ | | | | | | | | | | | | IFriendService::GetFriendList
| * | | | | IFriendService::GetFriendListDavid Marcec2019-07-091-1/+34
| | |_|/ / | |/| | | | | | | | | | | | | We don't have any friends implemented in Yuzu yet so it doesn't make sense to return any friends. For now we'll be returning 0 friends however the information provided will allow a proper implementation of this cmd when needed.
* | | | | Merge pull request #2611 from DarkLordZach/pm-info-cmdbunnei2019-07-103-16/+116
|\ \ \ \ \ | | | | | | | | | | | | pm: Implement various pm commands for finding process and title IDs
| * | | | | pm: Implement pm:shell and pm:dmnt GetApplicationPidZach Hilman2019-06-273-7/+33
| | | | | | | | | | | | | | | | | | | | | | | | Returns the process ID of the current application or 0 if no app is running.
| * | | | | pm: Implement pm:dmnt GetTitlePidZach Hilman2019-06-271-7/+36
| | | | | | | | | | | | | | | | | | | | | | | | Takes a title ID and searches for a matching process, returning error if it doesn't exist, otherwise the process ID.
| * | | | | pm: Implement pm:info GetTitleIdZach Hilman2019-06-271-2/+47
| | | | | | | | | | | | | | | | | | | | | | | | Searches the process list for a process with the specified ID, returning the title ID if it exists.
* | | | | | Merge pull request #2650 from DarkLordZach/mii-iface-verbunnei2019-07-101-1/+15
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | mii: Implement IDatabaseService SetInterfaceVersion
| * | | | | mii: Implement IDatabaseService SetInterfaceVersionZach Hilman2019-07-071-1/+15
| |/ / / / | | | | | | | | | | Appears to set a member variable used to affect the API that games access, and the method used to store data.
* | | | | Merge pull request #2657 from ogniK5377/npad-assignmentsZach Hilman2019-07-085-3/+99
|\ \ \ \ \ | | | | | | | | | | | | hid:StartLrAssignmentMode, hid:StopLrAssignmentMode, hid:SwapNpadAssignment
| * | | | | addressed issuesDavid Marcec2019-07-081-6/+7
| | | | | |
| * | | | | hid:StartLrAssignmentMode, hid:StopLrAssignmentMode, hid:SwapNpadAssignmentDavid Marcec2019-07-015-3/+98
| | | | | | | | | | | | | | | | | | | | | | | | StartLrAssignmentMode and StopLrAssignmentMode don't require any implementation as it's just used for showing the screen of changing the controller orientation if the user wishes to do so. Ever since #1634 this has not been needed as users can specify the controller orientation from the config and swap at any time. We store a private member just in case this gets used for anything extra in the future
* | | | | | Merge pull request #2651 from DarkLordZach/apm-boost-mode-1bunnei2019-07-0811-57/+236
|\ \ \ \ \ \ | | | | | | | | | | | | | | apm: Initial implementation of performance config and boost mode
| * | | | | | am: Implement SetCpuBoostMode in terms of APMZach Hilman2019-06-295-13/+26
| | | | | | |
| * | | | | | apm: Implement SetCpuBoostModeZach Hilman2019-06-292-0/+14
| | | | | | |
| * | | | | | apm: Add getters for performance config and modeZach Hilman2019-06-292-33/+49
| | | | | | |
| * | | | | | apm: Add apm:am serviceZach Hilman2019-06-292-11/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | 8.0.0+ identical version of apm
| * | | | | | apm: Add Controller class to manage speed data and applicationZach Hilman2019-06-292-0/+138
| | |/ / / / | |/| | | |
* | | | | | Merge pull request #2642 from DarkLordZach/fsp-log-2bunnei2019-07-086-27/+73
|\ \ \ \ \ \ | |_|_|/ / / |/| | | | | fsp-srv: Implement Access Logging Functionality
| * | | | | fsp-srv: Implement GetAccessLogVersionInfoZach Hilman2019-06-292-3/+14
| | | | | | | | | | | | | | | | | | | | | | | | Returns some misc. data about logging to help the game determine if it should log.
| * | | | | fsp-srv: Implement OutputAccessLogToSdCardZach Hilman2019-06-296-26/+61
| |/ / / / | | | | | | | | | | | | | | | Allows games to log data to the SD.
* | | | | Merge pull request #2677 from lioncash/assertZach Hilman2019-07-073-37/+48
|\ \ \ \ \ | | | | | | | | | | | | kernel/vm_manager: Handle stack/TLS IO region placement a little better
| * | | | | kernel/vm_manager: Rename 'new map' to 'stack'Lioncash2019-07-063-37/+37
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Provides a more accurate name for the memory region and also disambiguates between the map and new map regions of memory, making it easier to understand.
| * | | | | kernel/vm_manager: Handle stack/TLS IO region placement betterLioncash2019-07-061-2/+13
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Handles the placement of the stack a little nicer compared to the previous code, which was off in a few ways. e.g. The stack (new map) region, shouldn't be the width of the entire address space if the size of the region calculation ends up being zero. It should be placed at the same location as the TLS IO region and also have the same size. In the event the TLS IO region contains a size of zero, we should also be doing the same thing. This fixes our memory layout a little bit and also resolves some cases where assertions can trigger due to the memory layout being incorrect.
* | | | | clang-format fixesMichael Scire2019-07-061-4/+5
| | | | |
* | | | | am: Implement GetAccumulatedSuspendedTickValueMichael Scire2019-07-062-7/+19
|/ / / /
* | | | Merge pull request #2555 from lioncash/tlsZach Hilman2019-07-046-81/+148
|\ \ \ \ | | | | | | | | | | kernel/process: Decouple TLS handling from threads
| * | | | kernel/process: Default initialize all member variablesLioncash2019-07-041-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | Ensures a Process instance is always created with a deterministic initial state.
| * | | | kernel/process: Decouple TLS handling from threadsLioncash2019-07-044-66/+97
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Extracts out all of the thread local storage management from thread instances themselves and makes the owning process handle the management of the memory. This brings the memory management slightly more in line with how the kernel handles these allocations. Furthermore, this also makes the TLS page management a little more readable compared to the lingering implementation that was carried over from Citra.
| * | | | kernel/vm_manager: Add overload of FindFreeRegion() that operates on a boundaryLioncash2019-07-042-13/+49
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will be necessary for making our TLS slot management slightly more straightforward. This can also be utilized for other purposes in the future. We can implement the existing simpler overload in terms of this one anyways, we just pass the beginning and end of the ASLR region as the boundaries.
* | | | | Merge pull request #2658 from ogniK5377/QueryAudioDeviceOutputEventbunnei2019-07-041-3/+16
|\ \ \ \ \ | | | | | | | | | | | | IAudioDevice::QueryAudioDeviceOutputEvent
| * | | | | IAudioDevice::QueryAudioDeviceOutputEventDavid Marcec2019-07-011-3/+16
| | |_|/ / | |/| | | | | | | | | | | | | The event should only be signaled when an output audio device gets changed. Example, Speaker to USB headset. We don't identify different devices internally yet so there's no need to signal the event yet.
* | | | | Merge pull request #2638 from DarkLordZach/quest-flagbunnei2019-07-042-1/+10
|\ \ \ \ \ | |_|/ / / |/| | | | set: Implement GetQuestFlag with config option
| * | | | set: Implement GetQuestFlagZach Hilman2019-06-292-1/+10
| | |/ / | |/| | | | | | Simply returns a true/false value indicating if the system is a kiosk system. This has been mapped to a config option for the purposes of yuzu.
* | | | Merge pull request #2613 from ogniK5377/InitalizeApplicationInfoZach Hilman2019-07-044-6/+109
|\ \ \ \ | | | | | | | | | | Implemented InitializeApplicationInfo & InitializeApplicationInfoRestricted
| * | | | Addressed issuesDavid Marcec2019-06-282-17/+12
| | | | |
| * | | | Implemented InitializeApplicationInfo & InitializeApplicationInfoRestrictedDavid Marcec2019-06-274-6/+114
| |/ / / | | | | | | | | | | | | InitializeApplicationInfoRestricted will need further implementation as it's checking for other user requirements about the game. As we're emulating, we're assuming the user owns the game so we skip these checks currently, implementation will need to be added further on
* | | | Merge pull request #2608 from ogniK5377/Time_GetSharedMemoryNativeHandleZach Hilman2019-07-047-28/+258
|\ \ \ \ | | | | | | | | | | Implement Time::GetSharedMemoryNativeHandle
| * | | | Addressed issuesDavid Marcec2019-06-265-37/+53
| | | | |
| * | | | Implement Time::GetSharedMemoryNativeHandleDavid Marcec2019-06-257-29/+243
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This PR attempts to implement the shared memory provided by GetSharedMemoryNativeHandle. There is still more work to be done however that requires a rehaul of the current time module to handle clock contexts. This PR is mainly to get the basic functionality of the SharedMemory working and allow the use of addition to it whilst things get improved on. Things to note: Memory Barriers are used in the SharedMemory and a better solution would need to be done to implement this. Currently in this PR I’m faking the memory barriers as everything is sync and single threaded. They work by incrementing the counter and just populate the two data slots. On data reading, it will read the last added data. Specific values in the shared memory would need to be updated periodically. This isn't included in this PR since we don't actively do this yet. In a later PR when time is refactored this should be done. Finally, as we don't handle clock contexts. When time is refactored, we will need to update the shared memory for specific contexts. This PR does this already however since the contexts are all identical and not separated. We're just updating the same values for each context which in this case is empty. Tiime:SetStandardUserSystemClockAutomaticCorrectionEnabled, Time:IsStandardUserSystemClockAutomaticCorrectionEnabled are also partially implemented in this PR. The reason the implementation is partial is because once again, a lack of clock contexts. This will be improved on in a future PR. This PR closes issue #2556
* | | | | Merge pull request #2604 from ogniK5377/INotificationServicebunnei2019-07-034-1/+129
|\ \ \ \ \ | |_|_|_|/ |/| | | | Implemented INotificationService
| * | | | Attemp clang format fix?David Marcec2019-06-281-1/+0
| | | | | | | | | | | | | | | | | | | | Seems to be an issue with clang format
| * | | | Addressed issuesDavid Marcec2019-06-282-13/+13
| | | | |
| * | | | SizedNotificationInfo should be 0x10 bytes, user_uuid is incorrect, this should be the users account idDavid Marcec2019-06-251-1/+3
| | | | |
| * | | | fixed spelling errors and fixed issue with Pop not returning the SizedNotificationInfoDavid Marcec2019-06-251-6/+8
| | | | |
| * | | | Implemented INotificationServiceDavid Marcec2019-06-244-1/+126
| |/ / /
* | | / file_sys: Rename other ContentRecordType membersBakugo2019-07-021-2/+2
| |_|/ |/| |
* | | Merge pull request #2583 from FernandoS27/core-timing-safebunnei2019-06-301-3/+3
|\ \ \ | |_|/ |/| | Core_Timing: Make core_timing threadsafe by default.
| * | Core_Timing: Make core_timing threadsafe by default.Fernando Sahmkow2019-06-161-3/+3
| | | | | | | | | | | | | | | | | | The old implementation had faulty Threadsafe methods where events could be missing. This implementation unifies unsafe/safe methods and makes core timing thread safe overall.
* | | Merge pull request #2548 from DarkLordZach/applet-shopnbunnei2019-06-2613-112/+690
|\ \ \ | | | | | | | | applets: Implement backend and default frontend for Parental Controls and EShop (ShopN) applets
| * | | applets: Pass current process title ID to appletsZach Hilman2019-06-2511-41/+59
| | | | | | | | | | | | | | | | Avoids using system accessor to get current process in applet code.
| * | | general_frontend: Add documentation for parental controls and ecommerce appletsZach Hilman2019-06-252-16/+16
| | | |
| * | | web_browser: Only delete temporary directory if it was createdZach Hilman2019-06-251-1/+3
| | | | | | | | | | | | | | | | Prevents crashes with ShopN applet occasionally.
| * | | web_browser: Take ECommerce applet frontend optionally in constructorZach Hilman2019-06-251-1/+6
| | | | | | | | | | | | If it is needed but wasn't passed (or passed nullptr), the Shop handling code will alert and throw an error.
| * | | web_browser: Use function tables for execute and initializeZach Hilman2019-06-252-7/+285
| | | | | | | | | | | | Allows easy handling of multiple shim types, as they have enough in common to be the same backend but not enough to share init/exec.
| * | | web_browser: Correct structures and properly parse TLVs/ShimKindZach Hilman2019-06-252-61/+168
| | | | | | | | | | | | Much, much more HW-accurate and allows us to easily support all of the different web 'shim' types.
| * | | applets: Track ECommerce and Parental Control applet frontendsZach Hilman2019-06-252-7/+29
| | | |
| * | | applets: Implement Auth applet backendZach Hilman2019-06-252-0/+146
| | |/ | |/| | | | This is responsible for parental controls and supports verifying, changing, and registering PIN codes.
* | | glue: Correct missing bytes in ApplicationLaunchParameterZach Hilman2019-06-264-28/+61
| | |
* | | glue: Implement arp:w and arp:r servicesZach Hilman2019-06-253-2/+330
| | | | | | | | | | | | These keep track of running process' launch properties and control properties and allows for issuing and reading them by process and title ID.
* | | glue: Add errors for glue/arp servicesZach Hilman2019-06-253-0/+58
| | |
* | | glue: Add scaffolding for bgtc:t and bgtc:sc servicesZach Hilman2019-06-252-0/+73
| | |
* | | arp: Move to glue servicesZach Hilman2019-06-252-91/+0
| | | | | | | | | | | | Glue is the name of the sysmodule that contains both arp and bgtc.
* | | glue: Add manager to keep track of application registryZach Hilman2019-06-252-0/+119
|/ / | | | | | | Manages mapping between title IDs and application launch and control properties.
* | Merge pull request #2602 from lioncash/castbunnei2019-06-211-3/+3
|\ \ | | | | | | service/acc: Silence truncation warnings
| * | service/acc: Silence truncation warningsLioncash2019-06-211-3/+3
| | | | | | | | | | | | | | | The sanitizing function ensures that the returned type is always the correct type. This eliminates warnings without extra casts.
* | | Merge pull request #2575 from DarkLordZach/process-id-typesbunnei2019-06-214-8/+25
|\ \ \ | | | | | | | | kernel: Differentiate kernel and user processes when picking ID
| * | | kernel: Differentiate kernel and user processes when picking IDZach Hilman2019-06-104-8/+25
| | |/ | |/| | | | | | | This allows kernel internal type processes to be assigned IDs in the KIP range while userland processes are assigned in the user range.
* | | Merge pull request #2482 from DarkLordZach/prepobunnei2019-06-219-44/+102
|\ \ \ | |_|/ |/| | core: Add detailed local reporting feature for development
| * | loader: Move NSO module tracking to AppLoaderZach Hilman2019-05-263-6/+7
| | | | | | | | | Also cleanup of general stuff
| * | prepo: Save reports from PlayReport serviceZach Hilman2019-05-251-2/+23
| | | | | | | | | | | | Logs a lot of seemingly innocuous telemetry games generate.
| * | fatal: Save report on fatal:u callZach Hilman2019-05-251-21/+5
| | | | | | | | | | | | Matches offical behavior with creport and replaces old log/text based report system.
| * | service: Save report on unimplemented function callZach Hilman2019-05-251-0/+3
| | |
| * | applets/error: Save report on error appletZach Hilman2019-05-251-5/+14
| | | | | | | | | | | | This matches official behavior with the erpt/eclct/eupld service chain.
| * | applets: Save report on stubbed appletZach Hilman2019-05-254-15/+49
| | | | | | | | | | | | This also reworks the applet data storage to be peekable.
| * | svc: Save report on call to svcBreakZach Hilman2019-05-251-1/+7
| | |
* | | Revert PR 2590.Fernando Sahmkow2019-06-201-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | Even though it has been proven that IAudioRenderer:SystemEvent is actually an automatic event. The current implementation of such event is all thought to be manual. Thus it's implementation needs to be corrected when doing such change. As it is right now this PR introduced a series of regressions on softlocks on multiple games. Therefore, this pr reverts such change until a correct implementation is made.
* | | Merge pull request #2590 from lioncash/eventbunnei2019-06-201-1/+1
|\ \ \ | | | | | | | | service/audio/audren_u: Correct event reset type for the system event
| * | | service/audio/audren_u: Correct event reset type for the system eventLioncash2019-06-181-1/+1
| | | | | | | | | | | | | | | | | | | | This is actually an auto-reset event in the audio service itself, not a manual one.
* | | | Addressed issuesDavid Marcec2019-06-173-8/+13
| | | |
* | | | Signalled accumulated_suspended_tick_changed_event on creation based on REDavid Marcec2019-06-161-0/+1
| | | |
* | | | CleanupDavid Marcec2019-06-1611-29/+38
| | | |
* | | | Impl'd IsUserAccountSwitchLocked, SetAudioOutVolume, GetAudioOutVolume & Partial impl of GetAccumulatedSuspendedTickChangedEventDavid Marcec2019-06-166-7/+72
| | | | | | | | | | | | | | | | IPC-100 was changed to InitializeApplicationInfoOld instead of InitializeApplicationInfo. IPC-150 makes an indentical call to IPC-100 however does extra processing. They should not have the same name as it's quite confusing to debug.
* | | | Merge pull request #2581 from lioncash/hexZach Hilman2019-06-152-7/+7
|\ \ \ \ | | | | | | | | | | common/hex_util: Combine HexVectorToString() and HexArrayToString()
| * | | | common/hex_util: Combine HexVectorToString() and HexArrayToString()Lioncash2019-06-122-7/+7
| | |_|/ | |/| | | | | | | | | | | | | | | | | | These can be generified together by using a concept type to designate them. This also has the benefit of not making copies of potentially very large arrays.
* / | | kernel/vm_manager: Remove redundant Reset call in destructorLioncash2019-06-121-3/+1
|/ / / | | | | | | | | | | | | | | | | | | | | | | | | This is performing more work than would otherwise be necessary during VMManager's destruction. All we actually want to occur in this scenario is for any allocated memory to be freed, which will happen automatically as the VMManager instance goes out of scope. Anything else being done is simply unnecessary work.
* | | Merge pull request #2571 from lioncash/refZach Hilman2019-06-102-2/+2
|\ \ \ | | | | | | | | kernel/process: Make Create()'s name parameter be taken by value
| * | | kernel/process: Make Create()'s name parameter be taken by valueLioncash2019-06-102-2/+2
| |/ / | | | | | | | | | | | | Makes the interface more flexible in terms of how Create() may be called, while still allowing the parameter itself to be moved into.
* | | kernel/svc: Implement TotalMemoryUsedWithoutMmHeap/TotalMemoryAvailableWithoutMmHeapLioncash2019-06-103-2/+42
| | | | | | | | | | | | | | | | | | | | | | | | | | | Given we don't currently implement the personal heap yet, the existing memory querying functions are essentially doing what the memory querying types introduced in 6.0.0 do. So, we can build the necessary machinery over the top of those and just use them as part of info types.
* | | kernel/svc: Amend naming for TotalMemoryUsage in svcGetInfo()Lioncash2019-06-103-6/+6
| | | | | | | | | | | | | | | Disambiguates and makes the name a little more consistent with TotalPhysicalMemoryUsed.
* | | kernel/svc: Remove duplicate enum entry in svcGetInfo()Lioncash2019-06-101-2/+1
|/ /
* | constants: Extract backup JPEG used by account servicesZach Hilman2019-06-071-16/+4
| |
* | Merge pull request #2549 from lioncash/headerZach Hilman2019-06-061-1/+0
|\ \ | | | | | | kernel/process: Remove unused boost header include
| * | kernel/process: Remove unused boost header includeLioncash2019-06-051-1/+0
| | | | | | | | | | | | | | | Boost headers typically include a lot of other headers, so removing this can prevent a bit of unnecessary compiler churn when building.
* | | Merge pull request #2551 from lioncash/dtorbunnei2019-06-061-9/+9
|\ \ \ | | | | | | | | service/ns: Add missing override specifiers
| * | | service/ns: Add missing override specifiersLioncash2019-06-051-9/+9
| | | |
* | | | Merge pull request #2419 from DarkLordZach/srv-lr-ifacebunnei2019-06-061-3/+77
|\ \ \ \ | |/ / / |/| | | lr: Add command handler skeletons for Open*LocationResolver
| * | | ncm: Implement LR OpenAddOnContentLocationResolver (2)Zach Hilman2019-05-271-24/+21
| | | | | | | | | | | | Returns an object of type IAddOnContentLocationResolver for the provided StorageId.
| * | | ncm: Implement LR OpenRegisteredLocationResolver (1)Zach Hilman2019-05-271-0/+27
| | | | | | | | | | | | Returns an object of type IRegisteredLocationResolver for the StorageId.
| * | | ncm: Implement LR OpenLocationResolver (0)Zach Hilman2019-05-271-0/+50
| | | | | | | | | | | | Returns an object of type ILocationResolver with the provided StorageId.
* | | | Merge pull request #2526 from lioncash/globalZach Hilman2019-06-052-5/+37
|\ \ \ \ | | | | | | | | | | core/telemetry_session: Remove usages of the global system accessor
| * | | | core/core: Remove unnecessary includesLioncash2019-05-292-5/+37
| |/ / / | | | | | | | | | | | | | | | | The contents of these includes aren't used anywhere in this translation unit.
* | | | Merge pull request #2545 from lioncash/timingZach Hilman2019-06-053-7/+9
|\ \ \ \ | | | | | | | | | | core/core_timing_util: Use std::chrono types for specifying time units
| * | | | core/core_timing_util: Amend casing of cyclesTo* functionsLioncash2019-06-052-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | Makes the casing consistent with all of our general function naming conventions.
| * | | | core/core_timing_util: Use std::chrono types for specifying time unitsLioncash2019-06-053-7/+9
| | |/ / | |/| | | | | | | | | | | | | | Makes the interface more type-safe and consistent in terms of return values.
* | | | Merge pull request #2510 from SciresM/desired_languageZach Hilman2019-06-057-402/+1073
|\ \ \ \ | |/ / / |/| | | Implement/Fix IApplicationFunctions::GetDesiredLanguage
| * | | Fix bitmask logic inversionMichael Scire2019-05-231-2/+1
| | | |
| * | | fix introduced clang-format errorsMichael Scire2019-05-231-3/+2
| | | |
| * | | Address review commentsMichael Scire2019-05-235-45/+118
| | | |
| * | | clang-format fixesMichael Scire2019-05-234-31/+32
| | | |
| * | | Implement IApplicationFunctions::GetDesiredLanguageMichael Scire2019-05-236-403/+1002
| | | |
* | | | Merge pull request #1931 from DarkLordZach/mii-database-1bunnei2019-05-308-104/+1051
|\ \ \ \ | |_|/ / |/| | | mii: Implement MiiManager backend and several mii service commands
| * | | mii_manager: Fix incorrect loop condition in mii UUID generation codeZach Hilman2019-04-253-2/+3
| | | |
| * | | profile_select: Port Service::Account::UUID to Common::UUIDZach Hilman2019-04-253-6/+6
| | | |
| * | | mii: Implement Delete and Destroy fileZach Hilman2019-04-253-8/+116
| | | |
| * | | mii: Implement IsUpdated command (IPC 0)Zach Hilman2019-04-253-9/+34
| | | |
| * | | mii_manager: Cleanup and optimizationZach Hilman2019-04-253-36/+50
| | | |
| * | | mii: Implement IDatabaseService commands using MiiManagerZach Hilman2019-04-251-15/+242
| | | | | | | | | | | | Since the MiiManager was designed around the IPC interface, this is quite easy. Only functions that were clearly defined were implemented.
| * | | mii: Add MiiManager class to manage Mii databaseZach Hilman2019-04-252-0/+622
| | | | | | | | | | | | Provides serialization/deserialization to the database in system save files, accessors for database state and proper handling of both major Mii formats (MiiInfo and MiiStoreData)
| * | | common: Extract UUID to its own classZach Hilman2019-04-253-78/+28
| | | | | | | | | | | | Since the Mii database uses UUIDs very similar to the Accounts database, it makes no sense to not share code between them.
* | | | Merge pull request #2509 from lioncash/aocbunnei2019-05-261-19/+50
|\ \ \ \ | |_|_|/ |/| | | service/aoc_u: Minor cleanup
| * | | service/aoc: Avoid allocating and discarding dataLioncash2019-05-231-8/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, the code was accumulating data into a std::vector and then tossing all of it away if a setting was disabled. Instead, we can just check if it's disabled and do no work at all if possible. If it's enabled, then we can append to the vector and allocate. Unlikely to impact usage much, but it is slightly less sloppy with resources.
| * | | service/aoc: Remove unnecessary includesLioncash2019-05-231-2/+0
| | | | | | | | | | | | | | | | | | | | Removes two header dependencies related to file handling that aren't actually used within the source file.
| * | | service/aoc: Pop all passed values where applicableLioncash2019-05-231-12/+45
| | |/ | |/| | | | | | | | | | | | | A few of the aoc service stubs/implementations weren't fully popping all of the parameters passed to them. This ensures that all parameters are popped and, at minimum, logged out.
* | | Merge pull request #2489 from FearlessTobi/port-4716bunnei2019-05-254-9/+10
|\ \ \ | |/ / |/| | Port citra-emu/citra#4716: "HLE/IPC: HLEContext can memorize the client thread and use it for SleepClientThread"
| * | Address review commentTobias2019-05-191-1/+1
| | | | | | | | | Co-Authored-By: Mat M. <mathew1800@gmail.com>
| * | HLE/IPC: HLEContext can memorize the client thread and use it for SleepClientThreadWeiyi Wang2019-05-184-9/+10
| | | | | | | | | | | | This reduces the boilerplate that services have to write out the current thread explicitly. Using current thread instead of client thread is also semantically incorrect, and will be a problem when we implement multicore (at which time there will be multiple current threads)
* | | Merge pull request #2410 from lioncash/affinitybunnei2019-05-192-42/+58
|\ \ \ | | | | | | | | kernel/svc: Reorganize and fix up the initial handling of svcSetThreadCoreMask()
| * | | kernel/svc: Make svcCreateThread/svcStartThread/svcSleepThread/svcExitThread calls show up in the debug logLioncash2019-04-291-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | These are actually quite important indicators of thread lifetimes, so they should be going into the debug log, rather than being treated as misc info and delegated to the trace log.
| * | | kernel/svc: Reorganize svcSetThreadCoreMask()Lioncash2019-04-291-32/+39
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes the code much nicer to follow in terms of behavior and control flow. It also fixes a few bugs in the implementation. Notably, the thread's owner process shouldn't be accessed in order to retrieve the core mask or ideal core. This should be done through the current running process. The only reason this bug wasn't encountered yet is because we currently only support running one process, and thus every owner process will be the current process. We also weren't checking against the process' CPU core mask to see if an allowed core is specified or not. With this out of the way, it'll be less noisy to implement proper handling of the affinity flags internally within the kernel thread instances.
| * | | kernel/thread: Update thread processor ID flagsLioncash2019-04-292-7/+16
| | | | | | | | | | | | | | | | Adds the missing flags to the enum and documents them.
* | | | Merge pull request #2439 from lioncash/audrenHexagon122019-05-192-51/+299
|\ \ \ \ | | | | | | | | | | service/audren_u: Get rid of magic values within GetAudioRendererWorkBufferSize
| * | | | service/audren_u: Handle variadic command buffers in GetWorkBufferSize()Lioncash2019-05-012-17/+93
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also introduced in REV5 was a variable-size audio command buffer. This also affects how the size of the work buffer should be determined, so we can add handling for this as well. Thankfully, no other alterations were made to how the work buffer size is calculated in 7.0.0-8.0.0. There were indeed changes made to to how some of the actual audio commands are generated though (particularly in REV7), however they don't apply here.
| * | | | service/audren_u: Handle version 2 of performance frame info in GetWorkBufferSize()Lioncash2019-05-012-6/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Introduced in REV5. This is trivial to add support for, now that everything isn't a mess of random magic constant values. All this is, is a change in data type sizes as far as this function cares.
| * | | | service/audren_u: Clean up work buffer calculationsLioncash2019-05-011-49/+214
| | |_|/ | |/| | | | | | | | | | | | | | | | | | "Unmagics" quite a few magic constants within this code, making it much easier to understand. Particularly given this factors out specific sections into their own self-contained lambda functions.
* | | | Merge pull request #2463 from lioncash/setHexagon122019-05-191-34/+22
|\ \ \ \ | | | | | | | | | | service/set: Correct and simplify behavior related to copying language codes
| * | | | service/set: Correct and simplify behavior related to copying language codesLioncash2019-05-101-34/+22
| | |_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This corrects cases where it was possible to write more entries into the write buffer than were requested. Now, we check the size of the buffer before actually writing into them. We were also returning the wrong value for GetAvailableLanguageCodeCount2(). This was previously returning 64, but only 17 should have been returned. 64 entries is the size of the static array used in MakeLanguageCode() within the service binary itself, but isn't the actual total number of language codes present.
* | | | Merge pull request #2487 from lioncash/service-returnHexagon122019-05-191-0/+2
|\ \ \ \ | | | | | | | | | | service/am: Add missing return in error case for IStorageAccessor's Read/Write()
| * | | | service/am: Add missing return in error case for IStorageAccessor's Read()/Write().Lioncash2019-05-191-0/+2
| |/ / / | | | | | | | | | | | | | | | | Previously this would fall through and return successfully, despite being an out of bounds read or write.
* | | | Merge pull request #2490 from lioncash/floatHexagon122019-05-191-1/+1
|\ \ \ \ | | | | | | | | | | ipc_helpers: Amend floating-point type in Pop<double> specialization
| * | | | ipc_helpers: Amend floating-point type in Pop<double> specializationLioncash2019-05-191-1/+1
| |/ / / | | | | | | | | | | | | | | | | Currently, this overload isn't used, so this wasn't actually hit in any code, only the float overload is used.
* | | | Merge pull request #2486 from lioncash/resetnameSebastian Valle2019-05-1918-31/+32
|\ \ \ \ | | | | | | | | | | core/kernel/object: Rename ResetType enum members for clarity
| * | | | core/kernel/object: Rename ResetType enum membersLioncash2019-05-1818-31/+32
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Renames the members to more accurately indicate what they signify. "OneShot" and "Sticky" are kind of ambiguous identifiers for the reset types, and can be kind of misleading. Automatic and Manual communicate the kind of reset type in a clearer manner. Either the event is automatically reset, or it isn't and must be manually cleared. The "OneShot" and "Sticky" terminology is just a hold-over from Citra where the kernel had a third type of event reset type known as "Pulse". Given the Switch kernel only has two forms of event reset types, we don't need to keep the old terminology around anymore.
* / / / kernel/svc: Mark GetThreadList() and UnmapProcessCodeMemory() as internally linkedLioncash2019-05-191-4/+4
|/ / / | | | | | | | | | | | | | | | These are only used from within this translation unit, so they don't need to have external linkage. They were intended to be marked with this anyways to be consistent with the other service functions.
* | | Merge pull request #2437 from lioncash/audctlbunnei2019-05-091-2/+2
|\ \ \ | | | | | | | | service/audctl: Update documentation comments to be relative to 8.0.0
| * | | service/audctl: Update documentation comments to be relative to 8.0.0Lioncash2019-04-281-2/+2
| |/ / | | | | | | | | | The state of these service calls are still the same in version 8.0.0.
* | | Merge pull request #2412 from lioncash/systembunnei2019-04-293-7/+11
|\ \ \ | |/ / |/| | kernel/vm_manager: Remove usages of global system accessors
| * | kernel/vm_manager: Remove usages of global system accessorsLioncash2019-04-173-7/+11
| | | | | | | | | | | | | | | Makes the dependency on the system instance explicit within VMManager's interface.
* | | Merge pull request #2416 from lioncash/waitbunnei2019-04-256-44/+50
|\ \ \ | | | | | | | | kernel/svc: Clean up wait synchronization related functionality
| * | | kernel/thread: Unify wait synchronization typesLioncash2019-04-176-38/+34
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is a holdover from Citra, where the 3DS has both WaitSynchronization1 and WaitSynchronizationN. The switch only has one form of wait synchronizing (literally WaitSynchonization). This allows us to throw out code that doesn't apply at all to the Switch kernel. Because of this unnecessary dichotomy within the wait synchronization utilities, we were also neglecting to properly handle waiting on multiple objects. While we're at it, we can also scrub out any lingering references to WaitSynchronization1/WaitSynchronizationN in comments, and change them to WaitSynchronization (or remove them if the mention no longer applies).
| * | | kernel/svc: Migrate svcCancelSynchronization behavior to a thread functionLioncash2019-04-173-7/+17
| |/ / | | | | | | | | | | | | | | | | | | The actual behavior of this function is slightly more complex than what we're currently doing within the supervisor call. To avoid dumping most of this behavior in the supervisor call itself, we can migrate this to another function.
* | | Merge pull request #2228 from DarkLordZach/applet-manager-p1bunnei2019-04-2514-63/+487
|\ \ \ | | | | | | | | applets: Add AppletManager and implement PhotoViewer and Error applets
| * | | web_browser: Make OpenPage non-constZach Hilman2019-04-178-15/+20
| | | |
| * | | main: Add GMainWindow hooks for Error displayZach Hilman2019-04-171-2/+2
| | | |
| * | | general_backend: Move StubApplet and add backend PhotoViewerZach Hilman2019-04-172-1/+102
| | | |
| * | | applets: Add Error appletZach Hilman2019-04-173-24/+224
| | | | | | | | | | | | Responsible for displaying error codes and messages
| * | | applets: Port current applets to take frontend in constructorZach Hilman2019-04-176-14/+16
| | | | | | | | | | | | As opposed to using Core::System::GetInstance()
| * | | am: Delegate applet creation to AppletManagerZach Hilman2019-04-171-24/+3
| | | |
| * | | applets: Add AppletManager class to control lifetimeZach Hilman2019-04-172-0/+137
| |/ /
* | | Merge pull request #2420 from lioncash/audctlbunnei2019-04-232-2/+32
|\ \ \ | | | | | | | | service/audctl: Implement GetTargetVolumeMin() and GetTargetVolumeMax()
| * | | service/audctl: Implement GetTargetVolumeMin() and GetTargetVolumeMax()Lioncash2019-04-182-2/+32
| | | | | | | | | | | | | | | | | | | | These two service functions are literally hardcoded to always return these values without any other error checking.
* | | | Merge pull request #2415 from lioncash/constbunnei2019-04-202-2/+2
|\ \ \ \ | | | | | | | | | | kernel/wait_object: Make GetHighestPriorityReadyThread() a const member function
| * | | | kernel/wait_object: Make GetHighestPriorityReadyThread() a const member functionLioncash2019-04-172-2/+2
| | |/ / | |/| | | | | | | | | | | | | | This doesn't actually modify internal state of a wait object, so it can be const qualified.
* | | | Merge pull request #2421 from lioncash/svc-callbunnei2019-04-201-1/+1
|\ \ \ \ | | | | | | | | | | kernel/svc: Name supervisor call 0x36
| * | | | kernel/svc: Name supervisor call 0x36Lioncash2019-04-191-1/+1
| | |/ / | |/| | | | | | | | | | | | | | This call was added to the SVC handlers in the 8.0.0 kernel, so we can finally give it a name.
* | | | Merge pull request #2374 from lioncash/pagetablebunnei2019-04-203-14/+17
|\ \ \ \ | |/ / / |/| | | core: Reorganize boot order
| * | | core/core: Move process execution start to System's Load()Lioncash2019-04-122-8/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This gives us significantly more control over where in the initialization process we start execution of the main process. Previously we were running the main process before the CPU or GPU threads were initialized (not good). This amends execution to start after all of our threads are properly set up.
| * | | core/process: Remove unideal page table setting from LoadFromMetadata()Lioncash2019-04-121-5/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Initially required due to the split codepath with how the initial main process instance was initialized. We used to initialize the process like: Init() { main_process = Process::Create(...); kernel.MakeCurrentProcess(main_process.get()); } Load() { const auto load_result = loader.Load(*kernel.GetCurrentProcess()); if (load_result != Loader::ResultStatus::Success) { // Handle error here. } ... } which presented a problem. Setting a created process as the main process would set the page table for that process as the main page table. This is fine... until we get to the part that the page table can have its size changed in the Load() function via NPDM metadata, which can dictate either a 32-bit, 36-bit, or 39-bit usable address space. Now that we have full control over the process' creation in load, we can simply set the initial process as the main process after all the loading is done, reflecting the potential page table changes without any special-casing behavior. We can also remove the cache flushing within LoadModule(), as execution wouldn't have even begun yet during all usages of this function, now that we have the initialization order cleaned up.
| * | | core/cpu_core_manager: Create threads separately from initialization.Lioncash2019-04-122-2/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Our initialization process is a little wonky than one would expect when it comes to code flow. We initialize the CPU last, as opposed to hardware, where the CPU obviously needs to be first, otherwise nothing else would work, and we have code that adds checks to get around this. For example, in the page table setting code, we check to see if the system is turned on before we even notify the CPU instances of a page table switch. This results in dead code (at the moment), because the only time a page table switch will occur is when the system is *not* running, preventing the emulated CPU instances from being notified of a page table switch in a convenient manner (technically the code path could be taken, but we don't emulate the process creation svc handlers yet). This moves the threads creation into its own member function of the core manager and restores a little order (and predictability) to our initialization process. Previously, in the multi-threaded cases, we'd kick off several threads before even the main kernel process was created and ready to execute (gross!). Now the initialization process is like so: Initialization: 1. Timers 2. CPU 3. Kernel 4. Filesystem stuff (kind of gross, but can be amended trivially) 5. Applet stuff (ditto in terms of being kind of gross) 6. Main process (will be moved into the loading step in a following change) 7. Telemetry (this should be initialized last in the future). 8. Services (4 and 5 should ideally be alongside this). 9. GDB (gross. Uses namespace scope state. Needs to be refactored into a class or booted altogether). 10. Renderer 11. GPU (will also have its threads created in a separate step in a following change). Which... isn't *ideal* per-se, however getting rid of the wonky intertwining of CPU state initialization out of this mix gets rid of most of the footguns when it comes to our initialization process.
* | | | Merge pull request #2397 from lioncash/thread-unusedbunnei2019-04-183-18/+17
|\ \ \ \ | |_|/ / |/| | | kernel/thread: Remove unused guest_handle member variable
| * | | svc: Specify handle value in thread's nameLioncash2019-04-152-2/+10
| | | | | | | | | | | | | | | | Allows the handle to be seen alongside the entry point.
| * | | kernel/thread: Remove unused guest_handle member variableLioncash2019-04-143-16/+7
| | |/ | |/| | | | | | | | | | | | | This member variable is entirely unused. It was only set but never actually utilized. Given that, we can remove it to get rid of noise in the thread interface.
* | | Merge pull request #2382 from lioncash/tablebunnei2019-04-1627-57/+262
|\ \ \ | | | | | | | | service: Update service function tables
| * | | service: Update service function tablesLioncash2019-04-1127-57/+262
| | | | | | | | | | | | | | | | Updates function tables based off information from SwitchBrew.
* | | | Merge pull request #2393 from lioncash/svcbunnei2019-04-164-2/+274
|\ \ \ \ | | | | | | | | | | kernel/svc: Implement svcMapProcessCodeMemory/svcUnmapProcessCodeMemory
| * | | | kernel/svc: Implement svcUnmapProcessCodeMemoryLioncash2019-04-133-1/+143
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Essentially performs the inverse of svcMapProcessCodeMemory. This unmaps the aliasing region first, then restores the general traits of the aliased memory. What this entails, is: - Restoring Read/Write permissions to the VMA. - Restoring its memory state to reflect it as a general heap memory region. - Clearing the memory attributes on the region.
| * | | | kernel/svc: Implement svcMapProcessCodeMemoryLioncash2019-04-134-1/+131
| | |_|/ | |/| | | | | | | | | | | | | | This is utilized for mapping code modules into memory. Notably, the ldr service would call this in order to map objects into memory.
* | | | kernel/thread: Remove BoostPriority()Lioncash2019-04-152-11/+0
| |_|/ |/| | | | | | | | | | | This is a holdover from Citra that currently remains unused, so it can be removed from the Thread interface.
* | | Merge pull request #2378 from lioncash/robunnei2019-04-141-65/+85
|\ \ \ | | | | | | | | ldr: Minor amendments to IPC-related parameters
| * | | ldr: Mark IsValidNROHash() as a const member functionLioncash2019-04-101-5/+4
| | | | | | | | | | | | | | | | This doesn't modify instance state, so it can be made const.
| * | | ldr: Amend parameters for LoadNro/UnloadNro LoadNrr/UnloadNrrLioncash2019-04-101-60/+81
| | |/ | |/| | | | | | | | | | The initial two words indicate a process ID. Also UnloadNro only specifies one address, not two.
* | | Merge pull request #2357 from zarroboogs/force-30fps-modebunnei2019-04-141-6/+10
|\ \ \ | | | | | | | | Add a toggle to force 30FPS mode
| * | | added a toggle to force 30fps modezarroboogs2019-04-091-6/+10
| | | |
* | | | Merge pull request #2381 from lioncash/fsbunnei2019-04-141-8/+7
|\ \ \ \ | |_|_|/ |/| | | fsp_srv: Minor cleanup related changes
| * | | fsp_srv: Remove unnecessary parameter popping in IDirectory's Read()Lioncash2019-04-101-4/+1
| | | | | | | | | | | | | | | | | | | | IDirectory's Read() function doesn't take any input parameters. It only uses the output parameters that we already provide.
| * | | fsp_srv: Log out option values in IFile's Read and Write functionsLioncash2019-04-101-4/+6
| | |/ | |/| | | | | | | | | | | | | | | | | | | These indicate options that alter how a read/write is performed. Currently we don't need to handle these, as the only one that seems to be used is for writes, but all the custom options ever seem to do is immediate flushing, which we already do by default.
* | | Merge pull request #2360 from lioncash/svc-globalbunnei2019-04-123-322/+373
|\ \ \ | | | | | | | | kernel/svc: Deglobalize the supervisor call handlers
| * | | kernel/svc: Deglobalize the supervisor call handlersLioncash2019-04-083-322/+373
| | |/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | Adjusts the interface of the wrappers to take a system reference, which allows accessing a system instance without using the global accessors. This also allows getting rid of all global accessors within the supervisor call handling code. While this does make the wrappers themselves slightly more noisy, this will be further cleaned up in a follow-up. This eliminates the global system accessors in the current code while preserving the existing interface.
* | | Merge pull request #2388 from lioncash/constexprbunnei2019-04-1210-10/+10
|\ \ \ | | | | | | | | kernel: Make handle type declarations constexpr
| * | | kernel: Make handle type declarations constexprLioncash2019-04-1110-10/+10
| | |/ | |/| | | | | | | | | | | | | | | | Some objects declare their handle type as const, while others declare it as constexpr. This makes the const ones constexpr for consistency, and prevent unexpected compilation errors if these happen to be attempted to be used within a constexpr context.
* / | kernel/server_session: Remove obsolete TODOsLioncash2019-04-101-7/+2
|/ / | | | | | | These are holdovers from Citra.
* | Merge pull request #1957 from DarkLordZach/title-providerbunnei2019-04-104-10/+9
|\ \ | | | | | | file_sys: Provide generic interface for accessing game data
| * | patch_manager: Dump NSO name with build IDZach Hilman2019-03-281-2/+1
| | |
| * | game_list: Register content with ContentProviderZach Hilman2019-03-271-2/+3
| | |
| * | core: Port current uses of RegisteredCache to ContentProviderZach Hilman2019-03-273-9/+8
| | |
* | | kernel/process: Set page table when page table resizes occur.Lioncash2019-04-091-0/+2
| |/ |/| | | | | | | | | | | | | | | We need to ensure dynarmic gets a valid pointer if the page table is resized (the relevant pointers would be invalidated in this scenario). In this scenario, the page table can be resized depending on what kind of address space is specified within the NPDM metadata (if it's present).
* | Merge pull request #2361 from lioncash/pagetablebunnei2019-04-073-4/+2
|\ \ | | | | | | core/memory: Minor simplifications to page table management
| * | kernel: Handle page table switching within MakeCurrentProcess()Lioncash2019-04-073-4/+2
| | | | | | | | | | | | | | | Centralizes the page table switching to one spot, rather than making calling code deal with it everywhere.
* | | kernel/server_session: Return a std::pair from CreateSessionPair()Lioncash2019-04-064-11/+8
| | | | | | | | | | | | | | | | | | Keeps the return type consistent with the function name. While we're at it, we can also reduce the amount of boilerplate involved with handling these by using structured bindings.
* | | kernel/server_port: Return a std::pair from CreatePortPair()Lioncash2019-04-062-7/+7
|/ / | | | | | | Returns the same type that the function name describes.
* | Merge pull request #2325 from lioncash/namebunnei2019-04-061-0/+4
|\ \ | | | | | | kernel/server_session: Provide a GetName() override
| * | kernel/server_session: Provide a GetName() overrideLioncash2019-04-031-0/+4
| | | | | | | | | | | | | | | | | | Given server sessions can be given a name, we should allow retrieving it instead of using the default implementation of GetName(), which would just return "[UNKNOWN KERNEL OBJECT]".
* | | Merge pull request #2334 from lioncash/overridebunnei2019-04-069-18/+5
|\ \ \ | | | | | | | | core: Add missing override specifiers where applicable
| * | | core: Add missing override specifiers where applicableLioncash2019-04-049-18/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Applies the override specifier where applicable. In the case of destructors that are defaulted in their definition, they can simply be removed. This also removes the unnecessary inclusions being done in audin_u and audrec_u, given their close proximity.
* | | | Merge pull request #2339 from lioncash/rankbunnei2019-04-063-12/+15
|\ \ \ \ | | | | | | | | | | service/fsp_srv: Update SaveDataInfo and SaveDataDescriptor structs
| * | | | service/fsp_srv: Don't pass SaveDataDescriptor instances by value.Lioncash2019-04-052-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | Passing around a 64 byte data struct by value is kind of wasteful, instead pass a reference to the struct.
| * | | | service/fsp_srv: Remove unnecessary unknown member in OpenSaveDataFileSystemLioncash2019-04-051-7/+8
| | | | | | | | | | | | | | | | | | | | | | | | | The unknown member here is actually padding due to being passed as a struct. We can do the same, and remove the need to pop a padding word.
| * | | | service/fsp_srv: Update SaveDataInfo and SaveDataDescriptor structsLioncash2019-04-051-1/+3
| |/ / / | | | | | | | | | | | | | | | | I realized that I updated the documentation on SwitchBrew a while ago, but never actually updated the structs within yuzu.
* | | | Merge pull request #2329 from lioncash/sanitizebunnei2019-04-061-0/+14
|\ \ \ \ | | | | | | | | | | kernel/svc: Properly sanitize mutex address in WaitProcessWideKeyAtomic
| * | | | kernel/svc: Properly sanitize mutex address in WaitProcessWideKeyAtomicLioncash2019-04-041-0/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We need to be checking whether or not the given address is within the kernel address space or if the given address isn't word-aligned and bail in these scenarios instead of trashing any kernel state.
* | | | | Merge pull request #2344 from lioncash/resultbunnei2019-04-061-4/+0
|\ \ \ \ \ | | | | | | | | | | | | hle/result: Remove unnecessary bitfield entry for ResultCode
| * | | | | hle/result: Remove unnecessary bitfield entry for ResultCodeLioncash2019-04-051-4/+0
| | | | | | | | | | | | | | | | | | | | | | | | This is a hold over from the 3DS error codes in Citra.
* | | | | | Merge pull request #2338 from lioncash/fsbunnei2019-04-051-5/+8
|\ \ \ \ \ \ | |/ / / / / |/| | | | | filesystem: Use a std::string_view in OpenFile()
| * | | | | filesystem: Use a std::string_view in OpenFile()Lioncash2019-04-051-5/+8
| | |/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | Rather than make a full copy of the path, we can just use a string view and truncate the viewed portion of the string instead of creating a totally new truncated string.
* / | | | hle/service: Resolve unused variable warningsLioncash2019-04-048-62/+58
|/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In several places, we have request parsers where there's nothing to really parse, simply because the HLE function in question operates on buffers. In these cases we can just remove these instances altogether. In the other cases, we can retrieve the relevant members from the parser and at least log them out, giving them some use.
* | | | Merge pull request #2328 from lioncash/transferbunnei2019-04-043-17/+37
|\ \ \ \ | | | | | | | | | | service/am: Correct behavior of CreateTransferMemoryStorage()
| * | | | service/am: Correct behavior of CreateTransferMemoryStorage()Lioncash2019-04-031-6/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | For whatever reason, shared memory was being used here instead of transfer memory, which (quite clearly) will not work based off the name of the function. This corrects this wonky usage of shared memory.
| * | | | kernel/transfer_memory: Add accessors to data and sizesLioncash2019-04-032-11/+31
| |/ / / | | | | | | | | | | | | Also amend erroneous use of size_t. We should be using u64 here.
* | | | Merge pull request #2324 from lioncash/enum-unusedbunnei2019-04-042-2/+0
|\ \ \ \ | | | | | | | | | | kernel/object: Remove unused handle type entry
| * | | | kernel/object: Remove unused handle type entryLioncash2019-04-032-2/+0
| | |/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | The AddressArbiter type isn't actually used, given the arbiter itself isn't a direct kernel object (or object that implements the wait object facilities). Given this, we can remove the enum entry entirely.
* | | | Merge pull request #2294 from lioncash/fatalbunnei2019-04-032-36/+63
|\ \ \ \ | |_|/ / |/| | | service/am: Implement EnterFatalSection/LeaveFatalSection
| * | | service/am: Implement EnterFatalSection and LeaveFatalSectionLioncash2019-03-262-2/+29
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These functions act in tandem similar to how a lock or mutex require a balanced lock()/unlock() sequence. EnterFatalSection simply increments a counter for how many times it has been called, while LeaveFatalSection ensures that a previous call to EnterFatalSection has occured. If a previous call has occurred (the counter is not zero), then the counter gets decremented as one would expect. If a previous call has not occurred (the counter is zero), then an error code is returned.
| * | | service/am: Sort ISelfController's member functions according to table orderLioncash2019-03-262-36/+36
| | | | | | | | | | | | | | | | | | | | Makes the declaration order of the handling functions consistent with the handler table itself.
* | | | Merge pull request #2305 from lioncash/sharedbunnei2019-04-033-5/+18
|\ \ \ \ | | | | | | | | | | kernel/shared_memory: Sanitize supplied size when unmapping
| * | | | kernel/shared_memory: Remove unused core/memory.h includeLioncash2019-03-291-1/+0
| | | | | | | | | | | | | | | | | | | | | | | | | Nothing from this header is used, so we can remove this include, getting rid of a dependency on it.
| * | | | kernel/shared_memory: Sanitize supplied size when unmappingLioncash2019-03-293-4/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel makes sure that the given size to unmap is always the same size as the entire region managed by the shared memory instance, otherwise it returns an error code signifying an invalid size. This is similarly done for transfer memory (which we already check for).
* | | | | Merge pull request #2314 from lioncash/constbunnei2019-04-0311-18/+18
|\ \ \ \ \ | |_|_|/ / |/| | | | kernel/thread: Minor interface cleanup
| * | | | kernel/thread: Make AllWaitObjectsReady() a const qualified member functionLioncash2019-04-022-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that ShouldWait() is a const qualified member function, this one can be made const qualified as well, since it can handle passing a const qualified this pointer to ShouldWait().
| * | | | kernel/wait_object: Make ShouldWait() take thread members by pointer-to-constLioncash2019-04-0211-11/+11
| | | | | | | | | | | | | | | | | | | | | | | | | Given this is intended as a querying function, it doesn't make sense to allow the implementer to modify the state of the given thread.
| * | | | kernel/thread: Avoid sign conversion within GetCommandBufferAddress()Lioncash2019-04-011-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously this was performing a u64 + int sign conversion. When dealing with addresses, we should generally be keeping the arithmetic in the same signedness type. This also gets rid of the static lifetime of the constant, as there's no need to make a trivial type like this potentially live for the entire duration of the program.
| * | | | kernel/thread: Make parameter of GetWaitObjectIndex() const qualifiedLioncash2019-04-012-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | The pointed to member is never actually modified, so it can be made const.
* | | | | Merge pull request #2270 from lioncash/plistbunnei2019-04-037-2/+123
|\ \ \ \ \ | | | | | | | | | | | | kernel/svc: Implement svcGetProcessList and svcGetThreadList
| * | | | | kernel/svc: Implement svcGetThreadListLioncash2019-04-024-1/+70
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Similarly like svcGetProcessList, this retrieves the list of threads from the current process. In the kernel itself, a process instance maintains a list of threads, which are used within this function. Threads are registered to a process' thread list at thread initialization, and unregistered from the list upon thread destruction (if said thread has a non-null owning process). We assert on the debug event case, as we currently don't implement kernel debug objects.
| * | | | | kernel/svc: Implement svcGetProcessListLioncash2019-04-024-1/+53
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This service function simply copies out a specified number of kernel process IDs, while simultaneously reporting the total number of processes.
* | | | | | Merge pull request #2313 from lioncash/reslimitbunnei2019-04-023-14/+6
|\ \ \ \ \ \ | |/ / / / / |/| | | | | kernel/resource_limit: Remove the name member from resource limits
| * | | | | kernel/resource_limit: Remove the name member from resource limitsLioncash2019-04-013-14/+6
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This doesn't really provide any benefit to the resource limit interface. There's no way for callers to any of the service functions for resource limits to provide a custom name, so all created instances of resource limits other than the system resource limit would have a name of "Unknown". The system resource limit itself is already trivially identifiable from its limit values, so there's no real need to take up space in the object to identify one object meaningfully out of N total objects.
* | | | | process: Fix up compilationReinUsesLisp2019-04-021-1/+1
| | | | |
* | | | | Merge pull request #2281 from lioncash/memorybunnei2019-04-022-4/+5
|\ \ \ \ \ | |/ / / / |/| | | | kernel/codeset: Make CodeSet's memory data member a regular std::vector
| * | | | kernel/codeset: Make CodeSet's memory data member a regular std::vectorLioncash2019-03-222-4/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The use of a shared_ptr is an implementation detail of the VMManager itself when mapping memory. Because of that, we shouldn't require all users of the CodeSet to have to allocate the shared_ptr ahead of time. It's intended that CodeSet simply pass in the required direct data, and that the memory manager takes care of it from that point on. This means we just do the shared pointer allocation in a single place, when loading modules, as opposed to in each loader.
* | | | | Merge pull request #2301 from FearlessTobi/remove-amiibo-settingbunnei2019-04-011-1/+1
|\ \ \ \ \ | | | | | | | | | | | | core/yuzu: Remove enable_nfc setting
| * | | | | core/yuzu: Remove enable_nfc settingfearlessTobi2019-03-291-1/+1
| | |_|/ / | |/| | | | | | | | | | | | | This was initially added to prevent problems from stubbed/not implemented NFC services, but as we never encountered such and as it's only used in a deprecated function anyway, I guess we can just remove it to prevent more clutter of the settings.
* | | | | general: Use deducation guides for std::lock_guard and std::unique_lockLioncash2019-04-013-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Since C++17, the introduction of deduction guides for locking facilities means that we no longer need to hardcode the mutex type into the locks themselves, making it easier to switch mutex types, should it ever be necessary in the future.
* | | | | Merge pull request #2304 from lioncash/memsizebunnei2019-03-313-9/+28
|\ \ \ \ \ | | | | | | | | | | | | kernel/process: Report total physical memory used to svcGetInfo slightly better
| * | | | | kernel/process: Report total physical memory used to svcGetInfoLioncash2019-03-293-4/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Reports the (mostly) correct size through svcGetInfo now for queries to total used physical memory. This still doesn't correctly handle memory allocated via svcMapPhysicalMemory, however, we don't currently handle that case anyways.
| * | | | | kernel/process: Store the total size of the code memory loadedLioncash2019-03-292-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will be necessary to properly report the used memory size in svcGetInfo.
| * | | | | kernel/process: Store the main thread stack size to a data memberLioncash2019-03-282-4/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will be necessary in order to properly report memory usage within svcGetInfo.
| * | | | | kernel/process: Make Run's stack size parameter a u64Lioncash2019-03-282-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will make operating with the process-related SVC commands much nicer in the future (the parameter representing the stack size in svcStartProcess is a 64-bit value).
| * | | | | kernel/process: Ensure that given stack size is always page-alignedLioncash2019-03-281-0/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel always makes sure that the given stack size is aligned to page boundaries.
* | | | | | Merge pull request #2308 from lioncash/deductionbunnei2019-03-313-12/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/scheduler: Minor tidying up
| * | | | | | kernel/scheduler: Remove unused parameter to AddThread()Lioncash2019-03-303-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was made unused in b404fcdf1443b91ac9994c05ad1fe039fcd9675e, but the parameter itself wasn't removed.
| * | | | | | kernel/scheduler: Use deduction guides on mutex locksLioncash2019-03-301-8/+8
| | |_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | Since C++17, we no longer need to explicitly specify the type of the mutex within the lock_guard. The type system can now deduce these with deduction guides.
* | | | | | service/fatal: Mark local variables as const where applicableLioncash2019-03-301-6/+6
| | | | | |
* | | | | | service/fatal: Remove unnecessary semicolonLioncash2019-03-301-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | Resolves a -Wextra-semi warning.
* | | | | | service/fatal: Name FatalInfo structure membersLioncash2019-03-301-31/+44
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Based off RE, most of these structure members are register values, which makes, sense given this service is used to convey fatal errors. One member indicates the program entry point address, one is a set of bit flags used to determine which registers to print, and one member indicates the architecture type. The only member that still isn't determined is the final member within the data structure.
* | | | | Merge pull request #2266 from FernandoS27/arbitrationbunnei2019-03-295-14/+18
|\ \ \ \ \ | | | | | | | | | | | | Kernel: Fixes to Arbitration and SignalProcessWideKey Management
| * | | | | Fix small bug that kept a thread as a condvar thread after being signalled.Fernando Sahmkow2019-03-202-6/+8
| | | | | |
| * | | | | Add CondVar Thread State.Fernando Sahmkow2019-03-204-4/+6
| | | | | |
| * | | | | Small fixes to address_arbiter to better match the IDB.Fernando Sahmkow2019-03-202-5/+5
| | | | | |
* | | | | | Merge pull request #2265 from FernandoS27/multilevelqueuebunnei2019-03-292-19/+27
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | Replace old Thread Queue for a new Multi Level Queue
| * | | | | Fixes and corrections on formatting.Fernando Sahmkow2019-03-271-6/+9
| | | | | |
| * | | | | Use MultiLevelQueue instead of old ThreadQueueListFernando Sahmkow2019-03-272-19/+24
| | |/ / / | |/| | |
* | | | | Merge pull request #2284 from lioncash/heap-allocbunnei2019-03-283-59/+81
|\ \ \ \ \ | |/ / / / |/| | | | kernel/vm_manager: Unify heap allocation/freeing functions
| * | | | kernel/vm_manager: Handle shrinking of the heap size within SetHeapSize()Lioncash2019-03-242-24/+46
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | One behavior that we weren't handling properly in our heap allocation process was the ability for the heap to be shrunk down in size if a larger size was previously requested. This adds the basic behavior to do so and also gets rid of HeapFree, as it's no longer necessary now that we have allocations and deallocations going through the same API function. While we're at it, fully document the behavior that this function performs.
| * | | | kernel/vm_manager: Rename HeapAllocate to SetHeapSizeLioncash2019-03-243-4/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes it more obvious that this function is intending to stand in for the actual supervisor call itself, and not acting as a general heap allocation function. Also the following change will merge the freeing behavior of HeapFree into this function, so leaving it as HeapAllocate would be misleading.
| * | | | kernel/vm_manager: Handle case of identical calls to HeapAllocateLioncash2019-03-241-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In cases where HeapAllocate is called with the same size of the current heap, we can simply do nothing and return successfully. This avoids doing work where we otherwise don't have to. This is also what the kernel itself does in this scenario.
| * | | | kernel/vm_manager: Remove unused class variablesLioncash2019-03-241-3/+0
| | | | | | | | | | | | | | | | | | | | | | | | | Over time these have fallen out of use due to refactoring, so these can be removed.
| * | | | kernel/vm_manager: Remove unnecessary heap_used data memberLioncash2019-03-243-13/+2
| | | | | | | | | | | | | | | | | | | | | | | | | This isn't required anymore, as all the kernel ever queries is the size of the current heap, not the total usage of it.
| * | | | kernel/vm_manager: Tidy up heap allocation codeLioncash2019-03-243-27/+37
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Another holdover from citra that can be tossed out is the notion of the heap needing to be allocated in different addresses. On the switch, the base address of the heap will always be managed by the memory allocator in the kernel, so this doesn't need to be specified in the function's interface itself. The heap on the switch is always allocated with read/write permissions, so we don't need to add specifying the memory permissions as part of the heap allocation itself either. This also corrects the error code returned from within the function. If the size of the heap is larger than the entire heap region, then the kernel will report an out of memory condition.
* | | | | Merge pull request #2285 from lioncash/unused-structbunnei2019-03-261-8/+0
|\ \ \ \ \ | |_|_|_|/ |/| | | | kernel/process: Remove unused AddressMapping struct
| * | | | kernel/process: Remove unused AddressMapping structLioncash2019-03-241-8/+0
| | | | | | | | | | | | | | | | | | | | Another leftover from citra that's now no longer necessary.
* | | | | Merge pull request #2287 from lioncash/coretiming-cbbunnei2019-03-264-9/+9
|\ \ \ \ \ | | | | | | | | | | | | core/core_timing: Make callback parameters consistent
| * | | | | core/core_timing: Make callback parameters consistentLioncash2019-03-244-9/+9
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In some cases, our callbacks were using s64 as a parameter, and in other cases, they were using an int, which is inconsistent. To make all callbacks consistent, we can just use an s64 as the type for late cycles, given it gets rid of the need to cast internally. While we're at it, also resolve some signed/unsigned conversions that were occurring related to the callback registration.
* / / / / kernel/kernel: Remove unnecessary forward declarationLioncash2019-03-241-3/+0
|/ / / / | | | | | | | | | | | | | | | | This is no longer necessary, as ResultVal isn't used anywhere in the header.
* | | | Merge pull request #2232 from lioncash/transfer-memorybunnei2019-03-245-6/+280
|\ \ \ \ | |/ / / |/| | | core/hle/kernel: Split transfer memory handling out into its own class
| * | | core/hle/kernel/svc: Implement svcUnmapTransferMemoryLioncash2019-03-131-1/+48
| | | | | | | | | | | | | | | | | | | | Similarly, like svcMapTransferMemory, we can also implement svcUnmapTransferMemory fairly trivially as well.
| * | | core/hle/kernel/svc: Implement svcMapTransferMemoryLioncash2019-03-131-1/+57
| | | | | | | | | | | | | | | | | | | | Now that transfer memory handling is separated from shared memory, we can implement svcMapTransferMemory pretty trivially.
| * | | core/hle/kernel: Split transfer memory handling out into its own classLioncash2019-03-135-4/+175
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Within the kernel, shared memory and transfer memory facilities exist as completely different kernel objects. They also have different validity checking as well. Therefore, we shouldn't be treating the two as the same kind of memory. They also differ in terms of their behavioral aspect as well. Shared memory is intended for sharing memory between processes, while transfer memory is intended to be for transferring memory to other processes. This breaks out the handling for transfer memory into its own class and treats it as its own kernel object. This is also important when we consider resource limits as well. Particularly because transfer memory is limited by the resource limit value set for it. While we currently don't handle resource limit testing against objects yet (but we do allow setting them), this will make implementing that behavior much easier in the future, as we don't need to distinguish between shared memory and transfer memory allocations in the same place.
* | | | Merge pull request #2221 from DarkLordZach/firmware-versionbunnei2019-03-232-2/+79
|\ \ \ \ | | | | | | | | | | set_sys: Implement GetFirmwareVersion(2) for libnx hosversion
| * | | | set_sys: Move constants to anonymous namespaceZach Hilman2019-03-111-1/+1
| | | | |
| * | | | set_sys: Use official nintendo version stringZach Hilman2019-03-111-11/+7
| | | | |
| * | | | set_sys: Use correct error codes in GetFirmwareVersion*Zach Hilman2019-03-111-21/+41
| | | | |
| * | | | set_sys: Implement GetFirmwareVersion(2) for libnx hosversionZach Hilman2019-03-102-2/+63
| | | | | | | | | | | | | | | Uses the synthesized system archive 9 (SystemVersion) and reports v5.1.0-0.0
* | | | | Merge pull request #2256 from bunnei/gpu-vmmbunnei2019-03-221-12/+4
|\ \ \ \ \ | |_|_|_|/ |/| | | | gpu: Rewrite MemoryManager based on the VMManager implementation.
| * | | | gpu: Rewrite virtual memory manager using PageTable.bunnei2019-03-211-10/+2
| | | | |
| * | | | gpu: Move GPUVAddr definition to common_types.bunnei2019-03-211-2/+2
| | | | |
* | | | | Merge pull request #2234 from lioncash/mutexbunnei2019-03-225-29/+62
|\ \ \ \ \ | | | | | | | | | | | | core/hle/kernel: Make Mutex a per-process class.
| * | | | | core/hle/kernel/mutex: Remove usages of global system accessorsLioncash2019-03-151-11/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Removes the use of global system accessors, and instead uses the explicit interface provided.
| * | | | | core/hle/kernel: Make Mutex a per-process class.Lioncash2019-03-155-18/+47
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes it an instantiable class like it is in the actual kernel. This will also allow removing reliance on global accessors in a following change, now that we can encapsulate a reference to the system instance in the class.
* | | | | | Merge pull request #2275 from lioncash/memflagsbunnei2019-03-224-22/+20
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/vm_manager: Amend flag value for code data
| * | | | | | kernel/vm_manager: Rename CodeStatic/CodeMutable to Code and CodeData respectivelyLioncash2019-03-214-22/+20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes it more evident that one is for actual code and one is for actual data. Mutable and static are less than ideal terms here, because read-only data is technically not mutable, but we were mapping it with that label.
| * | | | | | kernel/vm_manager: Amend flag values for CodeMutableLioncash2019-03-211-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This should actually be using the data flags, rather than the code flags.
* | | | | | | Merge pull request #2276 from lioncash/ambunnei2019-03-221-1/+15
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service/am: Add function table for IDebugFunctions
| * | | | | | | service/am: Add function table for IDebugFunctionsLioncash2019-03-211-1/+15
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | We already have the service related stuff set up for this, however, it's missing the function table.
* | | | | | | Merge pull request #1933 from DarkLordZach/cheat-enginebunnei2019-03-222-0/+6
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | file_sys: Implement parser and interpreter for game memory cheats
| * | | | | | vm_manager: Remove cheat-specific ranges from VMManagerZach Hilman2019-03-053-25/+2
| | | | | | |
| * | | | | | vm_manager: Add support for storing and getting main code regionZach Hilman2019-03-052-0/+28
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Used as root for one region of cheats, set by loader
| * | | | | | controllers/npad: Add accessor for current press stateZach Hilman2019-03-051-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows frontend/features to access pressed buttons conveniently as possible
* | | | | | | Merge pull request #2090 from FearlessTobi/port-4599bunnei2019-03-216-96/+96
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Port citra-emu/citra#4244 and citra-emu/citra#4599: Changes to BitField
| * | | | | | | remove all occurance of specifying endianness inside BitFieldWeiyi Wang2019-02-066-96/+96
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This commit it automatically generated by command in zsh: sed -i -- 's/BitField<\(.*\)_le>/BitField<\1>/g' **/*(D.) BitField is now aware to endianness and default to little endian. It expects a value representation type without storage specification for its template parameter.
* | | | | | | | Merge pull request #2268 from lioncash/codesetbunnei2019-03-214-45/+106
|\ \ \ \ \ \ \ \ | |_|_|_|/ / / / |/| | | | | | | core/kernel: Migrate CodeSet to its own source files
| * | | | | | | kernel/process: Make MapSegment lambda reference parameter constLioncash2019-03-201-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The segment itself isn't actually modified.
| * | | | | | | kernel: Move CodeSet structure to its own source filesLioncash2019-03-204-44/+105
| | |_|_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given this is utilized by the loaders, this allows avoiding inclusion of the kernel process definitions where avoidable. This also keeps the loading format for all executable data separate from the kernel objects.
* | | | | | | Merge pull request #2267 from FernandoS27/fix-2238bunnei2019-03-211-1/+2
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Fix crash caused by #2238.
| * | | | | | | Fix crash caused by 2238.Fernando Sahmkow2019-03-201-1/+2
| |/ / / / / /
* | | | | | | Merge pull request #2224 from lioncash/opusbunnei2019-03-211-34/+48
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | hwopus: Leverage multistream API for decoding regular Opus packets
| * | | | | | hwopus: Leverage multistream API for decoding regular Opus packetsLioncash2019-03-111-34/+48
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | After doing a little more reading up on the Opus codec, it turns out that the multistream API that is part of libopus can handle regular packets. Regular packets are just a degenerate case of multistream Opus packets, and all that's necessary is to pass the number of streams as 1 and provide a basic channel mapping, then everything works fine for that case. This allows us to get rid of the need to use both APIs in the future when implementing multistream variants in a follow-up PR, greatly simplifying the code that needs to be written.
* | | | | | | Merge pull request #2258 from lioncash/ambunnei2019-03-192-13/+73
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service/am: Supply remaining missing IAudioController functions
| * | | | | | | service/am: Add basic implementation of ChangeMainAppletMasterVolumeLioncash2019-03-182-1/+29
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | All this does is supply a new volume level and a fade time in nanoseconds for the volume transition to occur within.
| * | | | | | | service/am: Unstub SetTransparentVolumeRate()Lioncash2019-03-182-1/+17
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Like the other volume setter, this mainly just sets a data member within the service, nothing too special.
| * | | | | | | service/am: Unstub SetExpectedMasterVolume()Lioncash2019-03-182-11/+27
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function passes in the desired main applet and library applet volume levels. We can then just pass those values back within the relevant volume getter functions, allowing us to unstub those as well. The initial values for the library and main applet volumes differ. The main applet volume is 0.25 by default, while the library applet volume is initialized to 1.0 by default in the services themselves.
* | | | | | | | fsp_srv: Unstub SetCurrentProcessLioncash2019-03-182-1/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This just acts as a basic setter for a given PID value and performs no further checking, so we can just store the passed in value.
* | | | | | | | Merge pull request #2238 from lioncash/threadbunnei2019-03-182-21/+41
|\ \ \ \ \ \ \ \ | |/ / / / / / / |/| | | | | | | kernel/thread: Amend conditional test and assignment within UpdatePriority()
| * | | | | | | kernel/thread: Expand documentation of nominal_priority and current_priorityLioncash2019-03-162-3/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Aims to disambiguate why each priority instance exists a little bit. While we're at it, also add an explanatory comment to UpdatePriority().
| * | | | | | | kernel/thread: Make bracing consistent within UpdatePriority()Lioncash2019-03-161-2/+4
| | | | | | | |
| * | | | | | | kernel/thread: Amend condition within UpdatePriority()Lioncash2019-03-161-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This condition was checking against the nominal thread priority, whereas the kernel itself checks against the current priority instead. We were also assigning the nominal priority, when we should be assigning current_priority, which takes priority inheritance into account. This can lead to the incorrect priority being assigned to a thread. Given we recursively update the relevant threads, we don't need to go through the whole mutex waiter list. This matches what the kernel does as well (only accessing the first entry within the waiting list).
| * | | | | | | kernel/thread: Maintain priority ordering of added mutex waiting threadsLioncash2019-03-161-14/+24
| | |_|_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | The kernel keeps the internal waiting list ordered by priority. This is trivial to do with std::find_if followed by an insertion.
* | | | | | | Merge pull request #2252 from bunnei/move-page-tablebunnei2019-03-174-9/+10
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | core: Move PageTable struct into Common.
| * | | | | | | core: Move PageTable struct into Common.bunnei2019-03-174-9/+10
| | | | | | | |
* | | | | | | | Merge pull request #2249 from lioncash/ipcbunnei2019-03-171-0/+30
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | ipc_helpers: Allow pushing and popping floating-point values
| * | | | | | | | ipc_helpers: Allow pushing and popping floating-point valuesLioncash2019-03-161-0/+30
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Certain values that are passed through the IPC buffer are actually floating point values, not solely integral values.
* / / / / / / / kernel/thread: Actually remove the definition of ExitCurrentThread()Lioncash2019-03-161-6/+0
|/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was intended to be removed in 51d7f6bffcc0498a47abc7de27bf0906fc523dae, but I guess I forgot to actually save the file like a dingus.
* | | | | | | Merge pull request #2242 from lioncash/thread-fnbunnei2019-03-164-33/+31
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | kernel/thread: Remove WaitCurrentThread_Sleep() and ExitCurrentThread()
| * | | | | | | kernel/thread: Move thread exiting logic from ExitCurrentThread to svcExitThreadLioncash2019-03-162-8/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Puts the operation on global state in the same places as the rest of the svc calls.
| * | | | | | | kernel/thread: Migrate WaitCurrentThread_Sleep into the Thread interfaceLioncash2019-03-164-25/+24
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than make a global accessor for this sort of thing. We can make it a part of the thread interface itself. This allows getting rid of a hidden global accessor in the kernel code.
* | | | | / / gpu: Use host address for caching instead of guest address.bunnei2019-03-151-1/+2
| |_|_|_|/ / |/| | | | |
* | | | | | Merge pull request #2230 from lioncash/globalbunnei2019-03-152-8/+9
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/process: Remove use of global system accessors
| * | | | | | kernel/process: Remove use of global system accessorsLioncash2019-03-132-8/+9
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | Now that we pass in a reference to the system instance, we can utilize it to eliminate the global accessors in Process-related code.
* | | | | | Merge pull request #2226 from lioncash/privatebunnei2019-03-134-14/+36
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/server_port: Make data members private
| * | | | | | kernel/server_port: Make data members privateLioncash2019-03-114-14/+36
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | With this, all kernel objects finally have all of their data members behind an interface, making it nicer to reason about interactions with other code (as external code no longer has the freedom to totally alter internals and potentially messing up invariants).
* | | | | | Merge pull request #2223 from lioncash/errorbunnei2019-03-133-19/+5
|\ \ \ \ \ \ | | | | | | | | | | | | | | core/hle/result: Tidy up the base error code result header.
| * | | | | | core/hle/result: Remove now-unnecessary manually defined copy assignment operatorLioncash2019-03-101-5/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously this was required, as BitField wasn't trivially copyable. BitField has since been made trivially copyable, so now this isn't required anymore.
| * | | | | | core/hle/result: Amend error in comment description for ResultCodeLioncash2019-03-101-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of another holdover from Citra, and describes the OS on the Switch instead.
| * | | | | | core/hle/result: Remove now-unused constructor for ResultCodeLioncash2019-03-101-10/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that the final stray ErrorDescription member was relocated, we can finally remove it and its relevant constructor in the ResultCode union.
| * | | | | | core/hle/result: Relocate IPC error code to ipc_helpersLioncash2019-03-103-3/+4
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Relocates the error code to where it's most related, similar to how all the other error codes are. Previously we were including a non-generic error in the main result code header.
* | | | | | Merge pull request #2166 from lioncash/vi-init-servicebunnei2019-03-139-40/+146
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | service/vi: Unstub GetDisplayService
| * | | | | service/vi: Unstub GetDisplayServiceLioncash2019-02-275-11/+49
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function is also supposed to check its given policy type with the permission of the service itself. This implements the necessary machinery to unstub these functions. Policy::User seems to just be basic access (which is probably why vi:u is restricted to that policy), while the other policy seems to be for extended abilities regarding which displays can be managed and queried, so this is assumed to be for a background compositor (which I've named, appropriately, Policy::Compositor).
| * | | | | core/ipc_helper: Allow popping all signed value types with RequestParserLioncash2019-02-271-0/+15
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no real reason this shouldn't be allowed, given some values sent via a request can be signed. This also makes it less annoying to work with popping enum values, given an enum class with no type specifier will work out of the box now. It's also kind of an oversight to allow popping s64 values, but nothing else.
| * | | | | service/vi: Remove use of a module classLioncash2019-02-268-46/+99
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This didn't really provide much benefit here, especially since the subsequent change requires that the behavior for each service's GetDisplayService differs in a minor detail. This also arguably makes the services nicer to read, since it gets rid of an indirection in the class hierarchy.
* | | | | | Merge pull request #2211 from lioncash/arbiterbunnei2019-03-127-63/+79
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel: Make the address arbiter instance per-process
| * | | | | | kernel: Make the address arbiter instance per-processLioncash2019-03-086-26/+33
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that we have the address arbiter extracted to its own class, we can fix an innaccuracy with the kernel. Said inaccuracy being that there isn't only one address arbiter. Each process instance contains its own AddressArbiter instance in the actual kernel. This fixes that and gets rid of another long-standing issue that could arise when attempting to create more than one process.
| * | | | | | kernel/svc: Move address arbiter signaling behind a unified API functionLioncash2019-03-083-22/+26
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Similar to how WaitForAddress was isolated to its own function, we can also move the necessary conditional checking into the address arbiter class itself, allowing us to hide the implementation details of it from public use.
| * | | | | | kernel/svc: Move address arbiter waiting behind a unified API functionLioncash2019-03-083-19/+24
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than let the service call itself work out which function is the proper one to call, we can make that a behavior of the arbiter itself, so we don't need to directly expose those implementation details.
* | | | | | | service/service: Remove unncessary calls to c_str()Lioncash2019-03-101-4/+3
| |_|/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These can just be passed regularly, now that we use fmt instead of our old logging system. While we're at it, make the parameters to MakeFunctionString std::string_views.
* | | | | | Merge pull request #2207 from lioncash/hwopusbunnei2019-03-101-69/+107
|\ \ \ \ \ \ | | | | | | | | | | | | | | service/audio/hwopus: Move decoder state to its own class
| * | | | | | service/audio/hwopus: Move decoder state to its own classLioncash2019-03-071-50/+85
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Moves the non-multistream specific state to its own class. This will be necessary to support the multistream variants of opus decoding.
| * | | | | | service/audio/hwopus: Provide a name for the second word of OpusPacketHeaderLioncash2019-03-071-2/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This indicates the entropy coder's final range.
| * | | | | | service/audio/hwopus: Move Opus packet header out of the IHardwareOpusDecoderManagerLioncash2019-03-071-17/+17
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This will be utilized by more than just that class in the future. This also renames it from OpusHeader to OpusPacketHeader to be more specific about what kind of header it is.
| * | | | | | service/audio/hwopus: Enclose internals in an anonymous namespaceLioncash2019-03-071-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes it impossible to violate the ODR, as well as providing a place for future changes.
* | | | | | | Merge pull request #2193 from lioncash/globalbunnei2019-03-102-9/+11
|\ \ \ \ \ \ \ | |_|_|_|_|_|/ |/| | | | | | kernel/scheduler: Pass in system instance in constructor
| * | | | | | kernel/scheduler: Pass in system instance in constructorLioncash2019-03-042-9/+11
| | |_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids directly relying on the global system instance and instead makes an arbitrary system instance an explicit dependency on construction. This also allows removing dependencies on some global accessor functions as well.
* | | | | | Merge pull request #2210 from lioncash/optionalbunnei2019-03-084-47/+47
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/hle_ipc: Convert std::shared_ptr IPC header instances to std::optional
| * | | | | | kernel/hle_ipc: Convert std::shared_ptr IPC header instances to std::optionalLioncash2019-03-084-47/+47
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | There's no real need to use a shared lifetime here, since we don't actually expose them to anything else. This is also kind of an unnecessary use of the heap given the objects themselves are so small; small enough, in fact that changing over to optionals actually reduces the overall size of the HLERequestContext struct (818 bytes to 808 bytes).
* | | | | | Merge pull request #2195 from lioncash/shared-globalbunnei2019-03-071-3/+2
|\ \ \ \ \ \ | |/ / / / / |/| | | | | kernel/shared_memory: Get rid of the use of global accessor functions within Create()
| * | | | | kernel/shared_memory: Get rid of the use of global accessor functions within Create()Lioncash2019-03-041-3/+2
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given we already pass in a reference to the kernel that the shared memory instance is created under, we can just use that to check the current process, rather than using the global accessor functions. This allows removing direct dependency on the system instance entirely.
* | | | | Merge pull request #2202 from lioncash/port-privbunnei2019-03-076-36/+78
|\ \ \ \ \ | | | | | | | | | | | | kernel/client_session, kernel/server_session: Make data members private
| * | | | | kernel/server_session: Make data members privateLioncash2019-03-065-32/+73
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes it much nicer to locally reason about server session behavior, as part of its functionality isn't placed around other classes.
| * | | | | kernel/client_session: Make data members privateLioncash2019-03-061-4/+5
| |/ / / / | | | | | | | | | | | | | | | | | | | | These can be made private, as they aren't accessed in contexts that require them to be public.
* | | | | Merge pull request #2206 from lioncash/audio-stopbunnei2019-03-071-1/+3
|\ \ \ \ \ | | | | | | | | | | | | service/audio/audout_u: Only actually stop the audio stream in StopAudioOut if the stream is playing
| * | | | | service/audio/audout_u: Only actually stop the audio stream in StopAudioOut if the stream is playingLioncash2019-03-071-1/+3
| | |/ / / | |/| | | | | | | | | | | | | | | | | | The service itself only does further actions if the stream is playing. If the stream is already stopped, then it just exits successfully.
* | | | | Merge pull request #2055 from bunnei/gpu-threadbunnei2019-03-074-15/+5
|\ \ \ \ \ | | | | | | | | | | | | Asynchronous GPU command processing
| * | | | | gpu: Move command processing to another thread.bunnei2019-03-071-1/+1
| | | | | |
| * | | | | gpu: Refactor command and swap buffers interface for asynch.bunnei2019-03-073-14/+4
| |/ / / /
* | | | | Merge pull request #2197 from lioncash/includebunnei2019-03-076-8/+12
|\ \ \ \ \ | |/ / / / |/| | | | core/hle/ipc: Remove unnecessary includes
| * | | | core/hle/ipc: Remove unnecessary includesLioncash2019-03-056-8/+12
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Removes a few inclusion dependencies from the headers or replaces existing ones with ones that don't indirectly include the required headers. This allows removing an inclusion of core/memory.h, meaning that if the memory header is ever changed in the future, it won't result in rebuilding the entirety of the HLE services (as the IPC headers are used quite ubiquitously throughout the HLE service implementations).
* | | | Merge pull request #2199 from lioncash/arbiterbunnei2019-03-065-110/+181
|\ \ \ \ | | | | | | | | | | kernel/address_arbiter: Convert the address arbiter into a class
| * | | | kernel/address_arbiter: Pass in system instance to constructorLioncash2019-03-054-21/+39
| | | | | | | | | | | | | | | | | | | | | | | | | Allows getting rid of reliance on the global accessor functions and instead operating on the provided system instance.
| * | | | kernel/address_arbiter: Minor tidying upLioncash2019-03-051-18/+18
| | | | | | | | | | | | | | | | | | | | | | | | | - Invert conditions into guard clases where applicable. - Mark std::vector parameter of WakeThreads as const
| * | | | kernel/address_arbiter: Convert the address arbiter into a classLioncash2019-03-055-82/+135
| |/ / / | | | | | | | | | | | | | | | | | | | | Places all of the functions for address arbiter operation into a class. This will be necessary for future deglobalizing efforts related to both the memory and system itself.
* | | | hle/service/audio/audout_u: Correct lack of return in failure case of AppendAudioOutBufferImpl()Lioncash2019-03-061-0/+1
| | | | | | | | | | | | | | | | | | | | Previously we were overwriting the error case with a success code further down (which is definitely not what we should be doing here).
* | | | Merge pull request #2194 from lioncash/membunnei2019-03-063-30/+66
|\ \ \ \ | | | | | | | | | | svc: Move memory range checking functions to the VMManager class
| * | | | vm_manager: Use range helpers in HeapAlloc() and HeapFree()Lioncash2019-03-041-4/+2
| | | | | | | | | | | | | | | | | | | | Significantly tidies up two guard conditionals.
| * | | | vm_manager: Provide address range checking functions for other memory regionsLioncash2019-03-042-4/+35
| | | | | | | | | | | | | | | | | | | | | | | | | Makes the interface uniform when it comes to checking various memory regions.
| * | | | svc: Migrate address range checking functions to VMManagerLioncash2019-03-043-23/+30
| |/ / / | | | | | | | | | | | | Provides a bit of a more proper interface for these functions.
* | | | Merge pull request #2200 from lioncash/audiobunnei2019-03-063-10/+20
|\ \ \ \ | | | | | | | | | | hle/service/audio: Extract audio error codes to a header
| * | | | hle/service/audio: Extract audio error codes to a headerLioncash2019-03-053-10/+20
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | Places all error codes in an easily includable header. This also corrects the unsupported error code (I accidentally used the hex value when I meant to use the decimal one).
* / / / kernel/thread: Remove obsolete TODO in Create()Lioncash2019-03-051-2/+0
|/ / / | | | | | | | | | This is a TODO carried over from Citra that doesn't apply here.
* | | Merge pull request #2180 from lioncash/audrenbunnei2019-03-011-1/+12
|\ \ \ | | | | | | | | service/audio: Provide an implementation of ExecuteAudioRendererRendering
| * | | service/audio: Provide an implementation of ExecuteAudioRendererRenderingLioncash2019-03-011-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | This service function appears to do nothing noteworthy on the switch. All it does at the moment is either return an error code or abort the system. Given we obviously don't want to kill the system, we just opt for always returning the error code.
* | | | service/audio/audren_u: Implement OpenAudioRendererAutoLioncash2019-03-012-7/+20
|/ / / | | | | | | | | | | | | | | | | | | This currently has the same behavior as the regular OpenAudioRenderer API function, so we can just move the code within OpenAudioRenderer to an internal function that both service functions call.
* | | service/hid: Amend forward declaration of ServiceManagerLioncash2019-02-271-1/+1
| | | | | | | | | | | | | | | The SM namespace is within the Service namespace, so this was forward declaring a type that didn't exist.
* | | Merge pull request #2169 from lioncash/namingbunnei2019-02-271-13/+13
|\ \ \ | | | | | | | | audio_core/audio_renderer: Provide names for some parameters of AudioRendererParameter
| * | | audio_core/audio_renderer: Name previously unknown parameters of AudioRendererParameterLioncash2019-02-271-13/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Provides names for previously unknown entries (aside from the two u8 that appear to be padding bytes, and a single word that also appears to be reserved or padding). This will be useful in subsequent changes when unstubbing behavior related to the audio renderer services.
* | | | Merge pull request #2161 from lioncash/handle-tablebunnei2019-02-276-19/+63
|\ \ \ \ | | | | | | | | | | kernel/handle_table: Allow process capabilities to limit the handle table size
| * | | | kernel/handle_table: Make local variables as const where applicableLioncash2019-02-251-4/+5
| | | | | | | | | | | | | | | | | | | | Makes immutable state explicit.
| * | | | kernel/handle_table: Allow process capabilities to limit the handle table sizeLioncash2019-02-256-10/+54
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel allows restricting the total size of the handle table through the process capability descriptors. Until now, this functionality wasn't hooked up. With this, the process handle tables become properly restricted. In the case of metadata-less executables, the handle table will assume the maximum size is requested, preserving the behavior that existed before these changes.
| * | | | kernel/handle-table: In-class initialize data membersLioncash2019-02-252-3/+2
| | | | | | | | | | | | | | | | | | | | Directly initializes members where applicable.
| * | | | kernel/handle_table: Resolve truncation warningsLioncash2019-02-251-2/+2
| | |/ / | |/| | | | | | | | | | | | | | Avoids implicit truncation warnings from u32 -> u16 (the truncation is desirable behavior here).
* | | | common/math_util: Move contents into the Common namespaceLioncash2019-02-275-6/+6
| |/ / |/| | | | | | | | | | | These types are within the common library, so they should be within the Common namespace.
* | | service/vi: Update IManagerDisplayService's function tableLioncash2019-02-251-0/+1
|/ / | | | | | | Amends it to add the 7.0.0+ CreateStrayLayer function.
* | service/nvflinger: Store BufferQueue instances as regular data membersLioncash2019-02-227-36/+39
| | | | | | | | | | | | | | The NVFlinger service is already passed into services that need to guarantee its lifetime, so the BufferQueue instances will already live as long as they're needed. Making them std::shared_ptr instances in this case is unnecessary.
* | service/vi/vi_layer: Convert Layer struct into a classLioncash2019-02-216-10/+43
| | | | | | | | | | | | | | Like the previous changes made to the Display struct, this prepares the Layer struct for changes to its interface. Given Layer will be given more invariants in the future, we convert it into a class to better signify that.
* | service/nvflinger: Move display specifics over to vi_displayLioncash2019-02-214-35/+141
| | | | | | | | | | | | | | | | | | With the display and layer structures relocated to the vi service, we can begin giving these a proper interface before beginning to properly support the display types. This converts the display struct into a class and provides it with the necessary functions to preserve behavior within the NVFlinger class.
* | service/nvflinger: Relocate definitions of Layer and Display to the vi serviceLioncash2019-02-206-57/+119
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These are more closely related to the vi service as opposed to the intermediary nvflinger. This also places them in their relevant subfolder, as future changes to these will likely result in subclassing to represent various displays and services, as they're done within the service itself on hardware. The reasoning for prefixing the display and layer source files is to avoid potential clashing if two files with the same name are compiled (e.g. if 'display.cpp/.h' or 'layer.cpp/.h' is added to another service at any point), which MSVC will actually warn against. This prevents that case from occurring. This also presently coverts the std::array introduced within f45c25aabacc70861723a7ca1096a677bd987487 back to a std::vector to allow the forward declaration of the Display type. Forward declaring a type within a std::vector is allowed since the introduction of N4510 (http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4510.html) by Zhihao Yuan.
* | address_arbiter: Use nested namespaces where applicableLioncash2019-02-162-8/+4
| | | | | | | | | | | | A fairly trivial change. Other sections of the codebase use nested namespaces instead of separate namespaces here. This one must have just been overlooked.
* | core_timing: Convert core timing into a classLioncash2019-02-1632-81/+123
| | | | | | | | | | | | | | | | | | | | | | Gets rid of the largest set of mutable global state within the core. This also paves a way for eliminating usages of GetInstance() on the System class as a follow-up. Note that no behavioral changes have been made, and this simply extracts the functionality into a class. This also has the benefit of making dependencies on the core timing functionality explicit within the relevant interfaces.
* | core_timing: Rename CoreTiming namespace to Core::TimingLioncash2019-02-1221-54/+50
| | | | | | | | | | | | Places all of the timing-related functionality under the existing Core namespace to keep things consistent, rather than having the timing utilities sitting in its own completely separate namespace.
* | nvdisp_disp0: change drawing message log level from Warning to TraceTobias2019-02-081-3/+3
| | | | | | | | | | This is a leftover from the early yuzu days. We shouldn't log every time when we are drawing by default, so let's change the log level to Trace.
* | service/nvflinger,service/vi: Handle failure cases with exposed APILioncash2019-02-064-47/+133
| | | | | | | | | | | | | | Converts many of the Find* functions to return a std::optional<T> as opposed to returning the raw return values directly. This allows removing a few assertions and handles error cases like the service itself does.
* | service/nvflinger: Mark FindVsyncEvent() as a const member functionLioncash2019-02-052-2/+2
| | | | | | | | | | This member function doesn't actually modify instance state, so it can be marked as a const member function.
* | service/nvflinger: Rename GetVsyncEvent() to FindVsyncEvent()Lioncash2019-02-053-3/+3
|/ | | | | This was missed within #2075. Renames the member function to make it consistent with the rest of the Find* functions.
* Merge pull request #2073 from lioncash/opusbunnei2019-02-011-42/+75
|\ | | | | hwopus: Implement DecodeInterleaved (the newest variant)
| * hwopus: Implement DecodeInterleavedLioncash2019-01-301-4/+35
| | | | | | | | | | | | | | | | | | | | | | | | This functions almost identically to DecodeInterleavedWithPerfOld, however this function also has the ability to reset the decoder context. This is documented as a potentially desirable thing in the libopus manual in some circumstances as it says for the OPUS_RESET_STATE ctl: "This should be called when switching streams in order to prevent the back to back decoding from giving different result from one at a time decoding."
| * hwopus: Deduplicate the decoding code within DecodeInterleavedOld and DecodeInterleavedWithPerfOldLioncash2019-01-301-19/+14
| | | | | | | | Keeps the logic in one spot for use by both functions.
| * hwopus: Replace std::optional<std::reference_wrapper<u64>> with u64*Lioncash2019-01-301-9/+6
| | | | | | | | | | This doesn't really offer anything over the use of a direct pointer, so we can just use that instead.
| * hwopus: Mark local variables as const where applicableLioncash2019-01-301-8/+16
| | | | | | | | Makes non-mutable state more explicit.
| * hwopus: Fill in the rest of the unknown service function namesLioncash2019-01-301-9/+11
| | | | | | | | Filled in via information provided by SwitchBrew.
* | kernel: Remove the Timer classLioncash2019-02-016-227/+0
| | | | | | | | | | | | | | | | | | | | | | | | A holdover from citra, the Horizon kernel on the switch has no prominent kernel object that functions as a timer. At least not to the degree of sophistication that this class provided. As such, this can be removed entirely. This class also wasn't used at all in any meaningful way within the core, so this was just code sitting around doing nothing. This also allows removing a few things from the main KernelCore class that allows it to use slightly less resources overall (though very minor and not anything really noticeable).
* | Merge pull request #2072 from lioncash/servicebunnei2019-01-3112-153/+281
|\ \ | | | | | | service: Update function tables
| * | service/ns: Update function tablesLioncash2019-01-301-14/+20
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew
| * | service/ncm: Update function tablesLioncash2019-01-301-4/+4
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew
| * | service/audio: Update function tablesLioncash2019-01-304-8/+23
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew.
| * | service/am/applet_ae: Update function tablesLioncash2019-01-301-1/+2
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew.
| * | service/fsp-srv: Update function tablesLioncash2019-01-302-17/+25
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew.
| * | service/btm: Update function tablesLioncash2019-01-301-55/+97
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew
| * | service/btdrv: Update function tablesLioncash2019-01-301-46/+101
| | | | | | | | | | | | Updates function tables based off information provided by SwitchBrew.
| * | service/psc: Update function tablesLioncash2019-01-301-8/+9
| | | | | | | | | | | | | | | Updates the function tables based off information on SwitchBrew. Gets rid of a swath of unknown names.
* | | Merge pull request #2077 from lioncash/virtbunnei2019-01-315-15/+3
|\ \ \ | | | | | | | | kernel/wait_object: Devirtualize functions related to manipulating the thread list directly
| * | | kernel/wait_object: Devirtualize functions related to manipulating the thread list directlyLioncash2019-01-301-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | No inheritors of the WaitObject class actually make use of their own implementations of these functions, so they can be made non-virtual. It's also kind of sketchy to allow overriding how the threads get added to the list anyways, given the kernel itself on the actual hardware doesn't seem to customize based off this.
| * | | kernel/timer: Remove unnecessary WakeupAllWaitingThreads() overrideLioncash2019-01-302-6/+0
| | | | | | | | | | | | | | | | | | | | This implementation just calls the base class variant of the function, so this isn't necessary.
| * | | kernel/readable_event: Remove unnecessary WakeupAllWaitingThreads() overrideLioncash2019-01-302-6/+0
| | |/ | |/| | | | | | | This just calls the base variant of the function, so it can be removed.
* | | service/nvflinger: Make FindBufferQueueId() a const member functionLioncash2019-01-302-2/+26
| | | | | | | | | | | | | | | This member function doesn't actually modify instance state, so it can be const-qualified.
* | | service/nvflinger: Rename Get prefix on function to FindLioncash2019-01-303-23/+23
|/ / | | | | | | | | This more accurately describes what the function is actually attempting to do (it's not a simple trivial getter).
* | nvflinger: Add the Null displayLioncash2019-01-301-1/+2
| | | | | | | | | | | | | | In addition to the default, external, EDID, and internal displays, there's also a null display provided as well, which as the name suggests, does nothing but discard all commands given to it. This is provided for completeness.
* | nvflinger: Change log message in OpenDisplay to be a debug log instead of a warningLioncash2019-01-301-1/+1
| | | | | | | | | | | | | | | | | | Opening a display isn't really a thing to warn about. It's an expected thing, so this can be a debug log. This also alters the string to indicate the display name better. Opening "Default" display reads a little nicer compared to Opening display Default.
* | nvflinger: Remove unnecessary header inclusionsLioncash2019-01-301-2/+0
| |
* | nvflinger: Mark locals const where applicableLioncash2019-01-301-11/+11
| | | | | | | | Makes non-mutable state more explicit.
* | nvflinger: Use a std::array for the available displays instead of std::vectorLioncash2019-01-302-7/+7
|/ | | | | The built-in set of displays is fixed, so we can utilize an array instead of a vector here.
* hle/ipc_helpers: Fix clang-format warningsLioncash2019-01-301-1/+0
|
* hle/ipc_helpers: Allow pushing signed valuesLioncash2019-01-291-0/+22
| | | | | This is kind of a large hole in the API, given we allow popping signed values. This fixes that.
* service/pm: Implement SetMaintenanceBoot()Lioncash2019-01-281-1/+10
| | | | | | | This quite literally functions as a basic setter. No other error checking or anything (since there's nothing to really check against). With this, it completes the pm:bm interface in terms of functionality.
* service/pm: Tidy up functionality related to SystemBootModeLioncash2019-01-282-2/+9
| | | | Just minor tidying of interfaces.
* service/vi: Remove stubbed notifier from SetLayerVisibilityLioncash2019-01-281-2/+3
| | | | | | | | | | This appears to be a vestigial API function that's only kept around for compatibility's sake, given the function only returns a success error code and exits. Since that's the case, we can remove the stubbed notification from the log, since doing nothing is technically the correct behavior in this case.
* kernel/svc: Log out uncaught C++ exceptions from svcBreakLioncash2019-01-271-0/+4
| | | | | | | | | | Looking into the implementation of the C++ standard facilities that seem to be within all modules, it appears that they use 7 as a break reason to indicate an uncaught C++ exception. This was primarily found via the third last function called within Horizon's equivalent of libcxxabi's demangling_terminate_handler(), which passes the value 0x80000007 to svcBreak.
* core/frontend/applets/web_browser: Include missing headersLioncash2019-01-171-2/+8
| | | | Gets rid of a few indirect inclusions.
* core/frontend/applets/web_browser: Make OpenPage() non-constLioncash2019-01-171-1/+1
| | | | | | | | This is a function that definitely doesn't always have a non-modifying behavior across all implementations, so this should be made non-const. This gets rid of the need to mark data members as mutable to work around the fact mutating data members needs to occur.
* Merge pull request #1959 from DarkLordZach/custom-rtcbunnei2019-01-101-7/+9
|\ | | | | settings: Add support for setting the RTC manually
| * settings: Use std::chrono::seconds instead of s64 for RTCZach Hilman2019-01-081-6/+4
| |
| * time: Use custom RTC settings if applicable for gameZach Hilman2019-01-081-6/+10
| |
* | Merge pull request #1939 from DarkLordZach/web-appletbunnei2019-01-108-583/+898
|\ \ | |/ |/| applets: Implement HLE web browser applet (LibAppletOff)
| * travis: Use correct package for linux Qt5WebEngineZach Hilman2018-12-292-3/+2
| |
| * web_browser: Add bounds checking to applet interfaceZach Hilman2018-12-294-132/+134
| |
| * core: Add getter and setter for WebBrowserApplet frontendZach Hilman2018-12-281-1/+1
| |
| * applets: Implement LibAppletOff (Web) appletZach Hilman2018-12-283-0/+232
| |
| * hid: Make Hid service accessible and add GetPressStateZach Hilman2018-12-284-459/+540
| |
| * am: Add size parameter to am:IStorage loggingZach Hilman2018-12-281-4/+4
| |
* | Merge pull request #1989 from lioncash/setbunnei2019-01-071-39/+58
|\ \ | | | | | | service/vi: Unstub IApplicationDisplayService's SetLayerScalingMode
| * | service/vi: Correct scaling mode conversionsLioncash2019-01-051-15/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | These values are not equivalent, based off RE. The internal value is put into a lookup table with the following values: [3, 0, 1, 2, 4] So the values absolutely do not map 1:1 like the comment was indicating.
| * | service/vi: Factor out scaling mode conversions from the IPC function itselfLioncash2019-01-051-17/+21
| | | | | | | | | | | | | | | | | | Avoids entangling the IPC buffer appending with the actual operation of converting the scaling values over. This also inserts the proper error handling for invalid scaling values.
| * | service/vi: Unstub IApplicationDisplayService' SetLayerScalingMode()Lioncash2019-01-051-21/+38
| | | | | | | | | | | | | | | | | | | | | | | | This appears to only check if the scaling mode can actually be handled, rather than actually setting the scaling mode for the layer. This implements the same error handling performed on the passed in values.
* | | Merge pull request #1988 from lioncash/resbunnei2019-01-051-12/+8
|\ \ \ | | | | | | | | service/vi: Correct reported dimensions from IApplicationDisplayService's GetDisplayResolution()
| * | | service/vi: Correct reported dimensions from IApplicationDisplayService's GetDisplayResolution()Lioncash2019-01-051-12/+8
| |/ / | | | | | | | | | | | | | | | Within the actual service, it makes no distinguishing between docked and undocked modes. This will always return the constants values reporting 1280x720 as the dimensions.
* | | Merge pull request #1981 from ogniK5377/open-app-area-createbunnei2019-01-051-4/+4
|\ \ \ | | | | | | | | Return no application area when games try to open an application area
| * | | Return no application area when games try to open an application areaDavid Marcec2019-01-041-4/+4
| | | | | | | | | | | | | | | | This will prompt CreateApplicationArea
* | | | Merge pull request #1980 from ogniK5377/applet-msg-updatebunnei2019-01-051-1/+10
|\ \ \ \ | |_|/ / |/| | | Proper no message handling for AM::PopMessage
| * | | Proper no message handling for AM::PopMessageDavid Marcec2019-01-041-1/+10
| |/ / | | | | | | | | | When we have no messages, we should be returning an error code.
* | | Removed pulse event typeDavid Marcec2019-01-043-7/+0
| | | | | | | | | | | | Pulse is considered a hack and nothing should be using it. We should completely remove it
* | | Merge pull request #1975 from lioncash/vibunnei2019-01-041-4/+15
|\ \ \ | | | | | | | | service/vi: Minor updates and corrections to the DisplayInfo struct
| * | | service/vi: Correct initial width and height valuesLioncash2019-01-021-2/+2
| | | | | | | | | | | | | | | | | | | | Based off RE, it appears that almost all display types seem to use 1920x1080 except for a few (null display, edid display).
| * | | service/vi: Document unknown DisplayInfo struct membersLioncash2019-01-021-2/+13
| | | | | | | | | | | | | | | | | | | | | | | | It appears that the two members indicate whether a display has a bounded number of layers (and if set, the second member indicates the total number of layers).
* | | | Fixed botw deadlock(and possibly 30 fps games rendering too fast? needs testing to confirm)David Marcec2019-01-031-1/+1
| |/ / |/| | | | | | | | Upon investigating the issue with #1878, I found that games are the ones who handle the vsync event resetting and not us.
* | | Merge pull request #1976 from lioncash/displaybunnei2019-01-031-4/+17
|\ \ \ | | | | | | | | service/vi: Implement OpenDefaultDisplay in terms of OpenDisplay
| * | | service/vi: Implement OpenDefaultDisplay in terms of OpenDisplayLioncash2019-01-031-4/+17
| |/ / | | | | | | | | | | | | | | | Internally within the vi services, this is essentially all that OpenDefaultDisplay does, so it's trivial to just do the same, and forward the default display string into the function.
* | | service/vi: Implement SetDisplayEnabled()Lioncash2019-01-031-1/+10
| | | | | | | | | | | | | | | | | | | | | This IPC command is simply a stub inside the actual service itself, and just returns a successful error code regardless of input. This is likely only retained in the service interface to not break older code that relied upon it succeeding in some way.
* | | Merge pull request #1977 from lioncash/vi-logbunnei2019-01-031-63/+74
|\ \ \ | | | | | | | | service/vi: Log more information where applicable
| * | | service/vi: Log more information where applicableLioncash2019-01-031-63/+74
| |/ / | | | | | | | | | | | | | | | In many cases, we didn't bother to log out any of the popped data members. This logs them out to the console within the logging call to provide more contextual information.
* / / core/kernel: Remove unnecessary inclusionsLioncash2019-01-0116-16/+22
|/ / | | | | | | Gets rid of a few unnecessary header dependencies in some source files.
* | kernel/svc: Correct misleading error message within CreateThread()Lioncash2018-12-311-2/+3
| | | | | | | | | | | | | | | | | | | | This is a bounds check to ensure that the thread priority is within the valid range of 0-64. If it exceeds 64, that doesn't necessarily mean that an actual priority of 64 was expected (it actually means whoever called the function screwed up their math). Instead clarify the message to indicate the allowed range of thread priorities.
* | kernel/svc: Sanitize core number and thread priorities in CreateThread()Lioncash2018-12-311-6/+17
| | | | | | | | | | | | Now that we handle the kernel capability descriptors we can correct CreateThread to properly check against the core and priority masks like the actual kernel does.
* | kernel/process: Rename GetAllowedProcessorMask() and GetAllowedThreadPriorityMask()Lioncash2018-12-312-11/+11
| | | | | | | | Makes them consistent with their kernel capability counterparts.
* | kernel/svc: Simplify thread core ID sanitizing in CreateThreadLioncash2018-12-311-7/+1
| | | | | | | | | | Rather than use a switch here, this can be collapsed into a simple range check, which is a little easier on the eyes.
* | Merge pull request #1956 from lioncash/process-threadSebastian Valle2018-12-315-57/+51
|\ \ | | | | | | kernel/process: Start the main thread using the specified ideal core
| * | kernel/process: Start the main thread using the specified ideal coreLioncash2018-12-281-2/+2
| | | | | | | | | | | | | | | This matches kernel behavior in that processes are started using their specified ideal core, rather than always starting on core 0.
| * | kernel: Rename 'default' CPU core to 'ideal' coreLioncash2018-12-284-21/+21
| | | | | | | | | | | | | | | | | | This makes the naming more closely match its meaning. It's just a preferred core, not a required default core. This also makes the usages of this term consistent across the thread and process implementations.
| * | kernel/thread: Move process thread initialization into process.cppLioncash2018-12-283-36/+30
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function isn't a general purpose function that should be exposed to everything, given it's specific to initializing the main thread for a Process instance. Given that, it's a tad bit more sensible to place this within process.cpp, which keeps it visible only to the code that actually needs it.
* | | Merge pull request #1847 from ogniK5377/backtrace-breakbunnei2018-12-302-1/+5
|\ \ \ | | | | | | | | Print backtrace on svcBreak
| * | | Moved log backtrace to arm_interface.cpp. Added printing of error code to fatalDavid Marcec2018-12-291-1/+2
| | | |
| * | | Moved backtrace to ArmInterfaceDavid Marcec2018-12-193-11/+3
| | | |
| * | | Moved backtrace to ArmInterfaceDavid Marcec2018-12-031-14/+1
| | | | | | | | | | | | | | | | Added to both dynarmic and unicorn
| * | | Print backtrace on svcBreakDavid Marcec2018-12-033-0/+24
| | | | | | | | | | | | | | | | When we get an svcBreak we get a backtrace now
* | | | service/time: Minor cleanup to GetClockSnapshot()Lioncash2018-12-301-7/+9
| | | | | | | | | | | | | | | | Moves some variables closer to their actual usage sites.
* | | | service/time: Fill in some structures and remove padding where not necessaryLioncash2018-12-302-7/+9
| |_|/ |/| |
* | | kernel/process: Remove most allocation functions from Process' interfaceLioncash2018-12-284-49/+35
| |/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | In all cases that these functions are needed, the VMManager can just be retrieved and used instead of providing the same functions in Process' interface. This also makes it a little nicer dependency-wise, since it gets rid of cases where the VMManager interface was being used, and then switched over to using the interface for a Process instance. Instead, it makes all accesses uniform and uses the VMManager instance for all necessary tasks. All the basic memory mapping functions did was forward to the Process' VMManager instance anyways.
* | Merge pull request #1928 from lioncash/capsbunnei2018-12-276-123/+642
|\ \ | | | | | | kernel: Handle kernel capability descriptors
| * | kernel/process: Hook up the process capability parser to the process itselfLioncash2018-12-212-120/+18
| | | | | | | | | | | | | | | While we're at it, we can also toss out the leftover capability parsing from Citra.
| * | kernel/process_capability: Handle debug capability flagsLioncash2018-12-212-1/+18
| | |
| * | kernel/process_capability: Handle handle table capability flagsLioncash2018-12-212-1/+11
| | | | | | | | | | | | | | | This just specifies the handle table size. There's also a section of reserved bits that are checked against.
| * | kernel/process_capability: Handle kernel version capability flagsLioncash2018-12-212-1/+18
| | |
| * | kernel/process_capability: Handle program capability flagsLioncash2018-12-213-2/+29
| | |
| * | kernel/process_capability: Handle interrupt capability flagsLioncash2018-12-211-1/+21
| | | | | | | | | | | | | | | | | | Similar to the service capability flags, however, we currently don't emulate the GIC, so this currently handles all interrupts as being valid for the time being.
| * | kernel/process_capability: Handle syscall capability flagsLioncash2018-12-212-1/+29
| | |
| * | kernel/process_capability: Handle the priority mask and core mask flagsLioncash2018-12-212-1/+40
| | | | | | | | | | | | | | | | | | Handles the priority mask and core mask flags to allow building up the masks to determine the usable thread priorities and cores for a kernel process instance.
| * | kernel/process: Introduce process capability parsing skeletonLioncash2018-12-214-3/+466
| | | | | | | | | | | | | | | | | | | | | We've had the old kernel capability parser from Citra, however, this is unused code and doesn't actually map to how the kernel on the Switch does it. This introduces the basic functional skeleton for parsing process capabilities.
* | | Merge pull request #1929 from bunnei/fix-hidbunnei2018-12-271-44/+163
|\ \ \ | | | | | | | | hid: Fix SetNpadJoyHoldType and improve logging.
| * | | hid: Fix SetNpadJoyHoldType and improve logging.bunnei2018-12-211-44/+163
| | | |
* | | | Merge pull request #1945 from bunnei/fix-hid-horizbunnei2018-12-271-46/+0
|\ \ \ \ | | | | | | | | | | npad: Remove code to invert input in horizontal mode.
| * | | | npad: Remove code to invert input in horizontal mode.bunnei2018-12-261-46/+0
| | | | | | | | | | | | | | | | | | | | | | | | | - This was incorrect, the game appears to handle this for us. - Fixes horizontal mode with Puyo Puyo Tetris and Super Mario Odyssey.
* | | | | Merge pull request #1949 from lioncash/unmapbunnei2018-12-271-0/+1
|\ \ \ \ \ | | | | | | | | | | | | kernel/vm_manager: Reset region attributes when unmapping a VMA
| * | | | | kernel/vm_manager: Reset region attributes when unmapping a VMALioncash2018-12-271-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Like the other members related to memory regions, the attributes need to be reset back to their defaults as well.
* | | | | | am: Implement GetSaveDataSize and ExtendSaveDataZach Hilman2018-12-272-2/+47
| | | | | | | | | | | | | | | | | | These functions come in a pair and are needed by Smash Ultimate, Minecraft, and Skyrim, amongst others.
* | | | | | filesystem: Populate save data sizes from control dataZach Hilman2018-12-272-0/+53
|/ / / / /
* | | | | Merge pull request #1849 from encounter/svcSetThreadActivitybunnei2018-12-264-6/+72
|\ \ \ \ \ | |/ / / / |/| | | | svc: Implement SetThreadActivity (thread suspension)
| * | | | svc: Implement SetThreadActivity (thread suspension)Luke Street2018-12-044-6/+72
| | | | |
* | | | | Merge pull request #1781 from DarkLordZach/applet-profile-selectbunnei2018-12-233-0/+131
|\ \ \ \ \ | | | | | | | | | | | | am: Implement HLE profile selector applet
| * | | | | applets: Correct event ResetTypes from OneShot to StickyZach Hilman2018-12-034-13/+5
| | | | | | | | | | | | | | | | | | | | | | | | Fixes bugs relating to signalling in software keyboard.
| * | | | | am: Use ProfileSelect appletZach Hilman2018-12-031-0/+4
| | | | | |
| * | | | | applets: Implement ProfileSelect appletZach Hilman2018-12-032-0/+130
| | | | | | | | | | | | | | | | | | Allows the player to select an emulated profile.
| * | | | | software_keyboard: Signal state changed event upon constructionZach Hilman2018-12-031-1/+6
| | | | | | | | | | | | | | | | | | Previously, ILibraryAppletAccessor would signal upon creation of any applet, but this is incorrect. A flag inside of the applet code determines whether or not creation should signal state change and swkbd happens to be one of these applets.
* | | | | | Merge pull request #1921 from ogniK5377/no-unitbunnei2018-12-211-0/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | Fixed uninitialized memory due to missing returns in canary
| * | | | | | Fixed uninitialized memory due to missing returns in canaryDavid Marcec2018-12-191-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Functions which are suppose to crash on non canary builds usually don't return anything which lead to uninitialized memory being used.
* | | | | | | Merge pull request #1925 from lioncash/pidbunnei2018-12-216-26/+57
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | kernel/{process, thread}: Amend behavior related to IDs
| * | | | | | | kernel/svc: Handle thread handles within GetProcessIdLioncash2018-12-191-10/+23
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | If a thread handle is passed to svcGetProcessId, the kernel attempts to access the process ID via the thread's instance's owning process. Technically, this function should also be handling the kernel debug objects as well, however we currently don't handle those kernel objects yet, so I've left a note via a comment about it to remind myself when implementing it in the future.
| * | | | | | | kernel/kernel: Use correct initial PID for userland Process instancesLioncash2018-12-192-4/+14
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Starts the process ID counter off at 81, which is what the kernel itself checks against internally when creating processes. It's actually supposed to panic if the PID is less than 81 for a userland process.
| * | | | | | | kernel/svc: Correct output parameter for svcGetThreadIdLioncash2018-12-191-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The service call uses a 64-bit value, just like svcGetProcessId. This amends the function signature accordingly.
| * | | | | | | kernel/thread: Make thread_id a 64-bit valueLioncash2018-12-193-5/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel uses a 64-bit value for the thread ID, so we shouldn't be using a 32-bit value.
| * | | | | | | kernel/svc: Correct output parameter for svcGetProcessIdLioncash2018-12-192-2/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcGetProcessId's out parameter is a pointer to a 64-bit value, not a 32-bit one.
| * | | | | | | kernel/process: Make process_id a 64-bit valueLioncash2018-12-193-6/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the actual kernel, this is a 64-bit value, so we shouldn't be using a 32-bit type to handle it.
* | | | | | | | Merge pull request #1914 from lioncash/idbunnei2018-12-211-2/+5
|\ \ \ \ \ \ \ \ | |_|_|_|_|/ / / |/| | | | | | | service/am: Unstub GetAppletResourceUserId
| * | | | | | | service/am: Unstub GetAppletResourceUserIdLioncash2018-12-181-2/+5
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is supposed to return the current process' ID. (0 indicates an invalid ID for both process IDs and ARU IDs).
* | | | | | | Merge pull request #1923 from ogniK5377/nfp-device-listbunnei2018-12-191-2/+2
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Device handle should not be a random id, instead it's the current npad id
| * | | | | | | Device handle should not be a random id, instead it's the current npad idDavid Marcec2018-12-191-2/+2
| | |/ / / / / | |/| | | | | | | | | | | | | | | | | | | Found during hardware testing
* | | | | | | Merge pull request #1915 from lioncash/smbunnei2018-12-191-4/+5
|\ \ \ \ \ \ \ | |_|_|_|_|/ / |/| | | | | | service/sm: Improve debug log for RegisterService
| * | | | | | service/sm: Improve debug log for RegisterServiceLioncash2018-12-191-4/+5
| | |/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now it also indicates the name and max session count. This also gives a name to the unknown bool. This indicates if the created port is supposed to be using light handles or regular handles internally. This is passed to the respective svcCreatePort parameter internally.
* | | | | | Merge pull request #1907 from lioncash/attributebunnei2018-12-193-14/+279
|\ \ \ \ \ \ | |_|/ / / / |/| | | | | kernel/svc: Implement svcSetMemoryAttribute
| * | | | | svc: Implement svcSetMemoryAttributeLioncash2018-12-191-5/+46
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | With all the basic backing functionality implemented, we can now unstub svcSetMemoryAttribute.
| * | | | | vm_manager: Add member function for setting memory attributes across an address rangeLioncash2018-12-192-0/+41
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This puts the backing functionality for svcSetMemoryAttribute in place, which will be utilized in a following change.
| * | | | | vm_manager: Add member function for checking a memory range adheres to certain attributes, permissions and statesLioncash2018-12-192-0/+100
| | | | | |
| * | | | | vm_manager: Rename meminfo_state to stateLioncash2018-12-162-10/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is shorter and more concise. This also removes the now-innaccurate comment, as it's not returned wholesale to svcQueryMemory anymore.
| * | | | | vm_manager: Add backing functionality for memory attributesLioncash2018-12-162-1/+85
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Adds the barebones enumeration constants and functions in place to handle memory attributes, while also essentially leaving the attribute itself non-functional.
* | | | | | Merge pull request #1913 from MerryMage/default-fpcrbunnei2018-12-181-0/+3
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/thread: Set default fpcr
| * | | | | | kernel/thread: Set default fpcrMerryMage2018-12-181-0/+3
| | |/ / / / | |/| | | |
* | | | | | Merge pull request #1889 from DarkLordZach/swkbd-state-changedbunnei2018-12-183-6/+4
|\ \ \ \ \ \ | |/ / / / / |/| | | | | applets: Correct usage of SignalStateChanged event
| * | | | | applets: Correct usage of SignalStateChanged eventZach Hilman2018-12-103-6/+4
| | | | | | | | | | | | | | | | | | | | | | | | This was causing some games (most notably Pokemon Quest) to softlock due to an event being fired when not supposed to. This also removes a hack wherein we were firing the state changed event when the game retrieves it, which is incorrect.
* | | | | | Merge pull request #1905 from bunnei/ignore-empty-gpu-listsbunnei2018-12-151-0/+4
|\ \ \ \ \ \ | | | | | | | | | | | | | | nvhost_gpu: Skip empty GPU command lists.
| * | | | | | nvhost_gpu: Skip empty GPU command lists.bunnei2018-12-151-0/+4
| | | | | | |
* | | | | | | Merge pull request #1901 from jschmer/ServiceLeakbunnei2018-12-152-10/+12
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | Fix Service object leak on emulation stop
| * | | | | | Fix Service object leak on emulation stopJens Schmer2018-12-132-10/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Services created with the ServiceFramework base class install themselves as HleHandlers with an owning shared_ptr in the ServerPort ServiceFrameworkBase::port member variable, creating a cyclic ownership between ServiceFrameworkBase and the ServerPort, preventing deletion of the service objects. Fix that by removing the ServiceFrameworkBase::port member because that was only used to detect multiple attempts at installing a port. Instead store a flag if the port was already installed to achieve the same functionality.
* | | | | | | Merge pull request #1732 from DarkLordZach/yield-typesbunnei2018-12-154-9/+165
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | svc: Implement yield types 0 and -1
| * | | | | | svc: Avoid incorrect fast yield conditionZach Hilman2018-12-051-6/+1
| | | | | | |
| * | | | | | scheduler: Avoid manual Reschedule callZach Hilman2018-12-042-11/+11
| | | | | | | | | | | | | | | | | | | | | This will automatically occur anyway when PrepareReschedule is called
| * | | | | | scheduler: Only work steal higher priority threads from other coresZach Hilman2018-12-033-35/+24
| | | | | | |
| * | | | | | svc: Avoid performance-degrading unnecessary rescheduleZach Hilman2018-12-022-8/+6
| | | | | | |
| * | | | | | scheduler: Add explanations for YieldWith and WithoutLoadBalancingZach Hilman2018-11-225-77/+139
| | | | | | |
| * | | | | | svc: Implement yield types 0 and -1Zach Hilman2018-11-195-2/+114
| | | | | | |
* | | | | | | Merge pull request #1899 from lioncash/statebunnei2018-12-147-84/+188
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | vm_manager/svc: Modify MemoryState enum, and correct error handling for svcQueryMemory
| * | | | | | | svc: Enable svcQueryProcessMemoryLioncash2018-12-122-1/+6
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcQueryProcessMemory is trivial to implement, given all the behavior necessary for it is present, it just needs a handler for it.
| * | | | | | | svc: Write out the complete MemoryInfo structure in QueryProcessMemoryLioncash2018-12-121-0/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | In the previous change, the memory writing was moved into the service function itself, however it still had a problem, in that the entire MemoryInfo structure wasn't being written out, only the first 32 bytes of it were being written out. We still need to write out the trailing two reference count members and zero out the padding bits. Not doing this can result in wrong behavior in userland code in the following scenario: MemoryInfo info; // Put on the stack, not quaranteed to be zeroed out. svcQueryMemory(&info, ...); if (info.device_refcount == ...) // Whoops, uninitialized read. This can also cause the wrong thing to happen if the user code uses std::memcmp to compare the struct, with another one (questionable, but allowed), as the padding bits are not guaranteed to be a deterministic value. Note that the kernel itself also fully zeroes out the structure before writing it out including the padding bits.
| * | | | | | | svc: Handle memory writing explicitly within QueryProcessMemoryLioncash2018-12-122-26/+22
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Moves the memory writes directly into QueryProcessMemory instead of letting the wrapper function do it. It would be inaccurate to allow the handler to do it because there's cases where memory shouldn't even be written to. For example, if the given process handle is invalid. HOWEVER, if the memory writing is within the wrapper, then we have no control over if these memory writes occur, meaning in an error case, 68 bytes of memory randomly get trashed with zeroes, 64 of those being written to wherever the memory info address points to, and the remaining 4 being written wherever the page info address points to. One solution in this case would be to just conditionally check within the handler itself, but this is kind of smelly, given the handler shouldn't be performing conditional behavior itself, it's a behavior of the managed function. In other words, if you remove the handler from the equation entirely, does the function still retain its proper behavior? In this case, no. Now, we don't potentially trash memory from this function if an invalid query is performed.
| * | | | | | | vm_manager: Correct ordering of last two struct members of MemoryInfoLioncash2018-12-121-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These should be swapped.
| * | | | | | | vm_manager: Amend the returned values for invalid memory queries in QueryMemory()Lioncash2018-12-122-4/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel returns a memory info instance with the base address set to the end of the address space, and the size of said block as 0 - address_space_end, it doesn't set both of said members to zero.
| * | | | | | | vm_manager: Migrate memory querying to the VMManager interfaceLioncash2018-12-124-18/+33
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of the need to directly access the managed VMAs outside of the memory manager itself just for querying memory.
| * | | | | | | vm_manager: Migrate MemoryInfo and PageInfo to vm_manager.hLioncash2018-12-123-17/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets the two structures out of an unrelated header and places them with the rest of the memory management code. This also corrects the structures. PageInfo appears to only contain a 32-bit flags member, and the extra padding word in MemoryInfo isn't necessary.
| * | | | | | | vm_manager: Amend MemoryState enum membersLioncash2018-12-125-28/+111
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Amends the MemoryState enum to use the same values like the actual kernel does. Also provides the necessary operators to operate on them. This will be necessary in the future for implementing svcSetMemoryAttribute, as memory block state is checked before applying the attribute.
* | | | | | | | Merge pull request #1900 from lioncash/wrapperbunnei2018-12-141-1/+1
|\ \ \ \ \ \ \ \ | |_|_|/ / / / / |/| | | | | | | svc_wrap: Correct register index for a wrapper specialization
| * | | | | | | svc_wrap: Correct register index for a wrapper specializationLioncash2018-12-121-1/+1
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This would result in svcSetMemoryAttribute getting the wrong value for its third parameter. This is currently fine, given the service function is stubbed, however this will be unstubbed in a future change, so this needs to change.
* | | | | | | Fix Process object leak on emulation stopJens Schmer2018-12-123-13/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The Process object kept itself alive indefinitely because its handle_table contains a SharedMemory object which owns a reference to the same Process object, creating a circular ownership scenario. Break that up by storing only a non-owning pointer in the SharedMemory object.
* | | | | | | Merge pull request #1891 from DarkLordZach/istorage-getsizeMat M2018-12-121-2/+15
|\ \ \ \ \ \ \ | |/ / / / / / |/| | | | | | fsp_srv: Implement IStorage::GetSize
| * | | | | | fsp_srv: Implement IStorage::GetSizeZach Hilman2018-12-101-2/+15
| | |/ / / / | |/| | | | | | | | | | | | | | | | Takes no input and returns the size as a u64. Needed by Katamari Damacy Reroll to boot.
* | | | | | Merge pull request #1819 from DarkLordZach/disable-addonsbunnei2018-12-111-0/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | patch_manager: Add support for disabling patches
| * | | | | | aoc_u: Obey disabled add-ons list when listing DLCZach Hilman2018-12-031-0/+12
| | |_|/ / / | |/| | | |
* | | | | | Merge pull request #1883 from lioncash/log-fspbunnei2018-12-111-1/+10
|\ \ \ \ \ \ | | | | | | | | | | | | | | service/fsp_srv: Correct returned value in GetGlobalAccessLogMode()
| * | | | | | service/fsp_srv: Correct returned value in GetGlobalAccessLogMode()Lioncash2018-12-101-1/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Based off RE, the backing code only ever seems to use 0-2 as the range of values 1 being a generic log enable, with 2 indicating logging should go to the SD card. These are used as a set of flags internally. Given we only care about receiving the log in general, we can just always signify that we want logging in general.
* | | | | | | Merge pull request #1872 from lioncash/proc-infoHexagon122018-12-101-0/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | kernel/process: Set ideal core from metadata
| * | | | | | | kernel/process: Set ideal core from metadataLioncash2018-12-051-0/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | A very trivial change. If metadata is available, the process should use it to retrieve the desired core for the process to run on.
* | | | | | | | Merge pull request #1876 from lioncash/vmabunnei2018-12-104-22/+36
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | vm_manager: Make vma_map private
| * | | | | | | | vm_manager: Make vma_map privateLioncash2018-12-064-22/+36
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This was only ever public so that code could check whether or not a handle was valid or not. Instead of exposing the object directly and allowing external code to potentially mess with the map contents, we just provide a member function that allows checking whether or not a handle is valid. This makes all member variables of the VMManager class private except for the page table.
* | | | | | | | Merge pull request #1864 from lioncash/nrrbunnei2018-12-081-4/+5
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | service/ldr: Amend layouts of NRO and NRR headers
| * | | | | | | | service/ldr: Amend layout of the NRO headerLioncash2018-12-051-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The first word is just a padding byte, it's not an actual entry instruction. Also renames the rest of the entries according to SwitchBrew.
| * | | | | | | | service/ldr: Corrent padding within the NRR header layoutLioncash2018-12-051-1/+2
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The padding after the magic signature value should be 12 bytes rather than 28 bytes. The other 16 should be placed after the title ID pattern.
* | | | | | | | Merge pull request #1874 from lioncash/bindingsbunnei2018-12-082-19/+8
|\ \ \ \ \ \ \ \ | |_|_|_|/ / / / |/| | | | | | | hle/service, hle/sm: Minor cleanup
| * | | | | | | hle/service: Replace log + UNIMPLEMENTED with UNIMPLEMENTED_MSGLioncash2018-12-061-2/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Combines the two into one, shortening the amount of code here.
| * | | | | | | hle/service: Remove unnecessary using declarationsLioncash2018-12-061-5/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Only one usage of the specified objects made use of the lack of namespacing. Given the low usage, we can just remove these.
| * | | | | | | hle/service, hle/sm: Compress usages of MakeResult()Lioncash2018-12-062-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These auto-deduce the result based off its arguments, so there's no need to do that work for the compiler, plus, the function return value itself already indicates what we're returning.
| * | | | | | | hle/service, hle/sm: Use structured bindings where applicableLioncash2018-12-062-9/+3
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | Gets rid of the need to keep the variables separate from their actual initialization spots.
* | | | | | | Merge pull request #1861 from lioncash/resetbunnei2018-12-066-11/+101
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | kernel/svc: Correct behavior of svcResetSignal()
| * | | | | | kernel/svc: Correct behavior of svcResetSignal()Lioncash2018-12-051-4/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While partially correct, this service call allows the retrieved event to be null, as it also uses the same handle to check if it was referring to a Process instance. The previous two changes put the necessary machinery in place to allow for this, so we can simply call those member functions here and be done with it.
| * | | | | | kernel/process: Make Process a WaitObjectLioncash2018-12-053-6/+68
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Process instances can be waited upon for state changes. This is also utilized by svcResetSignal, which will be modified in an upcoming change. This simply puts all of the WaitObject related machinery in place.
| * | | | | | kernel/readable_event: Add member function for enforcing a strict reset contractLioncash2018-12-052-1/+22
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcResetSignal relies on the event instance to have already been signaled before attempting to reset it. If this isn't the case, then an error code has to be returned.
* | | | | | | service/ldr: Deduplicate instruction cache clearing code in LoadNro()Lioncash2018-12-051-8/+2
| |/ / / / / |/| | | | | | | | | | | | | | | | | We don't need to specify all of the ARM interfaces explicitly.
* | | | | | Merge pull request #1704 from DarkLordZach/oss-sysarchivebunnei2018-12-051-0/+10
|\ \ \ \ \ \ | |/ / / / / |/| | | | | file_sys: Implement open source system archives
| * | | | | fsp_srv: Add support for using open source archive if not found in NANDZach Hilman2018-11-161-0/+10
| | | | | |
* | | | | | kernel/svc: Remove unused header inclusionLioncash2018-12-041-1/+0
| | | | | |
* | | | | | kernel/svc: Implement svcSignalEvent()Lioncash2018-12-041-1/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function simply does a handle table lookup for a writable event instance identified by the given handle value. If a writable event cannot be found for the given handle, then an invalid handle error is returned. If a writable event is found, then it simply signals the event, as one would expect.
* | | | | | kernel/svc: Implement svcCreateEvent()Lioncash2018-12-042-1/+42
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | svcCreateEvent operates by creating both a readable and writable event and then attempts to add both to the current process' handle table. If adding either of the events to the handle table fails, then the relevant error from the handle table is returned. If adding the readable event after the writable event to the table fails, then the writable event is removed from the handle table and the relevant error from the handle table is returned. Note that since we do not currently test resource limits, we don't check the resource limit table yet.
* | | | | | Merge pull request #1853 from lioncash/eventbunnei2018-12-045-10/+19
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/object: Amend handle types to distinguish between readable and writable events
| * | | | | | kernel/object: Amend handle types to distinguish between readable and writable eventsLioncash2018-12-045-10/+19
| | |_|_|/ / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Two kernel object should absolutely never have the same handle ID type. This can cause incorrect behavior when it comes to retrieving object types from the handle table. In this case it allows converting a WritableEvent into a ReadableEvent and vice-versa, which is undefined behavior, since the object types are not the same. This also corrects ClearEvent() to check both kernel types like the kernel itself does.
* | | | | | kernel/handle_table: Amend reference to CTR-OS in Create()Lioncash2018-12-041-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | Another hold-over from Citra.
* | | | | | kernel/svc: Implement the resource limit svcGetInfo optionLioncash2018-12-044-9/+34
|/ / / / / | | | | | | | | | | | | | | | | | | | | Allows a process to register the resource limit as part of its handle table.
* | | | | [Kernel::CreateThread] Match format specifiers to LOG_TRACE's argumentsV.Kalyuzhny2018-12-041-1/+1
| | | | |
* | | | | Merge pull request #1840 from lioncash/infobunnei2018-12-041-50/+100
|\ \ \ \ \ | |_|/ / / |/| | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categories
| * | | | svc: Use the current process' handle table for retrieving the process instance to act uponLioncash2018-12-021-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel uses the handle table of the current process to retrieve the process that should be used to retrieve certain information. To someone not familiar with the kernel, this might raise the question of "Ok, sounds nice, but doesn't this make it impossible to retrieve information about the current process?". No, it doesn't, because HandleTable instances in the kernel have the notion of a "pseudo-handle", where certain values allow the kernel to lookup objects outside of a given handle table. Currently, there's only a pseudo-handle for the current process (0xFFFF8001) and a pseudo-handle for the current thread (0xFFFF8000), so to retrieve the current process, one would just pass 0xFFFF8001 into svcGetInfo. The lookup itself in the handle table would be something like: template <typename T> T* Lookup(Handle handle) { if (handle == PSEUDO_HANDLE_CURRENT_PROCESS) { return CurrentProcess(); } if (handle == PSUEDO_HANDLE_CURRENT_THREAD) { return CurrentThread(); } return static_cast<T*>(&objects[handle]); } which, as is shown, allows accessing the current process or current thread, even if those two objects aren't actually within the HandleTable instance.
| * | | | svc: Reorganize svcGetInfo, handle more error cases for existing implemented info categoriesLioncash2018-12-021-50/+99
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Our implementation of svcGetInfo was slightly incorrect in that we weren't doing proper error checking everywhere. Instead, reorganize it to be similar to how the kernel seems to do it.
* | | | | Merge pull request #1835 from lioncash/cache-globalbunnei2018-12-033-19/+6
|\ \ \ \ \ | | | | | | | | | | | | filesystem: De-globalize registered_cache_union
| * | | | | filesystem: De-globalize registered_cache_unionLioncash2018-12-023-19/+6
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can just return a new instance of this when it's requested. This only ever holds pointers to the existing registed caches, so it's not a large object. Plus, this also gets rid of the need to keep around a separate member function just to properly clear out the union. Gets rid of one of five globals in the filesystem code.
* | | | | Merge pull request #1803 from DarkLordZach/k-able-eventbunnei2018-12-0332-234/+393
|\ \ \ \ \ | | | | | | | | | | | | kernel: Divide Event into ReadableEvent and WritableEvent
| * | | | | hle_ipc: Refactor SleepClientThread to avoid ReadableEventZach Hilman2018-11-299-14/+14
| | | | | |
| * | | | | kernel/event: Reference ReadableEvent from WritableEventZach Hilman2018-11-2930-311/+169
| | | | | |
| * | | | | core: Port all current usages of Event to Readable/WritableEventZach Hilman2018-11-2925-153/+274
| | | | | |
| * | | | | hle_ipc: Use event pair for SleepClientThreadZach Hilman2018-11-292-19/+22
| | | | | |
| * | | | | kernel: Add named event tableZach Hilman2018-11-292-0/+30
| | | | | | | | | | | | | | | | | | | | | | | | Used to store ReadableEvents of all events on the system.
| * | | | | kernel: Divide Event into ReadableEvent and WritableEventZach Hilman2018-11-295-59/+206
| | | | | | | | | | | | | | | | | | | | | | | | More hardware accurate. On the actual system, there is a differentiation between the signaler and signalee, they form a client/server relationship much like ServerPort and ClientPort.
| * | | | | kernel/object: Add descriptions to ResetTypesZach Hilman2018-11-291-3/+3
| | | | | |
* | | | | | Merge pull request #1833 from lioncash/cleanbunnei2018-12-033-1/+35
|\ \ \ \ \ \ | | | | | | | | | | | | | | service/fsp_srv: Implement CleanDirectoryRecursively
| * | | | | | service/fsp_srv: Implement CleanDirectoryRecursivelyLioncash2018-12-013-1/+35
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This is the same behavior-wise as DeleteDirectoryRecursively, with the only difference being that it doesn't delete the top level directory in the hierarchy, so given: root_dir/ - some_dir/ - File.txt - OtherFile.txt The end result is just: root_dir/
* | | | | | | Merge pull request #1839 from lioncash/initbunnei2018-12-031-2/+2
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | service/audio/audout_u: Amend constructor initialization list order
| * | | | | | | service/audio/audout_u: Amend constructor initialization list orderLioncash2018-12-021-2/+2
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | Orders the constructor initializer list the same way the members of the class are declared. Prevents -Wreorder warnings
* | | | | | | Merge pull request #1841 from ogniK5377/npad-mode-fixbunnei2018-12-031-2/+3
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Fixed crash with SetNpadMode
| * | | | | | | Fixed crash with SetNpadModeDavid Marcec2018-12-021-2/+3
| | |_|_|_|_|/ | |/| | | | | | | | | | | | | | | | | | | fixed crash due to handheld
* | | | | | | service/usb: Update function tableLioncash2018-12-021-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Updates the function table for IClientEpSession based off information provided by SwitchBrew.
* | | | | | | service/erpt: Update function tableLioncash2018-12-021-5/+7
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | Updates the function table according to information provided by SwitchBrew.
* | | | | | Merge pull request #1830 from Subv/vi_ubbunnei2018-12-021-0/+2
|\ \ \ \ \ \ | |/ / / / / |/| | | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior.
| * | | | | Services/VI: Dereferencing an uninitialized std::optional is undefined behavior.Subv2018-11-301-0/+2
| | |/ / / | |/| | | | | | | | | | | | | Assert that it is not empty before using it in the DequeueBuffer wait callback.
* | | | | Fix debug buildLioncash2018-12-011-1/+1
| |/ / / |/| | | | | | | | | | | | | | | A non-existent parameter was left in some formatting calls (the logging macro for which only does anything meaningful on debug builds)
* | | | service/set: Convert GetLanguageCode over to using PushEnum()Lioncash2018-11-301-1/+1
| | | | | | | | | | | | | | | | | | | | This code was around prior to the introduction of PushEnum, so convert it over so we don't need to cast here.
* | | | service/set: Implement MakeLanguageCodeLioncash2018-11-302-1/+19
|/ / / | | | | | | | | | This function simply converts a given index into a language code.
* | | Merge pull request #1801 from ogniK5377/log-before-executebunnei2018-11-2951-390/+860
|\ \ \ | | | | | | | | Changed logging to be "Log before execution", Added more error logging, all services/svc should now log on some level
| * | | Added comment on Main memory size for more clarityDavid Marcec2018-11-271-0/+1
| | | |
| * | | Made svcSetHeapSize and svcCreateSharedMemory more readableDavid Marcec2018-11-271-4/+4
| | | |
| * | | Reworked svcs slightly, improved error messages in AM and fsp_srvDavid Marcec2018-11-273-20/+30
| | | |
| * | | Fixed hwopus compile errorDavid Marcec2018-11-261-1/+1
| | | |
| * | | Improved error messages in AM, HwOpus and NvMapDavid Marcec2018-11-263-26/+39
| | | |
| * | | Improved error messages for SVCsDavid Marcec2018-11-261-76/+170
| | | |
| * | | Changed logging to be "Log before execution", Added more error logging, all services should now log on some levelDavid Marcec2018-11-2651-374/+726
| | | |
* | | | Merge pull request #1817 from DarkLordZach/npad-idx-fixbunnei2018-11-281-2/+2
|\ \ \ \ | | | | | | | | | | npad: Use NPadIdToIndex to prevent invalid array access
| * | | | npad: Use NPadIdToIndex to prevent invalid array accessZach Hilman2018-11-281-2/+2
| | | | |
* | | | | Merge pull request #1792 from bunnei/dma-pusherbunnei2018-11-281-5/+10
|\ \ \ \ \ | | | | | | | | | | | | gpu: Rewrite GPU command list processing with DmaPusher class.
| * | | | | dma_pushbuffer: Optimize to avoid loop and copy on Push.bunnei2018-11-281-8/+6
| | | | | |
| * | | | | gpu: Rewrite GPU command list processing with DmaPusher class.bunnei2018-11-271-3/+10
| | | | | | | | | | | | | | | | | | | | | | | | - More accurate impl., fixes Undertale (among other games).
* | | | | | npad: Fix copy/paste error with LED position assignmentsZach Hilman2018-11-271-3/+3
| | | | | |
* | | | | | Merge pull request #1802 from DarkLordZach/user-data-storagebunnei2018-11-273-17/+19
|\ \ \ \ \ \ | |/ / / / / |/| | | | | profile_manager: Save and load ProfileData from disk
| * | | | | profile_manager: Save and load ProfileData from diskZach Hilman2018-11-263-17/+19
| | | | | | | | | | | | | | | | | | | | | | | | The ProfileData is a 0x80-sized structure that stores various pieces of miscellaneous data for the account.
* | | | | | svc: Implement svcSetResourceLimitLimitValue()Lioncash2018-11-271-1/+36
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The opposite of the getter functions, this function sets the limit value for a particular ResourceLimit resource category, with the restriction that the new limit value must be equal to or greater than the current resource value. If this is violated, then ERR_INVALID_STATE is returned. e.g. Assume: current[Events] = 10; limit[Events] = 20; a call to this service function lowering the limit value to 10 would be fine, however, attempting to lower it to 9 in this case would cause an invalid state error.
* | | | | | svc: Implement svcGetResourceLimitCurrentValue()Lioncash2018-11-271-16/+49
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This kernel service function is essentially the exact same as svcGetResourceLimitLimitValue(), with the only difference being that it retrieves the current value for a given resource category using the provided resource limit handle, rather than retrieving the limiting value of that resource limit instance. Given these are exactly the same and only differ on returned values, we can extract the existing code for svcGetResourceLimitLimitValue() to handle both values.
* | | | | | svc: Implement svcGetResourceLimitLimitValue()Lioncash2018-11-272-2/+33
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This kernel service function retrieves the maximum allowable value for a provided resource category for a given resource limit instance. Given we already have the functionality added to the resource limit instance itself, it's sufficient to just hook it up. The error scenarios for this are: 1. If an invalid resource category type is provided, then ERR_INVALID_ENUM is returned. 2. If an invalid handle is provided, then ERR_INVALID_HANDLE is returned (bad thing goes in, bad thing goes out, as one would expect). If neither of the above error cases occur, then the out parameter is provided with the maximum limit value for the given category and success is returned.
* | | | | | svc: Implement svcCreateResourceLimit()Lioncash2018-11-272-1/+27
| |/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This function simply creates a ResourceLimit instance and attempts to create a handle for it within the current process' handle table. If the kernal fails to either create the ResourceLimit instance or create a handle for the ResourceLimit instance, it returns a failure code (OUT_OF_RESOURCE, and HANDLE_TABLE_FULL respectively). Finally, it exits by providing the output parameter with the handle value for the ResourceLimit instance and returning that it was successful. Note: We do not return OUT_OF_RESOURCE because, if yuzu runs out of available memory, then new will currently throw. We *could* allocate the kernel instance with std::nothrow, however this would be inconsistent with how all other kernel objects are currently allocated.
* | | | | Merge pull request #1793 from lioncash/refbunnei2018-11-262-2/+2
|\ \ \ \ \ | |_|/ / / |/| | | | service/sm: Take std::string by const reference in UnregisterService
| * | | | service/sm: Take std::string by const reference in UnregisterServiceLioncash2018-11-242-2/+2
| |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids the need to create a copy of the std::string instance (potentially allocating). The only reason RegisterService takes its argument by value is because it's std::moved internally.
* | | | svc: Return ERR_INVALID_ENUM_VALUE from svcGetInfoLuke Street2018-11-251-1/+2
| | | |
* | | | Merge pull request #1791 from bunnei/nvdrv-stubbunnei2018-11-252-2/+18
|\ \ \ \ | |/ / / |/| | | nvdrv: Implement/stub DumpGraphicsMemoryInfo and GetStatus.
| * | | nvdrv: Implement/stub DumpGraphicsMemoryInfo and GetStatus.bunnei2018-11-242-2/+18
| | | | | | | | | | | | | | | | - Used by Undertale.
* | | | Merge pull request #1641 from DarkLordZach/sm-register-unregisterbunnei2018-11-242-2/+55
|\ \ \ \ | | | | | | | | | | sm: Implement RegisterService and UnregisterService
| * | | | sm: Implement RegisterService and UnregisterServiceZach Hilman2018-11-042-2/+55
| | | | | | | | | | | | | | | These are needed by Edizon to boot. They are used to see if a user is using SX OS, as SX OS registers a custom service called 'tx' and attempting to register a service of the same name lets the application know if it is present.
* | | | | Merge pull request #1731 from DarkLordZach/change-dir-crashbunnei2018-11-242-0/+6
|\ \ \ \ \ | | | | | | | | | | | | filesystem: Clear registered union paths on factory creation
| * | | | | filesystem: Clear registered union paths on factory creationZach Hilman2018-11-192-0/+6
| | |_|_|/ | |/| | |
* | | | | Merge pull request #1708 from ogniK5377/res-scalebunnei2018-11-242-13/+31
|\ \ \ \ \ | |_|_|/ / |/| | | | Report resolution scaling support for vi and am
| * | | | Removed hard coded values for width and heightDavid Marcec2018-11-191-2/+4
| | | | |
| * | | | Report resolution scaling support for vi and amDavid Marcec2018-11-162-13/+29
| | | | | | | | | | | | | | | | | | | | Specifying an internal resolution in yuzu now will report the scaled changes to vi and am.
* | | | | Merge pull request #1770 from DarkLordZach/applet-stubbunnei2018-11-233-4/+100
|\ \ \ \ \ | | | | | | | | | | | | applets: Add StubApplet and use it as fallback when AppletId is not implemented
| * | | | | am: Return StubApplet instead of nullptr when AppletId not foundZach Hilman2018-11-223-11/+11
| | | | | |
| * | | | | applets: Add StubAppletZach Hilman2018-11-222-0/+96
| | | | | | | | | | | | | | | | | | | | | | | | This will log all data it receives, log all calls to its methods and push dummy data into both channels on execution.
* | | | | | Merge pull request #1762 from bunnei/getgputimebunnei2018-11-232-0/+19
|\ \ \ \ \ \ | | | | | | | | | | | | | | nvhost_ctrl_gpu: Implement IoctlGetGpuTime.
| * | | | | | nvhost_ctrl_gpu: Implement IoctlGetGpuTime.bunnei2018-11-212-0/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | - Used by Undertale.
* | | | | | | debug_pad: Avoid loading input for nonexistent buttons (Home and Screenshot)Zach Hilman2018-11-221-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents memory exceptions when the debug pad is enabled.
* | | | | | | Merge pull request #1765 from bunnei/multi-audoutbunnei2018-11-222-9/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | audout_u: Add support for multiple IAudioOut streams.
| * | | | | | | audout_u: Add support for multiple IAudioOut streams.bunnei2018-11-222-9/+22
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | - Used by Undertale.
* | | | | | | Merge pull request #1767 from lioncash/handlebunnei2018-11-222-12/+14
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | kernel/handle_table: Minor changes
| * | | | | | kernel/handle_table: Move private static functions into the cpp fileLioncash2018-11-222-7/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These don't depend on class state, and are effectively implementation details, so they can go into the cpp file .
| * | | | | | kernel/handle_table: Restrict handle table size to 1024 entriesLioncash2018-11-221-5/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The previous handle table size is a holdover from Citra. The actual handle table construct on Horizon only allows for a maximum of 1024 entries.
| * | | | | | kernel/handle_table: Default destructor in the cpp fileLioncash2018-11-222-0/+3
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | We don't need to potentially inline the teardown logic of all of the handle instances.
* | | | | | Merge pull request #1742 from lioncash/hle-swkbdbunnei2018-11-215-44/+63
|\ \ \ \ \ \ | |/ / / / / |/| | | | | am/applets: Minor cleanup
| * | | | | am/applets: Make the applet data broker part of the applet itself.Lioncash2018-11-205-31/+36
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The accessor should be doing just that, accessing, rather than retaining the lifetime of the data broker as well.
| * | | | | am/applets: Replace includes with forward declarations where applicableLioncash2018-11-202-2/+9
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Also resolve places where includes should have been provided, but weren't.
| * | | | | am/applets: Relocate comments above the relevant data member in AppletDataBrokerLioncash2018-11-201-11/+18
| | | | | | | | | | | | | | | | | | | | | | | | Avoids wonky wrapping and makes it nicer to read.
* | | | | | am: Correct build failureLioncash2018-11-211-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The interface for shared memory was changed, but another commit was merged that relied on the (previously public) internals of SharedMemory. This amends that discrepancy.
* | | | | | Merge pull request #1734 from lioncash/sharedbunnei2018-11-213-29/+45
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/shared_memory: Make data members private, plus minor interface changes
| * | | | | | kernel/shared_memory: Make Map() and Unmap() take the target process by reference rather than as a pointerLioncash2018-11-193-12/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Both member functions assume the passed in target process will not be null. Instead of making this assumption implicit, we can change the functions to be references and enforce this at the type-system level.
| * | | | | | kernel/shared_memory: Add a const qualified member function overload for GetPointer()Lioncash2018-11-192-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given this doesn't mutate instance state, we can provide a const-qualified variant as well.
| * | | | | | kernel/shared_memory: Use 64-bit types for offset and size in CreateForAppletLioncash2018-11-192-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Keeps the interface consistent with the regular Create() function.
| * | | | | | kernel/shared_memory: Make GetPointer() take a std::size_t instead of a u32Lioncash2018-11-192-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Makes the interface nicer to use in terms of 64-bit code, as it makes it less likely for one to get truncation warnings (and also makes sense in the context of the rest of the interface where 64-bit types are used for sizes and offsets
| * | | | | | kernel/shared_memory: Make data members privateLioncash2018-11-191-12/+17
| | |_|/ / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than allow unfettered access to the class internals, we hide all members by default and create and API that other code can operate against.
* | | | | | Merge pull request #1733 from lioncash/ldrbunnei2018-11-211-29/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | ldr: Clean up error codes
| * | | | | | ldr: Clean up error codesLioncash2018-11-191-29/+12
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The separate enum isn't particularly necessary here, and the values can just be directly put into the ResultCode instances, given the names are also self-documenting here.
* | / / / / kernel/process: Move <random> include to the cpp fileLioncash2018-11-202-1/+1
| |/ / / / |/| | | | | | | | | | | | | | | | | | | | | | | | <random> isn't necesary directly within the header and can be placed in the cpp file where its needed. Avoids propagating random generation utilities via a header file.
* | | | | Merge pull request #1667 from DarkLordZach/swkbdbunnei2018-11-207-106/+729
|\ \ \ \ \ | | | | | | | | | | | | am: Implement HLE software keyboard applet
| * | | | | software_keyboard: Fix erroneous extra PushNormalDataZach Hilman2018-11-191-3/+2
| | | | | |
| * | | | | software_keyboard: Return correct result code on user cancel operationZach Hilman2018-11-193-5/+1
| | | | | |
| * | | | | applet: Add AppletDataBroker to manage HLE to AM service interactionZach Hilman2018-11-195-104/+194
| | | | | | | | | | | | | | | | | | | | | | | | This cleans up most of the callbacks and such in the Applets::Applet interface, while also properly implementing all four data channels.
| * | | | | software_keyboard: Use correct offset for inital text stringZach Hilman2018-11-191-1/+2
| | | | | |
| * | | | | software_keyboard: Check for UTF-8 config flagZach Hilman2018-11-192-9/+23
| | | | | |
| * | | | | software_keyboard: Push all data over all channels on dialog completionZach Hilman2018-11-181-18/+26
| | | | | |
| * | | | | applet: Use std::queue instead of std::vector for storage stackZach Hilman2018-11-185-18/+44
| | | | | |
| * | | | | applet: Add operation completed callbackZach Hilman2018-11-182-3/+5
| | | | | |
| * | | | | software_keyboard: Push buffer size to offset 0x4 in output dataZach Hilman2018-11-184-18/+39
| | | | | |
| * | | | | software_keyboard: Make GetText asynchronousZach Hilman2018-11-183-6/+20
| | | | | | | | | | | | | | | | | | | | | | | | a
| * | | | | am: Allow applets to push multiple and different channels of dataZach Hilman2018-11-184-36/+34
| | | | | |
| * | | | | am: Implement ILibraryAppletAccessor IsCompleted and GetResultZach Hilman2018-11-181-4/+8
| | | | | |
| * | | | | am: Implement text check software keyboard modeZach Hilman2018-11-183-14/+95
| | | | | | | | | | | | | | | | | | | | | | | | Allows the game to verify and send a message to the frontend.
| * | | | | am: Deglobalize software keyboard appletZach Hilman2018-11-187-31/+48
| | | | | |
| * | | | | am: Construct and use proper applets with ILibraryAppletAccessorZach Hilman2018-11-181-1/+26
| | | | | | | | | | | | | | | | | | Allows use of software keyboard applet and future applets to be easily added by adding enum ID and a switch case.
| * | | | | am/applets: Add connector between frontend and AM applet classesZach Hilman2018-11-182-0/+128
| | | | | | | | | | | | | | | | | | Provides a middleman between the Frontend provider class and the expected AM::Applets::Applet class needed by ILibraryAppletAccessor
| * | | | | am/applets: Add Applet superclass to describe a generic appletZach Hilman2018-11-182-0/+75
| | | | | | | | | | | | | | | | | | Adds an Initialize and Execute methods which are used by the ILibraryAppletAccessor to start and control the applet.
| * | | | | am: Unstub ILibraryAppletAccessor::StartZach Hilman2018-11-181-5/+17
| | | | | | | | | | | | | | | | | | Now starts the applet provided in constructor.
| * | | | | am: Implement PopInteractiveOutData and PushInteractiveInDataZach Hilman2018-11-181-14/+24
| | | | | | | | | | | | | | | | | | Used by software keyboard applet for data transfer.
| * | | | | am: Convert storage stack to vectorZach Hilman2018-11-181-27/+59
| | | | | | | | | | | | | | | | | | std::stack was no longer suitable for non-trivial operations
| * | | | | am: Move AM::IStorage to headerZach Hilman2018-11-181-0/+16
| | | | | | | | | | | | | | | | | | Needs to be accessible by applet files.
| * | | | | am: Move IStorageAccessor to header and update backing bufferZach Hilman2018-11-182-64/+62
| | | | | | | | | | | | | | | | | | Writes to an AM::IStorage object through an IStorageAccessor will now be preserved once the accessor is destroyed.
| * | | | | am: Implement CreateTransferMemoryStorageZach Hilman2018-11-182-0/+26
| | | | | | | | | | | | | | | | | | Creates an AM::IStorage object with the contents of the transfer memory located at the handle provided.
| * | | | | svc: Implement svcCreateTransferMemoryZach Hilman2018-11-181-3/+33
| | | | | | | | | | | | | | | | | | Seems to be used and created identically to SharedMemory, so just reuse that.
* | | | | | Merge pull request #1739 from lioncash/lmbunnei2018-11-201-1/+12
|\ \ \ \ \ \ | | | | | | | | | | | | | | lm: Implement SetDestination by doing nothing
| * | | | | | lm: Implement SetDestination by doing nothingLioncash2018-11-201-1/+12
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This service function was likely intended to be a way to redirect where the output of a log went. e.g. Firing a log over a network, dumping over a tunneling session, etc. Given we always want to see the log and not change its output. It's one of the lucky service functions where the easiest implementation is to just do nothing at all and return success.
* | | | | | | kernel/resource_limit: Clean up interfaceLioncash2018-11-206-190/+81
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Cleans out the citra/3DS-specific implementation details that don't apply to the Switch. Sets the stage for implementing ResourceLimit instances properly. While we're at it, remove the erroneous checks within CreateThread() and SetThreadPriority(). While these are indeed checked in some capacity, they are not checked via a ResourceLimit instance. In the process of moving out Citra-specifics, this also replaces the system ResourceLimit instance's values with ones from the Switch.
* | | | | | hid: Use player-defined controller type as PREFERRED_CONTROLLERZach Hilman2018-11-194-174/+61
| | | | | |
* | | | | | hid/npad: Update NPad to use player controller bindings and typeZach Hilman2018-11-192-55/+108
| | | | | |
* | | | | | hid/touchscreen: Update Touchscreen to use advanced parametersZach Hilman2018-11-191-6/+6
| | | | | | | | | | | | | | | | | | | | | | | | Including finger ID, diamater x/y, and angle. Additionally, checks if the touchscreen is enabled.
* | | | | | hid: Add controller bindings for Mouse controllerZach Hilman2018-11-192-4/+30
| | | | | |
* | | | | | hid: Add keyboard bindings for Keyboard controllerZach Hilman2018-11-192-2/+24
| | | | | |
* | | | | | hid: Add controller bindings for DebugPad controllerZach Hilman2018-11-192-21/+43
| | | | | | | | | | | | | | | | | | | | | | | | Used by developers to test games, not present on retail systems. Some games are known to respond to DebugPad input though, for example Kirby Star Allies.
* | | | | | Added missing start/end touch attributes to touchscreenDavid Marcec2018-11-192-1/+18
| | | | | |
* | | | | | Added debugpad skeletonDavid Marcec2018-11-192-2/+55
| | | | | |
* | | | | | Added controller helper funcsDavid Marcec2018-11-192-0/+35
| | | | | |
* | | | | | Changed polling rate of hid and Right joycon rotationDavid Marcec2018-11-191-2/+2
| | | | | |
* | | | | | Left joycon rotation button remappingDavid Marcec2018-11-192-7/+21
| | | | | |
* | | | | | Added automatic npad switch based on supported stylesetsDavid Marcec2018-11-192-4/+124
| | | | | |
* | | | | | Added multi-input support and controller assignment at any portDavid Marcec2018-11-192-122/+181
| |/ / / / |/| | | |
* | | | | Merge pull request #1620 from DarkLordZach/ldr-robunnei2018-11-196-21/+400
|\ \ \ \ \ | | | | | | | | | | | | ldr_ro: Complete LDR:RO implementation
| * | | | | ldr_ro: Add error check for memory allocation failureZach Hilman2018-11-184-13/+27
| | | | | |
| * | | | | ldr_ro: Implement UnloadNro (command 1)Zach Hilman2018-11-151-22/+85
| | | | | | | | | | | | | | | | | | | | | | | | Includes actual unmapping and address error checking.
| * | | | | ldr_ro: Fully Implement LoadNro (command 0)Zach Hilman2018-11-151-11/+110
| | | | | | | | | | | | | | | | | | | | | | | | Includes NRO and BSS error checking, maximum loaded NRO check, NRR hash check, and proper remapping of BSS data.
| * | | | | ldr_ro: Implement UnloadNrr (command 3)Zach Hilman2018-11-151-2/+84
| | | | | | | | | | | | | | | | | | | | | | | | Includes initialization check, proper address check, alignment check, and actual unloading of a loaded NRR.
| * | | | | ldr_ro: Fully implement LoadNrr (command 2)Zach Hilman2018-11-151-0/+112
| | | | | | | | | | | | | | | | | | | | | | | | Includes parameter error checking, hash enforcement, initialization check, and max NRR load check.
| * | | | | process: Make MirrorMemory take state to map new memory asZach Hilman2018-11-151-1/+2
| | | | | | | | | | | | | | | | | | | | | | | | Credits to Subv
| * | | | | pl_u: Resize buffers in shared font data getter to what game requestsZach Hilman2018-11-151-0/+8
| | | | | | | | | | | | | | | | | | | | | | | | Fixes unmapped spam in SMP and buffer size errors in some other games
* | | | | | Merge pull request #1718 from ogniK5377/lets-go-softlockbunnei2018-11-193-1/+18
|\ \ \ \ \ \ | | | | | | | | | | | | | | Implemented CalculateStandardUserSystemClockDifferenceByUser
| * | | | | | Implemented CalculateStandardUserSystemClockDifferenceByUserDavid Marcec2018-11-173-1/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Seems pokemon calls this sometimes and it caused "random crashes"
* | | | | | | Merge pull request #1671 from DarkLordZach/vi-disconnectbunnei2018-11-191-0/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | vi: Implement TransactParcel for Disconnect and DetachBuffer
| * | | | | | | vi: Implement TransactParcel for Disconnect and DetachBufferZach Hilman2018-11-171-0/+22
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | Used by homebrew on exit. According to switchbrew, returns an empty response parcel with one zero in it.
* | | | | | | Merge pull request #1728 from FearlessTobi/reset-signalMat M2018-11-181-1/+1
|\ \ \ \ \ \ \ | |_|_|_|/ / / |/| | | | | | svc: ResetSignal is not stubbed
| * | | | | | svc: ResetSignal is not stubbedTobias2018-11-181-1/+1
| | | | | | | | | | | | | | | | | | | | | https://user-images.githubusercontent.com/20753089/48677874-b8e01c80-eb7b-11e8-8043-b99faa29022c.PNG
* | | | | | | Stubbed am:EnableApplicationCrashReportMysticExile2018-11-172-10/+18
| | | | | | |
* | | | | | | Merge pull request #1711 from ogniK5377/bluetooth-lets-gobunnei2018-11-172-1/+145
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | Added various bluetooth based cmds for palma
| * | | | | | | Added various bluetooth based cmds for palmaDavid Marcec2018-11-162-1/+145
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | It seems palma is done through bluetooth, we need this for pokemon go however more research needs to be done when we actually get palma working. This is presumably used for transfering data between the controller and the console, it does not seem for actual input as far as I know.
* | | | | | | Merge pull request #1719 from bunnei/hwopus-fixbunnei2018-11-171-1/+1
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | hwopus: DecodeInterleavedWithPerformance: Fix ordering of output parameters.
| * | | | | | | hwopus: DecodeInterleavedWithPerformance: Fix ordering of output parameters.bunnei2018-11-171-1/+1
| | |_|_|/ / / | |/| | | | | | | | | | | | | | | | | | | - Fixes audio issues with Pokemon: Let's Go Pikachu & Eevee.
* / | | | | | kernel/errors: Clean up error codesLioncash2018-11-162-62/+32
|/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Similar to PR 1706, which cleans up the error codes for the filesystem code, but done for the kernel error codes. This removes the ErrCodes namespace and specifies the errors directly. This also fixes up any straggling lines of code that weren't using the named error codes where applicable.
* | | | | | Merge pull request #1638 from FreddyFunk/SetMemoryPermission-StubbedMat M2018-11-162-1/+48
|\ \ \ \ \ \ | | | | | | | | | | | | | | Implement SetMemoryPermission
| * | | | | | Implement SetMemoryPermissionFrederic Laing2018-11-061-3/+39
| | | | | | |
| * | | | | | Stubbed SetMemoryPermissionFrederic Laing2018-11-032-1/+12
| | |_|/ / / | |/| | | |
* | | | | | Merge pull request #1632 from DarkLordZach/keys-manager-optimizationsbunnei2018-11-162-4/+11
|\ \ \ \ \ \ | | | | | | | | | | | | | | game_list: Optimize game list refresh
| * | | | | | filesystem: Cache RegisteredCacheUnion instead of constructing on demandZach Hilman2018-11-022-4/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Prevents unnecessary re-reads of the metadata and unnecessary temporary objects.
* | | | | | | Merge pull request #1706 from lioncash/file-errbunnei2018-11-163-13/+11
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | file_sys/errors: Clean up error code values
| * | | | | | | file_sys/errors: Extract FS-related error codes to file_sys/errors.hLioncash2018-11-163-13/+11
| | |_|/ / / / | |/| | | | | | | | | | | | | | | | | | | Keeps filesystem-related error codes in one spot.
* / | | | | | Added SetIsPalmaAllConnectable, SetPalmaBoostModeDavid Marcec2018-11-161-2/+14
|/ / / / / / | | | | | | | | | | | | | | | | | | Currently unclear what these do yet, will be researched at a later time when we want to implement palma.
* | | | | | Fixed priority switching edge case for handheld (#1675)David2018-11-161-12/+46
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fixed priority switching edge case for handheld We accidently used controller index instead of npad id * Moved NPadIdToIndex
* | | | | | Merge pull request #1699 from DarkLordZach/deterministic-rng-3bunnei2018-11-161-1/+2
|\ \ \ \ \ \ | | | | | | | | | | | | | | csrng: Use random integer distribution instead of raw engine
| * | | | | | csrng: Use random integer distribution instead of raw engineZach Hilman2018-11-161-1/+2
| | |_|_|/ / | |/| | | | | | | | | | | | | | | | Prevents returning the same value every single call.
* | | | | | Merge pull request #1687 from lioncash/deduplicationbunnei2018-11-152-37/+13
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/thread: Deduplicate scheduler switching code
| * | | | | | kernel/thread: Deduplicate scheduler switching codeLioncash2018-11-142-37/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The code in both places was the same verbatim, so we can extract it to a function to deduplicate the logic.
* | | | | | | Merge pull request #1618 from DarkLordZach/dump-nsobunnei2018-11-152-4/+22
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | patch_manager: Add support for dumping uncompressed NSOs
| * | | | | | | bis_factory: Add getter for mod dump root for a title IDZach Hilman2018-10-292-4/+22
| | |_|_|_|/ / | |/| | | | | | | | | | | | | | | | | | | Equates to yuzu_dir/dump/<title id>/
* | | | | | | Merge pull request #1691 from lioncash/audrenbunnei2018-11-151-3/+3
|\ \ \ \ \ \ \ | |_|_|/ / / / |/| | | | | | service/audren_u: Forward RequestUpdateAuto through the same function as RequestUpdate
| * | | | | | service/audren_u: Forward RequestUpdateAuto through the same function as RequestUpdateLioncash2018-11-141-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Based off RE, they both currently go through the same codepath with no difference in behavior.
* | | | | | | Merge pull request #1697 from lioncash/accbunnei2018-11-152-15/+23
|\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | acc/profile_manager: Minor cleanup-related changes
| * | | | | | | profile_manager: Replace iterative loop with a ranged-for loop in ParseUserSaveFile()Lioncash2018-11-141-4/+5
| | | | | | | |
| * | | | | | | profile_manager: Move UUID Format function definitions into the cpp fileLioncash2018-11-142-11/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids relying on fmt always being indirectly included.
* | | | | | | | Merge pull request #1696 from lioncash/acc-condbunnei2018-11-151-2/+4
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | service/acc: Correct error case within TrySelectUserWithoutInteraction()
| * | | | | | | | service/acc: Correct error case within TrySelectUserWithoutInteraction()Lioncash2018-11-141-2/+4
| |/ / / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | empty() in this case will always return false, since the returned container is a std::array. Instead, check if all given users are invalid before returning the error code.
* | | | | | | | Merge pull request #1690 from lioncash/nfpbunnei2018-11-141-1/+1
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | nfp: Correct erroneous sizeof expression within GetTagInfo()
| * | | | | | | | nfp: Correct erroneous sizeof expression within GetTagInfo()Lioncash2018-11-141-1/+1
| | |_|_|/ / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The previous expression would copy sizeof(size_t) amount of bytes (8 on a 64-bit platform) rather than the full 10 bytes comprising the uuid member. Given the source and destination types are the same, we can just use an assignment here instead.
* | | | | | | | Merge pull request #1689 from lioncash/breakbunnei2018-11-141-0/+1
|\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | hid/npad: Add missing break in switch statement within Controller_NPad::OnUpdate
| * | | | | | | | hid/npad: Add missing break in switch statement within Controller_NPad::OnUpdate()Lioncash2018-11-141-0/+1
| |/ / / / / / /
* | | | | | | | Merge pull request #1688 from lioncash/unusedbunnei2018-11-141-2/+2
|\ \ \ \ \ \ \ \ | |_|/ / / / / / |/| | | | | | | service: Mark MakeFunctionString with the [[maybe_unused]] attribute.
| * | | | | | | service: Mark MakeFunctionString with the [[maybe_unused]] attribute.Lioncash2018-11-141-2/+2
| |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When yuzu is compiled in release mode this function is unused, however, when compiled in debug mode, it's used within a LOG_TRACE statement. This prevents erroneous compilation warnings about an unused function (that isn't actually totally unused).
* | | | | | | Merge pull request #1679 from DarkLordZach/deterministic-rng-2bunnei2018-11-143-1/+27
|\ \ \ \ \ \ \ | |_|/ / / / / |/| | | | | | svc: Use proper random entropy generation algorithm
| * | | | | | svc: Use proper random entropy generation algorithmZach Hilman2018-11-133-1/+27
| |/ / / / /
* | | | | | Merge pull request #1680 from lioncash/membunnei2018-11-144-86/+98
|\ \ \ \ \ \ | | | | | | | | | | | | | | kernel/process: Migrate heap-related memory management out of the process class and into the vm manager
| * | | | | | vm_manager: Unstub GetTotalHeapUsage()Lioncash2018-11-131-2/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now that we've moved all of the heap-related stuff to the VMManager class, we can unstub this function, as the necessary members are visible now.
| * | | | | | kernel/process: Migrate heap-related memory management out of the process class and into the vm managerLioncash2018-11-134-84/+97
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | Avoids a breach of responsibilities in the interface and keeps the direct code for memory management within the VMManager class.
* | | | | | Merge pull request #1682 from lioncash/audiobunnei2018-11-141-2/+23
|\ \ \ \ \ \ | | | | | | | | | | | | | | hle/audren_u: Implement Get/SetRenderingTimeLimit
| * | | | | | hle/audren_u: Implement Get/SetRenderingTimeLimitLioncash2018-11-131-2/+23
| |/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | These appear to be a basic getter and setter pair, so these are fairly trivial to implement and get out of the way.
* | | | | | Merge pull request #1608 from DarkLordZach/save-data-readerbunnei2018-11-145-2/+227
|\ \ \ \ \ \ | |/ / / / / |/| | | | | [ns|fsp_srv]: Implement various functions to boot Checkpoint
| * | | | | ns: Implement command 400: GetApplicationControlDataZach Hilman2018-10-292-15/+73
| | | | | | | | | | | | | | | | | | Returns the raw NACP bytes and the raw icon bytes into a title-provided buffer. Pulls from Registration Cache for control data, returning all zeros should it not exist.
| * | | | | fsp_srv: Implement ISaveDataInfoReaderZach Hilman2018-10-291-0/+144
| | | | | | | | | | | | | | | | | | | | | | | | An object to read SaveDataInfo objects, which describe a unique save on the system. This implementation iterates through all the directories in the save data space and uses the paths to reconstruct the metadata.
| * | | | | fsp_srv: Implement command 61: OpenSaveDataInfoReaderBySaveDataSpaceIdZach Hilman2018-10-292-1/+13
| | | | | | | | | | | | | | | | | | | | | | | | Needed by Checkpoint. Returns an object that can iterate through all savedata on the system.
| * | | | | savedata_factory: Expose accessors for SaveDataSpaceZach Hilman2018-10-292-0/+11
| |/ / / /
* | | | | Merge pull request #1670 from DarkLordZach/deterministic-rngbunnei2018-11-133-3/+13
|\ \ \ \ \ | | | | | | | | | | | | csrng: Add config option to set RNG seed
| * | | | | svc: Return random seed for svcGetInfo RandomEntropyZach Hilman2018-11-131-1/+2
| | | | | |
| * | | | | csrng: Use std::mt19937 engine for random number generationZach Hilman2018-11-122-2/+11
| | |_|_|/ | |/| | |
* | | | | Merge pull request #1665 from ogniK5377/GetClockSnapshotbunnei2018-11-133-21/+132
|\ \ \ \ \ | |/ / / / |/| | | | Implement GetClockSnapshot, ToPosixTime & ToPosixTimeWithMyRule
| * | | | Added maybe_unusedDavid Marcec2018-11-102-2/+7
| | | | |
| * | | | Added ToPosixTime & ToPosixTimeWithMyRuleDavid Marcec2018-11-101-2/+41
| | | | | | | | | | | | | | | | | | | | Added instead of using a seperate PR to prevent conflicts
| * | | | Added consts and staticDavid Marcec2018-11-101-6/+6
| | | | |
| * | | | Implement GetClockSnapshotDavid Marcec2018-11-093-21/+88
| | | | | | | | | | | | | | | | | | | | Needed by megaman 11
* | | | | Merge pull request #1656 from ogniK5377/message-queueJames Rowe2018-11-106-35/+138
|\ \ \ \ \ | |/ / / / |/| | | | Ability to switch between docked and undocked mode in-game
| * | | | FixupsDavid Marcec2018-11-071-1/+1
| | | | |
| * | | | Ability to switch between docked and undocked mode in-gameDavid Marcec2018-11-076-35/+138
| | | | | | | | | | | | | | | | | | | | Started implementation of the AM message queue mainly used in state getters. Added the ability to switch docked mode whilst in game without stopping emulation. Also removed some things which shouldn't be labelled as stubs as they're implemented correctly
* | | | | Merge pull request #1658 from ogniK5377/holdtype-stylebunnei2018-11-081-0/+2
|\ \ \ \ \ | | | | | | | | | | | | Updated npad styles on holdtype switches
| * | | | | Updated npad styles on holdtype switchesDavid Marcec2018-11-071-0/+2
| |/ / / / | | | | | | | | | | | | | | | Fixes input for megaman
* | | | | svcBreak now dumps information from the debug buffer passed (#1646)David2018-11-081-0/+28
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * svcBreak now dumps information from the debug buffer passed info1 and info2 seem to somtimes hold an address to a buffer, this is usually 4 bytes or the size of the int and contains an error code. There's other circumstances where it can be something different so we hexdump these to examine them at a later date. * Addressed comments
* | | | | fixed spelling errorDavid Marcec2018-11-071-1/+1
| | | | |
* | | | | Added missing logDavid Marcec2018-11-071-0/+1
| | | | |
* | | | | Implement acc:TrySelectUserWithoutInteractionDavid Marcec2018-11-075-3/+25
|/ / / / | | | | | | | | | | | | Needed for Shantae - Half-Genie Hero - Ultimate Edition!
* | | | Merge pull request #1633 from ogniK5377/reload-inputbunnei2018-11-052-0/+5
|\ \ \ \ | | | | | | | | | | Fixed HID crash when launching more than 1 game & signaled styleset change event
| * | | | Fixed HID crash when launching more than 1 game & signaled syleset change eventDavid Marcec2018-11-022-0/+5
| | | | | | | | | | | | | | | | | | | | This should fix crashes when launching multiple games in yuzu
* | | | | Fix typo in BufferTransformFlagsFrederic Laing2018-11-041-2/+2
| |_|_|/ |/| | |
* | | | Fixed incorrect hwopus assertDavid Marcec2018-11-021-1/+1
|/ / /
* | | Merge pull request #1615 from lioncash/inputbunnei2018-11-021-1/+2
|\ \ \ | | | | | | | | configure_system: Contrain profile usernames to 32 characters
| * | | configure_system: Contrain profile usernames to 32 charactersLioncash2018-10-311-1/+2
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, we would let a user enter an unbounded name and then silently truncate away characters that went over the 32-character limit. This is kind of bad from the UX point of view, because we're essentially not doing what the user intended in certain scenarios. Instead, we clamp it to 32 characters and make that visually apparent in the dialog box to provide a name for a user.
* | / service/usb: Update IPdSession's function tableLioncash2018-10-301-3/+3
| |/ |/| | | | | Updated based off information on SwitchBrew.
* | general: Remove unused boost inclusions where applicableLioncash2018-10-301-2/+0
| | | | | | | | Cleans up unused includes and trims off some dependencies on externals.
* | global: Use std::optional instead of boost::optional (#1578)Frederic L2018-10-307-23/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * get rid of boost::optional * Remove optional references * Use std::reference_wrapper for optional references * Fix clang format * Fix clang format part 2 * Adressed feedback * Fix clang format and MacOS build
* | Merge pull request #1621 from lioncash/ipcbunnei2018-10-303-6/+9
|\ \ | | | | | | hle_ipc: Make GetDomainMessageHeader return a regular pointer
| * | hle_ipc: Add member function for querying the existence of a domain headerLioncash2018-10-303-3/+6
| | | | | | | | | | | | Gets rid of the need to call the getter and then check for null.
| * | hle_ipc: Make GetDomainMessageHeader return a regular pointerLioncash2018-10-302-3/+3
| |/ | | | | | | | | Nothing requires the shared owner ship here, so we can just return a plain pointer.
* / core: Make System references const where applicableLioncash2018-10-282-3/+3
|/
* Merge pull request #1593 from lioncash/svcbunnei2018-10-286-35/+128
|\ | | | | svc: Implement svcGetInfo command 0xF0000002
| * svc: Localize the GetInfo enum class to the function itselfLioncash2018-10-262-32/+31
| | | | | | | | Nothing from this enum is intended to be used outside of this function.
| * svc: Implement svcGetInfo command 0xF0000002Lioncash2018-10-266-4/+98
| | | | | | | | | | | | | | | | | | | | This retrieves: if (curr_thread == handle_thread) { result = total_thread_ticks + (hardware_tick_count - last_context_switch_ticks); } else if (curr_thread == handle_thread && sub_id == current_core_index) { result = hardware_tick_count - last_context_switch_ticks; }
* | service/filesystem: Add DirectoryDelete & DirectoryDeleteRecursivelyDeeJayBro2018-10-271-2/+26
|/
* Merge pull request #1569 from lioncash/amiibobunnei2018-10-262-3/+5
|\ | | | | yuzu/main: Notify user of loading errors with Amiibo data
| * yuzu/main: Notify user of loading errors with Amiibo dataLioncash2018-10-242-3/+5
| | | | | | | | | | We shouldn't silently continue if loading failed, since the general assumption is that no messages showing up implicitly indicates success.
* | ldr: Partially implement LoadNro.bunnei2018-10-261-3/+49
| | | | | | | | - This is an incomplete implementation. It was tested with Super Mario Party.
* | process: LoadModule should clear JIT instruction cache.bunnei2018-10-261-0/+6
| |
* | Kernel/Memory: Added a function to first a suitable guest address at which to allocate a region of a given size.bunnei2018-10-262-0/+28
| |
* | Merge pull request #1579 from lioncash/usbbunnei2018-10-251-21/+22
|\ \ | | | | | | service/usb: Update service function tables
| * | service/usb: Update service function tablesLioncash2018-10-251-21/+22
| | | | | | | | | | | | Updated based off the information provided by Hexkyz on Switchbrew.
* | | Merge pull request #1576 from lioncash/acc-warnbunnei2018-10-251-25/+27
|\ \ \ | | | | | | | | service/acc: Silence compiler truncation warnings
| * | | service/acc: Move fallback image to file scopeLioncash2018-10-251-14/+13
| | | | | | | | | | | | | | | | | | | | | | | | This is just flat data, so it doesn't really need to be in the function itself. This also allows deduplicating the constant for the backup size in GetImageSize().
| * | | service/acc: Silence compiler warningsLioncash2018-10-251-5/+8
| | | | | | | | | | | | | | | | | | | | Silences compiler warnings related to truncation. This also introduces a small helper function to perform the clamping of the image size.
| * | | service/acc: Early return in failure case in LoadImage()Lioncash2018-10-251-8/+8
| |/ / | | | | | | | | | Allows unindenting the other branch's code.
* | | Merge pull request #1577 from lioncash/errbunnei2018-10-255-34/+16
|\ \ \ | | | | | | | | kernel/error: Amend error return code values
| * | | kernel/errors: Remove now-unused, unnecessary, error codesLioncash2018-10-242-13/+0
| | | | | | | | | | | | | | | | | | | | | | | | Now that we've gotten the innaccurate error codes out of the way, we can finally toss away a bunch of these, trimming down the error codes to ones that are actually used and knocking out two TODO comments.
| * | | kernel/shared_memory: Return ERR_INVALID_MEMORY_PERMISSIONS instead of ERR_INVALID_COMBINATIONLioncash2018-10-241-4/+3
| | | | | | | | | | | | | | | | This is more consistent with what the kernel does.
| * | | kernel/server_port: Simplify emptiness check within ShouldWait()Lioncash2018-10-241-1/+1
| | | |
| * | | kernel/server_port: Change error case return value in Accept() to ERR_NOT_FOUNDLioncash2018-10-242-3/+1
| | | | | | | | | | | | | | | | This is what the kernel does in this instance.
| * | | kernel/error: Remove leftover 3DS error codesLioncash2018-10-241-5/+0
| | | | | | | | | | | | | | | | These are now entirely unused and can be removed.
| * | | kernel/svc: Amend returned error code for invalid priorities in CreateThreadLioncash2018-10-241-1/+1
| | | | | | | | | | | | | | | | | | | | Like with the previous change, the kernel doesn't return NOT_AUTHORIZED here. It returns INVALID_THREAD_PRIORITY.
| * | | kernel/svc: Move and correct returned error code for invalid thread priorities in SetThreadPriority()Lioncash2018-10-241-5/+6
| | | | | | | | | | | | | | | | | | | | | | | | All priority checks are supposed to occur before checking the validity of the thread handle, we're also not supposed to return ERR_NOT_AUTHORIZED here.
| * | | kernel/error: Add error code for invalid pointersLioncash2018-10-241-1/+1
| | | | | | | | | | | | | | | | | | | | The kernel appears to return 0xE601 for this situation. Particularly in svcWaitSynchronization, svcReplyAndReceive, and svcGetThreadContext
| * | | kernel/error: Add error code for closed sessionsLioncash2018-10-241-1/+3
| |/ / | | | | | | | | | The kernel appears to return 0xF601 for this case.
* | | Merge pull request #1570 from lioncash/optionalbunnei2018-10-253-43/+48
|\ \ \ | | | | | | | | profile_manager: Use std::optional instead of boost::optional
| * | | profile_manager: Use std::optional instead of boost::optionalLioncash2018-10-243-43/+48
| |/ / | | | | | | | | | | | | Now that we can actually use std::optional on macOS, we don't need to continue using boost::optional here.
* | | Merge pull request #1564 from lioncash/npadbunnei2018-10-241-2/+3
|\ \ \ | | | | | | | | npad: Remove unused controller variable from OnInit()
| * | | npad: Remove unused controller variable from OnInit()Lioncash2018-10-241-2/+3
| | |/ | |/| | | | | | | | | | This also gets rid of variable shadowing related to the lambda parameter a little bit below this code as well.
* | | Merge pull request #1562 from lioncash/aocbunnei2018-10-241-3/+3
|\ \ \ | |_|/ |/| | aoc_u: Make use of previously-unused CheckAOCTitleIDMatchesBase() function
| * | aoc_u: Make use of previously-unused CheckAOCTitleIDMatchesBase() functionLioncash2018-10-241-3/+3
| |/ | | | | | | | | | | | | | | We can just call the function instead of duplicating the code here. This also prevents an unused function warning. We also don't need to take the lambda capture by reference. It's just a u64 value, so by value is fine here.
* | Merge pull request #1468 from DarkLordZach/profile-manager-uiMat M2018-10-244-29/+226
|\ \ | |/ |/| qt: Add UI to manage emulated user profiles
| * profile_manager: Create save data if it doesn't exist on useZach Hilman2018-10-242-13/+37
| |
| * acc: Fix account UUID duplication errorZach Hilman2018-10-244-17/+47
| |
| * configure_system: Clear selection after user deleteZach Hilman2018-10-241-1/+1
| |
| * profile_manager: Load user icons, names, and UUIDs from system saveZach Hilman2018-10-244-26/+129
| |
| * acc: Load user images from config dirZach Hilman2018-10-241-9/+45
| |
| * am: Pass current user UUID to launch parametersZach Hilman2018-10-241-7/+9
| |
| * profile_manager: Load users from emulator settingsZach Hilman2018-10-242-5/+7
| |
* | Merge pull request #1551 from ogniK5377/improved-svcbreakbunnei2018-10-241-5/+51
|\ \ | |/ |/| Added break types to svcBreak
| * Added assertion failed, reworked logging levelsDavid Marcec2018-10-231-16/+24
| |
| * Added break types to svcBreakDavid Marcec2018-10-231-4/+42
| | | | | | | | There seems to be more such as type 1, and 2. Unsure what these currently are but when a game hits them we can investigate and add the rest
* | Added Amiibo support (#1390)David2018-10-243-50/+294
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fixed conflict with nfp * Few fixups for nfc * Conflict 2 * Fixed AttachAvailabilityChangeEvent * Conflict 3 * Fixed byte padding * Refactored amiibo to not reside in "System" * Removed remaining references of nfc from system * used enum for Nfc GetStateOld * Added missing newline * Moved file operations to front end * Conflict 4 * Amiibos now use structs and added mutexes * Removed amiibo_path
* | Merge pull request #1515 from DarkLordZach/dlc-lfsbunnei2018-10-241-1/+5
|\ \ | | | | | | patch_manager: Add support for LayeredFS on DLC RomFS
| * | fsp_srv: Apply patches to Data storage in OpenDataStorageByDataIdZach Hilman2018-10-171-1/+5
| | |
* | | Merge pull request #1540 from lioncash/handlebunnei2018-10-248-98/+95
|\ \ \ | |_|/ |/| | kernel/process: Make the handle table per-process
| * | kernel/process: Make the handle table per-processLioncash2018-10-208-98/+95
| | | | | | | | | | | | | | | | | | | | | | | | In the kernel, there isn't a singular handle table that everything gets tossed into or used, rather, each process gets its own handle table that it uses. This currently isn't an issue for us, since we only execute one process at the moment, but we may as well get this out of the way so it's not a headache later on.
* | | Merge pull request #1545 from DarkLordZach/psmbunnei2018-10-223-0/+88
|\ \ \ | | | | | | | | psm: Add psm service and stub commands 0 and 1
| * | | psm: Stub GetChargerTypeZach Hilman2018-10-222-24/+27
| | | | | | | | | | | | Used by LovePotion Lua Homebrew. Stubbed as connected to official Nintendo Switch dock.
| * | | psm: Stub GetBatteryChargePercentageZach Hilman2018-10-212-1/+14
| | | | | | | | | | | | | | | | Used by LovePotion Lua Homebrew. Stubbed to return 100% charge.
| * | | service: Add skeleton for psm serviceZach Hilman2018-10-213-0/+72
| |/ / | | | | | | | | | Seems to be the power controller. Listed in switchbrew under the category PTM services.
* | | Merge pull request #1538 from lioncash/querybunnei2018-10-221-1/+1
|\ \ \ | | | | | | | | svc: Fix vma boundary check in svcQueryMemory
| * | | svc: Fix vma boundary check in svcQueryMemoryLioncash2018-10-201-1/+1
| |/ / | | | | | | | | | | | | | | | This should be comparing against the queried process' vma_map, not the current process'. The only reason this hasn't become an issue yet is we currently only handle one process being active at any time.
* | | service: Add the basic skeleton for the NPNS servicesLioncash2018-10-213-2/+107
| | |
* | | hid: Update service function table for hidbusLioncash2018-10-211-0/+1
| | | | | | | | | | | | Updated based off information provided by Switchbrew.
* | | am: Add the basic skeleton for the tcap serviceLioncash2018-10-213-0/+42
| | | | | | | | | | | | Added based off information provided by Switchbrew.
* | | am: Update service function tablesLioncash2018-10-214-15/+60
| | | | | | | | | | | | Updated based off information from Switchbrew
* | | prepo: Update service function table.Lioncash2018-10-211-8/+13
| | | | | | | | | | | | | | | | | | Also introduces the new prepo:a2 service. Updated based off information provided by Switchbrew.
* | | lbl: Update service function table namesLioncash2018-10-211-28/+28
| | | | | | | | | | | | Updated based off information provided by Switchbrew.
* | | Added auto controller switching to supported controllers and single joycon button rotationDavid Marcec2018-10-202-4/+189
|/ / | | | | | | This is a subset of the better-hid-2 changes, this fixes input in various games which don't support dual joycons. This pr will search for the next best controller which is supported by the current game
* | Merge pull request #1520 from lioncash/sanbunnei2018-10-203-3/+50
|\ \ | | | | | | svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemory
| * | svc: Add missing sanitizing checks for MapSharedMemory/UnmapSharedMemoryLioncash2018-10-183-3/+50
| | | | | | | | | | | | | | | | | | | | | | | | Now that the changes clarifying the address spaces has been merged, we can wrap the checks that the kernel performs when mapping shared memory (and other forms of memory) into its own helper function and then use those within MapSharedMemory and UnmapSharedMemory to complete the sanitizing checks that are supposed to be done.
* | | Merge pull request #1526 from lioncash/svc-idbunnei2018-10-208-53/+163
|\ \ \ | | | | | | | | service: Update function tables
| * | | es: Update service function tablesLioncash2018-10-191-7/+11
| | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew.
| * | | audio: Update service function tablesLioncash2018-10-191-17/+20
| | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew.
| * | | omm: Update service function tablesLioncash2018-10-191-16/+18
| | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew.
| * | | nifm: Update service function tablesLioncash2018-10-191-0/+1
| | | | | | | | | | | | | | | | Updated based off information provided by switchbrew.
| * | | hid: Update service function tablesLioncash2018-10-191-6/+45
| | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew.
| * | | nim: Add the basic skeleton of the nim:eca serviceLioncash2018-10-191-0/+17
| | | | | | | | | | | | | | | | Added based off information provided by Switchbrew
| * | | ns: Update service function tableLioncash2018-10-191-6/+49
| | | | | | | | | | | | | | | | Updated based off information provided by Switchbrew.
| * | | set_cal: Update service function tableLioncash2018-10-191-1/+2
| | | | | | | | | | | | | | | | Updated based on information from Switchbrew.
* | | | Merge pull request #1530 from DarkLordZach/aoc-8bunnei2018-10-202-1/+16
|\ \ \ \ | | | | | | | | | | aoc_u: Stub GetAddOnContentListChangedEvent
| * | | | aoc_u: Stub GetAddOnContentListChangedEventZach Hilman2018-10-202-1/+16
| | | | | | | | | | | | | | | | | | | | This event signals the game when new DLC is purchased from the eShop while the game is running. Since, for the forseeable future, yuzu will not have this ability, it seems safe to stub with a dummy event that will never fire. This is needed to boot Sonic Mania Plus (update v1.04).
* | | | | Merge pull request #1516 from lioncash/hidbunnei2018-10-2018-19/+33
|\ \ \ \ \ | |/ / / / |/| | | | hid: Minor cleanup-related changes
| * | | | hid/controller: Remove unused header inclusionsLioncash2018-10-189-9/+0
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | swap.h only needs to be present in the header for the type aliases and definitions, it's not actually needed in the cpp files though. input.h is just unused entirely in xpad.h
| * | | | hid/controller/npad: Remove unused dump_idx member variableLioncash2018-10-181-1/+0
| | | | | | | | | | | | | | | | | | | | Given it's unused, we may as well toss it.
| * | | | hid/controller/npad: Remove unnecessary semicolon from the closing brace of LedPattern's constructorLioncash2018-10-181-1/+1
| | | | |
| * | | | hid/controller/npad: Remove #pragma once from the cpp fileLioncash2018-10-181-2/+0
| | | | | | | | | | | | | | | | | | | | This is only useful in headers.
| * | | | hid/controller/npad: Move npad_id_list into the cpp fileLioncash2018-10-182-2/+10
| | | | | | | | | | | | | | | | | | | | | | | | | This is just a lookup table, and since it's private, there's nothing really stateful about it, so we can just move it into the cpp file.
| * | | | hid/controller/npad: Remove unnecessary const from void return typeLioncash2018-10-182-2/+2
| | | | | | | | | | | | | | | | | | | | This literally does nothing.
| * | | | hid/controller: Default the destructors of all controller types in the cpp fileLioncash2018-10-1816-0/+16
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | These classes are non-trivial and are definitely going to be changed in the future, so we default these to prevent issues with forward declarations, and to keep the compiler from inlining tear-down code.
| * | | | controller_base: Default the base class constructor and destructor in the cpp fileLioncash2018-10-182-2/+4
| | |/ / | |/| | | | | | | | | | The destructor doesn't need to be a pure-virtual function.
* | | | Stubbed home blockingDavid Marcec2018-10-192-4/+36
| |/ / |/| | | | | | | | Needed by arms due to new hid rework
* | | Merge pull request #1523 from lioncash/lockbunnei2018-10-191-9/+15
|\ \ \ | | | | | | | | svc: Add missing error checks in svcArbitrateLock/svcArbitrateUnlock
| * | | svc: Check for word alignment of addresses within svcArbitrateLock/svcArbitrateUnlockLioncash2018-10-181-0/+8
| | | | | | | | | | | | | | | | | | | | The kernel itself checks whether or not the provided addresses are word aligned before continuing, so we should be doing the same.
| * | | common: Move Is4KBAligned() to alignment.hLioncash2018-10-181-9/+7
| |/ / | | | | | | | | | | | | Aligning on 4KB pages isn't a Switch-specific thing, so this can be moved to common so it can be used with other things as well.
* / / Used better names for mm:u and fixed bad stubDavid Marcec2018-10-181-8/+42
|/ / | | | | | | InitializeWithId needs to return an id which is a u32 which should be a non zero value
* | Merge pull request #1444 from ogniK5377/better-hidbunnei2018-10-1821-648/+1702
|\ \ | | | | | | "Better Hid" Rework Part 1
| * | Using dual joycons as the default controllerDavid Marcec2018-10-173-77/+59
| | | | | | | | | | | | Reason for the change is to allow both docked and undocked mode to work
| * | WipDavid Marcec2018-10-122-3/+23
| | |
| * | Dynamically decide handheld variant based on supported npad id priorityDavid Marcec2018-10-113-19/+62
| | | | | | | | | | | | Kirby input still doesn't work, should fix a lot of other games
| * | Added BeginPermitVibrationSession and EndPermitVibrationSessionDavid Marcec2018-10-103-2/+26
| | | | | | | | | | | | Used by Mario Party
| * | Added GetLedPattern and HandheldVariantDavid Marcec2018-10-103-6/+63
| | | | | | | | | | | | HandheldVariant is for specific games which expect handheld controllers to be at position 8(kirby), however this doesn't fix all games as some games require handhelds to be at position 0(snipperclips)
| * | Kirby expects handheld controllers to be at position 8David Marcec2018-10-101-2/+8
| | |
| * | Added the ability to "disconnect" individual npadsDavid Marcec2018-10-103-16/+40
| | | | | | | | | | | | Fixes arms
| * | Removed unneeded forward declarationsDavid Marcec2018-10-102-13/+2
| | |
| * | Addressed changes for better hidDavid Marcec2018-10-1019-167/+238
| | |
| * | "Better Hid" rework part 1David Marcec2018-10-1021-644/+1482
| | |
* | | Merge pull request #1498 from lioncash/aslrbunnei2018-10-184-28/+44
|\ \ \ | |_|/ |/| | svc: Clarify enum values for AddressSpaceBaseAddr and AddressSpaceSize in svcGetInfo()
| * | svc: Clarify enum values for AddressSpaceBaseAddr and AddressSpaceSize in svcGetInfo()Lioncash2018-10-154-28/+44
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | So, one thing that's puzzled me is why the kernel seemed to *not* use the direct code address ranges in some cases for some service functions. For example, in svcMapMemory, the full address space width is compared against for validity, but for svcMapSharedMemory, it compares against 0xFFE00000, 0xFF8000000, and 0x7FF8000000 as upper bounds, and uses either 0x200000 or 0x8000000 as the lower-bounds as the beginning of the compared range. Coincidentally, these exact same values are also used in svcGetInfo, and also when initializing the user address space, so this is actually retrieving the ASLR extents, not the extents of the address space in general.
* | | Implement VI ConvertScalingMode (#1475)David2018-10-161-1/+49
| | | | | | | | | | | | | | | | | | | | | | | | * Implement VI ConvertScalingMode * Fixed push enum * Scale mode now uses Nintendo scale mode as an enum as well
* | | Merge pull request #1502 from lioncash/uniquebunnei2018-10-164-15/+15
|\ \ \ | | | | | | | | core: Convert shared_ptr instances into unique_ptr instances where applicable for System and Cpu
| * | | core_cpu: Make Cpu scheduler instances unique_ptrs instead of shared_ptrsLioncash2018-10-154-15/+15
| | | |
* | | | file_sys/registered_cache: Use unique_ptr and regular pointers instead of shared_ptrs where applicableLioncash2018-10-163-12/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The data retrieved in these cases are ultimately chiefly owned by either the RegisteredCache instance itself, or the filesystem factories. Both these should live throughout the use of their contained data. If they don't, it should be considered an interface/design issue, and using shared_ptr instances here would mask that, as the data would always be prolonged after the main owner's lifetime ended. This makes the lifetime of the data explicit and makes it harder to accidentally create cyclic references. It also makes the interface slightly more flexible than the previous API, as a shared_ptr can be created from a unique_ptr, but not the other way around, so this allows for that use-case if it ever becomes necessary in some form.
* | | | Merge pull request #1494 from DarkLordZach/aoc-signature-fixesbunnei2018-10-161-3/+15
|\ \ \ \ | |/ / / |/| | | aoc: Fix various bugs in current AOC implementation
| * | | aoc: Read DLC base title ID from RegisteredCacheZach Hilman2018-10-151-2/+13
| | | | | | | | | | | | Falls back to title ID + 0x1000, which is what HOS does.
| * | | aoc: Return size in ListAddOnContentZach Hilman2018-10-141-1/+2
| | | |
* | | | Merge pull request #1491 from lioncash/referencebunnei2018-10-144-14/+13
|\ \ \ \ | |_|/ / |/| | | filesystem: Make CreateFactories() and InstallInterface() take a VfsFilesystem by reference
| * | | filesystem: Make CreateFactories() and InstallInterface() take a VfsFilesystem instance by referenceLioncash2018-10-134-14/+13
| |/ / | | | | | | | | | | | | | | | | | | Neither of these functions alter the ownership of the provided pointer, so we can simply make the parameters a reference rather than a direct shared pointer alias. This way we also disallow passing incorrect memory values like nullptr.
* | | Merge pull request #1492 from lioncash/procbunnei2018-10-143-4/+50
|\ \ \ | | | | | | | | svc: Implement svcGetProcessInfo
| * | | svc: Implement svcGetProcessInfoLioncash2018-10-133-4/+50
| |/ / | | | | | | | | | | | | | | | | | | A fairly basic service function, which only appears to currently support retrieving the process state. This also alters the ProcessStatus enum to contain all of the values that a kernel process seems to be able of reporting with regards to state.
* / / Stop all threads on svcBreakDavid Marcec2018-10-141-0/+6
|/ / | | | | | | This should help diagnose crashes easier and prevent many users thinking that a game is still running when in fact it's just an audio thread still running(this is typically not killed when svcBreak is hit since the game expects us to do this)
* | Merge pull request #1483 from lioncash/codesetbunnei2018-10-134-40/+14
|\ \ | | | | | | kernel/process: Make CodeSet a regular non-inherited object
| * | kernel/process: Make CodeSet a regular non-inherited objectLioncash2018-10-124-40/+14
| | | | | | | | | | | | | | | | | | | | | | | | These only exist to ferry data into a Process instance and end up going out of scope quite early. Because of this, we can just make it a plain struct for holding things and just std::move it into the relevant function. There's no need to make this inherit from the kernel's Object type.
* | | Merge pull request #1481 from lioncash/typobunnei2018-10-131-3/+3
|\ \ \ | | | | | | | | svc: Fix typos in sanitizing checks for MapMemory/UnmapMemory
| * | | svc: Fix typos in sanitizing checks for MapMemory/UnmapMemoryLioncash2018-10-121-3/+3
| |/ /
* | | Merge pull request #1467 from ogniK5377/svcbreak-type-fixbunnei2018-10-122-28/+36
|\ \ \ | | | | | | | | Fixed incorrect types for svcBreak
| * | | Changed all casts in svc_wrap.h to be static_cast insteadDavid Marcec2018-10-101-25/+28
| | | |
| * | | Use a better name than "dont_kill_application"David Marcec2018-10-101-2/+2
| | | | | | | | | | | | | | | | signal_debugger seems like a more fitting name
| * | | Fixed incorrect types for svcBreakDavid Marcec2018-10-102-3/+8
| | |/ | |/| | | | | | | svcBreak reason should be a u32, not a u64.
* | | Merge pull request #1478 from ogniK5377/remap-invalidhandle-remapbunnei2018-10-121-3/+10
|\ \ \ | | | | | | | | Passing an invalid nmap handle to Remap should throw an error
| * | | Returned an error before processing other remapsDavid Marcec2018-10-121-6/+2
| | | |
| * | | Passing an invalid nmap handle to Remap should throw an errorDavid Marcec2018-10-111-3/+14
| | | | | | | | | | | | | | | | Added error for invalid nmap handles
* | | | Merge pull request #1482 from lioncash/initbunnei2018-10-121-4/+1
|\ \ \ \ | | | | | | | | | | thread: Remove unnecessary memset from ResetThreadContext()
| * | | | thread: Remove unnecessary memset from ResetThreadContext()Lioncash2018-10-121-4/+1
| | |_|/ | |/| | | | | | | | | | | | | | | | | | Regular value initialization is adequate here for zeroing out data. It also has the benefit of not invoking undefined behavior if a non-trivial type is ever added to the struct for whatever reason.
* | | | Merge pull request #1479 from ogniK5377/nmap-revampedbunnei2018-10-121-12/+60
|\ \ \ \ | |/ / / |/| | | Added error codes for nvmap
| * | | Made the minimum alignment more clearDavid Marcec2018-10-121-2/+3
| | | |
| * | | Added error codes for nvmapDavid Marcec2018-10-111-12/+59
| |/ /
* | | Merge pull request #1474 from ogniK5377/hwopus-decodeinterleavedwithperformancebunnei2018-10-111-3/+34
|\ \ \ | | | | | | | | HwOpus, Implemented DecodeInterleavedWithPerformance
| * | | HwOpus, Implemented DecodeInterleavedWithPerformanceDavid Marcec2018-10-111-3/+34
| |/ / | | | | | | | | | Used by sonic ages
* | | Merge pull request #1472 from lioncash/sanbunnei2018-10-112-12/+81
|\ \ \ | | | | | | | | svc: Add missing address range sanitizing checks to MapMemory/UnmapMemory
| * | | svc: Add missing address range sanitizing checks to MapMemory/UnmapMemoryLioncash2018-10-112-12/+81
| |/ / | | | | | | | | | | | | | | | | | | | | | This adds the missing address range checking that the service functions do before attempting to map or unmap memory. Given that both service functions perform the same set of checks in the same order, we can wrap these into a function and just call it from both functions, which deduplicates a little bit of code.
* / / nvhost_as_gpu: Flush CPU VAddr on UnmapBuffer.bunnei2018-10-111-3/+4
|/ /
* / kernel/thread: Use a regular pointer for the owner/current processLioncash2018-10-106-29/+29
|/ | | | | | | | | | | There's no real need to use a shared pointer in these cases, and only makes object management more fragile in terms of how easy it would be to introduce cycles. Instead, just do the simple thing of using a regular pointer. Much of this is just a hold-over from citra anyways. It also doesn't make sense from a behavioral point of view for a process' thread to prolong the lifetime of the process itself (the process is supposed to own the thread, not the other way around).
* Added bitfield instead of manually checking if the bit is setDavid Marcec2018-10-091-4/+12
|
* Actual kill execution when the bit isn't set, not the other way aroundDavid Marcec2018-10-091-1/+1
|
* svcBreak, Signalling to the debugger should not kill executionDavid Marcec2018-10-091-5/+12
| | | | When loading NROs, svcBreak is called to signal to the debugger that a new "module" is loaded. As no debugger is technically attached we shouldn't be killing the programs execution.
* Merge pull request #1456 from ogniK5377/aoc-u-fixupsbunnei2018-10-081-5/+5
|\ | | | | Fixed assertion due to CountAddOnContent & Casting warnings
| * Fixed assertion due to CountAddOnContentDavid Marcec2018-10-071-5/+5
| | | | | | | | | | | | Word count should be 3 since we're pushing a result code and a u32. Also fixed up compiler warnings due to casting
* | Unmapping an unmapped buffer should succeedDavid Marcec2018-10-081-1/+6
|/ | | | Hardware tests show that trying to unmap an unmapped buffer already should always succeed. Hardware test was tested up to 32 iterations of attempting to unmap
* Merge pull request #1396 from DarkLordZach/packed-updatesbunnei2018-10-072-0/+10
|\ | | | | loader: Add support for packed updates
| * romfs_factory: Extract packed update setter to new functionZach Hilman2018-10-052-0/+10
| |
* | Added forward define for ServerPortDavid Marcec2018-10-062-4/+6
| |
* | Ported #4296 from citraDavid Marcec2018-10-063-1/+25
| | | | | | | | This will allow us to easily remove the use of "NFC" in "System"
* | kernel/mutex: Amend behavior of TransferMutexOwnership()Lioncash2018-10-061-1/+1
| | | | | | | | | | | | | | | | | | This was the result of a typo accidentally introduced in e51d715700a35a8f14e5b804b6f7553c9a40888b. This restores the previous correct behavior. The behavior with the reference was incorrect and would cause some games to fail to boot.
* | thread: Make the scheduler pointer a regular pointerbalika0112018-10-052-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | Conceptually, it doesn't make sense for a thread to be able to persist the lifetime of a scheduler. A scheduler should be taking care of the threads; the threads should not be taking care of the scheduler. If the threads outlive the scheduler (or we simply don't actually terminate/shutdown the threads), then it should be considered a bug that we need to fix. Attributing this to balika011, as they opened #1317 to attempt to fix this in a similar way, but my refactoring of the kernel code caused quite a few conflicts.
* | Merge pull request #1439 from lioncash/threadbunnei2018-10-0511-187/+363
|\ \ | |/ |/| kernel/thread: Make all instance variables private
| * kernel/thread: Make all instance variables privateLioncash2018-10-0411-187/+363
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Many of the member variables of the thread class aren't even used outside of the class itself, so there's no need to make those variables public. This change follows in the steps of the previous changes that made other kernel types' members private. The main motivation behind this is that the Thread class will likely change in the future as emulation becomes more accurate, and letting random bits of the emulator access data members of the Thread class directly makes it a pain to shuffle around and/or modify internals. Having all data members public like this also makes it difficult to reason about certain bits of behavior without first verifying what parts of the core actually use them. Everything being public also generally follows the tendency for changes to be introduced in completely different translation units that would otherwise be better introduced as an addition to the Thread class' public interface.
* | Merge pull request #1434 from DarkLordZach/dlc-edge-casebunnei2018-10-041-1/+1
|\ \ | | | | | | aoc_u: Fix edge case with DLC that causes breaks
| * | aoc_u: Fix edge case with DLC that causes breaksZach Hilman2018-10-031-1/+1
| | | | | | | | | | | | In some games (Splatoon 2 and Splatoon 2 Splatfest World Premiere, notably), pass offset=0 and count=2047 into the ListAddOnContent method which should return all DLCs for the current title. The (presumably) intended behavior is to successfully return a empty array but because of a < v. <= in an if statement, a failure error code was returned causing these games to svcBreak. This fixes that if statement.
* | | Merge pull request #1433 from lioncash/fsbunnei2018-10-041-0/+2
|\ \ \ | | | | | | | | services/fsp_srv: Amend service function table
| * | | services/fsp_srv: Amend service function tableLioncash2018-10-031-0/+2
| | |/ | |/| | | | | | | | | | Adds new functions that have been given names to the table. Information is based off what is provided on Switchbrew.
* | | service/lbl: Update service function tableLioncash2018-10-031-19/+19
| |/ |/| | | | | | | Amends the lbl service table to include new names of functions that were added to Switchbrew.
* | aoc_u: Extract AccumulateAOCTitleIDs to separate functionZach Hilman2018-10-011-20/+26
| |
* | aoc_u: Implement GetAddOnContentBaseIdZach Hilman2018-10-012-3/+5
| | | | | | Command #5
* | aoc_u: Implement Count, List and Prepare AddOnContentZach Hilman2018-10-012-3/+78
|/ | | | Commands #2, #3, and #7
* Merge pull request #1338 from raven02/service_vibunnei2018-09-301-1/+19
|\ | | | | Implement ISystemDisplayService::GetDisplayMode
| * Implement ISystemDisplayService::GetDisplayModeraven022018-09-301-1/+19
| |
* | kernel/svc: Implement svcGetThreadContext()Lioncash2018-09-303-2/+37
| | | | | | | | | | | | | | | | | | Now that we have all of the rearranging and proper structure sizes in place, it's fairly trivial to implement svcGetThreadContext(). In the 64-bit case we can more or less just write out the context as is, minus some minor value sanitizing. In the 32-bit case we'll need to clear out the registers that wouldn't normally be accessible from a 32-bit AArch32 exectuable (or process).
* | kernel/process: Add a data member to determine if a process is 64-bit or not.Lioncash2018-09-302-0/+11
| | | | | | | | | | | | | | | | | | | | | | This will be necessary for the implementation of svcGetThreadContext(), as the kernel checks whether or not the process that owns the thread that has it context being retrieved is a 64-bit or 32-bit process. If the process is 32-bit, then the upper 15 general-purpose registers and upper 16 vector registers are cleared to zero (as AArch32 only has 15 GPRs and 16 128-bit vector registers. not 31 general-purpose registers and 32 128-bit vector registers like AArch64).
* | kernel/process: Make data member variables privateLioncash2018-09-307-55/+100
| | | | | | | | | | | | | | Makes the public interface consistent in terms of how accesses are done on a process object. It also makes it slightly nicer to reason about the logic of the process class, as we don't want to expose everything to external code.
* | Merge pull request #1412 from lioncash/movebunnei2018-09-292-3/+2
|\ \ | | | | | | kernel/object: Remove unnecessary std::move from DynamicObjectCast()
| * | kernel/object: Remove unnecessary std::move from DynamicObjectCast()Lioncash2018-09-282-3/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | boost::static_pointer_cast for boost::intrusive_ptr (what SharedPtr is), takes its parameter by const reference. Given that, it means that this std::move doesn't actually do anything other than obscure what the function's actual behavior is, so we can remove this. To clarify, this would only do something if the parameter was either taking its argument by value, by non-const ref, or by rvalue-reference.
* | | Merge pull request #1395 from lioncash/vmbunnei2018-09-297-53/+319
|\ \ \ | | | | | | | | process/vm_manager: Initial modifications to load NPDM metadata
| * | | memory: Dehardcode the use of fixed memory range constantsLioncash2018-09-254-13/+17
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The locations of these can actually vary depending on the address space layout, so we shouldn't be using these when determining where to map memory or be using them as offsets for calculations. This keeps all the memory ranges flexible and malleable based off of the virtual memory manager instance state.
| * | | svc: Report correct memory-related values within some of the cases in svcGetInfo()Lioncash2018-09-253-28/+41
| | | | | | | | | | | | | | | | | | | | | | | | Previously, these were reporting hardcoded values, but given the regions can change depending on the requested address spaces, these need to report the values that the memory manager contains.
| * | | memory: Dehardcode the use of a 36-bit address spaceLioncash2018-09-252-5/+16
| | | | | | | | | | | | | | | | | | | | Given games can also request a 32-bit or 39-bit address space, we shouldn't be hardcoding the address space range as 36-bit.
| * | | process/vm_manager: Amend API to allow reading parameters from NPDM metadataLioncash2018-09-244-10/+248
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rather than hard-code the address range to be 36-bit, we can derive the parameters from supplied NPDM metadata if the supplied exectuable supports it. This is the bare minimum necessary for this to be possible. The following commits will rework the memory code further to adjust to this.
* | | | Merge pull request #1394 from lioncash/streambunnei2018-09-271-1/+1
|\ \ \ \ | |_|/ / |/| | | stream: Preserve enum class type in GetState()
| * | | stream: Preserve enum class type in GetState()Lioncash2018-09-241-1/+1
| |/ / | | | | | | | | | | | | | | | Preserves the meaning/type-safetiness of the stream state instead of making it an opaque u32. This makes it usable for other things outside of the service HLE context.
* | | Merge pull request #1399 from lioncash/schedbunnei2018-09-262-9/+9
|\ \ \ | | | | | | | | kernel/scheduler: Take ARM_Interface instances by reference
| * | | kernel/scheduler: Take ARM_Interface instance by reference in the constructorLioncash2018-09-252-9/+9
| | | | | | | | | | | | | | | | | | | | It doesn't make sense to allow a scheduler to be constructed around a null pointer.
* | | | Merge pull request #1400 from lioncash/headerbunnei2018-09-265-1/+7
|\ \ \ \ | | | | | | | | | | service: Add missing headers inclusions where applicable
| * | | | service: Add missing headers inclusions where applicableLioncash2018-09-255-1/+7
| | | | | | | | | | | | | | | | | | | | Gets rid of a few indirect inclusions.
* | | | | Merge pull request #1365 from DarkLordZach/lfsbunnei2018-09-252-1/+14
|\ \ \ \ \ | |/ / / / |/| | | | file_sys: Add support for LayeredFS mods
| * | | | filesystem: Add LayeredFS VFS directory getterZach Hilman2018-09-222-1/+14
| | | | |
* | | | | Merge pull request #1393 from tech4me/svcbunnei2018-09-251-7/+7
|\ \ \ \ \ | | | | | | | | | | | | svc: Updated svc names
| * | | | | svc: Updated svc namestech4me2018-09-241-7/+7
| | | | | |
* | | | | | Implemented fatal:u properly (#1347)David2018-09-243-4/+140
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Implemented fatal:u properly fatal:u now is properly implemented with all the ipc cmds. Error reports/Crash reports are also now implemented for fatal:u. Crash reports save to yuzu/logs/crash_reports/ The register dump is currently known as sysmodules send all zeros. If there are any non zero values for the "registers" or the unknown values, let me know! * Fatal:U fixups * Made fatal:u execution break more clear * Fatal fixups
* | | | | | Stubbed IRS (#1349)David2018-09-242-18/+167
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Stubbed IRS Currently we have no ideal way of implementing IRS. For the time being we should have the functions stubbed until we come up with a way to emulate IRS properly. * Added IRS to logging backend * Forward declared shared memory for irs
* | | | | | Merge pull request #1354 from ogniK5377/ssl-versionbunnei2018-09-241-3/+3
|\ \ \ \ \ \ | |_|_|_|/ / |/| | | | | Corrected SSL::SetInterfaceVersion
| * | | | | Corrected SSL::SetInterfaceVersionDavid Marcec2018-09-191-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | Should be a single u32
* | | | | | Added audren:u#GetAudioRendererStateDavid Marcec2018-09-231-1/+8
| |_|_|/ / |/| | | |
* | | | | svc: Move most process termination code to its own function within ProcessLioncash2018-09-213-32/+56
| | | | | | | | | | | | | | | | | | | | | | | | | Reduces the use of Process class members externally and keeps most code related to tearing down a process with the rest of the process code.
* | | | | thread/process: Move TLS slot marking/freeing to the process classLioncash2018-09-214-68/+89
| |_|/ / |/| | | | | | | | | | | | | | | | | | | Allows making several members of the process class private, it also avoids going through Core::CurrentProcess() just to retrieve the owning process.
* | | | Merge pull request #1372 from lioncash/threadbunnei2018-09-213-5/+5
|\ \ \ \ | | | | | | | | | | kernel/thread: Use owner_process when setting the page table in SetupMainThread()
| * | | | kernel/thread: Use owner_process when setting the page table in SetupMainThread()Lioncash2018-09-213-5/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The owning process of a thread is required to exist before the thread, so we can enforce this API-wise by using a reference. We can also avoid the reliance on the system instance by using that parameter to access the page table that needs to be set.
* | | | | Merge pull request #1371 from lioncash/fwd-armbunnei2018-09-211-0/+1
|\ \ \ \ \ | | | | | | | | | | | | arm_interface: Replace kernel vm_manager include with a forward declaration
| * | | | | arm_interface: Replace kernel vm_manager include with a forward declarationLioncash2018-09-211-0/+1
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | Avoids an unnecessary inclusion and also uncovers three places where indirect inclusions were relied upon, which allows us to also resolve those.
* | | | | Merge pull request #1368 from ogniK5377/nifm-fixbunnei2018-09-211-1/+7
|\ \ \ \ \ | | | | | | | | | | | | Added IRequest::Submit
| * | | | | Fixed submitDavid Marcec2018-09-201-2/+1
| | | | | |
| * | | | | Added IRequest::SubmitDavid Marcec2018-09-201-1/+8
| |/ / / / | | | | | | | | | | | | | | | This fixes updated versions of SMO. Currently unable to test as I don't have an updated version
* / / / / Revert GetRequestStateDavid Marcec2018-09-211-1/+1
|/ / / / | | | | | | | | | | | | Even though setting this value to 3 is more correct. We break more games than we fix due to missing implementations. We should keep this as 0 for the time being
* | | | Removed unneeded event clearDavid Marcec2018-09-201-1/+0
| | | |
* | | | Implemented NTC & IEnsureNetworkClockAvailabilityServiceDavid Marcec2018-09-201-3/+100
| |/ / |/| | | | | | | | Needed because of the recent nim fixes
* | | Reworked incorrect nifm stubs (#1355)David2018-09-191-3/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Reworked incorrect nifm stubs Need confirmation on `CreateTemporaryNetworkProfile`, unsure which game uses it but according to reversing. It should return a uuid which we currently don't do. Any 0 client id is considered an invalid client id. GetRequestState 0 is considered invalid. * Fixups for nifm
* | | Merge pull request #1359 from ogniK5377/nesbunnei2018-09-193-7/+12
|\ \ \ | | | | | | | | Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevision
| * | | Fixed GetAccountId stub, Added error code for OpenDirectory and added ActivateNpadWithRevisionDavid Marcec2018-09-193-7/+12
| |/ / | | | | | | | | | With these, `Nintendo Entertainment System - Nintendo Switch Online` loads
* | | Removed MakeBuilder as it's not needed anymoreDavid Marcec2018-09-191-7/+0
| | |
* | | Removed the use of rp.MakeBuilderDavid Marcec2018-09-196-27/+26
|/ / | | | | | | Due to keeping the code style consistent in the yuzu codebase. `rb = rp.MakeBuilder(...)` was replaced with `rb{ctx, ...}`
* | Merge pull request #1348 from ogniK5377/GetImageSizebunnei2018-09-191-1/+9
|\ \ | | | | | | Implemented IProfile::GetImageSize
| * | Implemented GetImageSizeDavid Marcec2018-09-181-1/+9
| | |
* | | Merge pull request #1351 from ogniK5377/GetDefaultDisplayResolutionbunnei2018-09-192-1/+18
|\ \ \ | | | | | | | | Implemented GetDefaultDisplayResolution
| * | | Implemented GetDefaultDisplayResolutionDavid Marcec2018-09-182-1/+18
| |/ /
* | | Merge pull request #1346 from lioncash/svcbunnei2018-09-191-37/+36
|\ \ \ | | | | | | | | svc_wrap: Convert the PARAM macro into a function
| * | | svc_wrap: Convert the PARAM macro into a functionLioncash2018-09-181-37/+36
| |/ / | | | | | | | | | | | | | | | This can just be a regular function, getting rid of the need to also explicitly undef the define at the end of the file. Given FuncReturn() was already converted into a function, it's #undef can also be removed.
* | | Merge pull request #1350 from ogniK5377/Six-Axis-Stubbunnei2018-09-191-4/+28
|\ \ \ | | | | | | | | Stubbed ActivateConsoleSixAxisSensor & StartConsoleSixAxisSensor
| * | | Added ActivateGestureDavid Marcec2018-09-181-1/+7
| | | |
| * | | Added StopSixAxisSensorDavid Marcec2018-09-181-1/+7
| | | |
| * | | Stubbed ActivateConsoleSixAxisSensor & StartConsoleSixAxisSensorDavid Marcec2018-09-181-2/+14
| |/ /
* | | Invalid default value of username in yuzu_cmd (#1334)Philippe Babin2018-09-191-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | * Fix bug where default username value for yuzu_cmd create an userprofile with uninitialize data as username * Fix format * Apply code review changes * Remove nullptr check
* | | Merge pull request #1343 from lioncash/mutexbunnei2018-09-182-2/+10
|\ \ \ | | | | | | | | kernel/svc: Handle invalid address cases within svcArbitrateLock() and svcArbitrateUnlock()
| * | | kernel/mutex: Replace ResultCode construction for invalid addresses with the named variantLioncash2018-09-181-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | We already have a ResultCode constant for the case of an invalid address, so we can just use it instead of re-rolling that ResultCode type.
| * | | kernel/svc: Handle error cases for svcArbitrateLock() and svcArbitrateUnlock()Lioncash2018-09-181-0/+8
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel does the equivalent of the following check before proceeding: if (address + 0x8000000000 < 0x7FFFE00000) { return ERR_INVALID_MEMORY_STATE; } which is essentially what our IsKernelVirtualAddress() function does. So we should also be checking for this. The kernel also checks if the given input addresses are 4-byte aligned, however our Mutex::TryAcquire() and Mutex::Release() functions already handle this, so we don't need to add code for this case.
* / / arm_interface: Remove ARM11-isms from the CPU interfaceLioncash2018-09-181-2/+2
|/ / | | | | | | | | | | | | | | | | This modifies the CPU interface to more accurately match an AArch64-supporting CPU as opposed to an ARM11 one. Two of the methods don't even make sense to keep around for this interface, as Adv Simd is used, rather than the VFP in the primary execution state. This is essentially a modernization change that should have occurred from the get-go.
* | Merge pull request #1312 from lioncash/fwdbunnei2018-09-173-7/+9
|\ \ | | | | | | service/vi: Replace includes with forward declarations where applicable
| * | service/vi: Replace includes with forward declarations where applicableLioncash2018-09-133-7/+9
| | |
* | | Merge pull request #1313 from lioncash/errorbunnei2018-09-171-1/+2
|\ \ \ | | | | | | | | kernel/errors: Amend error code for ERR_NOT_FOUND
| * | | kernel/errors: Amend error code for ERR_NOT_FOUNDLioncash2018-09-131-1/+2
| |/ / | | | | | | | | | | | | This is the value returned by the kernel for svcConnectToNamedPort() if the named port cannot be found.
* | | Merge pull request #1318 from lioncash/errors-smbunnei2018-09-172-8/+6
|\ \ \ | | | | | | | | services/sm: Amend error code constants
| * | | services/sm: Amend error code constantsLioncash2018-09-142-8/+6
| |/ / | | | | | | | | | | | | | | | | | | | | | Courtesy of @ogniK5377. This also moves them into the cpp file and limits the visibility to where they're directly used. It also gets rid of unused or duplicate error codes.
* | | Merge pull request #1315 from lioncash/sizebunnei2018-09-172-19/+74
|\ \ \ | | | | | | | | kernel/svc: Handle a few error cases within memory-related functions
| * | | kernel/svc: Sanitize creation of shared memory via svcCreateSharedMemory()Lioncash2018-09-141-2/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The kernel caps the size limit of shared memory to 8589930496 bytes (or (1GB - 512 bytes) * 8), so approximately 8GB, where every GB has a 512 byte sector taken off of it. It also ensures the shared memory is created with either read or read/write permissions for both permission types passed in, allowing the remote permissions to also be set as "don't care".
| * | | kernel/svc: Sanitize addresses, permissions, and sizes within svcMapSharedMemory() and svcUnmapSharedMemory()Lioncash2018-09-141-17/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Part of the checking done by the kernel is to check if the given address and size are 4KB aligned, as well as checking if the size isn't zero. It also only allows mapping shared memory as readable or read/write, but nothing else, and so we shouldn't allow mapping as anything else either.
| * | | kernel/svc: Sanitize addresses and sizes within svcMapMemory() and svcUnmapMemory()Lioncash2018-09-141-0/+23
| | | | | | | | | | | | | | | | | | | | The kernel checks if the addresses and given size is 4KB aligned before continuing onwards to map the memory.
| * | | kernel/svc: Sanitize heap sizes within svcSetHeapSize()Lioncash2018-09-142-0/+8
| |/ / | | | | | | | | | | | | The kernel checks if the given size is a multiple of 2MB and <= to 4GB before going ahead and attempting to allocate that much memory.
* | | Merge pull request #1328 from FearlessTobi/port-4192bunnei2018-09-171-1/+1
|\ \ \ | | | | | | | | Port #4192 from Citra: "svc: change unknown to thread in CreateThread"
| * | | Port # #4192 from Citra: "svc: change unknown to thread in CreateThread"Valentin Vanelslande2018-09-151-1/+1
| | |/ | |/|
* / | Port #4182 from Citra: "Prefix all size_t with std::"fearlessTobi2018-09-1531-119/+125
|/ /
* | Merge pull request #1310 from lioncash/kernel-nsbunnei2018-09-142-7/+7
|\ \ | | | | | | kernel/thread: Include thread-related enums within the kernel namespace
| * | kernel/thread: Include thread-related enums within the kernel namespaceLioncash2018-09-132-7/+7
| |/ | | | | | | | | | | Previously, these were sitting outside of the Kernel namespace, which doesn't really make sense, given they're related to the Thread class which is within the Kernel namespace.
* | Merge pull request #1309 from lioncash/nestedbunnei2018-09-143-12/+6
|\ \ | | | | | | service: Use nested namespace specifiers where applicable
| * | service: Use nested namespace specifiers where applicableLioncash2018-09-133-12/+6
| |/ | | | | | | | | | | There were a few places where nested namespace specifiers weren't being used where they could be within the service code. This amends that to make the namespacing a tiny bit more compact.
* | Merge pull request #1307 from lioncash/plbunnei2018-09-141-2/+4
|\ \ | |/ |/| services/pl_u: Add missing Korean font to the fallback case for shared fonts
| * services/pl_u: Add missing Korean font to the fallback case for shared fontsLioncash2018-09-131-2/+4
| | | | | | | | Previously this wasn't using the Korean font at all.
* | ipc: minor fixValentin Vanelslande2018-09-131-1/+1
|/
* Merge pull request #1297 from lioncash/plbunnei2018-09-122-66/+88
|\ | | | | pl_u: Eliminate mutable file-scope state
| * pl_u: Eliminate mutable file-scope stateLioncash2018-09-122-66/+88
| | | | | | | | | | Converts the PL_U internals to use the PImpl idiom and makes the state part of the Impl struct, eliminating mutable global/file state.
* | Merge pull request #1303 from lioncash/errorbunnei2018-09-123-9/+11
|\ \ | | | | | | kernel/errors: Amend invalid thread priority and invalid processor ID error codes
| * | svc: Return ERR_INVALID_PROCESSOR_ID in CreateThread() if an invalid processor ID is givenLioncash2018-09-121-2/+2
| | | | | | | | | | | | This is what the kernel does for an out-of-range processor ID.
| * | kernel/errors: Correct error codes for invalid thread priority and invalid processor IDLioncash2018-09-123-7/+9
| | |
* | | svc: Do nothing if svcOutputDebugString() is given a length of zeroLioncash2018-09-121-0/+4
| | | | | | | | | | | | | | | | | | While unlikely, it does avoid constructing a std::string and unnecessarily calling into the memory code if a game or executable decides to be really silly about their logging.
* | | svc: Correct parameter type for OutputDebugString()Lioncash2018-09-122-3/+3
|/ / | | | | | | This should be a u64 to represent size.
* | Merge pull request #1296 from lioncash/prepobunnei2018-09-122-39/+40
|\ \ | | | | | | service/prepo: Move class into the cpp file
| * | service/prepo: Move class into the cpp fileLioncash2018-09-122-39/+40
| |/ | | | | | | | | | | This doesn't need to be exposed within the header and be kept in the translation unit, eliminating the need to include anything within the header.
* / service/audio: Replace includes with forward declarations where applicableLioncash2018-09-127-17/+34
|/ | | | | A few headers were including other headers when a forward declaration can be used instead, allowing the include to be moved to the cpp file.
* Merge pull request #1291 from lioncash/defaultbunnei2018-09-11148-45/+291
|\ | | | | hle/service: Default constructors and destructors in the cpp file where applicable
| * hle/service: Default constructors and destructors in the cpp file where applicableLioncash2018-09-11148-45/+291
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | When a destructor isn't defaulted into a cpp file, it can cause the use of forward declarations to seemingly fail to compile for non-obvious reasons. It also allows inlining of the construction/destruction logic all over the place where a constructor or destructor is invoked, which can lead to code bloat. This isn't so much a worry here, given the services won't be created and destroyed frequently. The cause of the above mentioned non-obvious errors can be demonstrated as follows: ------- Demonstrative example, if you know how the described error happens, skip forwards ------- Assume we have the following in the header, which we'll call "thing.h": \#include <memory> // Forward declaration. For example purposes, assume the definition // of Object is in some header named "object.h" class Object; class Thing { public: // assume no constructors or destructors are specified here, // or the constructors/destructors are defined as: // // Thing() = default; // ~Thing() = default; // // ... Some interface member functions would be defined here private: std::shared_ptr<Object> obj; }; If this header is included in a cpp file, (which we'll call "main.cpp"), this will result in a compilation error, because even though no destructor is specified, the destructor will still need to be generated by the compiler because std::shared_ptr's destructor is *not* trivial (in other words, it does something other than nothing), as std::shared_ptr's destructor needs to do two things: 1. Decrement the shared reference count of the object being pointed to, and if the reference count decrements to zero, 2. Free the Object instance's memory (aka deallocate the memory it's pointing to). And so the compiler generates the code for the destructor doing this inside main.cpp. Now, keep in mind, the Object forward declaration is not a complete type. All it does is tell the compiler "a type named Object exists" and allows us to use the name in certain situations to avoid a header dependency. So the compiler needs to generate destruction code for Object, but the compiler doesn't know *how* to destruct it. A forward declaration doesn't tell the compiler anything about Object's constructor or destructor. So, the compiler will issue an error in this case because it's undefined behavior to try and deallocate (or construct) an incomplete type and std::shared_ptr and std::unique_ptr make sure this isn't the case internally. Now, if we had defaulted the destructor in "thing.cpp", where we also include "object.h", this would never be an issue, as the destructor would only have its code generated in one place, and it would be in a place where the full class definition of Object would be visible to the compiler. ---------------------- End example ---------------------------- Given these service classes are more than certainly going to change in the future, this defaults the constructors and destructors into the relevant cpp files to make the construction and destruction of all of the services consistent and unlikely to run into cases where forward declarations are indirectly causing compilation errors. It also has the plus of avoiding the need to rebuild several services if destruction logic changes, since it would only be necessary to recompile the single cpp file.
* | externals: Place font data within cpp filesLioncash2018-09-111-6/+6
|/ | | | | | | | | | | | | | | This places the font data within cpp files, which mitigates the possibility of the font data being duplicated within the binary if it's referred to in more than one translation unit in the future. It also stores the data within a std::array, which is more flexible when it comes to operating with the standard library. Furthermore, it makes the data arrays const. This is what we want, as it allows the compiler to store the data within the read-only segment. As it is, having several large sections of mutable data like this just leaves spots in memory that we can accidentally write to (via accidental overruns, what have you) and actually have it work. This ensures the font data remains the same no matter what.
* Use open-source shared fonts if no dumped file is available (#1269)Tobias2018-09-111-1/+25
| | | | | | * Add open-source shared fonts * Address review comments
* video_core: Move command buffer loop.Markus Wick2018-09-102-31/+12
| | | | This moves the hot loop into video_core. This refactoring shall reduce the CPU overhead of calling ProcessCommandList.
* Merge pull request #1276 from FearlessTobi/fix-stupid-stubbunnei2018-09-101-4/+4
|\ | | | | hid: Implement ReloadInputDevices
| * hid: Implement ReloadInputDevicesfearlessTobi2018-09-091-4/+4
| |
* | service: Remove unused g_kernel_named_ports variableLioncash2018-09-101-2/+0
|/ | | | | With the named port functionality all migrated over to the kernel, there's no need to keep this around anymore.
* core: Migrate current_process pointer to the kernelLioncash2018-09-072-0/+23
| | | | | | | | | | Given we now have the kernel as a class, it doesn't make sense to keep the current process pointer within the System class, as processes are related to the kernel. This also gets rid of a subtle case where memory wouldn't be freed on core shutdown, as the current_process pointer would never be reset, causing the pointed to contents to continue to live.
* core/core: Remove unnecessary sm/controller includeLioncash2018-09-064-1/+5
| | | | | | | | | | The only reason this include was necessary, was because the constructor wasn't defaulted in the cpp file and the compiler would inline it wherever it was used. However, given Controller is forward declared, all those inlined constructors would see an incomplete type, causing a compilation failure. So, we just place the constructor in the cpp file, where it can see the complete type definition, allowing us to remove this include.
* bktr: Fix bucket overlap errorZach Hilman2018-09-041-1/+1
|
* registration: Add RegisteredCacheUnionZach Hilman2018-09-042-0/+10
| | | | Aggregates multiple caches into one interface
* Merge pull request #1235 from lioncash/forward-declbunnei2018-09-041-1/+3
|\ | | | | file_sys: Replace includes with forward declarations where applicable
| * file_sys: Replace includes with forward declarations where applicableLioncash2018-09-041-1/+3
| | | | | | | | | | Cuts down on include dependencies, resulting in less files that need to be rebuilt when certain things are changed.
* | Merge pull request #1230 from lioncash/sslbunnei2018-09-042-37/+39
|\ \ | |/ |/| ssl: Move SSL class to cpp file
| * ssl: Move SSL class to cpp fileLioncash2018-09-022-37/+39
| | | | | | | | | | | | This isn't required to be visible to anything outside of the main source file, and will eliminate needing to rebuild anything else including the header if the SSL class needs to be changed in the future.
* | service: Migrate global named port map to the KernelCore classLioncash2018-09-025-19/+51
| | | | | | | | | | | | Now that we have a class representing the kernel in some capacity, we now have a place to put the named port map, so we move it over and get rid of another piece of global state within the core.
* | Merge pull request #1213 from DarkLordZach/octopath-fsbunnei2018-09-022-2/+30
|\ \ | | | | | | filesystem/maxwell_3d: Various changes to boot Project Octopath Traveller
| * | filesystem: Implement OpenReadOnlySaveDataFilesystemZach Hilman2018-09-012-1/+7
| | |
| * | filesystem: Add OpenFileSystemWithPatchZach Hilman2018-09-012-1/+23
| |/
* / filesystem: Move dir retrieval after path checking in DeleteFile()Lioncash2018-09-021-2/+5
|/ | | | | We don't need to do the lookup if the path is considered empty currently.
* core/core: Replace includes with forward declarations where applicableLioncash2018-08-316-4/+13
| | | | | | | | | | | The follow-up to e2457418dae19b889b2ad85255bb95d4cd0e4bff, which replaces most of the includes in the core header with forward declarations. This makes it so that if any of the headers the core header was previously including change, then no one will need to rebuild the bulk of the core, due to core.h being quite a prevalent inclusion. This should make turnaround for changes much faster for developers.
* gl_renderer: Cache textures, framebuffers, and shaders based on CPU address.bunnei2018-08-311-0/+1
|
* core: Make the main System class use the PImpl idiomLioncash2018-08-312-2/+4
| | | | | | | | | | | | | core.h is kind of a massive header in terms what it includes within itself. It includes VFS utilities, kernel headers, file_sys header, ARM-related headers, etc. This means that changing anything in the headers included by core.h essentially requires you to rebuild almost all of core. Instead, we can modify the System class to use the PImpl idiom, which allows us to move all of those headers to the cpp file and forward declare the bulk of the types that would otherwise be included, reducing compile times. This change specifically only performs the PImpl portion.
* kernel: Eliminate kernel global stateLioncash2018-08-2945-429/+629
| | | | | | | | | | | | | | | | | | | | | | As means to pave the way for getting rid of global state within core, This eliminates kernel global state by removing all globals. Instead this introduces a KernelCore class which acts as a kernel instance. This instance lives in the System class, which keeps its lifetime contained to the lifetime of the System class. This also forces the kernel types to actually interact with the main kernel instance itself instead of having transient kernel state placed all over several translation units, keeping everything together. It also has a nice consequence of making dependencies much more explicit. This also makes our initialization a tad bit more correct. Previously we were creating a kernel process before the actual kernel was initialized, which doesn't really make much sense. The KernelCore class itself follows the PImpl idiom, which allows keeping all the implementation details sealed away from everything else, which forces the use of the exposed API and allows us to avoid any unnecessary inclusions within the main kernel header.
* Merge pull request #1193 from lioncash/privbunnei2018-08-281-6/+6
|\ | | | | gpu: Make memory_manager private
| * gpu: Make memory_manager privateLioncash2018-08-281-6/+6
| | | | | | | | | | | | | | | | | | | | Makes the class interface consistent and provides accessors for obtaining a reference to the memory manager instance. Given we also return references, this makes our more flimsy uses of const apparent, given const doesn't propagate through pointers in the way one would typically expect. This makes our mutable state more apparent in some places.
* | hle/result: Make ResultVal's move constructor as noexceptLioncash2018-08-281-1/+1
|/ | | | | | | | | | | | | | | | | | | | | | | Many containers within the standard library provide different behaviors based on whether or not a move constructor/assignment operator can be guaranteed not to throw or not. Notably, implementations will generally use std::move_if_noexcept (or an internal implementation of it) to provide strong exception guarantees. If a move constructor potentially throws (in other words, is not noexcept), then certain behaviors will create copies, rather than moving the values. For example, consider std::vector. When a std::vector calls resize(), there are two ways the elements can be relocated to the new block of memory (if a reallocation happens), by copy, or by moving the existing elements into the new block of memory. If a type does not have a guarantee that it will not throw in the move constructor, a copy will happen. However, if it can be guaranteed that the move constructor won't throw, then the elements will be moved. This just allows ResultVal to be moved instead of copied all the time if ever used in conjunction with containers for whatever reason.
* Merge pull request #1177 from lioncash/errbunnei2018-08-284-12/+15
|\ | | | | kernel/error: Amend several error codes
| * kernel/error: Amend error code for ERR_MAX_CONNECTIONS_REACHEDLioncash2018-08-251-2/+4
| | | | | | | | | | | | We can make this error code an alias of the resource limit exceeded error code, allowing us to get rid of the lingering 3DS error code of the same type.
| * kernel/error: Amend error code for ERR_PORT_NAME_TOO_LONGLioncash2018-08-251-2/+1
| | | | | | | | | | We can treat this as an alias of TooLarge for documentation purposes. This also lets us get rid of another lingering 3DS-related error code.
| * kernel/error: Add error code for the handle table being fullLioncash2018-08-253-4/+4
| | | | | | | | | | This replaces the lingering 3DS constant with the proper one, and utilizes it within HandleTable's Create() member function.
| * kernel/error: Add error code for invalid memory permissionsLioncash2018-08-252-3/+4
| |
| * kernel/error: Correct kernel error code for invalid combinationLioncash2018-08-251-1/+2
| |
* | Merge pull request #1175 from lioncash/nsbunnei2018-08-284-6/+8
|\ \ | | | | | | core: Namespace all code in the arm subdirectory under the Core namespace
| * | core: Namespace all code in the arm subdirectory under the Core namespaceLioncash2018-08-254-6/+8
| | | | | | | | | | | | Gets all of these types and interfaces out of the global namespace.
* | | Merge pull request #1176 from lioncash/infobunnei2018-08-271-2/+1
|\ \ \ | | | | | | | | svc: Return process title ID if queried in GetInfo()
| * | | svc: Return process title ID if queried in GetInfo()Lioncash2018-08-251-2/+1
| | | | | | | | | | | | | | | | | | | | | | | | We already have the variable itself set up to perform this task, so we can just return its value from the currently executing process instead of always stubbing it to zero.
* | | | Merge pull request #1162 from ogniK5377/ttf-plubunnei2018-08-271-5/+51
|\ \ \ \ | | | | | | | | | | PL:U Added SharedFonts loading via TTF
| * | | | Addressed plu TTF changesDavid Marcec2018-08-231-6/+7
| | | | |
| * | | | Added SharedFonts loading via TTFDavid Marcec2018-08-231-5/+50
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | By having the following TTF files in your yuzu sysdata directory. You can load sharedfonts via TTF files. FontStandard.ttf FontChineseSimplified.ttf FontExtendedChineseSimplified.ttf FontChineseTraditional.ttf FontKorean.ttf FontNintendoExtended.ttf FontNintendoExtended2.ttf
* | | | | Merge pull request #1168 from lioncash/headerbunnei2018-08-272-1/+4
|\ \ \ \ \ | | | | | | | | | | | | hid: Move core include to cpp file
| * | | | | hid: Move core include to cpp fileLioncash2018-08-242-1/+4
| | |_|/ / | |/| | | | | | | | | | | | | | | | | | This isn't required to be in the header. Instead, directly include what this header needs and move it to the cpp file where it belongs.
* | | | | set: Fixed GetAvailableLanguageCodes() to follow the max_entriestech4me2018-08-262-8/+45
| |_|_|/ |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Rightnow, in games use GetAvailableLanguageCodes(), there is a WriteBuffer() with size larger than the buffer_size. (Core Critical core\hle\kernel\hle_ipc.cpp:WriteBuffer:296: size (0000000000000088) is greater than buffer_size (0000000000000078)) 0x88 = 17(languages) * 8 0x78 = 15(languages) * 8 GetAvailableLanguageCodes() can only support 15 languages. After firmware 4.0.0 there are 17 supported language instead of 15, to enable this GetAvailableLanguageCodes2() need to be used. So GetAvailableLanguageCodes() will be caped at 15 languages. Reference: http://switchbrew.org/index.php/Settings_services
* | | | Merge pull request #1166 from lioncash/typoSebastian Valle2018-08-251-1/+1
|\ \ \ \ | |_|_|/ |/| | | filesystem: Fix typo in log message
| * | | filesystem: Fix typo in log messageLioncash2018-08-241-1/+1
| |/ /
* | | Merge pull request #1094 from DarkLordZach/nax0Mat M2018-08-252-12/+36
|\ \ \ | |/ / |/| | file_sys: Add support for NAX archives
| * | filesystem: Add CreateFactories methods to fsZach Hilman2018-08-232-8/+11
| | | | | | | | | | | | Allows frontend to create registration caches for use before a game has booted.
| * | filesystem: Add logging to registration gettersZach Hilman2018-08-231-4/+25
| |/
* / Added GetBootMode (#1107)David2018-08-244-3/+25
|/ | | | | | | | * Added GetBootMode Used by homebrew * Added enum for GetBootMode
* Added missing include for pl:uDavid Marcec2018-08-221-0/+1
| | | | Should fix any compile errors
* PL:U Added BFTTF loading(Loading from System NAND dumps) (#1088)David2018-08-221-25/+140
| | | | | | | | | | | | * Added bfttf loading We can now load system bfttf fonts from system archives AND shared memory dumps. This allows people who have installed their system nand dumps to yuzu to automatically get shared font support. We also now don't hard code the offsets or the sizes of the shared fonts and it's all calculated for us now. * Addressed plu fixups * Style changes for plu * Fixed logic error for plu and added more error checks.
* Merge pull request #1145 from lioncash/fwd-declbunnei2018-08-223-2/+3
|\ | | | | vfs: Replace mode.h include with forward declarations where applicable
| * vfs: Replace mode.h include with forward declarations where applicableLioncash2018-08-213-2/+3
| | | | | | | | | | Avoids the need to rebuild these source files if the mode header changes.
* | am: Utilize std::array within PopLaunchParameter()Lioncash2018-08-211-3/+4
|/ | | | | | Gets rid of the potential for C array-to-pointer decay, and also makes pointer arithmetic to get the end of the copy range unnecessary. We can just use std::array's begin() and end() member functions.
* Merge pull request #1129 from lioncash/headerbunnei2018-08-213-5/+19
|\ | | | | romfs_factory, service/filesystem: Use forward declarations where applicable
| * service/filesystem: Use forward declarations where applicableLioncash2018-08-213-5/+19
| | | | | | | | | | | | | | | | Avoids the need to rebuild multiple source files if the filesystem code headers change. This also gets rid of a few instances of indirect inclusions being relied upon
* | Merge pull request #1122 from lioncash/accbunnei2018-08-214-57/+61
|\ \ | |/ |/| acc/profile_manager: General cleanup
| * acc: Replace profile_manager include with a forward declarationLioncash2018-08-212-2/+6
| | | | | | | | This is only used in a shared_ptr, so we can forward declare it.
| * acc: Simplify WriteBuffer call within LoadImage()Lioncash2018-08-211-3/+3
| | | | | | | | | | | | We have an overload of WriteBuffer that accepts containers that satisfy the ContiguousContainer concept, which std::array does, so we only need to pass in the array itself.
| * acc: Correct IProfile's constructor initializer list orderLioncash2018-08-211-1/+1
| | | | | | | | Arranges them in the order the members would be initialized
| * acc: Remove unused DEFAULT_USER_IDLioncash2018-08-211-3/+0
| | | | | | | | This is no longer used, so it can be removed.
| * profile_manager: Use INVALID_UUID in the initializer of last_opened_userLioncash2018-08-211-1/+1
| | | | | | | | Makes it a little bit more self-documenting.
| * profile_manager: Remove unnecessary memcpy in GetProfileBaseAndData()Lioncash2018-08-211-1/+1
| | | | | | | | | | Given the source and destination types are the same std::array type, we can simply use regular assignment to perform the same behavior.
| * profile_manager: Use type aliases for username data, profile data, and user arraysLioncash2018-08-212-19/+22
| | | | | | | | | | Avoids the need to repeatedly specify the whole array type in multiple places.
| * profile_manager: Take ProfileInfo by const reference where applicableLioncash2018-08-212-8/+8
| | | | | | | | | | | | ProfileInfo is quite a large struct in terms of data, and we don't need to perform a copy in these instances, so we can just pass constant references instead.
| * profile_manager: Make array parameter to CreateNewUser a const referenceLioncash2018-08-212-2/+2
| | | | | | | | | | This doesn't modify the passed in array, so this can be a const reference.
| * profile_manager: Remove unnecessary staticLioncash2018-08-211-1/+1
| | | | | | | | This can just be constexpr like the others
| * profile_manager: Simplify UUID's two param constructor, operator==, and operator boolLioncash2018-08-211-6/+4
| | | | | | | | | | | | We can use the constructor initializer list and just compare the contained u128's together instead of comparing each element individually. Ditto for comparing against an invalid UUID.
| * profile_manager: Move UUID generation function to the cpp fileLioncash2018-08-212-10/+12
| | | | | | | | | | This avoids needing to dump the contents of <random> into other files that include the profile manager header.
| * profile_manager: Remove unnecessary std::move in AddToProfiles() and CreateNewUser()Lioncash2018-08-201-2/+2
| | | | | | | | | | | | Moving a const reference isn't possible, so this just results in a copy (and given ProfileInfo is composed of trivial types and aggregates, a move wouldn't really do anything).
* | Merge pull request #1095 from DarkLordZach/sysarchivesbunnei2018-08-214-16/+50
|\ \ | |/ |/| filesystem: Add support for loading of system archives
| * filesystem: Add support for loading of system archivesZach Hilman2018-08-194-16/+50
| |
* | Merge pull request #1117 from ogniK5377/CheckFreeCommunicationPermissionbunnei2018-08-201-1/+8
|\ \ | | | | | | Added CheckFreeCommunicationPermission
| * | Added CheckFreeCommunicationPermissionDavid Marcec2018-08-201-1/+8
| |/ | | | | | | This fixes save files not loading in splatoon 2
* | Merge pull request #1017 from ogniK5377/better-accountbunnei2018-08-2012-74/+438
|\ \ | |/ |/| New account backend to allow for future extended support
| * Better UUID randomnessDavid Marcec2018-08-111-2/+7
| |
| * Removed un-needed count from ListOpenUsers and ListAllUsersDavid Marcec2018-08-111-4/+2
| |
| * Added better explanations in the profile managerDavid Marcec2018-08-112-1/+34
| |
| * Code cleanup for profile managerDavid Marcec2018-08-113-40/+47
| |
| * Removed const from ProfileBase InvalidateDavid Marcec2018-08-111-1/+1
| |
| * fixed invalid uuid bool operatorDavid Marcec2018-08-111-1/+1
| |
| * Added GetOpenUserCountDavid Marcec2018-08-113-3/+14
| |
| * Removed all for loops from the profile managerDavid Marcec2018-08-111-9/+4
| |
| * Added missing ListAllUsers countDavid Marcec2018-08-111-1/+2
| |
| * If statement style changeDavid Marcec2018-08-111-11/+19
| |
| * Second round of account changesDavid Marcec2018-08-113-18/+21
| |
| * First round of account changesDavid Marcec2018-08-113-49/+55
| |
| * Refactored profile manager sharingDavid Marcec2018-08-1110-20/+28
| |
| * Merge remote-tracking branch 'origin/master' into better-accountDavid Marcec2018-08-1117-36/+78
| |\
| * | Added IsUserRegistrationRequestPermittedDavid Marcec2018-08-117-3/+19
| | |
| * | Don't add user if the uuid already existsDavid Marcec2018-08-091-0/+4
| | |
| * | Open first user addedDavid Marcec2018-08-081-1/+3
| | |
| * | Inital pass of account backend implementationDavid Marcec2018-08-083-12/+22
| | | | | | | | | | | | This commit verified working on puyo
| * | GetProfileBase and GetProfileBaseAndData addedDavid Marcec2018-08-083-44/+106
| | |
| * | began initial implementation of "ProfileManager"David Marcec2018-08-084-44/+200
| | |
| * | Switched uuids from u128 to new UUID structDavid Marcec2018-08-082-10/+49
| | |
* | | Implement SetIdleTimeDetectionExtension & GetIdleTimeDetectionExtension (#1059)greggameplayer2018-08-172-2/+22
| | | | | | | | | * Used by Mario Tennis Aces
* | | correct coding stylegreggameplayer2018-08-161-1/+1
| | |
* | | Implement GetDefaultDisplayResolutionChangeEventgreggameplayer2018-08-162-1/+13
| | | | | | | | | | | | Require by Toki Tori and Toki Tori 2+
* | | Merge pull request #1005 from DarkLordZach/registered-fmtbunnei2018-08-162-4/+23
|\ \ \ | | | | | | | | file_sys: Add support for registration format
| * | | filesystem: Add Open and Register functions for BISFactoryZach Hilman2018-08-122-4/+23
| | | |
* | | | Merge pull request #1078 from lioncash/messagebunnei2018-08-161-2/+20
|\ \ \ \ | | | | | | | | | | lm: Handle threads and modules within the logger
| * | | | lm: Use LOG_DEBUG for printing out trace logsLioncash2018-08-151-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Using LOG_TRACE here isn't a good idea because LOG_TRACE is only enabled when yuzu is compiled in debug mode. Debug mode is also quite slow, and so we're potentially throwing away logging messages that can provide value when trying to boot games.
| * | | | lm: Handle threads and modules within the loggerLioncash2018-08-151-1/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The thread field serves to indicate which thread a log is related to and provides the length of the thread's name, so we can print that out, ditto for modules. Now we can know what threads are potentially spawning off logging messages (for example Lydie & Suelle bounces between MainThread and LoadingThread when initializing the game).
* | | | | Merge pull request #1051 from B3n30/UnscheduleEventThreadsafebunnei2018-08-161-1/+1
|\ \ \ \ \ | | | | | | | | | | | | Core::CoreTiming: add UnscheduleEventThreadsafe
| * | | | | Core::CoreTiming: add UnscheduleEventThreadsafeB3n302018-08-131-1/+1
| | | | | |
* | | | | | Merge pull request #1080 from lioncash/retbunnei2018-08-161-1/+1
|\ \ \ \ \ \ | | | | | | | | | | | | | | sm/controller: Correct return value of QueryPointerBufferSize
| * | | | | | sm/controller: Correct return value of QueryPointerBufferSizeLioncash2018-08-151-1/+1
| | |/ / / / | |/| | | | | | | | | | | | | | | | This should be returning a u16 according to Switch Brew.
* / | | | | kernel/server_session: Add IsSession() member functionLioncash2018-08-153-3/+8
|/ / / / / | | | | | | | | | | | | | | | | | | | | | | | | | Allows querying the inverse of IsDomain() to make things more readable. This will likely also be usable in the event of implementing ConvertDomainToSession().
* | | | | Merge pull request #1072 from lioncash/svcbunnei2018-08-151-2/+5
|\ \ \ \ \ | | | | | | | | | | | | kernel/svc: Log svcBreak parameters
| * | | | | kernel/svc: Log svcBreak parametersLioncash2018-08-151-2/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Given if we hit here all is lost, we should probably be logging the break reason code and associated information to distinguish between the causes.
* | | | | | Merge pull request #1056 from lioncash/mmbunnei2018-08-152-46/+52
|\ \ \ \ \ \ | |/ / / / / |/| | | | | mm_u: Move interface class into the cpp file
| * | | | | mm_u: Forward all old variants of functions to the new onesLioncash2018-08-141-5/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Ensures both variants go through the same interface, and while we're at it, add Finalize to provide the inverse of Initialize for consistency.
| * | | | | mm_u: Move implementation class into the cpp fileLioncash2018-08-142-46/+46
| |/ / / / | | | | | | | | | | | | | | | | | | | | Now if changes are ever made to the behavior of the class, it doesn't involve rebuilding everything that includes the mm_u header.
* | | | | Merge pull request #1055 from lioncash/initbunnei2018-08-141-1/+1
|\ \ \ \ \ | | | | | | | | | | | | audout_u: Correct IAudioOut initializer list order
| * | | | | audout_u: Correct IAudioOut initializer list orderLioncash2018-08-141-1/+1
| |/ / / / | | | | | | | | | | | | | | | Orders elements in the precise order they'll be initialized.
* | | | | Merge pull request #1046 from ogniK5377/missing-channelsMat M2018-08-145-0/+144
|\ \ \ \ \ | |/ / / / |/| | | | Added missing channel devices
| * | | | Registered missing channel devicesDavid Marcec2018-08-131-0/+4
| | | | |
| * | | | Added missing channel devicesDavid Marcec2018-08-134-0/+140
| | | | |
* | | | | kernel/object: Tighten object against data racesLioncash2018-08-132-8/+9
|/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Despite being covered by a global mutex, we should still ensure that the class handles its reference counts properly. This avoids potential shenanigans when it comes to data races. Given this is the root object that drives quite a bit of the kernel object hierarchy, ensuring we always have the correct behavior (and no races) is a good thing.
* | | | Merge pull request #1043 from Subv/timingbunnei2018-08-131-1/+0
|\ \ \ \ | | | | | | | | | | Use an approximated amortized amount of ticks when advancing timing.
| * | | | Kernel/SVC: Don't reschedule the current core when creating a new thread.Subv2018-08-131-1/+0
| | | | | | | | | | | | | | | | | | | | The current core may have nothing to do with the core where the new thread was scheduled to run. In case it's the same core, then the following PrepareReshedule call will take care of that.
* | | | | Merge pull request #1036 from lioncash/threadbunnei2018-08-132-2/+2
|\ \ \ \ \ | | | | | | | | | | | | scheduler: Make HaveReadyThreads() a const member function
| * | | | | scheduler: Make HaveReadyThreads() a const member functionLioncash2018-08-122-2/+2
| |/ / / / | | | | | | | | | | | | | | | | | | | | This function doesn't modify instance state, so the const qualifier can be added to it.
* | | | | Merge pull request #1042 from Subv/racesbunnei2018-08-131-2/+9
|\ \ \ \ \ | | | | | | | | | | | | Fixed a bunch of race conditions when running in multicore mode.
| * | | | | Kernel/Threads: Lock the HLE mutex when executing the wakeup callback.Subv2018-08-131-0/+5
| | | | | | | | | | | | | | | | | | | | | | | | Another thread might be in the middle of a reschedule, thus altering the state of the schedulers.
| * | | | | Kernel/Thread: Always use the threadsafe option when scheduling wakeups.Subv2018-08-131-2/+4
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | WakeAfterDelay might be called from any host thread, so err on the side of caution and use the thread-safe CoreTiming::ScheduleEventThreadsafe. Note that CoreTiming is still far from thread-safe, there may be more things we have to work on for it to be up to par with what we want.
* | | | | Merge pull request #1041 from Subv/duplicated_mutexbunnei2018-08-132-2/+22
|\ \ \ \ \ | | | | | | | | | | | | Kernel/Mutex: Don't duplicate threads in the mutex waiter list.
| * | | | | Kernel/Mutex: Don't duplicate threads in the mutex waiter list.Subv2018-08-122-2/+22
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Exit from AddMutexWaiter early if the thread is already waiting for a mutex owned by the owner thread. This accounts for the possibility of a thread that is waiting on a condition variable being awakened twice in a row. Also added more validation asserts. This should fix one of the random crashes in Breath Of The Wild.
* | | | | vfs: Make type hierarchy objects classes instead of structsLioncash2018-08-121-1/+1
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | struct should be used when the data type is very simple or otherwise has no invariants associated with it. Given these are used to form a hierarchy, class should be used instead.
* | | | | Merge pull request #1035 from ogniK5377/audio-dev-revision-infobunnei2018-08-122-1/+13
|\ \ \ \ \ | | | | | | | | | | | | GetAudioDeviceServiceWithRevisionInfo (Used by Bloodstained: Curse of the Moon)
| * | | | | GetAudioDeviceServiceWithRevisionInfoDavid Marcec2018-08-122-1/+13
| |/ / / / | | | | | | | | | | | | | | | As we're not handling any anything about the revision data for GetAudioDeviceServiceWithRevisionInfo, it's currently marked as stubbed. However for games this shouldn't affect the result. Proper revision info would be more for homebrew.
* | | | | Merge pull request #1028 from ogniK5377/aoabunnei2018-08-121-5/+26
|\ \ \ \ \ | | | | | | | | | | | | Added GetAudioRendererSampleRate, GetAudioRendererSampleCount & GetAudioRendererMixBufferCount
| * | | | | Pushed the requested sample rate instead of our fixed sample rateDavid Marcec2018-08-121-4/+2
| | | | | |
| * | | | | Added GetAudioRendererSampleRate, GetAudioRendererSampleCount & GetAudioRendererMixBufferCountDavid Marcec2018-08-121-5/+28
| | |/ / / | |/| | | | | | | | | | | | | GetAudioRendererSampleRate is set as a "STUB" as a game could check if the sample rate it sent and the sample rate it wants don't match. Just a thought of something which could happen so keeping it as stub for the mean time
* | | | | hid: disable clang-format around tablesLioncash2018-08-121-4/+5
| | | | | | | | | | | | | | | | | | | | Prevents clang-format from butchering them.
* | | | | hid: Stub DisconnectNpad()Lioncash2018-08-121-1/+7
| |/ / / |/| | | | | | | | | | | This is required by ARMS.
* | | | Stub UpdateUserPresenceDavid Marcec2018-08-121-1/+8
|/ / / | | | | | | | | | Needed for Retro City Rampage to go in game
* | | friend: Stub DeclareCloseOnlinePlaySession.bunnei2018-08-121-1/+10
| | | | | | | | | | | | - Used by Splatoon 2.
* | | friend: Fix CreateFriendService to return an IFriendService interface.bunnei2018-08-121-2/+86
| | |
* | | server_session: Provide more useful information and don't crash on bad IPC request.bunnei2018-08-121-0/+8
| | |
* | | video_core; Get rid of global g_toggle_framelimit_enabled variableLioncash2018-08-111-0/+1
| |/ |/| | | | | | | | | | | | | | | Instead, we make a struct for renderer settings and allow the renderer to update all of these settings, getting rid of the need for global-scoped variables. This also uncovered a few indirect inclusions for certain headers, which this commit also fixes.
* | Merge pull request #997 from lioncash/const-funcbunnei2018-08-104-4/+4
|\ \ | | | | | | core: Make function reference parameters const where applicable
| * | buffer_queue: Make reference parameter of SetPreallocatedBuffer constLioncash2018-08-092-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | This is simply copied by value, so there's no need to make it a modifiable reference. While we're at it, make the names of the parameters match its definition.
| * | hle_ipc: Make WriteToOutgoingCommandBuffer()'s reference parameter constLioncash2018-08-092-2/+2
| | | | | | | | | | | | | | | This function doesn't modify anything within the reference Thread instance.
* | | Merge pull request #990 from lioncash/entrybunnei2018-08-101-6/+3
|\ \ \ | | | | | | | | fsp_srv: Emplace entries first when building index instead of emplacing last
| * | | fsp_srv: Use std::string_view's copy() function instead of strncpy()Lioncash2018-08-091-5/+1
| | | | | | | | | | | | | | | | | | | | | | | | Given elements inserted into a vector are zeroed out, we can just copy MAX_LEN - 1 elements and the data will already be properly null terminated.
| * | | fsp_srv: Emplace entries first when building index instead of emplacing lastLioncash2018-08-091-2/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The current way were doing it would require copying a 768 character buffer (part of the Entry struct) to the new element in the vector. Given it's a plain array, std::move won't eliminate that. Instead, we can emplace an instance directly into the destination buffer and then fill it out, avoiding the need to perform any unnecessary copies. Given this is done in a loop, we can request the destination to allocate all of the necessary memory ahead of time, avoiding the need to potentially keep reallocating over and over on every few insertions into the vector.
* | | | Merge pull request #897 from DarkLordZach/vfs-accuracy-2bunnei2018-08-104-12/+17
|\ \ \ \ | |_|/ / |/| | | vfs: Add VfsFilesystem and fix RealVfs* implementations
| * | | core: Port core to VfsFilesystem for file accessZach Hilman2018-08-094-11/+16
| | | |
| * | | filesystem: Remove unnecessary if conditionsZach Hilman2018-08-091-1/+1
| | | |
* | | | Merge pull request #986 from mailwl/acc-loadimagebunnei2018-08-091-1/+22
|\ \ \ \ | |/ / / |/| | | Service/Account: stub LoadImage function
| * | | Service/Account: stub LoadImage functionmailwl2018-08-081-1/+22
| | |/ | |/|
* | | Merge pull request #978 from bunnei/fixioctlbunnei2018-08-091-1/+1
|\ \ \ | | | | | | | | nvhost_gpu: Don't over copy IoctlSubmitGpfifo.
| * | | nvhost_gpu: Don't over copy IoctlSubmitGpfifo.bunnei2018-08-081-1/+1
| | | |
* | | | Merge pull request #975 from bunnei/am-stubbunnei2018-08-082-1/+9
|\ \ \ \ | |_|_|/ |/| | | am: Stub SetScreenShotImageOrientation.
| * | | am: Stub SetScreenShotImageOrientation.bunnei2018-08-082-1/+9
| |/ / | | | | | | | | | - Used by Super Mario Odyssey.
* | | Merge pull request #958 from lioncash/nv-globalbunnei2018-08-085-11/+22
|\ \ \ | |_|/ |/| | nvdrv: Get rid of global std::weak_ptr
| * | nvdrv: Get rid of global std::weak_ptrLioncash2018-08-085-11/+22
| |/ | | | | | | | | Rather than use global state, we can simply pass the instance into the NVFlinger instance directly.
* | Merge pull request #965 from lioncash/unused-filesbunnei2018-08-082-124/+0
|\ \ | | | | | | hle: Remove unused romfs.cpp/.h
| * | hle: Remove unused romfs.cpp/.hLioncash2018-08-082-124/+0
| |/ | | | | | | These files are no longer used, so we can get rid of them.
* | Merge pull request #974 from lioncash/accbunnei2018-08-082-2/+2
|\ \ | | | | | | acc: Add missing function table entries for GetUserCount
| * | acc: Add missing function table entries for GetUserCountLioncash2018-08-082-2/+2
| | | | | | | | | | | | | | | Given this is stubbed within the common module in 5ac7b84, it should be added to the other relevant tables as well.
* | | hid: fix IsSixAxisSensorAtRest() responsemailwl2018-08-081-1/+1
|/ /
* / acc: Stub GetUserCount. (#973)bunnei2018-08-083-1/+9
|/ | | - Used by Pokken Tournament DX.
* Merge pull request #957 from lioncash/eventbunnei2018-08-071-1/+1
|\ | | | | nvflinger: Correct typo in name of composition event
| * nvflinger: Correct typo in name of composition eventLioncash2018-08-071-1/+1
| |
* | Merge pull request #954 from lioncash/hidbunnei2018-08-071-0/+1
|\ \ | | | | | | services/hid: Add ActivateNpadWithRevision() to the hid function info array
| * | services/hid: Add ActivateNpadWithRevision() to the hid function info arrayLioncash2018-08-071-0/+1
| |/ | | | | | | Updated based off the information on Switch Brew.
* | Merge pull request #960 from lioncash/apmbunnei2018-08-073-0/+34
|\ \ | | | | | | service/apm: Add the apm:sys service
| * | service/apm: Add the apm:sys serviceLioncash2018-08-073-0/+34
| |/ | | | | | | | | Adds the basic skeleton of the apm:sys service based off the information on Switch Brew.
* | Merge pull request #955 from lioncash/viewbunnei2018-08-072-3/+10
|\ \ | | | | | | nvflinger: Use std::string_view in OpenDisplay()
| * | nvflinger: Get rid of indirect inclusionsLioncash2018-08-072-1/+7
| | |
| * | nvflinger: Use std::string_view in OpenDisplay()Lioncash2018-08-072-2/+3
| |/ | | | | | | | | | | We don't need to use a std::string here, given all that's done is comparing the character sequence against another. This allows passing regular const char* without needing to heap allocate.
* | Merge pull request #953 from lioncash/timebunnei2018-08-071-2/+2
|\ \ | | | | | | service/time: Amend command IDs of ToPosixTime() and ToPosixTimeWithMyRule()
| * | service/time: Amend command IDs of ToPosixTime() and ToPosixTimeWithMyRule()Lioncash2018-08-071-2/+2
| |/ | | | | | | Updates the ID of these based off the information on Switch Brew.
* | Merge pull request #956 from lioncash/nvbunnei2018-08-0713-16/+18
|\ \ | | | | | | nvdrv: Get rid of indirect inclusions
| * | nvdrv: Make Ioctl()'s definition match its prototypeLioncash2018-08-071-1/+1
| | | | | | | | | | | | | | | The only reason this wasn't a compilation error is because we use little-endian systems.
| * | nvdrv: Get rid of indirect inclusionsLioncash2018-08-0712-15/+17
| |/
* | Merge pull request #952 from lioncash/usbbunnei2018-08-073-0/+255
|\ \ | | | | | | service: Add usb services
| * | service: Add usb servicesLioncash2018-08-073-0/+255
| |/ | | | | | | Adds basic skeleton for the usb services based off the information provided by Switch Brew.
* / client_port: Make all data members privateLioncash2018-08-073-7/+21
|/ | | | | | | | These members don't need to be entirely exposed, we can instead expose an API to operate on them without directly needing to mutate them We can also guard against overflow/API misuse this way as well, given active_sessions is an unsigned value.
* kernel/event: Make data members privateLioncash2018-08-061-4/+8
| | | | | Instead we can simply provide accessors to the required data instead of giving external read/write access to the variables directly.
* Service/Audio: audout_a.cpp: remove pragma oncemailwl2018-08-061-2/+0
|
* Merge pull request #930 from lioncash/threadbunnei2018-08-061-15/+15
|\ | | | | address_arbiter: Return by value from GetThreadsWaitingOnAddress()
| * address_arbiter: Return by value from GetThreadsWaitingOnAddress()Lioncash2018-08-051-15/+15
| | | | | | | | | | In all cases the vector being supplied is empty, so we can just return by value in these instances.
* | Merge pull request #925 from bunnei/audrenbunnei2018-08-064-233/+16
|\ \ | | | | | | Implement audren audio output
| * | audio_core: Implement audren_u audio playback.bunnei2018-08-052-218/+9
| | |
| * | audio_core: Use s16 where possible for audio samples.bunnei2018-08-051-3/+3
| | |
| * | audio_core: Port codec code from Citra for ADPCM decoding.bunnei2018-08-052-11/+3
| | |
| * | audio_core: Streams need unique names for CoreTiming.bunnei2018-08-041-1/+1
| | |
* | | Merge pull request #912 from lioncash/global-varbunnei2018-08-053-10/+13
|\ \ \ | |_|/ |/| | video_core: Eliminate the g_renderer global variable
| * | renderer_base: Make Rasterizer() return the rasterizer by referenceLioncash2018-08-041-2/+2
| | | | | | | | | | | | | | | | | | | | | All calling code assumes that the rasterizer will be in a valid state, which is a totally fine assumption. The only way the rasterizer wouldn't be is if initialization is done incorrectly or fails, which is checked against in System::Init().
| * | video_core: Eliminate the g_renderer global variableLioncash2018-08-043-10/+13
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | We move the initialization of the renderer to the core class, while keeping the creation of it and any other specifics in video_core. This way we can ensure that the renderer is initialized and doesn't give unfettered access to the renderer. This also makes dependencies on types more explicit. For example, the GPU class doesn't need to depend on the existence of a renderer, it only needs to care about whether or not it has a rasterizer, but since it was accessing the global variable, it was also making the renderer a part of its dependency chain. By adjusting the interface, we can get rid of this dependency.
* | Merge pull request #924 from lioncash/arpbunnei2018-08-053-0/+93
|\ \ | | | | | | service: Add arp services
| * | service: Add arp servicesLioncash2018-08-053-0/+93
| |/ | | | | | | | | Adds the basic skeleton of the arp services based off the information provided by Switch Brew.
* / service: Remove redundant #pragma once directivesLioncash2018-08-045-10/+0
|/ | | | | These don't do anything within .cpp files (we don't include cpp files, so...)
* Merge pull request #914 from lioncash/codesetbunnei2018-08-042-15/+36
|\ | | | | kernel/process: Use accessors instead of class members for referencing segment array
| * kernel/process: Use std::array where applicableLioncash2018-08-031-1/+2
| |
| * kernel/process: Use accessors instead of class members for referencing segment arrayLioncash2018-08-032-15/+35
| | | | | | | | | | | | | | Using member variables for referencing the segments array increases the size of the class in memory for little benefit. The same behavior can be achieved through the use of accessors that just return the relevant segment.
* | kernel/thread: Fix potential crashes introduced in 26de4bb521b1ace7af76eff4f6956cb23ac0d58cLioncash2018-08-043-13/+38
|/ | | | | | This amends cases where crashes can occur that were missed due to the odd way the previous code was set up (using 3DS memory regions that don't exist).
* Merge pull request #908 from lioncash/memorybunnei2018-08-039-302/+24
|\ | | | | core/memory: Get rid of 3DS leftovers
| * core/memory: Get rid of 3DS leftoversLioncash2018-08-039-302/+24
| | | | | | | | Removes leftover code from citra that isn't needed.
* | Added ability to change username & language code in the settings ui. Added IProfile::Get and SET::GetLanguageCode for libnx tests (#851)David2018-08-034-5/+45
| |
* | Merge pull request #898 from lioncash/migbunnei2018-08-033-0/+51
|\ \ | |/ |/| service: Add migration services
| * service: Add migration servicesLioncash2018-08-023-0/+51
| | | | | | | | | | Adds the basic skeleton for the mig:usr service based off information provided by Switch Brew.
* | Merge pull request #894 from lioncash/objectbunnei2018-08-0333-146/+177
|\ \ | | | | | | kernel: Move object class to its own source files
| * | kernel: Move object class to its own source filesLioncash2018-08-0233-146/+177
| |/ | | | | | | | | | | General moving to keep kernel object types separate from the direct kernel code. Also essentially a preliminary cleanup before eliminating global kernel state in the kernel code.
* | Merge pull request #904 from lioncash/staticbunnei2018-08-031-8/+6
|\ \ | | | | | | kernel/thread: Minor changes
| * | kernel/thread: Make GetFreeThreadLocalSlot()'s loop indices size_tLioncash2018-08-021-8/+5
| | | | | | | | | | | | | | | | | | Avoids using a u32 to compare against a range of size_t, which can be a source of warnings. While we're at it, compress a std::tie into a structured binding.
| * | kernel/thread: Make GetFreeThreadLocalSlot() reference parameter a const referenceLioncash2018-08-021-1/+2
| | | | | | | | | | | | | | | This function only reads the data being referenced, it doesn't modify it, so we can turn the reference into a const reference.
| * | kernel/thread: Make GetFreeThreadLocalSlot() internally linkedLioncash2018-08-021-1/+1
| |/ | | | | | | | | This function isn't used outside of this translation unit, so we can make it internally linked.
* | Merge pull request #905 from lioncash/vmabunnei2018-08-033-23/+23
|\ \ | | | | | | kernel/vm_manager: Minor changes
| * | kernel/vm_manager: Convert loop into std::any_of()Lioncash2018-08-021-4/+4
| | |
| * | kernel/vm_manager: Use const where applicableLioncash2018-08-023-19/+19
| | | | | | | | | | | | Makes our immutable state explicit.
| * | kernel/vm_manager: Use the VAddr type alias in CarveVMA()Lioncash2018-08-021-2/+2
| |/ | | | | | | These two variables correspond to address ranges.
* | Merge pull request #891 from lioncash/nsbunnei2018-08-021-0/+447
|\ \ | | | | | | service/ns: Add missing ns services
| * | service/ns: Add missing ns servicesLioncash2018-08-021-0/+447
| | | | | | | | | | | | | | | | | | Implements the basic skeleton of ns:am2, ns:ec, ns:rid, ns:rt, ns:su, ns:vm, and ns:web based off the information provided by Switch Brew and SwIPC.
* | | service: Add psc servicesLioncash2018-08-023-0/+94
| |/ |/| | | | | | | Adds the basic skeleton for the psc services based off the information provided by Switch Brew.
* | Merge pull request #888 from lioncash/capsbunnei2018-08-023-0/+169
|\ \ | | | | | | service: Add capture services
| * | service: Add capture servicesLioncash2018-08-013-0/+169
| |/ | | | | | | | | Adds the basic skeleton for the capture services based off information provided by Switch Brew.
* | Merge pull request #890 from lioncash/loggerbunnei2018-08-021-4/+4
|\ \ | | | | | | lm: Amend name of ILogger
| * | lm: Amend name of ILoggerLioncash2018-08-011-4/+4
| |/ | | | | | | | | Previously this was being registered with the name "Logger". While we're at it, also change the name of the class to match it.
* | Merge pull request #889 from lioncash/fspbunnei2018-08-025-0/+85
|\ \ | | | | | | service/filesystem: Add fsp:ldr and fsp:pr services
| * | service/filesystem: Add fsp:ldr and fsp:pr servicesLioncash2018-08-015-0/+85
| |/ | | | | | | | | Adds the basic skeleton for the remaining fsp services based off information provided by Switch Brew.
* / service: Add bpc and pcv servicesLioncash2018-08-015-0/+175
|/ | | | | Adds the basic skeleton for the remaining pcv-related services based off information on Switch Brew.
* kernel/thread: Remove unimplemented function prototypeLioncash2018-08-011-6/+0
| | | | | Given there's no implementation, we may as well remove the code entirely.
* Merge pull request #877 from lioncash/removebunnei2018-08-015-102/+0
|\ | | | | kernel: Remove unused object_address_table.cpp/.h
| * kernel: Remove unused object_address_table.cpp/.hLioncash2018-07-315-102/+0
| | | | | | | | | | | | These source files were entirely unused throughout the rest of the codebase. This also has the benefit of getting rid of a global variable as well.
* | Merge pull request #880 from lioncash/audiobunnei2018-08-0113-0/+277
|\ \ | | | | | | service/audio: Add missing services
| * | service/audio: Add missing servicesLioncash2018-08-0113-0/+277
| | | | | | | | | | | | | | | Adds the missing audctl service, as well as the :a and :d services for audin, audout, audrec, and audren.
* | | Merge pull request #876 from lioncash/includebunnei2018-08-0122-27/+46
|\ \ \ | | | | | | | | kernel: Remove unnecessary includes
| * | | kernel: Remove unnecessary includesLioncash2018-07-3122-27/+46
| | |/ | |/| | | | | | | | | | Removes unnecessary direct dependencies in some headers and also gets rid of indirect dependencies that were being relied on to be included.
* | | Merge pull request #879 from lioncash/audiobunnei2018-08-011-1/+1
|\ \ \ | |_|/ |/| | audout_u: Remove std::move in OpenAudioOutImpl()
| * | audout_u: Remove std::move in OpenAudioOutImpl()Lioncash2018-07-311-1/+1
| | | | | | | | | | | | | | | | | | | | | Previously the code was using the values from params further below after it was std::moved. Thankfully, given AudoutParams is a trivially copyable struct, the values would have simply been copied in this instance and not invalidated to garbage values.
* | | Merge pull request #869 from Subv/ubsanbunnei2018-07-312-6/+17
|\ \ \ | | | | | | | | Corrected a few error cases detected by asan/ubsan
| * | | nvhost_gpu: Added checks to ensure we don't read past the end of the entries when handling a GPU command list.Subv2018-07-311-3/+6
| | | |
| * | | nvhost_ctrl_gpu: Only read the input parameters if they are actually there.Subv2018-07-311-3/+11
| | | | | | | | | | | | | | | | Passing nullptr to memcpy is undefined behavior.
* | | | Merge pull request #875 from lioncash/fgmbunnei2018-07-313-0/+92
|\ \ \ \ | | | | | | | | | | service: Add fgm services
| * | | | service: Add fgm servicesLioncash2018-07-313-0/+92
| | |_|/ | |/| | | | | | | | | | | | | | Adds the basic skeleton for the fgm services based off the information provided by Switch Brew.
* | | | Merge pull request #874 from lioncash/ambunnei2018-07-317-0/+150
|\ \ \ \ | |_|_|/ |/| | | service/am: Add missing am services
| * | | service/am: Add missing am servicesLioncash2018-07-317-0/+150
| |/ / | | | | | | | | | | | | Adds the basic skeleton for missing am services idle:sys, omm, and spsm based off the information provided by Switch Brew.
* / / service: Add the pcie serviceLioncash2018-07-313-0/+81
|/ / | | | | | | | | Adds the basic skeleton of the pcie service based off information on Switch Brew.
* | audio_core: Move to audout_u impl.bunnei2018-07-312-4/+6
| | | | | | | | - This is necessary so streams are created on the same thread.
* | Implemented various hwopus functions (#853)David2018-07-312-5/+131
| |
* | Merge pull request #857 from lioncash/wlanbunnei2018-07-303-1/+190
|\ \ | | | | | | service: Add wlan services
| * | service: Add wlan servicesLioncash2018-07-293-1/+190
| | | | | | | | | | | | | | | Adds the basic skeleton for the wlan services based off the information on Switch Brew.
* | | Merge pull request #856 from lioncash/btmbunnei2018-07-303-0/+138
|\ \ \ | | | | | | | | service: Add btm services
| * | | service/btm: Add basic implementation of GetCoreImpl()Lioncash2018-07-291-1/+35
| | | | | | | | | | | | | | | | Based off information on SwIPC and Switch Brew.
| * | | service: Add btm servicesLioncash2018-07-293-0/+104
| |/ / | | | | | | | | | | | | Adds the skeleton for the btm services based off the information on Switch Brew.
* / / Add some HID commands (#843)Hexagon122018-07-301-2/+16
|/ / | | | | | | | | | | * Added some HID commands * Addressed comments
* | Merge pull request #847 from lioncash/ncmbunnei2018-07-283-0/+76
|\ \ | | | | | | service: Add ncm services
| * | service: Add ncm servicesLioncash2018-07-273-0/+76
| | | | | | | | | | | | | | | Adds the basic skeleton for the ncm services based off information on Switch Brew.
* | | Merge pull request #846 from lioncash/miibunnei2018-07-283-0/+124
|\ \ \ | | | | | | | | service: Add mii services
| * | | service: Add mii servicesLioncash2018-07-273-0/+124
| | | | | | | | | | | | | | | | | | | | Adds the skeleton for the mii services based off information provided by Switch Brew
* | | | audout: Implement IAudioOut interface with AudioCore.bunnei2018-07-282-93/+114
| |/ / |/| |
* | | Merge pull request #845 from lioncash/nfcbunnei2018-07-273-0/+239
|\ \ \ | | | | | | | | service: Add nfc services
| * | | service/nfc: Implement Create[x]Interface functionsLioncash2018-07-271-4/+43
| | | | | | | | | | | | | | | | These simply return the respective interface.
| * | | service: Add nfc servicesLioncash2018-07-273-0/+200
| |/ / | | | | | | | | | | | | Adds the skeleton of the nfc service based off the information provided on Switch Brew.
* | | Merge pull request #844 from lioncash/lblbunnei2018-07-273-0/+107
|\ \ \ | | | | | | | | service: Add the lbl service
| * | | service/lbl: Implement EnableVrMode, DisableVrMode and GetVrModeLioncash2018-07-271-3/+35
| | | | | | | | | | | | | | | | | | | | Implements these functions according to the information available on Switch Brew.
| * | | service: Add the lbl serviceLioncash2018-07-273-0/+75
| |/ / | | | | | | | | | | | | Adds the skeleton of the lbl service based off the information provided by Switch Brew.
* | | Merge pull request #841 from lioncash/btdrvbunnei2018-07-273-1/+91
|\ \ \ | |/ / |/| | service: Add the btdrv service
| * | service: Add the btdrv serviceLioncash2018-07-273-1/+91
| | | | | | | | | | | | Adds the skeleton for the btdrv service based off the information provided by Switch Brew
* | | Merge pull request #837 from lioncash/privbunnei2018-07-271-5/+17
|\ \ \ | | | | | | | | kernel/timer: Make data members private where applicable
| * | | kernel/timer: Make data members private where applicableLioncash2018-07-261-5/+17
| | | | | | | | | | | | | | | | | | | | Instead, we can just expose functions that return the queryable state instead of letting anything modify it.
* | | | service/hid: Add the hidbus, hid:dbg, hid:sys, and hid:tmp servicesLioncash2018-07-261-0/+220
| | | |
* | | | service/hid: Add the xcd:sys serviceLioncash2018-07-263-0/+55
| | | |
* | | | service/hid: Add irs servicesLioncash2018-07-263-0/+73
| |/ / |/| |
* | | Merge pull request #834 from lioncash/grcbunnei2018-07-263-0/+48
|\ \ \ | | | | | | | | service: Add the grc:c service
| * | | service: Add the grc:c serviceLioncash2018-07-263-0/+48
| |/ / | | | | | | | | | | | | Adds the basic skeleton for the grc:c service based off the information provided by Switch Brew.
* | | Merge pull request #832 from lioncash/nimbunnei2018-07-263-0/+141
|\ \ \ | | | | | | | | service: Add the nim services
| * | | service: Add the nim servicesLioncash2018-07-263-0/+141
| |/ / | | | | | | | | | | | | Adds the skeleton for the nim services based off information from Switch Brew.
* | | Merge pull request #831 from lioncash/ldnbunnei2018-07-263-0/+160
|\ \ \ | | | | | | | | service: Add ldn services
| * | | service: Add ldn servicesLioncash2018-07-263-0/+160
| |/ / | | | | | | | | | Adds ldn services based off information provided by Switch Brew.
* | | Merge pull request #830 from lioncash/socketbunnei2018-07-265-0/+93
|\ \ \ | |_|/ |/| | service/sockets: Add missing socket services
| * | service/sockets: Add ethc:c and ethc:i servicesLioncash2018-07-263-0/+64
| | |
| * | service/sockets: Add missing bsdcfg socket serviceLioncash2018-07-263-0/+29
| |/
* | Merge pull request #827 from lioncash/logbunnei2018-07-262-40/+35
|\ \ | |/ |/| service/lm: Minor changes
| * lm: Move LM's class declaration into the cpp fileLioncash2018-07-262-37/+31
| | | | | | | | | | This isn't used directly outside of this translation unit, so we can hide it from external use.
| * lm: Amend names of Initialize() in Logger and Initialize() in LMLioncash2018-07-262-7/+7
| | | | | | | | Amends these to match the information on Switch Brew.
| * lm: Add missing function entry to Logger's function tableLioncash2018-07-261-0/+1
| |
* | Merge pull request #828 from lioncash/ldrSebastian Valle2018-07-263-0/+99
|\ \ | | | | | | service: Add ldr services
| * | service: Add ldr servicesLioncash2018-07-263-0/+99
| | | | | | | | | | | | | | | Adds the skeleton for the ldr-related services based off the information provided on Switch Brew.
* | | Merge pull request #826 from lioncash/erptSebastian Valle2018-07-265-0/+139
|\ \ \ | | | | | | | | service: Add erpt and eupld services
| * | | service: Add eupld servicesLioncash2018-07-263-0/+70
| | | | | | | | | | | | | | | | | | | | Adds the skeleton for the eupld services based off information on Switch Brew.
| * | | service: Add the erpt servicesLioncash2018-07-263-0/+69
| | |/ | |/| | | | | | | | | | Adds the basic skeleton of the erpt service based off information on Switch Brew.
* | | Merge pull request #823 from lioncash/nifmSebastian Valle2018-07-268-135/+30
|\ \ \ | |_|/ |/| | service/nifm: Deduplicate interface code
| * | service/nifm: Deduplicate interface codeLioncash2018-07-258-135/+30
| | | | | | | | | | | | | | | Rather than having the same code for each nifm service variant, we can centralize it on one class and get rid of a bit of extra code.
* | | Merge pull request #824 from lioncash/nvdrvbunnei2018-07-262-5/+7
|\ \ \ | | | | | | | | service/nvdrv: Minor changes
| * | | service/nvdrv: Take std::string in Open() by const referenceLioncash2018-07-252-2/+2
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Avoids copies from being made, since the string is only ever used for lookup, the data is never transfered anywhere. Ideally, we'd use a std::string_view here, but devices is a std::unordered_map, not a std::map, so we can't use heterogenous lookup here.
| * | | service/nvdrv: Use std::move where applicableLioncash2018-07-251-3/+5
| |/ / | | | | | | | | | | | | | | | | | | Avoids unnecessary reference count increments and decrements. In one case, we don't need to make a shared_ptr copy at all, just to call a member function.
* | | Merge pull request #822 from lioncash/pmbunnei2018-07-263-0/+88
|\ \ \ | |_|/ |/| | service: Add pm services
| * | service: Add pm servicesLioncash2018-07-253-0/+88
| |/ | | | | | | | | Adds the skeleton for the process management services based off information on Switch Brew.
* / service: Add the es serviceLioncash2018-07-253-0/+75
|/ | | | | Adds the skeleton for the ETicket service based off the information on Switch Brew
* Merge pull request #801 from lioncash/timeMat M2018-07-255-60/+14
|\ | | | | time: Add the time:a service
| * time: Add the time:a serviceLioncash2018-07-253-10/+11
| | | | | | | | Given we already have time:s and time:u, we should also have time:a
| * time: Simplify interface creationLioncash2018-07-245-60/+13
| | | | | | | | We can use one instance of the interface instead of duplicating code.
* | Merge pull request #804 from lioncash/logMat M2018-07-251-1/+3
|\ \ | | | | | | svc: Log parameters in SetMemoryAttribute()
| * | svc: Log parameters in SetMemoryAttribute()Lioncash2018-07-241-1/+3
| | | | | | | | | | | | Provides slightly more context than only logging out the address value.
* | | Merge pull request #803 from MerryMage/core_timing_utilbunnei2018-07-257-0/+7
|\ \ \ | | | | | | | | core_timing: Split off utility functions into core_timing_util
| * | | core_timing: Split off utility functions into core_timing_utilMerryMage2018-07-247-0/+7
| | | |
* | | | Merge pull request #800 from lioncash/setbunnei2018-07-253-5/+33
|\ \ \ \ | | | | | | | | | | set_sys: Implement SetColorSetId()
| * | | | set_sys: Implement SetColorSetId()Lioncash2018-07-242-5/+25
| | | | |
| * | | | ipc_helper: Add helper member function for popping enum values to RequestParserLioncash2018-07-241-0/+8
| | |_|/ | |/| |
* | | | Merge pull request #806 from lioncash/friendbunnei2018-07-255-44/+13
|\ \ \ \ | | | | | | | | | | friend: Deduplicate interfaces
| * | | | friend: Add friend:m, friend:s, and friend:v servicesLioncash2018-07-241-0/+3
| | | | | | | | | | | | | | | | | | | | | | | | | Given we already have friend:a and friend:u, we should add the remaining services as well.
| * | | | friend/interface: Add missing CreateDaemonSuspendSessionService() to the function handler tableLioncash2018-07-241-0/+1
| | | | |
| * | | | friend: Deduplicate interfacesLioncash2018-07-245-44/+9
| | |_|/ | |/| |
* / | | svc: Resolve sign comparison warnings in WaitSynchronization()Lioncash2018-07-241-4/+7
|/ / / | | | | | | | | | | | | The loop's induction variable was signed, but we were comparing against an unsigned variable.
* | | Merge pull request #797 from lioncash/explicitbunnei2018-07-242-2/+2
|\ \ \ | | | | | | | | core: Make converting constructors explicit where applicable
| * | | core: Make converting constructors explicit where applicableLioncash2018-07-242-2/+2
| |/ / | | | | | | | | | | | | Avoids unwanted implicit conversions. Thankfully, given the large amount of cleanup in past PRs, only this tiny amount is left over to cover.
* | | Merge pull request #795 from lioncash/declbunnei2018-07-241-3/+0
|\ \ \ | | | | | | | | apm/interface: Remove redundant declaration of InstallInterfaces()
| * | | apm/interface: Remove redundant declaration of InstallInterfaces()Lioncash2018-07-241-3/+0
| |/ / | | | | | | | | | This is already declared in apm/apm.h
* | | Merge pull request #794 from lioncash/refbunnei2018-07-241-1/+1
|\ \ \ | |_|/ |/| | mutex: Pass SharedPtr to GetHighestPriorityMutexWaitingThread() by reference
| * | mutex: Pass SharedPtr to GetHighestPriorityMutexWaitingThread() by referenceLioncash2018-07-241-1/+1
| | | | | | | | | | | | | | | The pointed to thread's members are simply observed in this case, so we don't need to copy it here.
* | | Merge pull request #793 from lioncash/privbunnei2018-07-242-17/+19
|\ \ \ | |_|/ |/| | ipc_helpers: Make member variables of ResponseBuilder private
| * | hle_ipc: Make constructors explicit where applicableLioncash2018-07-242-12/+13
| | |
| * | ipc_helpers: Make member variables of ResponseBuilder privateLioncash2018-07-241-5/+6
| |/ | | | | | | These aren't used externally at all, so they can be made private.
* / VFS Regression and Accuracy Fixes (#776)Zach Hilman2018-07-241-16/+29
|/ | | | | | | | | | | | | | | | * Regression and Mode Fixes * Review Fixes * string_view correction * Add operator& for FileSys::Mode * Return std::string from SanitizePath * Farming Simulator Fix * Use != With mode operator&
* Merge pull request #780 from lioncash/movebunnei2018-07-241-11/+22
|\ | | | | vi: Minor changes
| * vi: Add std::is_trivially_copyable checks to Read and Write functionsLioncash2018-07-231-2/+13
| | | | | | | | | | | | It's undefined behavior to memcpy an object that isn't considered trivially copyable, so put a compile-time check in to make sure this doesn't occur.
| * vi: std::move std::vector in constructors where applicableLioncash2018-07-231-9/+9
| | | | | | | | | | | | | | Allows avoiding unnecessary copies of the vector depending on the calling code. While we're at it, remove a redundant no-parameter base constructor call
* | Merge pull request #779 from lioncash/sharedbunnei2018-07-247-259/+0
|\ \ | | | | | | hle: Remove unused config_mem and shared_page source files
| * | hle: Remove config_mem.h/.cppLioncash2018-07-235-100/+0
| | | | | | | | | | | | | | | This is just an unused hold-over from citra, so we can get rid of this to trim off an exposed global, among other things.
| * | hle: Remove shared_page.h/.cppLioncash2018-07-235-159/+0
| |/ | | | | | | This is a holdover from citra that's essentially unused.
* / set: Add missing log call in GetAvailableLanguageCodeCount()Lioncash2018-07-231-0/+2
|/ | | | Forgot to include this in 22f448b6327044076959e338811ee576f3dcf093
* Merge pull request #777 from lioncash/langbunnei2018-07-232-23/+31
|\ | | | | set: Amend return value of GetAvailableLanguageCodes()
| * set: Implement GetAvailableLanguageCodeCount()Lioncash2018-07-232-21/+29
| | | | | | | | This just returns the size of the language code buffer.
| * set: Correct return code size of value in GetAvailableLanguageCodes()Lioncash2018-07-231-2/+2
| | | | | | | | The return code should be 32-bit in size.
* | Merge pull request #774 from Subv/atomic_signalbunnei2018-07-221-7/+31
|\ \ | |/ |/| Kernel/SVC: Perform atomic accesses in SignalProcessWideKey as per the real kernel.
| * Kernel/SVC: Perform atomic accesses in SignalProcessWideKey as per the real kernel.Subv2018-07-221-7/+31
| |
* | file_util, vfs: Use std::string_view where applicableLioncash2018-07-221-1/+1
|/ | | | | Avoids unnecessary construction of std::string instances where applicable.
* Merge pull request #760 from lioncash/pathbunnei2018-07-222-3/+3
|\ | | | | file_util: Use an enum class for GetUserPath()
| * file_util: Use an enum class for GetUserPath()Lioncash2018-07-212-3/+3
| | | | | | | | | | | | | | | | | | | | | | | | | | Instead of using an unsigned int as a parameter and expecting a user to always pass in the correct values, we can just convert the enum into an enum class and use that type as the parameter type instead, which makes the interface more type safe. We also get rid of the bookkeeping "NUM_" element in the enum by just using an unordered map. This function is generally low-frequency in terms of calls (and I'd hope so, considering otherwise would mean we're slamming the disk with IO all the time) so I'd consider this acceptable in this case.
* | GPU: Implement the NVGPU_IOCTL_CHANNEL_KICKOFF_PB ioctl2 command.Subv2018-07-213-6/+34
|/ | | | | This behaves quite similarly to the SubmitGPFIFO command. Referenced from Ryujinx. Many thanks to @gdkchan for investigating this!
* Merge pull request #751 from Subv/tpidr_el0bunnei2018-07-213-0/+13
|\ | | | | CPU: Save and restore the TPIDR_EL0 system register on every context switch
| * CPU: Save and restore the TPIDR_EL0 system register on every context switch.Subv2018-07-213-0/+13
| | | | | | | | Note that there's currently a dynarmic bug preventing this register from being written.
* | Merge pull request #742 from bunnei/misc-apmbunnei2018-07-211-1/+16
|\ \ | | | | | | apm: Improve stub for GetPerformanceConfiguration.
| * | apm: Improve stub for GetPerformanceConfiguration.bunnei2018-07-201-1/+16
| | |
* | | ipc_helpers: Add PushEnum() member function to ResponseBuilderLioncash2018-07-201-0/+19
|/ / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Allows pushing strongly-typed enum members without the need to always cast them at the call sites. Note that we *only* allow strongly-typed enums in this case. The reason for this is that strongly typed enums have a guaranteed defined size, so the size of the data being pushed is always deterministic. With regular enums this can be a little more error-prone, so we disallow them. This function simply uses the underlying type of the enum to determine the size of the data. For example, if an enum is defined as: enum class SomeEnum : u16 { SomeEntry }; if PushEnum(SomeEnum::SomeEntry); is called, then it will push a u16-size amount of data.
* | Merge pull request #740 from Subv/acc_crashbunnei2018-07-201-6/+8
|\ \ | | | | | | HLE/ACC: Stub IManagerForApplication::GetAccountId to return an error.
| * | HLE/ACC: Stub IManagerForApplication::GetAccountId to return an error.Subv2018-07-201-6/+8
| |/ | | | | | | | | | | And make IManagerForApplication::CheckAvailability always return false. Returning a bogus id from GetAccountId causes games to crash on boot. We should investigate this with a hwtest and either stub it properly or implement it.
* | Merge pull request #736 from lioncash/nullbunnei2018-07-202-3/+6
|\ \ | | | | | | audout_u/audren_u: Ensure null terminators are written out in ListAudioOutsImpl(), ListAudioDeviceName(), and GetActiveAudioDeviceName()
| * | audren_u: Use a std::array instead of std::string for holding the audio interface/device nameLioncash2018-07-201-2/+4
| | | | | | | | | | | | | | | std::string doesn't include the null-terminator in its data() + size() range. This ensures that the null-terminator will also be written to the buffer
| * | audout_u: Use a std::array instead of std::string for holding the audio interface nameLioncash2018-07-201-1/+2
| | | | | | | | | | | | | | | | | | Uses a type that doesn't potentially dynamically allocate, and ensures that the name of the interface is properly null-terminated when writing it to the buffer.
* | | Merge pull request #734 from lioncash/threadbunnei2018-07-209-71/+70
|\ \ \ | |_|/ |/| | thread: Convert ThreadStatus into an enum class
| * | thread: Convert ThreadStatus into an enum classLioncash2018-07-209-71/+70
| |/ | | | | | | | | Makes the thread status strongly typed, so implicit conversions can't happen. It also makes it easier to catch mistakes at compile time.
* / pl_u: Simplify WriteBuffer() calls in GetSharedFontInOrderOfPriority()Lioncash2018-07-201-3/+3
|/ | | | With the new overload, we can simply pass the container directly.
* Merge pull request #726 from lioncash/overloadbunnei2018-07-205-10/+25
|\ | | | | hle_ipc: Introduce generic WriteBuffer overload for multiple container types
| * hle_ipc: Introduce generic WriteBuffer overload for multiple container typesLioncash2018-07-195-10/+25
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This introduces a slightly more generic variant of WriteBuffer(). Notably, this variant doesn't constrain the arguments to only accepting std::vector instances. It accepts whatever adheres to the ContiguousContainer concept in the C++ standard library. This essentially means, std::array, std::string, and std::vector can be used directly with this interface. The interface no longer forces you to solely use containers that dynamically allocate. To ensure our overloads play nice with one another, we only enable the container-based WriteBuffer if the argument is not a pointer, otherwise we fall back to the pointer-based one.
* | Merge pull request #725 from lioncash/bytesbunnei2018-07-201-3/+3
|\ \ | | | | | | pl_u: Specify correct size for buffers in GetSharedFontInOrderOfPriority()
| * | pl_u: Specify correct size for buffers in GetSharedFontInOrderOfPriority()Lioncash2018-07-191-3/+3
| |/ | | | | | | | | This WriteBuffer overload expects its size argument to be in bytes, not elements.
* | Merge pull request #728 from Subv/acc_profilebunnei2018-07-201-7/+16
|\ \ | | | | | | HLE/ACC: Change the default user id and small improvements to the way we handle profiles
| * | HLE/ACC: Return an IProfile that is consistent with what was requested.Subv2018-07-191-5/+15
| | | | | | | | | | | | | | | The default username for now is "yuzu". We should eventually allow the creation of users in the emulator and have the ability to modify their parameters.
| * | HLE/ACC: Change the default user id to be consistent with what we tell games on startup.Subv2018-07-191-2/+1
| | | | | | | | | | | | In IApplicationFunctions::PopLaunchParameter we tell the games that they were launched as user id 1.
* | | Merge pull request #727 from Subv/acc_usersbunnei2018-07-201-4/+6
|\ \ \ | | | | | | | | HLE/ACC: Write a single whole user id in ListAllUsers and ListOpenUsers.
| * | | HLE/ACC: Write a single whole user id in ListAllUsers and ListOpenUsers.Subv2018-07-191-4/+6
| |/ / | | | | | | | | | We only emulate a single user id for now.
* | | Merge pull request #724 from lioncash/printfbunnei2018-07-201-1/+1
|\ \ \ | | | | | | | | pl_u: Remove printf specifier in log call in a log call in GetSharedFontInOrderOfPriority()
| * | | pl_u: Remove printf specifier in log call in a log call in GetSharedFontInOrderOfPriority()Lioncash2018-07-191-1/+1
| | |/ | |/| | | | | | | This can just use the fmt specifiers and be type-agnostic.
* | | Merge pull request #722 from lioncash/signedbunnei2018-07-202-8/+4
|\ \ \ | | | | | | | | hid: Resolve a signed/unsigned comparison warning
| * | | hid: Use a ranged-for loops in UpdatePadCallbackLioncash2018-07-191-7/+3
| | | | | | | | | | | | | | | | | | | | Modernizes the loops themselves while also getting rid of a signed/unsigned comparison in a loop condition.
| * | | hid: Use HID_NUM_LAYOUTS constant for indicating size of the layouts arrayLioncash2018-07-191-1/+1
| | | | | | | | | | | | | | | | Gets rid of the use of a magic constant
* | | | Merge pull request #721 from lioncash/svcbunnei2018-07-201-3/+4
|\ \ \ \ | | | | | | | | | | svc: Correct always true assertion case in SetThreadCoreMask
| * | | | svc: Correct always true assertion case in SetThreadCoreMaskLioncash2018-07-191-3/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The reason this would never be true is that ideal_processor is a u8 and THREADPROCESSORID_DEFAULT is an s32. In this case, it boils down to how arithmetic conversions are performed before performing the comparison. If an unsigned value has a lesser conversion rank (aka smaller size) than the signed type being compared, then the unsigned value is promoted to the signed value (i.e. u8 -> s32 happens before the comparison). No sign-extension occurs here either. An alternative phrasing: Say we have a variable named core and it's given a value of -2. u8 core = -2; This becomes 254 due to the lack of sign. During integral promotion to the signed type, this still remains as 254, and therefore the condition will always be true, because no matter what value the u8 is given it will never be -2 in terms of 32 bits. Now, if one type was a s32 and one was a u32, this would be entirely different, since they have the same bit width (and the signed type would be converted to unsigned instead of the other way around) but would still have its representation preserved in terms of bits, allowing the comparison to be false in some cases, as opposed to being true all the time. --- We also get rid of two signed/unsigned comparison warnings while we're at it.
* | | | | Merge pull request #717 from lioncash/explicitbunnei2018-07-2022-25/+25
|\ \ \ \ \ | | | | | | | | | | | | hle/service: Make constructors explicit where applicable
| * | | | | hle/service: Make constructors explicit where applicableLioncash2018-07-1922-25/+25
| |/ / / / | | | | | | | | | | | | | | | | | | | | Prevents implicit construction and makes these lingering non-explicit constructors consistent with the rest of the other classes in services.
* | | | | Merge pull request #716 from lioncash/constructbunnei2018-07-191-9/+4
|\ \ \ \ \ | | | | | | | | | | | | nvflinger: Emplace Display instances directly
| * | | | | nvflinger: Emplace Display instances directlyLioncash2018-07-191-9/+4
| |/ / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We can use emplace_back to construct the Display instances directly, instead of constructing them separately and copying them, avoiding the need to copy std::string and std::vector instances that are part of the Display struct.
* | | | | Merge pull request #715 from lioncash/const-refbunnei2018-07-191-1/+1
|\ \ \ \ \ | |_|_|_|/ |/| | | | nvdrv: Take std::string by const reference in GetDevice()
| * | | | nvdrv: Take std::string by const reference in GetDevice()Lioncash2018-07-191-1/+1
| |/ / / | | | | | | | | | | | | | | | | This is only ever used as a lookup into the device map, so we don't need to take the std::string instance by value here.
* | | | Merge pull request #720 from Subv/getentrytype_rootSebastian Valle2018-07-191-0/+4
|\ \ \ \ | |_|_|/ |/| | | Filesystem: Return EntryType::Directory for the root directory.
| * | | Filesystem: Return EntryType::Directory for the root directory.Subv2018-07-191-0/+4
| |/ / | | | | | | | | | It is unknown if this is correct behavior, but it makes sense and fixes a regression with Stardew Valley.
* | | Merge pull request #714 from lioncash/indexSebastian Valle2018-07-191-1/+1
|\ \ \ | | | | | | | | hle_ipc: Amend usage of buffer_index within one of HLERequestContext's WriteBuffer() overloads
| * | | hle_ipc: Amend usage of buffer_index within one of HLERequestContext's WriteBuffer() overloadsLioncash2018-07-191-1/+1
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | Previously, the buffer_index parameter was unused, causing all writes to use the buffer index of zero, which is not necessarily what is wanted all the time. Thankfully, all current usages don't use a buffer index other than zero, so this just prevents a bug before it has a chance to spring.
* | | Merge pull request #712 from lioncash/fspbunnei2018-07-191-17/+22
|\ \ \ | |_|/ |/| | fsp_srv: Misc individual changes
| * | fsp_srv: Remove unnecessary vector construction in IFile's Write() functionLioncash2018-07-191-2/+3
| | | | | | | | | | | | | | | | | | | | | We can avoid constructing a std::vector here by simply passing a pointer to the original data and the size of the copy we wish to perform to the backend's Write() function instead, avoiding copying the data where it's otherwise not needed.
| * | fsp_srv: Remove unnecessary std::vector construction in IDirectory's Read() functionLioncash2018-07-191-10/+8
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | We were using a second std::vector as a buffer to convert another std::vector's data into a byte sequence, however we can just use pointers to the original data and use them directly with WriteBuffer, which avoids copying the data at all into a separate std::vector. We simply cast the pointers to u8* (which is allowed by the standard, given std::uint8_t is an alias for unsigned char on platforms that we support).
| * | fsp_srv: Make IStorage constructor explicitLioncash2018-07-191-1/+1
| | | | | | | | | | | | Prevents implicit conversions.
| * | fsp_srv: Add missing includesLioncash2018-07-191-0/+5
| | | | | | | | | | | | Gets rid of relying on indirect inclusions.
| * | fsp_srv: Resolve sign-mismatch warnings in assertion comparisonsLioncash2018-07-191-3/+3
| | |
| * | fsp_srv: Respect write length in Write()Lioncash2018-07-191-4/+5
| |/ | | | | | | | | | | | | | | | | | | | | Previously we were just copying the data whole-sale, even if the length was less than the total data size. This effectively makes the actual_data vector useless, which is likely not intended. Instead, amend this to only copy the given length amount of data. At the same time, we can avoid zeroing out the data before using it by passing iterators to the constructor instead of a size.
* | filesystem: std::move VirtualDir instance in VfsDirectoryServiceWrapper's constructorLioncash2018-07-191-1/+3
| | | | | | | | Avoids unnecessary atomic reference count incrementing and decrementing
* | filesystem: Use std::string's empty() function instead of comparing against a literalLioncash2018-07-191-1/+1
| | | | | | | | | | This is simply a basic value check as opposed to potentially doing string based operations (unlikely, but still, avoiding it is free).
* | filesystem: Remove pragma disabling global optimizationsLioncash2018-07-191-2/+0
|/ | | | This was just an artifact missed during PR review.
* Merge pull request #692 from lioncash/assignbunnei2018-07-191-1/+1
|\ | | | | address_arbiter: Correct assignment within an assertion statement in WakeThreads()
| * address_arbiter: Correct assignment within an assertion statement in WakeThreads()Lioncash2018-07-191-1/+1
| | | | | | | | | | | | This was introduced within 4f81bc4e1bd12e4df7410c6790ba818d8dbba9c0, and considering there's no comment indicating that this is intentional, this is very likely a bug.
* | Merge pull request #690 from lioncash/movebunnei2018-07-198-13/+21
|\ \ | | | | | | core/memory, core/hle/kernel: Use std::move where applicable
| * | core/memory, core/hle/kernel: Use std::move where applicableLioncash2018-07-198-13/+21
| | | | | | | | | | | | Avoids pointless copies
* | | Merge pull request #691 from lioncash/guardbunnei2018-07-191-0/+2
|\ \ \ | | | | | | | | service/prepo: Add missing header guard
| * | | service/prepo: Add missing header guardLioncash2018-07-191-0/+2
| | |/ | |/|
* | | Merge pull request #688 from lioncash/commabunnei2018-07-191-22/+12
|\ \ \ | | | | | | | | vm_manager: Add missing commas to string literal array elements in GetMemoryStateName()
| * | | vm_manager: Add missing commas to string literal array elements in GetMemoryStateName()Lioncash2018-07-191-22/+12
| | |/ | |/| | | | | | | | | | Without these, this would perform concatenation, which is definitely not what we want here.
* | | Merge pull request #687 from lioncash/instancebunnei2018-07-191-6/+6
|\ \ \ | | | | | | | | core: Don't construct instance of Core::System, just to access its live instance
| * | | core: Don't construct instance of Core::System, just to access its live instanceLioncash2018-07-191-6/+6
| |/ / | | | | | | | | | | | | | | | | | | | | | | | | This would result in a lot of allocations and related object construction, just to toss it all away immediately after the call. These are definitely not intentional, and it was intended that all of these should have been accessing the static function GetInstance() through the name itself, not constructed instances.
* | / Virtual Filesystem 2: Electric Boogaloo (#676)Zach Hilman2018-07-195-116/+383
| |/ |/| | | | | | | | | | | | | | | | | * Virtual Filesystem * Fix delete bug and documentate * Review fixes + other stuff * Fix puyo regression
* | Fill in more fields in TouchScreenEntryTouchZach Hilman2018-07-181-4/+9
| |
* | Single touch supportZach Hilman2018-07-181-4/+19
|/
* vi: Change TransactionId::CancelBuffer to LOG_CRITICAL.bunnei2018-07-181-1/+1
|
* vi: Fix size for ListDisplays default display.bunnei2018-07-181-2/+2
|
* vi: Partially implement buffer crop parameters.bunnei2018-07-186-10/+26
|
* General Filesystem and Save Data Fixes (#670)Zach Hilman2018-07-175-101/+130
|
* Merge pull request #671 from MerryMage/clear-exclusive-statebunnei2018-07-171-0/+1
|\ | | | | scheduler: Clear exclusive state when switching contexts
| * scheduler: Clear exclusive state when switching contextsMerryMage2018-07-161-0/+1
| |
* | Merge pull request #672 from SciresM/to_address_fixbunnei2018-07-171-2/+4
|\ \ | | | | | | svc:: Fix bug in svcWaitForAddress
| * | Kernel/Arbiter: Fix bug in WaitIfLessThanMichael Scire2018-07-171-2/+4
| |/
* / nvflinger: Fix for BufferQueue event handling.bunnei2018-07-176-32/+21
|/
* HID: Update controllers less oftenJames Rowe2018-07-151-3/+3
|
* Merge pull request #663 from Subv/bsdbunnei2018-07-151-2/+1
|\ | | | | Services/BSD: Corrected the return for StartMonitoring according to SwIPC
| * Services/BSD: Corrected the return for StartMonitoring according to SwIPC.Subv2018-07-141-2/+1
| |
* | No need to use ASSERT_MSG with an empty messageDavid Marcec2018-07-141-2/+2
|/
* We only need to alert for memory pool changesDavid Marcec2018-07-131-2/+0
|
* initialized voice status and unused sizes in the update data headerDavid Marcec2018-07-131-1/+3
|
* Merge pull request #648 from ogniK5377/no-netbunnei2018-07-121-3/+21
|\ | | | | Let games/application know that we're offline
| * Added IsWirelessCommunicationEnabled, IsEthernetCommunicationEnabled, IsAnyInternetRequestAcceptedDavid Marcec2018-07-121-3/+21
| | | | | | | | Since we have no socket implementation we should be returning 0 to indicate we're currently offline.
* | Audout "Auto" functionsDavid Marcec2018-07-122-14/+14
|/ | | | Audout autos are identical to their counterpart except for the buffer type which yuzu already handles for us.
* Merge pull request #559 from Subv/mount_savedatabunnei2018-07-121-2/+11
|\ | | | | Services/FS: Return the correct error code when trying to mount a nonexistent savedata.