Difference between revisions of "Configuration Memory"
Line 127: | Line 127: | ||
== UPDATEFLAG == | == UPDATEFLAG == | ||
− | Normally this flag is zero | + | Normally this flag is zero. When the ARM11 kernel is booting it will set this flag to 1, when bit0 from the data which field 0x1FF80016 is loaded from is clear, if the following [[PAD]] buttons are pressed: L, R, A, Up. When this flag is set, the system will launch the [[System_Settings#System_Updater|System Updater]] title instead of displaying the [[Home Menu]]. |
== NSTID == | == NSTID == |
Revision as of 04:37, 14 April 2013
ARM11 Kernel Configuration Memory
NAME | PROCESS VIRTUAL ADDRESS | WIDTH |
---|---|---|
KERNEL_? | 0x1FF80000 | 1 |
KERNEL_VERSIONREVISION | 0x1FF80001 | 1 |
KERNEL_VERSIONMINOR | 0x1FF80002 | 1 |
KERNEL_VERSIONMAJOR | 0x1FF80003 | 1 |
UPDATEFLAG | 0x1FF80004 | 4 |
NSTID | 0x1FF80008 | 8 |
SYSCOREVER | 0x1FF80010 | 4 |
UNITINFO | 0x1FF80014 | 1 |
? | 0x1FF80015 | 1 |
? | 0x1FF80016 | 1 |
KERNEL_CTRSDKVERSION | 0x1FF80018 | 4 |
APPMEMTYPE | 0x1FF80030 | 4 |
APPMEMALLOC | 0x1FF80040 | 4 |
? | 0x1FF80044 | 4 |
? | 0x1FF80048 | 4 |
FIRM_? | 0x1FF80060 | 1 |
FIRM_VERSIONREVISION | 0x1FF80061 | 1 |
FIRM_VERSIONMINOR | 0x1FF80062 | 1 |
FIRM_VERSIONMAJOR | 0x1FF80063 | 1 |
FIRM_SYSCOREVER | 0x1FF80064 | 4 |
FIRM_CTRSDKVERSION | 0x1FF80068 | 4 |
This memory page is read-only for ARM11 processes.
NAME | PROCESS VIRTUAL ADDRESS | WIDTH |
---|---|---|
MENUTID | 0x1FF810A0 | 8 |
ACTIVEMENUTID | 0x1FF810A8 | 8 |
This memory page is normally read-only for ARM11 processes, write-access is determined by the process exheader kernel "Shared page writing" flag.
ARM11 Kernel Config Fields
0x1FF80000 / 0x1FF80060
Unknown, this is normally value 0.
KERNEL_VERSIONREVISION / FIRM_VERSIONREVISION
This is the version-revision for the currently running FIRM.
KERNEL_VERSIONMINOR
This is the version-minor from ((title-version & 0x3FF) >> 4), for the currently running FIRM. The values from KERNEL_VERSIONMINOR and KERNEL_VERSIONMAJOR can be stored in applications' CXI exheader.
FIRM_VERSIONMINOR
This is the same as KERNEL_VERSIONMINOR. After AM:InstallNATIVEFIRM checks FIRM_SYSCOREVER, AM:InstallNATIVEFIRM then compares FIRM_VERSIONMINOR with the NATIVE_FIRM ((title-version & 0x3FF) >> 4), when the latter is larger than FIRM_VERSIONMINOR AM:InstallNATIVEFIRM will trigger a FIRM install.
KERNEL_VERSIONMAJOR / FIRM_VERSIONMAJOR
This is the version-major for the currently running FIRM.
UPDATEFLAG
Normally this flag is zero. When the ARM11 kernel is booting it will set this flag to 1, when bit0 from the data which field 0x1FF80016 is loaded from is clear, if the following PAD buttons are pressed: L, R, A, Up. When this flag is set, the system will launch the System Updater title instead of displaying the Home Menu.
NSTID
This field contains the titleID of the first title to launch from CTR-NAND after the FIRM system processes are loaded. The PM module launches this title. If this field titleID is all-zero, the system will not attempt to launch the title. The regular ARM11 kernel sets this to the regular NS titleID, while the SAFE_MODE ARM11 kernel sets this to the SAFE_MODE NS titleID.
SYSCOREVER
When launching CXIs, the value stored here must match the core version field stored in the CXI exheader. If they do not match, the PM module will refuse to launch the ARM11 process. The regular ARM11 kernel sets this to 0x2, while the SAFE_MODE ARM11 kernel sets this to 0x3.
FIRM_SYSCOREVER
Normally this is the same as SYSCOREVER. This used by AM:InstallNATIVEFIRM for comparing with the NATIVE_FIRM titleID-low. When the low u8 from the NATIVE_FIRM titleID-low is larger than FIRMSYSCOREVER, AM:InstallNATIVEFIRM will trigger FIRM installing. When that u8 is not larger than FIRM_SYSCOREVER, and these two values don't match, AM:InstallNATIVEFIRM will return an error.
UNITINFO
Bit | Description |
---|---|
0 | Clear for dev unit, set for retail.(See 0x1FF80015) |
1 | Set for debug units |
2-7 | ? |
Bit1 in this field is set by the ARM11 kernel when ARM debug CP14 DSCR bit14 is set. NS loads the menu TID from MENUTID when bits 1-7 of this register are clear. ErrDisp will display development error info when bit0 is clear.
0x1FF80015
When this field is zero, bit0 for UNITINFO is set for retail. When this field is non-zero, bit0 for UNITINFO is clear for dev/debug units, and an ARM11 kernel state flag which enables debugging is set.
0x1FF80016
This originates from the low 8-bits of register 0x10010000.
KERNEL_CTRSDKVERSION / FIRM_CTRSDKVERSION
This is the CTR-SDK version which was used to build the currently running FIRM.
APPMEMTYPE
Value | Size |
---|---|
2 | 0x6000000 96MB |
3 | 0x5000000 80MB |
4 | 0x4800000 72MB |
5 | 0x2000000 32MB |
Other values | 0x4000000 64MB (retail) |
The value of this field determines the size for APPMEMALLOC.
APPMEMALLOC
This contains the total size of the memory that can be allocated with the application memory-type. On retail this is 64MB for prod.
0x1FF80044
The size value for this field is: 0x08000000 - (APPMEMALLOC + *0x1FF80048).(Total FCRAM size - APPMEMALLOC - *0x1FF80048)
0x1FF80048
Normally this is value 0x1400000, for size 20MB.
MENUTID
This contains the titleID of the retail menu which will be launched by NS.
ACTIVEMENUTID
This contains the titleID of the currently running menu launched by NS. Normally this is the home menu TID from MENUTID, but if launching that fails this titleID is the alternate menu.(On debug units this is the TID loaded from config)