Michael Scire
8d507aa5a1
kern: implement SvcSignalToAddress, SvcWaitForAddress
2020-07-31 14:50:52 -07:00
Michael Scire
a0cc22302c
kern: add KAddressArbiter::WaitIfEqual
2020-07-31 14:50:52 -07:00
Michael Scire
01a7606f95
kern: implement SvcSetHeapSize
2020-07-31 14:50:52 -07:00
Michael Scire
9c4c058307
kern: implement all device address space svcs
2020-07-31 14:50:52 -07:00
Michael Scire
9beb05da50
kern: retrieve target firmware from exosphere instead of hardcoding
2020-07-31 14:50:52 -07:00
Michael Scire
2ca6772475
kern: implement DetachDeviceAddressSpace, skeleton other das funcs in KDevicePageTable
2020-07-31 14:50:52 -07:00
Michael Scire
0d3aa13f70
kern: add infra (but not impl) for all DeviceAddressSpace svcs
2020-07-31 14:50:52 -07:00
Michael Scire
863515a3b5
kern: qualify inherited KAutoObjectWithListContainer accessor typenames
2020-07-31 14:50:52 -07:00
Michael Scire
fe035736ca
kern: implement SvcGetProcessList
2020-07-31 14:50:52 -07:00
Michael Scire
cfddb75398
kern: add SvcCreateDeviceAddressSpace, SvcAttachDeviceAddressSpace
2020-07-31 14:50:52 -07:00
Michael Scire
04f325cf5a
kern: implement SvcCreateInterruptEvent
2020-07-31 14:50:52 -07:00
Michael Scire
b35380a942
kern: implement SvcCreateEvent, SvcSignalEvent, SvcClearEvent, SvcResetSignal
2020-07-31 14:50:52 -07:00
Michael Scire
93be2ffcba
kern: add SvcCreatePort, SvcConnectToPort
2020-07-31 14:50:52 -07:00
Michael Scire
9f79710cb7
kern: add SvcReadWriteRegister
2020-07-31 14:50:52 -07:00
Michael Scire
ef1763334b
kern: patch svc tables via asm, instead of relying on compiler to be nice
2020-07-31 14:50:52 -07:00
Michael Scire
d9e9fbe3c2
kern: Implement QueryIoMapping logic for < 8.0.0
2020-07-31 14:50:52 -07:00
Michael Scire
ff022115ca
kern: Support older SVC ABIs
2020-07-31 14:50:52 -07:00
Michael Scire
46bd03c06d
fs: correct retry loop again
2020-07-20 13:33:09 -07:00
Michael Scire
9482fafabd
fs: fix retry bug in OpenContentStorageFileSystem
2020-07-20 13:18:48 -07:00
Michael Scire
762db93f4a
libs: add libexosphere to targets
2020-07-20 13:12:43 -07:00
misson20000
9382ff0939
Add stack overflow detection to fatal error code
2020-07-15 20:45:47 -07:00
Michael Scire
c01753370a
ams: update to know about 10.1.0
2020-07-13 17:34:48 -07:00
Michael Scire
18698bf1d3
kern: add SvcQueryIoMapping (NOTE: pre-10.x, ABI needs update)
2020-07-13 13:24:32 -07:00
Michael Scire
57867d6ced
kern: fix/add InfoType_(Total/Used)(NonSystem/)MemorySize
2020-07-13 12:17:28 -07:00
Michael Scire
35c1959131
kern: assert correctness for complete class hierarchy
2020-07-13 11:11:30 -07:00
Michael Scire
a4e3eae4b6
svc/ipc: fix handle count accessors
2020-07-13 11:00:46 -07:00
Michael Scire
84d8634938
kern: fix bugs in Receive/Exchange ipc buffers
2020-07-13 10:02:01 -07:00
Michael Scire
095fc6b996
kern: fix UpdateLock perms for ipc
2020-07-12 22:22:54 -07:00
Michael Scire
bc767742f7
kern: fix unaligned map alias buffers
2020-07-12 18:53:45 -07:00
Michael Scire
e2e5a2ccc2
kern: fix bugs in MapAlias ipc mappings
2020-07-12 18:17:29 -07:00
Michael Scire
a8d4b10b17
kern: implement IPC KPageTable functionality
2020-07-12 15:42:47 -07:00
Michael Scire
3c8d8161cc
kern: fix bug in ToMessageBuffer pointer transfer selection
2020-07-11 02:06:44 -07:00
Michael Scire
4a7ce9dd75
kern/KScheduler: implement special yields
2020-07-11 00:48:26 -07:00
Michael Scire
ca9327a120
kern: implement SvcSleepThread for ns > 0
2020-07-10 23:30:15 -07:00
Michael Scire
f37eda6b86
kern: implement KPageTableBase::CopyHeapToHeap(WithoutCheckDestination)
2020-07-10 21:37:56 -07:00
Michael Scire
c72bdec328
kern: add KPageTableBase::CopyMemory Linear <-> User and Linear <-> Kernel
2020-07-10 20:09:06 -07:00
Michael Scire
4a767c9082
kern: mostly implement thread exit
2020-07-10 18:39:53 -07:00
Michael Scire
c8f71007ec
kern/ipc: fix bug in SendMessage
2020-07-10 16:57:11 -07:00
Michael Scire
4ff10f3ce0
kern/ipc: implement remaining KServerSession reply code
2020-07-10 16:46:55 -07:00
Michael Scire
d52655eaf1
kern: add SvcExitThread, SvcSendAsyncRequestWithUserBuffer, SvcReplyAndReceiveWithUserBuffer
2020-07-10 15:31:23 -07:00
Michael Scire
1b429918de
kern/ipc: implement most of reply
2020-07-10 13:42:36 -07:00
Michael Scire
b29dc76b20
kern/ipc: implement SendReply, declare SendMessage
2020-07-10 12:49:52 -07:00
Michael Scire
4db9d95958
os: fix building with new svc defs
2020-07-10 11:57:40 -07:00
Michael Scire
2ec4ed3568
kern/ipc: add Atmosphere's mitm pid passthrough logic
2020-07-10 11:55:33 -07:00
Michael Scire
4e226b523e
ipc/receive: trivially correct result return codeflow
2020-07-10 11:55:33 -07:00
Michael Scire
9fa6d12586
kern/ipc: finish Receive part of ReplyAndReceive
2020-07-10 11:55:33 -07:00
Michael Scire
804aa0e55d
ipc: add MapAlias processing logic for Receive
2020-07-10 11:55:33 -07:00
Michael Scire
9d57783aa8
ipc::Reply -> implement Pointer handling logic
2020-07-10 11:55:33 -07:00
Michael Scire
a510a1138d
ipc::Reply -> add raw data copy logic
2020-07-10 11:55:33 -07:00
Michael Scire
4e667bc7c1
kern: implement remaining non-KServerSession:: part of Reply/Receive
2020-07-10 11:55:33 -07:00
Michael Scire
84b1be1d58
kern: partially implement Receive half of ReplyAndReceive
2020-07-10 11:55:33 -07:00
Michael Scire
1b2203d102
kern: implement SvcSendSyncRequest(WithUserBuffer)
2020-07-10 11:55:33 -07:00
Michael Scire
4f12449acf
kern: implement SvcArbitrateLock, SvcArbitrateUnlock
2020-07-10 11:55:33 -07:00
Michael Scire
f4fd4cbbb2
kern: skeleton SvcReplyAndReceive
2020-07-10 11:55:33 -07:00
Michael Scire
be98aaa185
kern: partially implement SvcSignalProcessWideKey
2020-07-10 11:55:33 -07:00
Michael Scire
7f4c6ae9e7
kern: implement SvcCreateThread, SvcStartThread
2020-07-10 11:55:33 -07:00
Michael Scire
9503aae522
kern: implement SvcMapMemory
2020-07-10 11:55:33 -07:00
Michael Scire
78da7422ae
kern: implement SvcAcceptSession
2020-07-10 11:55:33 -07:00
Michael Scire
f52232f0f2
kern: implement SvcWaitSynchronization
2020-07-10 11:55:33 -07:00
Michael Scire
16c9c53a4a
kern: implement KEvent, KWritableEvent, KServerSession::OnClientClosed
2020-07-10 11:55:33 -07:00
Michael Scire
d0d8914f28
kern: implement SvcCloseHandle
2020-07-10 11:55:33 -07:00
Michael Scire
7400a8ff68
kern: SvcConnectToNamedPort
2020-07-10 11:55:33 -07:00
Michael Scire
a2eb93fde8
kern: svcOutputDebugString, svcGetThreadPriority, svcGetThreadId
2020-07-10 11:55:33 -07:00
Michael Scire
1a0696f8a3
kern: implement SvcUnmapMemory, more of SvcGetInfo
2020-07-10 11:55:33 -07:00
Michael Scire
faad5609b9
ncm: safer access patterns for FirmwareVariationInfo
2020-07-10 11:49:44 -07:00
Michael Scire
ad551c3b55
ncm: loosen FirmwareVariation restrictions.
2020-07-10 11:46:53 -07:00
VolcaEM
8d6e076b77
ncm: Mark two variables as const ( #1078 )
...
ncm: Mark two variables as const
2020-07-08 21:48:41 -07:00
Michael Scire
9bd6916646
ams: bump version to 0.14.0, add emummc info configitem
2020-07-08 17:36:52 -07:00
Michael Scire
852c039f70
ncm: rights ids were added in 2.0.0
2020-07-08 16:02:47 -07:00
Michael Scire
bffd553b80
sf: correct deprecated spl interface definition
2020-07-08 15:42:15 -07:00
Michael Scire
2d9f5b6942
sf: support service objects which must themselves be shared pointers
2020-07-08 15:07:40 -07:00
Michael Scire
499f29d2f0
ncm: make *ActivateContentMetaDatabase play nice with 1.0.0
2020-07-07 20:00:51 -07:00
SciresM
9fde97cfdd
sf: Change interface definition methodology ( #1074 )
...
* sf: Begin experimenting with new interface declaration format
* sf: convert fs interfaces to new format
* sf: finish conversion of libstrat to new definitions
* sf: convert loader to new format
* sf: convert spl to new format
* sf: update ncm for new format
* sf: convert pm to new format
* sf: convert ro/sm to new format
* sf: update fatal for new format
* sf: support building dmnt under new scheme
* sf: update ams.mitm for new format
* sf: correct invocation def for pointer holder
* fs: correct 10.x+ user bindings for Get*SpaceSize
2020-07-07 17:07:23 -07:00
Michael Scire
b08ccd7341
exo: fixes, now tested working on mariko hardware
2020-07-02 14:06:42 -07:00
Michael Scire
0a53c74aad
libstrat: fix bugs/compiler warnings
2020-07-02 14:02:50 -07:00
Michael Scire
70e67da1e1
fs: use access_log for other user fs/dir/file bindings
2020-07-02 14:02:50 -07:00
Michael Scire
e2b17086d4
fs: implement AccessLog, enable for File operations
2020-07-02 14:02:50 -07:00
Michael Scire
828b170aac
exo: add mariko spare reg write during setup
2020-06-29 05:40:09 -07:00
Michael Scire
e16b87c843
exo: implement mariko fuse driver
2020-06-29 04:40:59 -07:00
Michael Scire
2a5d1572e1
libstrat: correct firmware comparison in meta database builder
2020-06-29 04:40:01 -07:00
Michael Scire
bf92daf055
exo: implement remaining SE changes for mariko support
2020-06-28 21:11:29 -07:00
Michael Scire
5cb9fa510e
exo: implement mariko se/tzram context save
2020-06-28 20:32:45 -07:00
Michael Scire
46c460e235
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "89f8944f"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "89f8944f"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-06-28 19:41:42 -07:00
Michael Scire
29f1eb8070
libstrat: fix dependencies for pre-compiled header
2020-06-28 19:40:56 -07:00
Michael Scire
1473adf5c4
fusee/exo: correct device key management for newer consoles ( closes #1053 )
2020-06-28 05:39:25 -07:00
Michael Scire
a5447dd72d
fs: more IndirectStorage::OperatePerEntry updates/fixes
2020-06-28 02:52:02 -07:00
Michael Scire
ecbd986529
sysupdater: minor api fixes (now verified working on hardware)
2020-06-28 01:46:51 -07:00
Michael Scire
73a6aeed15
sysupdater: implement (untested) rest of the api
2020-06-28 01:46:51 -07:00
Michael Scire
f223c27bb0
sysupdater: Add ValidateUpdate, begin implementing Async logic
2020-06-28 01:46:51 -07:00
Michael Scire
3324dd52ef
sysupdater: make GetUpdateInformation work on hardware.
2020-06-28 01:46:51 -07:00
Michael Scire
a6218ed814
sysupdater: implement content meta mounting
2020-06-28 01:46:51 -07:00
Michael Scire
28a6bb713c
sysupdater: begin implementing api
2020-06-28 01:46:51 -07:00
Michael Scire
f197b88dd7
fs: update IndirectStorage for 10.x, bugfixes
2020-06-25 17:36:05 -07:00
Michael Scire
f594de0081
ams: add -Wno-format-truncation to flags
2020-06-25 17:32:34 -07:00
Adubbz
9003ad6e49
ncm: fix exfat system updates
2020-06-22 16:15:56 -07:00
Michael Scire
22ae311393
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "cf8f0c3c"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "cf8f0c3c"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-06-14 22:59:53 -07:00
Michael Scire
033ae1dbe0
ams: fix comment warn
2020-06-14 22:59:12 -07:00
Michael Scire
2ed7f84523
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "adf5cd34"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "adf5cd34"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-06-14 22:55:18 -07:00
Michael Scire
a680b35e09
hos: fix c/p error'
2020-06-14 22:53:39 -07:00
Michael Scire
d236b88571
hos: be a little friendlier about versioning
2020-06-14 22:50:08 -07:00
Michael Scire
c129256dd0
exo: amend pk21 restrictions
2020-06-14 22:07:45 -07:00
Michael Scire
d165ec7162
stratosphere: fix command availability to include minor versions
2020-06-14 22:07:45 -07:00
Michael Scire
79e4c0ef6e
exo2: add security checks, full 2.0.0 support
2020-06-14 22:07:45 -07:00
Michael Scire
37d13f92a8
ams: bump to 0.13.0, add 10.0.4 recognition
2020-06-14 22:07:45 -07:00
Michael Scire
6780b096ca
exo2: address volca review commentary
2020-06-14 22:07:45 -07:00
Michael Scire
293c213bf2
exo2: implement warmboot firmware
2020-06-14 22:07:45 -07:00
Michael Scire
6c145d76c7
exo2: implement SmcIramCopy/reboot to payload/rcm
2020-06-14 22:07:45 -07:00
Michael Scire
bb6671a94a
exo2: implement SmcReencryptDeviceUniqueData
2020-06-14 22:07:45 -07:00
Michael Scire
95d38a1a94
exo2: suspend fixes (sleep/wake now works on hardware)
2020-06-14 22:07:45 -07:00
Michael Scire
2fb363dcf0
exo2: implement the rest of cpu suspend (security checks TODO)
2020-06-14 22:07:45 -07:00
Michael Scire
34098f7215
exo2: add sc7fw load, skeleton rest of suspend
2020-06-14 22:07:45 -07:00
Michael Scire
0202a95832
exo2: implement the first half of SmcCpuSuspend
2020-06-14 22:07:45 -07:00
Michael Scire
068c25ce66
exo2: add a number of minor configuration fixes
2020-06-14 22:07:45 -07:00
Michael Scire
8e401f4daa
exo2: implement smc cpu off
2020-06-14 22:07:45 -07:00
Michael Scire
ccba70abfe
exo2: implement SmcPrepareEsDeviceUniqueKey, SmcPrepareEsCommonTitleKey, SmcLoadPreparedAesKey
2020-06-14 22:07:45 -07:00
Michael Scire
1e0124fb67
exo2: fix bugs in device unique data decrypytion
2020-06-14 22:07:45 -07:00
Michael Scire
91e0bbd9d7
exo2: Implement (untested) SmcDecryptDeviceUniqueData
2020-06-14 22:07:45 -07:00
Michael Scire
4fe42eb997
exo2: implement some mariko TODOs
2020-06-14 22:07:45 -07:00
Michael Scire
99e0448f30
exo2: cache soc type/hardware type for quick lookup
2020-06-14 22:07:45 -07:00
Michael Scire
a0b08d0540
exo2: fix bugs in Cmac and DeviceId calculation
2020-06-14 22:07:45 -07:00
Michael Scire
aa50944568
exo2: tentative (read: bugged) SmcComputeCmac, SmcGenerateSpecificAesKey, SmcGetSecureData
2020-06-14 22:07:45 -07:00
Michael Scire
e0dbfc69a8
exo2: implement SmcComputeAes, SmcGetResult, SmcGetResultData
2020-06-14 22:07:45 -07:00
Michael Scire
bf546d5fb3
exo2: implement SmcGenerateAesKek, SmcLoadAesKey
2020-06-14 22:07:45 -07:00
Michael Scire
6bf283ec2e
exo2: implement SmcGetConfig
2020-06-14 22:07:45 -07:00
Michael Scire
e3eadcd2e3
exo2: Implement SmcReadWriteRegister
2020-06-14 22:07:45 -07:00
Michael Scire
8c4c1db506
exo2: minor fixes, now completes main and receives SMCs on hw
2020-06-14 22:07:45 -07:00
Michael Scire
27843314a4
exo2: minor stack/mmu fixes, now gets to main on hw
2020-06-14 22:07:45 -07:00
Michael Scire
3d6baf96a3
exo2: implement SmcPowerCpuOn
2020-06-14 22:07:45 -07:00
Michael Scire
ab703646d5
exo2: by default, map end of iram for debug
2020-06-14 22:07:45 -07:00
Michael Scire
b7ff9e8fcc
exo2: reorganize to save >0x300 bytes and 0x100 of stack in main
2020-06-14 22:07:45 -07:00
Michael Scire
ad664daea5
exo2: implement remainder of warmboot tz code
2020-06-14 22:07:45 -07:00
Michael Scire
dc6abf9f68
exo2: Implement the rest of main/return-to-el1
2020-06-14 22:07:45 -07:00
Michael Scire
87bdc46beb
exo2: implement rest of main other than SetupSocProtections
2020-06-14 22:07:45 -07:00
Michael Scire
f391354415
exo2: implement through package2 decryption
2020-06-14 22:07:45 -07:00
Michael Scire
9ddcbe9dc3
exo2: implement main through sync-for-pk21-load
2020-06-14 22:07:45 -07:00
Michael Scire
e11fad6598
exo2: implement through boot config load/validate
2020-06-14 22:07:45 -07:00
Michael Scire
cbcd1d87fb
exo2: implement through end of random cache init
2020-06-14 22:07:45 -07:00
Michael Scire
f66b41c027
exo2: Initial work on the exosphere rewrite.
...
exo2: Implement uncompressor stub and boot code up to Main().
exo2: implement some more init (uart/gic)
exo2: implement more of init
exo2: improve reg api, add keyslot flag setters
exo2: implement se aes decryption/enc
exo2: fix bugs in loader stub/mmu mappings
exo2: start skeletoning bootconfig/global context types
arch: fix makefile flags
exo2: implement through master key derivation
exo2: implement device master keygen
exo2: more init through start of SetupSocSecurity
exo2: implement pmc secure scratch management
se: implement sticky bit validation
libexosphere: fix building for arm32
libexo: fix makefile flags
libexo: support building for arm64/arm
sc7fw: skeleton binary
sc7fw: skeleton a little more
sc7fw: implement all non-dram functionality
exo2: fix DivideUp error
sc7fw: implement more dram code, fix reg library errors
sc7fw: complete sc7fw impl.
exo2: skeleton the rest of SetupSocSecurity
exo2: implement fiq interrupt handler
exo2: implement all exception handlers
exo2: skeleton the entire smc api, implement the svc invoker
exo2: implement rest of SetupSocSecurity
exo2: correct slave security errors
exo2: fix register definition
exo2: minor fixes
2020-06-14 22:07:45 -07:00
Michael Scire
80e49696ea
ams: update for 10.0.3
2020-05-25 19:33:21 -07:00
Michael Scire
f215da3b37
fs: miscellaneous bucket tree fixes
2020-05-19 09:48:44 -07:00
Michael Scire
de9a3c6dfc
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "797dfa78"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "797dfa78"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-05-18 08:22:36 -07:00
Adubbz
79ae47f028
ncm: implement firmware downgrading ( #958 )
...
* ncm: implement firmware downgrading
* ncm: make storage list const
2020-05-18 08:03:38 -07:00
Michael Scire
19d8a0fc2b
os: use ported libnx mutex impl
2020-05-17 23:20:21 -07:00
Michael Scire
c8e5461e3f
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "bbbe6793"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "bbbe6793"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-05-14 02:22:58 -07:00
Michael Scire
53a47e07fd
nca-pr: update for c++20
2020-05-14 02:22:24 -07:00
Michael Scire
311d2678c7
git subrepo push libraries
...
subrepo:
subdir: "libraries"
merged: "b38939ad"
upstream:
origin: "https://github.com/Atmosphere-NX/Atmosphere-libs "
branch: "master"
commit: "b38939ad"
git-subrepo:
version: "0.4.1"
origin: "???"
commit: "???"
2020-05-12 15:44:47 -07:00
SciresM
81f91803ec
Implement support for parsing/interacting with NCAs. ( #942 )
...
* fs: implement support for interacting with ncas.
* spl: extend to use virtual keyslots
2020-05-11 15:04:51 -07:00
SciresM
3a1ccdd919
Switch atmosphere's build target to C++20. ( #952 )
...
* ams: update to build with gcc10/c++20
* remove mno-outline-atomics
* ams: take care of most TODO C++20s
* fusee/sept: update for gcc10
* whoosh, your code now uses pre-compiled headers
* make: dependency fixes
2020-05-11 15:02:10 -07:00
Michael Scire
0e289461bb
ams: use psc acknowledge_ex on 5.1.0+ (fixes wake-from-sleep on 5.1.0)
2020-05-06 22:34:34 -07:00
Michael Scire
8e75a4169d
ams: revamp target firmware
2020-05-06 22:29:07 -07:00