Commit Graph

5688 Commits

Author SHA1 Message Date
Gliniak 2815244716 [XAM/User] Added descriptions and labels for achievements
Disclaimer: On old dash it causes memleak (slight),
newer dashboards allocates them only once which is solution for that.

Ps. If anyone have easy solution please implement it. Cheers
2020-03-20 20:54:36 +11:00
Gliniak d6e9612459 [XAM/Misc] Added stub for: XamIsXbox1TitleId 2020-03-20 20:54:36 +11:00
Gliniak 5dd015ad56 [User] Removed hardcode from XPROFILE_GAMERCARD_TITLES_PLAYED
(Now dashboard 9199 shows more reliable amount of games played)
2020-03-20 20:54:36 +11:00
Cancerous e901ea8376 stubs for 9199 (eventually) 2020-03-20 20:54:36 +11:00
Gliniak 78225c12ee [User] Added method for calculating gamerscore 2020-03-20 20:54:36 +11:00
Gliniak 692bc914f5 [XAM/Media] Added stub for: XamLoaderGetMediaInfo 2020-03-20 20:54:36 +11:00
Gliniak e320fcee1f [XAM/User] Added Stub for: XamUserIsOnlineEnabled 2020-03-20 20:54:35 +11:00
Gliniak b25fecea91 [XAM/User] XamUserGetGamerTag - added exception for user_index -1 (0xFF)
(Fixes gamertag in 9199 dash)
2020-03-20 20:54:35 +11:00
Gliniak c30b028be5 [Profile] Added dummy settings (This causes gamertag to appear) 2020-03-20 20:54:35 +11:00
Gliniak 4cec87cf1d [XAM] XamReadTile - Changed size of item_id 2020-03-20 20:54:35 +11:00
Gliniak dd86ff9449 [XAM/User] Implemented XamUserGetGamerTag 2020-03-20 20:54:35 +11:00
Gliniak 6b216d6a15 [XAM] XNotifyGetNext - Fixed null check for !param_ptr (Thanks randprint) 2020-03-20 20:54:35 +11:00
Gliniak a0f9f21f47 [XAM/Avatar] Added stub for: XamAvatarLoadAnimation
This enable running AvatarEditor

Disclaimer: Games that uses Avatars might crash
2020-03-20 20:54:34 +11:00
Gliniak 17b457bf1d [Kernel] Added few elemenmts to xeExGetXConfigSetting
This will allow to go inside "Console Settings" in NXE Dashboard
and fixes stability on older dashboards
2020-03-20 20:54:34 +11:00
Gliniak 11dfd2ed65 [XAM/Nui] Added stubs for: XamNuiIsDeviceReady, XamIsNuiAutomationEnabled 2020-03-20 20:54:34 +11:00
Gliniak 148fec9cd3 [XAM/Notify] XNotifyGetNext - Added check to assure if param_ptr is correct 2020-03-20 20:54:34 +11:00
Gliniak c160281e21 [Memory] Preallocate encrypted memory region
(Fixes dashboards up to 12625)
2020-03-20 20:54:34 +11:00
Gliniak 2d06b66d8f [XAM/Sketchy] Implemented XamReadTile 2020-03-20 20:54:34 +11:00
Gliniak 8b357fc0b3 [KERNEL] Do not convert time if provided time_ptr is invalid (Fixes Dark Souls crash) 2020-03-20 20:54:33 +11:00
Gliniak 0329007e6c [GPD] Implemented XamUserCreateTitlesPlayedEnumerator 2020-03-20 20:54:33 +11:00
Cancerous 22571492aa [Kernel] Make XHttpStartup succeed and add stubs for XHttpOpen and XHttpConnect that fail 2020-03-20 20:54:33 +11:00
Cancerous 9fe0230acb Revert "[Kernel] - Try to shut down XMP so games won't spam it's functions"
This reverts commit 2df353fdde.
2020-03-20 20:54:33 +11:00
emoose 96e2d8d12f [XBDM] Add impl. for DmGetXboxName, stub 5 functions
Stubs: DmGetXbeInfo, DmIsDebuggerPresent, DmRegisterCommandProcessor, DmRegisterCommandProcessorEx
This helps progress some debug builds of games, DmGetXboxName error codes are based on what some games seem to expect from it.
Will probably be a good idea to move most of this to xbdm_info.cc soon.
2020-03-20 20:54:33 +11:00
Cancerous 6beeb8c427 [Kernel] remove option to disable WSAStartup 2020-03-20 20:54:33 +11:00
Cancerous d4cfd903e5 [Kernel] - Try to shut down XMP so games won't spam it's functions 2020-03-20 20:54:32 +11:00
Cancerous 18e1c26dae [Kernel] Add XHttpStartup Stub, try to gracefully fail and shutdown more of the networking so games won't spam the related functions 2020-03-20 20:54:32 +11:00
emoose 7340a0c53f [Kernel] Include XEX version in log 2020-03-20 20:54:32 +11:00
emoose 3273acef3a [Kernel/CPU] Fix XEX version numbers not being output correctly
Couldn't find a way to get bitfields & byte-swapping to play well together, so this was the best I could come up with... at least the proper version numbers will show in the log file now :)
2020-03-20 20:54:32 +11:00
emoose 05b3a6516d [Kernel] Allow XEX to continue load after ApplyPatch fails
This should be safe to do hopefully, most errors happen before any part of the XEX is modified, and the errors that can happen after modification should be very rare/impossible thanks to the earlier checks.
It might be good to write up some way to revert any changes though...
2020-03-20 20:54:32 +11:00
emoose 4264b5be16 [CPU] Check patch MediaID if patch signature check failed
This should let us make sure patches are being applied to the right XEX, without needing to rely on the signature.
2020-03-20 20:54:32 +11:00
emoose efe8681980 [CPU] Fix heap corruption by XEXP header patch not resizing headers correctly
This should hopefully fix GTA IV's TU (for media ID 6AC07221 at least)
2020-03-20 20:54:32 +11:00
emoose 70abd9584a [VFS/Kernel] Fixes to allow games to make use of cache partitions
Happy new year! Here's my first commit of the 2020s :)

