Changes

7,528 bytes added ,  08:39, 1 July 2023
m
Line 32: Line 32:  
| [[#Item structure|Items]], each one at an offset specified by "Item offsets"<br/>Unused offsets are zeroed completely
 
| [[#Item structure|Items]], each one at an offset specified by "Item offsets"<br/>Unused offsets are zeroed completely
 
|-
 
|-
| <code>0x3FB0</code> ?
+
| <code>0x3FAE</code> ?
 
| 2 bytes each
 
| 2 bytes each
| [[#Lookup table for settings|Lookup table for specific item names]], 38 entries long. When the value is non-zero, it contains the offset where the item offset is stored (name LUT → item offset → actual item)
+
| [[#Lookup table for settings|Lookup table for specific item names]], 39 entries long. When the value is non-zero, it contains the offset where the item offset is stored (name LUT → item offset → actual item)
 
|-
 
|-
 
| <code>0x3FFC</code>  
 
| <code>0x3FFC</code>  
Line 105: Line 105:  
|}
 
|}
   −
Note that both BIGARRAY and SMALLARRAY store the length (minus one) in the beginning and their actual size must be calculated from there. The name "ARRAY" need not indicate the actual content type; most settings store an application defined structure in them.
+
Note that both BIGARRAY and SMALLARRAY store the length (minus one) in the beginning and their actual size must be calculated from there. The name "ARRAY" need not indicate the actual content type; most settings store an [[#Application-defined structures|application defined structure]] in them.
    
=== Lookup table for settings ===
 
=== Lookup table for settings ===
 
The end of the SYSCONF file acts as lookup table, supposedly to make finding settings easier/quicker. A lookup looks like this:
 
The end of the SYSCONF file acts as lookup table, supposedly to make finding settings easier/quicker. A lookup looks like this:
# Seek 80 bytes (2 bytes per entry, 38 known entries at this point, plus 4 bytes for the <code>SCed</code> marker) backwards from the end of the file and read 76 bytes to obtain the lookup table.
+
# Seek 82 bytes (2 bytes per entry, 39 known entries at this point, plus 4 bytes for the <code>SCed</code> marker) backwards from the end of the file and read 78 bytes to obtain the lookup table.
 
# Read the desired setting offset. In case this value is <code>0x0000</code>, the [[System Menu]] falls back to searching for the entry (otherwise [[Dolphin]] generated SYSCONF files would not work).
 
# Read the desired setting offset. In case this value is <code>0x0000</code>, the [[System Menu]] falls back to searching for the entry (otherwise [[Dolphin]] generated SYSCONF files would not work).
 
# When non-zero, it represents an offset in the Item offset list. Seek to the value read, and read another 2 bytes from there.
 
# When non-zero, it represents an offset in the Item offset list. Seek to the value read, and read another 2 bytes from there.
# Seek to the location indicated by the previous read (which is inside the Item offset list, and exists regardless of whether the lookup table is correct) to find the actual settinng.
+
# Seek to the location indicated by the previous read (which is inside the Item offset list, and exists regardless of whether the lookup table is correct) to find the actual setting.
    
New settings are added at the beginning, supposedly for backwards compatibility.
 
New settings are added at the beginning, supposedly for backwards compatibility.
Line 122: Line 122:  
! File offset
 
! File offset
 
! Setting
 
! Setting
 +
|-
 +
| <code>0x3FAE</code>
 +
| <code>IPL.APD</code>
 
|-
 
|-
 
| <code>0x3FB0</code>
 
| <code>0x3FB0</code>
Line 127: Line 130:  
|-  
 
|-  
 
| <code>0x3FB2</code>
 
| <code>0x3FB2</code>
| <code>IPL.TID</code>?
+
| <code>IPL.TID</code>
 
|-  
 
|-  
 
| <code>0x3FB4</code>
 
| <code>0x3FB4</code>
Line 169: Line 172:  
|-  
 
|-  
 
| <code>0x3FCE</code>
 
| <code>0x3FCE</code>
| <code>NET.WCPC</code>?
+
| <code>NET.WCPC</code>
 
|-  
 
|-  
 
| <code>0x3FD0</code>
 
| <code>0x3FD0</code>
Line 184: Line 187:  
|-  
 
|-  
 
| <code>0x3FD8</code>
 
| <code>0x3FD8</code>
| <code>IPL.SND</code>?
+
| <code>IPL.SND</code>
 
|-  
 
|-  
 
| <code>0x3FDA</code>
 
| <code>0x3FDA</code>
Line 257: Line 260:  
| BT.CDIF
 
| BT.CDIF
 
| BIGARRAY
 
| BIGARRAY
| 0x205
+
| 0x207
| ?
+
| [[#BT.CDIF|struct]]
| ?
+
| List of something connected/paired (?) to the system
 
|-
 
|-
 
| BT.DINF
 
| BT.DINF
 
| BIGARRAY
 
| BIGARRAY
| 0x461
+
| 0x463
| Bluetooth Addresses plus Device Names
+
| [[#BT.DINF|struct]]
 
| List of Wiimotes "synced" to the system
 
| List of Wiimotes "synced" to the system
 
|-
 
|-
Line 294: Line 297:  
! Values  
 
! Values  
 
! Description  
 
! Description  
 +
|-
 +
| IPL.APD
 +
| LONG
 +
| 4
 +
| 0, 60, 120, ..., 720
 +
| Auto power-down (minutes, 0=never). Only used on the [[vWii]] and PAL [[Wii mini]].
 
|-
 
|-
 
| IPL.AR
 
| IPL.AR
Line 302: Line 311:  
|-
 
|-
 
| IPL.ARN
 
| IPL.ARN
| ?
+
| BYTE
| ?
+
| 1
| ?
+
| 0 = Off, 1 = On
| ?
+
| "Auto Run mode".
 
|-
 
|-
 
| IPL.CB
 
| IPL.CB
Line 357: Line 366:  
| IPL.IDL
 
| IPL.IDL
 
| SMALLARRAY
 
| SMALLARRAY
| 3
+
| 0x03
| 0 = off, 1 = on<br/>0 = off, 1 = dim, 2 = bright
+
| [[#IPL.IDL|struct]]
 
| WiiConnect24 standby settings (Standby connection, Slot illumination)
 
| WiiConnect24 standby settings (Standby connection, Slot illumination)
 
|-
 
|-
Line 369: Line 378:  
| IPL.NIK
 
| IPL.NIK
 
| SMALLARRAY
 
| SMALLARRAY
| 0x16
+
| 0x17
| struct:<br/>UTF16BE string, max. 10 characters, zero-padded<br/>Last byte = string length of the nickname
+
| [[#IPL.NIK|struct]]
 
| Console Nickname
 
| Console Nickname
 
|-
 
|-
 
| IPL.PC
 
| IPL.PC
 
| SMALLARRAY
 
| SMALLARRAY
| 0x4A
+
| 0x4B
| struct
+
| [[#IPL.PC|struct]]
 
| Parental Controls
 
| Parental Controls
 
|-
 
|-
Line 387: Line 396:  
| IPL.SADR
 
| IPL.SADR
 
| BIGARRAY
 
| BIGARRAY
| 0x1008
+
| 0x100A
| lots
+
| [[#IPL.SADR|struct]]
| "Simple Address" Contains some region info<br/>Offset 0 is a [[Country Codes|Country Code]] and offset 1 seems to be a more localized region code.
+
| "Simple Address"
 
|-
 
|-
 
| IPL.SND
 
| IPL.SND
Line 404: Line 413:  
|-
 
|-
 
| IPL.TID
 
| IPL.TID
| ?
+
| LONGLONG
| ?
+
| 8
| ?
+
| Title ID or 0
| Unknown system setting?
+
| ID of the temporarily installed title for the SD channel feature. Set to 0 after erasing the title.
 
|-
 
|-
 
| IPL.UPT
 
| IPL.UPT
 
| BYTE
 
| BYTE
 
| 1
 
| 1
| 2,?
+
| 0 = None, 1 = Disc, 2 = Net
 
| Update Type
 
| Update Type
 
|}
 
|}
Line 434: Line 443:  
| BYTE
 
| BYTE
 
| 1
 
| 1
| 0
+
| 0 = JPN, 1 = USA, 2 = EUR, 3 = AUS, 4 = BRA, 5 = TWN, 6 = KOR, 7 = HKG, 8 = ASI, 9 = LTN, 10 = SAF, 11 = CHN
| ?
+
| Boot IRDC Code
 
|-
 
|-
 
| DEV.DSM
 
| DEV.DSM
Line 446: Line 455:  
| BYTE
 
| BYTE
 
| 1
 
| 1
| ?
+
| 0 = NTSC, 1 = PAL
| ?
+
| Boot IRDV Mode
 
|-
 
|-
 
| DVD.CNF
 
| DVD.CNF
 
| BYTE
 
| BYTE
 
| 1
 
| 1
| ?
+
| [[#DVD.CNF|struct]]
| DVD Config?
+
| DVD Config
 
|-
 
|-
 
| MPLS.MOVIE
 
| MPLS.MOVIE
 
| BYTE
 
| BYTE
 
| 1
 
| 1
| 0 = Watched, 1 = Not Watched
+
| 0 = Not Watched, 1 = Watched
 
| Wii Motion Plus Tutorial Movie
 
| Wii Motion Plus Tutorial Movie
 
|-
 
|-
Line 486: Line 495:  
|-
 
|-
 
| NET.WCPC
 
| NET.WCPC
| LONG
+
| BOOL
| 4
+
| 1
| ?
+
| always <code>FALSE</code>?
 
| WiiConnect24 Parental control flags?
 
| WiiConnect24 Parental control flags?
 
|-
 
|-
Line 498: Line 507:  
|}
 
|}
   −
[[Category:Wii Filesystem]]
+
== Application-defined structures ==
 +
Most SMALLARRAY and BIGARRAY values follow an application-defined structure to store data in a structured way. The type SMALLARRAY or BIGARRAY gives no indication of what kind of data is stored, only that it may not exceed 255 or 65535 bytes in size.
 +
 
 +
=== BT.CDIF ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x0000</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Array Size (minus 1); here: <code>0x0204</code> for 0x0205 bytes
 +
|-
 +
| <code>0x0002</code>
 +
| Byte
 +
| <code>0x0001</code>
 +
| Number of ? devices
 +
|-
 +
| <code>0x0003</code>
 +
| ?
 +
| <code>0x0056</code>
 +
| Entry: <code>{u8 bdaddr[6]; char name[64]; u8 unk[16]}</code>
 +
|-
 +
| <code>0x0059</code>
 +
| until
 +
| <code>0x0207</code>
 +
| Repeats up to a total of 6 entries.
 +
|}
 +
 
 +
=== BT.DINF ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x0000</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Array Size (minus 1); here: <code>0x0460</code> for 0x0461 bytes
 +
|-
 +
| <code>0x0002</code>
 +
| Byte
 +
| <code>0x0001</code>
 +
| Number of registered Wiimotes
 +
|-
 +
| <code>0x0003</code>
 +
| MAC Address
 +
| <code>0x0006</code>
 +
| Bluetooth MAC Address of registered/known Wiimote No. 1
 +
|-
 +
| <code>0x0009</code>
 +
| ASCII String
 +
| <code>0x0040</code>
 +
| Zero-terminated Device Name of registered/known Wiimote No. 1
 +
|-
 +
| <code>0x0049</code>
 +
| until
 +
| <code>0x02BE</code>
 +
| Repeats up to a total of 10 entries.
 +
|-
 +
| <code>0x02BF</code>
 +
| MAC Address
 +
| <code>0x0006</code>
 +
| Bluetooth MAC Address of active Wiimote No. 1 (only set at runtime, when a Wiimote is actually connected)
 +
|-
 +
| <code>0x02C5</code>
 +
| ASCII String?
 +
| <code>0x0040</code>
 +
| Zero-terminated Device Name of active Wiimote No. 1? Usually empty, probably doesn't matter (but reuses the same struct as registered Wiimotes)
 +
|-
 +
| <code>0x0305</code>
 +
| until
 +
| <code>0x0463</code>
 +
| Repeats up to a total of 6 entries.
 +
|}
 +
 
 +
=== DVD.CNF ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x00</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Video mode
 +
|-
 +
| <code>0x01</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Parental Control Level
 +
|-
 +
| <code>0x02</code>
 +
| Short
 +
| <code>0x02</code>
 +
| Parental Control Country
 +
|}
 +
 
 +
=== IPL.IDL ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x00</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Array Size (minus 1); here: <code>0x01</code> for 0x02 bytes
 +
|-
 +
| <code>0x01</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Standby connection (0 = off, 1 = on)
 +
|-
 +
| <code>0x02</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Slot illumination (0 = off, 1 = dim, 2 = bright)
 +
|}
 +
 
 +
=== IPL.NIK ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x00</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Array Size (minus 1); here: <code>0x15</code> for 0x16 bytes
 +
|-
 +
| <code>0x01</code>
 +
| UTF16BE String
 +
| <code>0x14</code>
 +
| Console Nickname, max. 10 characters (padded with 0x00 at the end)
 +
|-
 +
| <code>0x15</code>
 +
| Word
 +
| <code>0x02</code>
 +
| Actual string length of the Console Nickname
 +
|}
 +
 
 +
=== IPL.PC ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x00</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Array Size (minus 1); here: <code>0x49</code> for 0x4A bytes
 +
|-
 +
| <code>0x01</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Are parental controls enabled? (0x00 = off, 0x80 = on)
 +
|-
 +
| <code>0x02</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Organization
 +
|-
 +
| <code>0x03</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| Highest game rating allowed (value equals minimum age; 0x14 = 20 years/up = no restriction)
 +
|-
 +
| <code>0x04</code>
 +
| ASCII String
 +
| <code>0x04</code>
 +
| PIN, not delimited by a null-terminator, exactly 4 digits
 +
|-
 +
| <code>0x08</code>
 +
| Byte
 +
| <code>0x01</code>
 +
| [[#Secret Questions|Secret Question]] (in case you forget your PIN)<br/>Always 0x00 on Wii U
 +
|-
 +
| <code>0x09</code>
 +
| UTF16BE String
 +
| <code>0x40</code>
 +
| Answer, max. 32 characters (padded with 0x00 at the end)<br/>Always "Nintendo" on Wii U
 +
|-
 +
| <code>0x49</code>
 +
| Word
 +
| <code>0x02</code>
 +
| Actual string length of the Answer
 +
|}
 +
 
 +
==== Secret Questions ====
 +
Questions differ by language. These are the English questions.
 +
{| class="wikitable"
 +
|-
 +
! Question ID
 +
! Question
 +
|-
 +
| 0
 +
| "What is your mother's maiden name?"
 +
|-
 +
| 1
 +
| "What is your place of birth?"
 +
|-
 +
| 2
 +
| "What is your favorite sports team?"
 +
|-
 +
| 3
 +
| "What was your favorite birthday present?"
 +
|-
 +
| 4
 +
| "What's your favorite movie?"
 +
|-
 +
| 5
 +
| "If you could go anywhere, where would you go?"
 +
|}
 +
 
 +
=== IPL.SADR ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x0000</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Array Size (minus 1); here: <code>0x1007</code> for 0x1008 bytes
 +
|-
 +
| <code>0x0002</code>
 +
| Byte
 +
| <code>0x0001</code>
 +
| Country code
 +
|-
 +
| <code>0x0003</code>
 +
| Byte
 +
| <code>0x0001</code>
 +
| Region code
 +
|-
 +
| <code>0x0004</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| City code (where relevant, e.g. [[News Channel]], [[Forecast Channel]])
 +
|-
 +
| <code>0x0006</code>
 +
| UTF16BE String
 +
| <code>0x0080</code>
 +
| Japanese country name
 +
|-
 +
| <code>0x0086</code>
 +
| until
 +
| <code>0x0805</code>
 +
| Repeats up to a total of 16 entries (Japanese, English, German, French, Spanish, Italian, Dutch,<!--Simp. Chinese, Trad. Chinese, Korean, 6 undefined--> 9 undefined).
 +
|-
 +
| <code>0x0806</code>
 +
| UTF16BE String
 +
| <code>0x0080</code>
 +
| Japanese region name
 +
|-
 +
| <code>0x0886</code>
 +
| until
 +
| <code>0x1005</code>
 +
| Repeats up to a total of 16 entries (same order).
 +
|-
 +
| <code>0x1006</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Latitude (N+/S-, measured in increments of 45/8192 degree, allowing up to 180°, though latitude never exceeds 90°)
 +
|-
 +
| <code>0x1008</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Longitude (E+/W-, measured in increments of 45/8192 degree, allowing up to 180°)
 +
|}
 +
 
 +
=== NET.PROF ===
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>?</code>
 +
| Word
 +
| <code>0x0001</code>
 +
| Flags.
 +
|-
 +
| <code>?</code>
 +
| Byte[4]
 +
| <code>0x0004</code>
 +
| IP Address.
 +
|-
 +
| <code>?</code>
 +
| Byte[4]
 +
| <code>0x0004</code>
 +
| IP Netmask.
 +
|-
 +
| <code>?</code>
 +
| Byte[4]
 +
| <code>0x0004</code>
 +
| DNS 1.
 +
|-
 +
| <code>?</code>
 +
| Byte[4]
 +
| <code>0x0004</code>
 +
| DNS 2.
 +
|-
 +
| <code>?</code>
 +
| Char[256]
 +
| <code>0x0100</code>
 +
| Proxy Server Name.
 +
|-
 +
| <code>?</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Proxy Server Port.
 +
|-
 +
| <code>?</code>
 +
| Char[1024]
 +
| <code>0x0400</code>
 +
| Another server name?
 +
|-
 +
| <code>?</code>
 +
| BOOL
 +
| <code>0x0001</code>
 +
| Enabled?
 +
|-
 +
| <code>?</code>
 +
| BOOL
 +
| <code>0x0400</code>
 +
| ?
 +
|-
 +
| <code>?</code>
 +
| BOOL
 +
| <code>0x0001</code>
 +
| ?
 +
|-
 +
| <code>?</code>
 +
| Char[256]
 +
| <code>0x0100</code>
 +
| ?
 +
|-
 +
| <code>?</code>
 +
| Char[128]
 +
| <code>0x0080</code>
 +
| PPPOE Service Name.
 +
|-
 +
| <code>?</code>
 +
| Char[256]
 +
| <code>0x0100</code>
 +
| PPPOE Service User Name.
 +
|-
 +
| <code>?</code>
 +
| Char[256]
 +
| <code>0x0100</code>
 +
| PPPOE Service Password
 +
|}
 +
 
 +
The data is then accessed based on the connection type.
 +
 
 +
==== Wired ====
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x0000</code>
 +
| Word
 +
| <code>0x0001</code>
 +
| Link Type.
 +
|}
 +
 
 +
==== Wireless ====
 +
{| class="wikitable"
 +
|-
 +
! Offset
 +
! Type
 +
! Size
 +
! Value
 +
|-
 +
| <code>0x0000</code>
 +
| Word
 +
| <code>0x0002</code>
 +
| Rate Set.
 +
|-
 +
| <code>0x0002</code>
 +
| Byte
 +
| <code>0x0001</code>
 +
| Configuration Method.
 +
|}
 +
 
 +
{{Navbox filebrowser}}
12

edits