Commit Graph

5636 Commits

Author SHA1 Message Date
Gliniak b2120a182f [Log] Added information about implementation state 2020-01-09 20:55:38 +01:00
Gliniak 63b91b2338 Revert "[XAM/User] Added title_id == 0 check for few User functions"
This reverts commit 05433007c5.
2020-01-09 15:09:43 +01:00
Gliniak 05433007c5 [XAM/User] Added title_id == 0 check for few User functions
Games like to report title_id as 0 (it is expected behaviour).
0 in this case means currently opened title
2020-01-09 14:17:51 +01:00
Gliniak 20660e7c14 [GPU] InitializeRingBuffer - Clear buffer space to prevent random data readout 2020-01-06 23:10:00 +01:00
emoose 87fe381910 [XAM] Add XamShowCreateProfileUI & XamProfileCreate impl.
Seems to kinda work, xshell uses XamProfileCreate and says that it's successful at least.
Dash uses the ShowUI function, but doesn't seem to login to the created profile correctly for some reason... restarting with the toml configured for the new profile does seem to work though.
2020-01-06 07:37:16 +00:00
emoose 93a7e6ec8f [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-01-05 21:00:01 +00:00
emoose 579ada1b2a [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-01-05 20:44:31 +00:00
emoose 5349da7b40 [VFS] Oops, fix wrong BlockToOffset result for non-CON packages 2020-01-05 20:33:09 +00:00
emoose cc43875684 [Kernel] Fix XamReadTile not returning profile pic, breaking dash profile...
This caused dash not to load profile anymore, since dash passes user_index == kNone...
The new method should be closer to how things are actually meant to work.
2020-01-05 20:23:44 +00:00
emoose d2e2bda1da [VFS] Port new BlockToOffsetSTFS algo from stfs-headers
65ca664fdb
This should give better compatibility with CON packages - ie. profiles taken from actual consoles should hopefully extract properly without errors, now there's shouldn't be any need for extracting them with Velocity/Horizon first.
2020-01-05 20:18:14 +00:00
emoose 1fbcf7677a [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-01-05 19:18:18 +00:00
emoose f245dd9cc0 [XMP] Add extra checks from XAM to help prevent dash host crash 2020-01-04 20:14:16 +00:00
emoose e11abb8efa [User] Add some extra checks from XAM to Read/WriteProfileSettings exports 2020-01-04 19:52:13 +00:00
emoose 1b8b01af8d [XAM/User] Fix wrong error code given when ReadProfileSettings buffer is too small
Strange, seems ReadProfileSettings returns this error as the result code instead of the xoverlapped error code - it could be possible other Xam functions do the same too.
This fixes Crackdown loading (thanks Gliniak for the tip about buffer size), hope it doesn't break any other games though.
2020-01-04 14:34:56 +00:00
emoose 0b390c9f96 [XAM/User] Fix dashboard GPD overwrite when loading new game 2020-01-04 13:09:58 +00:00
emoose 4d242e7681 [XAM/User] Allow titles to actually access title-specific settings
Would only allow access to dash GPD previously...
I'm not sure if we need to setup the XPROFILE_TITLE_SPECIFIC settings in advance or not though, really it should be on the games to do this themselves, but not sure whats actually needed...

This should probably fix games that would save progress to profile (Halo 3 progression, etc.), haven't actually noticed any changes myself yet though.
2020-01-04 11:52:41 +00:00
emoose 5fcf2c29bd [User/XAM] Oops, fix null pointer deref 2020-01-04 09:02:49 +00:00
emoose 0ebfbb1f1f [XAM/User] Try logging in to any available profile when XUID isn't set
Now the XUID doesn't need to be set at all for Xenia to try logging into an available profile (as long as signin_state != 0, previously this needed XUID to be set to '1')

So from a default install, you should be able to just drop an X360 profile into the right profiles dir, and when you run Xenia it'll login to it automatically for you, no config changes needed!

This applies to all 4 user slots, just set their signin states, drop 4 profiles in and it should log them all into each one seperately, then you can edit the config with specific profile XUIDs for each user.

Xenia should now only generate a default XeniaUser profile when no profiles are available for a user.
2020-01-03 11:46:08 +00:00
emoose cc31b66d80 [XAM/User] Add UserIndex enum, handle special UserIndexes inside KernelState::user_profile 2020-01-03 11:31:52 +00:00
emoose 2e93a23a5e [XAM/User] Add support for multiple signed-in users/profiles
This adds support for multiple profiles to Xenia, profiles can be configured with the [Profiles] user_*_xuid / user_*_state config settings.
If state is non-zero (1 = offline, 2 = LIVE), the profile will be counted as logged-on - either with a generated XeniaUser gamertag, or if the XUID is set to 1 the first available profile will be loaded.
The XUID can also be set to the offline-XUID (E000...) of an existing profile, to sign in the user as that profile.
(Profiles should be stored in the Xenia content/FFFE07D1/00010000/ folder, either as an STFS package or an extracted folder)

All the XamUser* functions have been updated to support multiple user_index's provided to them too.
(there's still issues with weird indexes like 0xFF, 0x7FF9... being given though, still dunno what's with that, the KernelState::user_profile() code will treat 0xFF as 0)

I'm not really sure if this is the most ideal way to do things though, but it does appear to work fine, at least Halo 3 does detect the profiles with state > 0 fine.

TODO: look into changing up xam_content to make use of user_index & profiles.
It shouldn't be too difficult now to emulate the same content paths X360 uses (seperating content by XUID etc)
Would probably be a good idea, since it'd probably be needed for us to support multiple profiles properly, so that they don't all share savegames etc...
2020-01-03 00:05:00 +00:00
emoose e3073f3c9e [HID] Allow winkey driver to use the first unused user index
This removes the user_index == 0 requirement from the InputSystem code, and updates WinKeyInputDriver to use the first non-connected user index if it can.

Eg. if you had 2 XInput controllers plugged in, those two will take up user index 0 and 1, and keyboard will take user index 2.
If all four indexes are taken up already, the WinKey driver will be disabled.

(This is done by passing already-setup drivers to each drivers Setup function: since WinKey is the last to be setup, this'll let it query the XInput driver and find which user_index it should handle)
2020-01-02 23:59:50 +00:00
emoose 919ee3ef55 [Xam/Content] Remove unused ResolveGameUserContentPath func
(not needed since we store this stuff inside GPD now)
2019-12-31 04:43:57 +00:00
emoose 7bf03f6fa9 [XAM] Allow loading profile from STFS (extracts package automatically!)
Profiles can now be placed as either an extracted folder with GPDs, or an STFS package, inside the Documents\Xenia\content\FFFE07D1\00010000\ directory
eg. Documents\Xenia\content\FFFE07D1\00010000\E0000E07FA53D7F1
(this roughly matches the same location as X360 stores it)

If loading an STFS package the package will first get extracted to <path>.dir/, and then the profile is loaded/saved into that directory.
(originally was going to mount the package and read everything in-memory, but then realized how hard adding new files/modifying/etc would be.. VFS doesn't allow mixing two devices into the same mount_path afaik)

Code for extraction is taken from xenia-vfs-dump (as StfsContainerDevice::ExtractToFolder)

A [XAM]profile_xuid config option is added too, which should let you pick which profile to load from the FFFE07D1\00010000\ folder if you have multiple there.
(at least I hope it should - something like "profile_xuid = 0xE0000E07FA53D7F1" will work I hope... cpptoml might have issues with hex digits though, not sure, will investigate later...)
If profile_xuid isn't set (left at -1), Xenia will just load whatever the first file/folder inside there is.
2019-12-26 07:22:24 +00:00
emoose e3e14a9943 [Base] Change DEFINE_uint64 -> DEFINE_int64, cpptoml seems to have issues with uint64..
Tried setting a uint64 setting to -1 (FFFF FFFF FFFF FFFF), which made it throw a out of range exception when loading the toml...
Internally it uses int64 to parse numbers, so I guess it doesn't work well with converting to uint64?
Changing everything from uint64->int64 seems to solve it though, now -1 works fine.
2019-12-26 06:49:20 +00:00
emoose 306e348554 [VFS] Fix STFS file table info being read in wrong endian 2019-12-26 05:22:10 +00:00
emoose a0b95125af [XAM/User] Fix AchievementPlatform definitions...
big oof
2019-12-26 03:13:40 +00:00
emoose af738683bc [XAM/User] Store profile inside content root instead of next to EXE
eg. Documents/Xenia/content/profile/
2019-12-26 02:48:31 +00:00
emoose 5476aad0fc [XAM/Misc] Impl. IsSystem/IsXbox1/IsSystemExperience & FirstRunExperienceShouldRun exports 2019-12-26 02:19:57 +00:00
emoose 50fede65cf [XAM/User] Only add arcade games to profile if license_mask is set 2019-12-26 02:11:59 +00:00
emoose 3319bb8c14 [XAM/User] GetTitleId -> GetTitleData, check flags/titletype before adding to profile 2019-12-26 01:35:38 +00:00
emoose 1a49bd94b8 [XAM/User] ...CreateTitlesPlayedEnumerator: sort titles by date played (thanks Gliniak!) 2019-12-26 01:32:33 +00:00
emoose c44bc45d2e [XAM/User] Stub GetIndexFromXUID, add param to IsOnlineEnabled
Maybe can help with user_index issues? Not sure, dash still seems to use some wacky indexes sometimes..
2019-12-25 23:33:14 +00:00
emoose 3418c10255 [XAM/User] XamReadTile: support reading gamerpic from profile tile_64.png file 2019-12-25 23:09:53 +00:00
emoose 6caf986153 [XAM/User] Add extra checks to XamReadTile, remove GetTitleSpa
GetTitleGpd should work fine for what we're using it for here... it could be a good idea to keep an instance of the current SpaFile of the running title and have a GetTitleSpa that returns that though, since I think some stuff like XamReadString might eventually need access to SPA data, not really sure yet though.
2019-12-25 20:44:41 +00:00
emoose 598cff4b50 [XAM] Allow reading binary & unicode settings, but block AVATAR_INFO_1 2019-12-25 20:28:44 +00:00
emoose 8cdf8fd12c [XAM] Small XamUserCreateTitlesPlayedEnumerator tweaks + other fixups 2019-12-25 20:26:04 +00:00
emoose 919a775e60 [XAM] UserProfile: Update ach/gamerscore info inside UpdateGpd, add dash checks to SetTitleSpaData 2019-12-24 16:31:08 +00:00
emoose 894fa57d44 [XAM] UserProfile::LoadProfile: setup default settings 2019-12-24 16:21:46 +00:00
emoose 86c3ab5cac [XAM] Update profile setting code to use new xdbf::Setting struct 2019-12-24 16:14:28 +00:00
emoose bc8b426634 [XAM] xdbf.h: const-ify some parameters 2019-12-24 15:59:08 +00:00
emoose 8d14a9564c [XAM] xdbf.h: add more achievement details (flags, comments..) 2019-12-24 15:55:15 +00:00
emoose 6fa3aac574 [XAM] xdbf_xbox.h: add X360 GPD settings structs + minor fixups 2019-12-24 15:50:31 +00:00
Gliniak 350e3ff738 [XAM/User] XamUserCreateTitlesPlayedEnumerator - Skip titles without achievements
It mimics behaviour of real 360 dashboard that
skips info about demos and system apps

also smaller code style changes
2019-12-24 12:27:05 +01:00
Gliniak 21097bb77a [XAM/User] Implemented sketchy XamReadTileEx
Also changes to XamReadTile
2019-12-24 11:35:53 +01:00
Gliniak 6b56f98672 [XAM/User] Resolved missing profile tab on 12xxx dashboard
It doesn't provide overlap pointer and requires instant response
2019-12-23 18:58:42 +01:00
Gliniak d30e415bc0 [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
2019-12-23 18:57:02 +01:00
Gliniak 4d753faf19 [XAM/Misc] Added stub for: XamIsXbox1TitleId 2019-12-23 09:34:55 +01:00
Cancerous e9c802dfcf added more checks to filter user_index out of range 2019-12-23 09:28:28 +01:00
Gliniak 52ba854e4a [User] Removed hardcode from XPROFILE_GAMERCARD_TITLES_PLAYED
(Now dashboard 9199 shows more reliable amount of games played)
2019-12-23 09:18:56 +01:00
Gliniak ee72ed5a9f [XAM/User] Added checks for user_index -1 (Fixes profile tab in 9199 dashboard)
Thanks Randprint for finding
2019-12-21 22:53:57 +01:00