With these fixes, Halo 3 Epsilon will now write cached map data & other things (autosaves/datamine...) to the cache0/cache1 partitions, (as long as mount_cache cvar is set)
(Halo 3 retail will also write some things to cache with this, but oddly doesn't cache map stuff... which is strange because Epsilon was built only a day or two after the retail build, so I'm not sure why it'd work differently...
Maybe retail needs a TU applied for it to work or something like that)
Other games should hopefully work with cache now too (AFAIK the problem was in SDK library code, that a lot of games probably share)
No idea if this will actually improve anything though, but at least things will work closer to what games expect :)

The way this works is by tricking the cache-partition code (staticly linked into the game exe) into thinking that the Partition0/Cache0/Cache1 devices are valid.
To do that I made another kind of VFS device, the NullDevice, which just takes in a list of paths to handle.
Whenever an IO request is made to one of these paths, the NullDevice can simply pretend to the game that everything was successful, which satisfies the requirements needed for caching.

It also makes use of another trick: setting TitleInsecureCacheDrive XEX permission, which seems to skip a huge chunk of cache-init code (STFC filesystem device registration & stuff like that)
I'm not sure if this would work with every single revision of the STFC/cache code though...
At least in Halo 3 the retail code will handle the TitleInsecureCacheDrive case for us fine, but maybe older/more recent versions don't include functionality for it, need to look into it some more.
(I did try an impl. without needing this permission months ago, got pretty far with it but got caught on one tiny issue that I couldn't figure out... too bad I didn't find out about this permission earlier!)
2020-03-20 20:54:31 +11:00
Cancerous 745c33de8c [Kernel] HDD and save detection changes 2020-03-20 20:54:31 +11:00
Cancerous aa80e4265d [Kernel] added more checks to filter user_index out of range 2020-03-20 20:54:31 +11:00
Cancerous 6b0cb5ae63 [Kernel] - further adjustments to xam overlapped ui for storage selection and messages 2020-03-20 20:54:31 +11:00
Cancerous 92bac99043 [Kernel] - time fix for darksouls 2020-03-20 20:54:31 +11:00
Cancerous 4629d6686f [VFS] more logging for resolving files 2020-03-20 20:54:31 +11:00
Cancerous b488740d10 [Kernel] - swapdisc fixes for gtav 2020-03-20 20:54:30 +11:00
Cancerous 3669645cd6 [Kernel] stubs for 9199 (eventually) 2020-03-20 20:54:30 +11:00
illusion98 0800655bb9 Force 1080p output mode 2020-03-20 20:54:30 +11:00
Gliniak 8e43b48907 [Achievements] XamUserCreateAchievementEnumerator - title_id 0 behaviour
Based on research 0 in title_id is interpreted as current game
2020-03-20 20:54:30 +11:00
Gliniak 8957c10f35 [XAM] Removed code related to buffer clear
Some games have hardcoded buffer size which doesn't match real size
2020-03-20 20:54:30 +11:00
Margen67 130578feaf [AppVeyor] Skip tests
this is already slow enough
2020-03-20 20:54:30 +11:00
Cancerous cbbc826fe4 further ajustment to buffer size to fix regression 2020-03-20 20:54:30 +11:00
Cancerous c7270ad262 title update fixup - breaks xex1 temporarily 2020-03-20 20:54:29 +11:00
Cancerous 9169091320 [Kernel] More adjustment to XNotification spam filter 2020-03-20 20:54:29 +11:00
Cancerous acfdeb7ac7 [Kernel] - adjusting XAMEnumerate buffer size to fix Angry Birds and Resonance of Fate - thanks Gliniak 2020-03-20 20:54:29 +11:00
Gliniak 5b13b58072 [Kernel/Sketchy] Implemented NtQueueApcThread
Signed-off-by: Gliniak <Gliniak93@gmail.com>
2020-03-20 20:54:29 +11:00
Cancerous 89d67e0ed4 [Kernel, UI]
threaded UI notifications from emoose Issue 1296
added fixups for hdd detection in more games (wheelman for example)
changed filter that stops notification spam
2020-03-20 20:54:29 +11:00
Cancerous d9c8e81382 [Base] icon fix 2020-03-20 20:54:29 +11:00