Editing Syscon Hardware

Jump to navigation Jump to search
Warning: You are not logged in. Your IP address will be publicly visible if you make any edits. If you log in or create an account, your edits will be attributed to your username, along with other benefits.

The edit can be undone. Please check the comparison below to verify that this is what you want to do, and then publish the changes below to finish undoing the edit.

Latest revision Your text
Line 1: Line 1:
<div style="float:right">[[File:Syscon CXR713120-203GB DIE (detail).jpg|300px|thumb| Syscon CX'''R7131'''20-203GB DIE (detail)]]<br />[[File:Pyramid Syscon live probing.jpg|300px|thumb|Pyramid Syscon live probing]]</div>
[[Category:Hardware]]
[[File:SYSCON_GEN1.JPG|thumb|Syscon 1st Generation (BGA Packaging)]]
Syscon is the main power controller chip. It is responsible for powering up the various power systems and for configuring and initialising the CELL, RSX and southbridge. It communicates with these devices via seperate SPI busses. There is external access by JTAG (Which appears to have been disabled after factory programming) and Serial.


= Description =
= Nonretail =
The PS3 syscon is the main power controller chip of the PS3. It is responsible for powering up the main 12v rail of the [[Power Supply]] and various power systems by switching different [[Talk:Regulators|voltage regulators]] in the motherboard, and for configuring and initialising the [[CELL BE|BE]], [[RSX]] and [[South Bridge|SB]] via dedicated SPI buses.


The LEDs and buttons of the [[Switch boards|Switch board]] are connected to syscon, as well as the [[Cooling|fan/s]], buzzer, etc.
== CXR713F120A ==
Located on the Communication Processor Board in Reference Tool DECR1000A <br />
JTAG/SPI/UART is not disabled on this models. Pinout should be fairly the same as retail CXR713120-201GB. <br />


The Syscon is a SoC and based on a ARM7TDMI-S (in the [[Mullion]] syscons) or a NEC 78K0R (in the [[Sherwood]] syscons) design. There is external access by "JTAG" (disabled from factory on retail models), an EEPROM programming interface (only on Mullion) and Serial (UART).
= Retail =


<!--// Remote Power ON/OFF (from network, HDMI CEC commands, etc...) is managed by devices connected to the southbridge (ethernet/wifi/BT, HDMI controller, etc...) //-->
== Generation 1: CXR713120-201GB ==
<div style="float:right">[[File:SYSCON_GEN1.JPG|thumb|Syscon 1st Generation (BGA Packaging)]]</div>
Early PS3 : up to including CECHK/DIA-002


== PlayStation system controllers ==
=== Packaging ===


{| class="wikitable" style="font-size:small; line-height:105%"
The first generation of the chip comes in a 200 pin BGA package as per below:
! Production Start Date (<=) || PS2 Mechacon !! PSP Syscon !! PS3 Syscon !! PSVita Syscon !! PS4 Syscon !! Used IC/CPU Core
 
<pre>Ball array, board orientated
 
    T R P N M L K J H G F E D C B A
 
1    M M M M - N N N N N - O O +    1
2  M M M M M @ N N N N N N @ - J J  2
3  - @                        J J  3
4  & -  A A N N N N O O O O  J J  4
5  & +  A A N N N N O O O O  J J  5
6  - -  A A + - + N - + H H  R R  6
7  & #  A A * * # # - + H H  R R  7
8  Q Q  G G * *    - + H H  K K  8
9  Q Q  G G * *        H H  K K  9
10  Q Q  G G # # . + - + F F  K K  10
11  Q B  G G # - & & + ^ F F  K K  11
12  B B  C C C C D D D D F F  E E  12
13  B B  C C C C D D D D F F  E E  13
14  B B                        E E  14
15  B P P I I I $ . $ $ $ $ & - E E  15
16    P P I I I $ . $ $ $ $ & & &    16
 
    T R P N M L K J H G F E D C B A
 
Legend:
* = JTAG
  = N/C
& = Reset & Clock
$ = EEPROM Interface (U15, U16?? Perhaps J15 & J16)
- = Ground
+ = +3.3v
# = +1.8v (U10?? Perhaps J10)
^ = +battery
@ = VDD2, VDD1, VDD0
</pre>
 
=== Pinout ===
 
<div style="height:400px; overflow:auto">
{|class="wikitable"
! Pin # !! Name !! Port !! Description
|-
| T2 || /BE_INT || rowspan="9" | Port M <br />Cell Control Line ||
|-
| R1 || PM7 ||
|-
| R2 || PM6 ||
|-
| P1 || BE_POWGOOD ||
|-
| P2 || /BE_RESET ||
|-
| N1 || BE_SPI_CLK || rowspan="4" | Cell SPI Bus
|-
|-
| <abbr title="GH-001+">10/1999</abbr> || CXP101064 || - || - || - || - || rowspan="2" | Sony SPC970 (100 pin)
| N2 || BE_SPI_DO
|-
|-
| <abbr title="GH-003+">01/2000</abbr> || CXP102064 || - || - || - || -
| M1 || BE_SPI_DI
|-
|-
| <abbr title="GH-015+">09/2000</abbr> || CXP103049 || - || - || - || - || Sony SPC??? (136 pin)
| M2 || /BE_SPI_CS
|-
|-
| style="padding:0px" colspan="7" |
| L4 || PL8 || rowspan="9" | Port N || rowspan="9" | unused
|-
|-
| <abbr title="TMU-001, TMU-002, TA-079, TA-081">08/2004</abbr> || - || BAR''xx'' || - || - || - || NEC <abbr title="D790019">D780032AY</abbr> (78K0/78003xA, 64 pin)
| L5 || PL7
|-
|-
| <abbr title="TA-082, TA-086">07/2005</abbr> || - || B30''x'' || - || - || - || NEC <abbr title="D79F0036">D78F0531</abbr> (78K0/KE2 V2.00, 64 pin)
| K4 || PL6
|-
|-
| <abbr title="TA-085, TA-088, TA-091, TA-094">07/2007</abbr> || - || B40''x'' / 40''xx'' || - || - || - || NEC <abbr title="D79F????">D78F0544</abbr> (78K0/KF2 V2.00, 84 pin)
| K5 || PL5
|-
|-
| <abbr title="TA-090, TA-092, TA-093, TA-095, TA-096, TA-097">07/2008</abbr> || - || 3''xxx'' || - || - || - || NEC <abbr title="D79F????">D78F0534</abbr> (78K0/KE2 V2.00, 64 pin)
| J4 || PL4
|-
|-
| style="padding:0px" colspan="7" |
| J5 || PL3
|-
|-
| <abbr title="GH-023+, XPD-001, XPD-005">03/2003</abbr> || CXR706080 || - || - || - || - || rowspan="3" | Sony SR11 (ARM7TDMI)<br>PS2 (''Dragon''): 164 pin<br>PS3 (''Donkey''): 200 pin
| H4 || PL2
|-
|-
| <abbr title="GH-032+">09/2004</abbr> || CXR716080 || - || CXR713120 || - || -
| H5 || PL1
|-
|-
| <abbr title="GH-061+">07/2007</abbr> || CXR726080 || - || CXR714120 || - || -
| H6 || PL0
|-
|-
| style="padding:0px" colspan="7" |
| A8 || SB_SPI_CLK || rowspan="8" | Port K || rowspan="4" | Southbridge SPI Bus
|-
|-
| 03/2008 || - || - || SW || - || - || NEC <abbr title="D79F0073">D78F11AA</abbr> (78K0R/KH3 V3.40, 128 pin)
| B8 || SB_SPI_DO
|-
|-
| 05/2009 || - || - || SW2 || - || - || NEC <abbr title="D79F0086">D78F11BB</abbr> (78K0R/KH3 V1.00, 128 pin)
| A9 || SB_SPI_DI
|-
|-
| <abbr title="IRT-001, IRT-002, IRS-002, IRS-1001, DOL-1001, DOL-1002">07/2010</abbr> || - || - || - || <abbr title="No official name">"SC"</abbr> || - || NEC <abbr title="No/Matching internal name">D79F0109</abbr> (<abbr title="Mix between 78K0R/KH3 and 78K0R/Kx3-L">78K0R/KH3-L</abbr> V1.00, 121 pin)
| B9 || /SB_SPI_CS
|-
|-
| 06/2011 || - || - || SW3 || - || - || NEC <abbr title="D79F0123">D78F11CC</abbr> (78K0R/KG3 V1.00, 100 pin)
| A10 || SEL2_I2C_SCL ||
|-
|-
| style="padding:0px" colspan="7" |
| B10 || SEL2_I2C_SDA ||
|-
|-
| <abbr title="CVN-001, SAA-001, SAB-001">07/2013</abbr> || - || - ||- || - || C0L || Renesas R5F100PL (RL78/G13 V3.03, 100 pin)
| A11 || ACDC_STBY ||
|-
|-
| <abbr title="USS-1001, USS-1002">08/2013</abbr> || - || - ||- || A0''xxx'' || - || Renesas R5F1ZCRK (RL78/G13 V3.03, 121 pin)
| B11 || PK0 ||
|-
|-
| <abbr title="SAC-001, SAD-001, SAD-002, SAD-003, SAE-001, SAE-002, SAE-003, SAE-004, SAF-004, SAF-006, HAC-001, NVA-001, NVB-003, NVB-004, NVG-001, NVG-002">04/2015</abbr> || - || - ||- || - || C0L2 || Renesas R5F101LL (RL78/G13 V3.03, 64 pin)
| B5 || PJ7 || rowspan="8" | Port J ||
|-
|-
|}
| A5 || DISC_OUT12_SW ||
 
|-
* The SPC900 core was designed by Texas Instruments ([https://www.linkedin.com/in/hirakawa-katsunobu-55b09b2])
| B2 || DISC_OUT8_SW ||
* ''CXP101064'', ''CXP102064'' are similar to CXP97 (''CXP971000'', ''CXP972032'', '''CXP973064''', ''CXP973F064''), the ''CXP103049'' matches no COTS because of its OCD support
|-
** In-Circuit-Emulator: Mitek NICE-SPC970 ([http://www.hitechfacility.co.jp/details.php?id=E0001913]); Debug software: SVD970; Flash programmer: SFP-2
| A2 || DISC_IN ||
* A ''F'' inside the model name specifies that the IC contains flash memory.
|-
** Mass-produced CXR/SW units don't have/use program flash memory for updates, instead an encrypted firmware patch is stored on the data-"EEPROM"
| B3 || SW_10 ||
* CXR7 series uses Sony SR11 CPU (ARM7TDMI)
|-
** Models with public datasheet: ''CXR702080'', ''CXR702F080'', ''CXR704060'' (datasheet: [http://www.alldatasheet.com/datasheet-pdf/pdf/294279/SONY/CXR704060.html 1])
| A3 || SW_0 ||
* Prototype PS3 Syscon's:
|-
** [[CXR713F120A]] Syscon used on (early) pre-release prototypes, e.g. [[CEB-2030]], [[DECR-1000]], [[DEH-H1001-D]], [[DEH-H1000A-E]]
| B4 || SW_8_B ||
** [[DEH-FH1500J-A]] with [[VERTIGO-02]] board and SW series prototype ''[[Media:DEH-FH1500J-A_-_VERTIGO-02_-_Syscon_Hardware.jpg|D79F0073]]''
|-
** [[CBEH-H2001]] with [[SUR-00x#SURTEES-03|SURTEES-03]] board and SW2 series prototype ''D79F0086''
| A4 || SW_8_C ||
** [[DEH-ML00AK-G]] with MPX-001 (Prototype) board and SW3 series prototype ''[[Media:DEH-ML00AK-G_Board_4.jpg|D79F0123]]''
|-
 
| L16 || SW_PCI || rowspan="6" | Port I ||
= PS3 Syscon models =
|-
{| class="wikitable" style="font-size:small; line-height:105%"
| L15 || DISC_CHUCK ||
|-
| M16 || DISC_PHOT_LED ||
|-
| M15 || SW_2 ||
|-
| N16 || DIAG_MODE ||
|-
| N15 || BACKUP_MODE ||
|-
| E6 || /HDMI_INT || rowspan="8" | Port H ||
|-
| D6 || VD_CECI0 ||
|-
| E7 || PH5 ||
|-
| D7 || /RS_POW_FAIL ||
|-
| E8 || /MUL_CHKSTP_IN ||
|-
| D8 || /MUL_TRG_IN ||
|-
| E9 || /SYS_THR_ALRT ||
|-
| D9 || /SB_INT ||
|-
| M11 || SW_ATA || rowspan="8" | Port G ||
|-
| N11 || SW_4_A ||
|-
| M10 || /XDR_FET_VREF ||
|-
| N10 || /XDR_FET_SCK ||
|-
| M9 || BUZZER ||
|-
| N9 || SW_PWM ||
|-
| M8 || FANPWM1 ||
|-
| N8 || FANPWM0 ||
|-
| E10 || /MUL_CHKSTP_OUT || rowspan="8" | Port F ||
|-
| D10 || /MUL_TAG_OUT ||
|-
| E11 || /SB_CGRESET ||
|-
| D11 || /SB_RESET ||
|-
| E12 || BT_WAKEON ||
|-
| D12 || BE_VCS_1.25_ON ||
|-
| E13 || BE_VCS_1.30_ON ||
|-
| D13 || SW_1A ||
|-
| A12 || /EJECT_SW || rowspan="8" | Port E ||
|-
| B12 || /POW_SW ||
|-
| A13 || /SB_EBUS_RESET ||
|-
| B13 || SB_EBUS_BRDY ||
|-
| A14 || PE3 ||
|-
| B14 || VD_CECI1 ||
|-
| A15 || /BE_POW_FAIL ||
|-
| B15 || /POW_FAIL ||
|-
| F13 || SW_5_B || rowspan="8" | Port D ||
|-
| F12 || MK_EN ||
|-
| G13 || BEVRM_VID5 ||
|-
| G12 || BEVRM_VID4 ||
|-
| H13 || BEVRM_VID3 ||
|-
| H12 || BEVRM_VID2 ||
|-
| J13 || BEVRM_VID1 ||
|-
| J12 || BEVRM_VID0 ||
|-
| K13 || SW_HDD || rowspan="8" | Port C ||
|-
| K12 || I2CBUS_EN ||
|-
| L13 || RSXVRM_VID5 ||
|-
| L12 || RSXVRM_VID4 ||
|-
| M13 || RSXVRM_VID3 ||
|-
| M12 || RSXVRM_VID2 ||
|-
| N13 || RSXVRM_VID1 ||
|-
| N12 || RSXVRM_VID0 ||
|-
| T15 || SW_8_A || rowspan="8" | Port B ||
|-
| R14 || SW_7_A ||
|-
| T14 || SW_6 ||
|-
| R13 || SW_1_B ||
|-
| T13 || SW_4_B ||
|-
| R12 || SW_3 ||
|-
| T12 || VD_CECO1 ||
|-
| R11 || VD_CECO0 ||
|-
| N7 || STBY_LED || rowspan="8" | Port A ||
|-
| M7 || POW_LED ||
|-
| N6 || /AUDIO_MUTE ||
|-
| M6 || SW_7_B ||
|-
| N5 || /BT_RESET ||
|-
| M5 || /GBE_RESET ||
|-
| N4 || SW_5_A ||
|-
| M4 || SW_9 ||
|-
| U16 || RBB || rowspan="12" | EEPROM Interface ||
|-
| K16 || PI7 ||
|-
| U15 || WCB ||
|-
| K15 || PI6 ||
|-
| E16 || SKB ||
|-
| E15 || PP3 ||
|-
| G16 || DI ||
|-
| G15 || PP2 ||
|-
| H16 || DO ||
|-
| H15 || PP1 ||
|-
| F16 || CSB ||
|-
| F15 || PP0 ||
|-
| H11 || TESTMODE || rowspan="9" | Reset & Clock ||
|-
| B16 || OSCOUT ||
|-
| C16 || OSCIN ||
|-
| D16 || 32KOUT ||
|-
| D15 || 32KIN ||
|-
| T5 || EXTAL ||
|-
| T4 || XTAL ||
|-
| T7 || XXTALO ||
|-
| J11 || /RST ||
|-
| R4 || AVSUO || rowspan="35" | Power Port || Ground
|-
| R5 || AVDUO || +3.3v
|-
| G6 || AVSS || Ground
|-
| C2 || AVREF2 || Ground
|-
| B1 || AVREF1 || +3.3v
|-
| F7 || AVDD || +3.3v
|-
| K11 || VSSF || Ground
|-
| K6 || VSSF || Ground
|-
| L6 || VDDF || +3.3v
|-
| G7 || rowspan="8" | VSS || rowspan="8" | Ground
|-
| G8
|-
| G10
|-
| T6
|-
| R6
|-
| T3
|-
| L1
|-
| E1
|-
| C15 || VSSep || Ground
|-
| G11 || VDDep || +3.3v
|-
| F11 || VDDbat || +battery
|-
| H7 || rowspan="7" | DVDD || rowspan="7" | +1.8v
|-
| U10
|-
| K10
|-
| L10
|-
| L11
|-
| R7
|-
| J7
|-
| F8 || rowspan="5" | VDD3 || rowspan="5" | +3.3v
|-
| F10
|-
| H10
|-
| J6
|-
| F6
|-
| D2 || VDD2 || +1.5V_RSX_VDDIO
|-
| R3 || VDD1 || +1.2V_MC2_VDDIO
|-
| L2 || VDD0 || +1.2V_MC2_VDDIO
|-
| A16 || rowspan="6" colspan="3"| NC
|-
| T16
|-
| T1
|-
| A1
|-
| G9
|-
| F9
|-
| L8 || JRTCK || rowspan="6" | JTAG Interface ||
|-
| K8 || JTCK ||
|-
| K9 || JTDO ||
|-
| L9 || JTMS ||
|-
| K7 || JTDI ||
|-
| L7 || JNTAST ||
|-
| A6 || PR3 || rowspan="4" | Port R ||
|-
| B6 || MC_P_OFF_REQ ||
|-
| A7 || MC_ALIVE ||
|-
| B7 || MC_RESERVED1 ||
|-
| R10 || RMC_IN || rowspan="7" | Port Q ||
|-
| T11 || PQ5 ||
|-
| T10 || PQ4 ||
|-
| T8 || SEL2_IEC_SCL ||
|-
|-
! colspan="10" | [[Mullion]] [[Syscon Hardware|Syscons]] !! rowspan="13" style="padding:1px" | !! colspan="8" | [[SKU Models|PS3 model]] & [[Motherboard Revisions|Motherboard]] compatibility by [[Platform ID]]
| T9 || SEL2_I2C_SDA ||
|-
|-
! Model !! [[Syscon Firmware|Rev.]] !! [[Syscon Firmware|Ver.]] !! <abbr title="Syscon Firmware build date">Year</abbr> !! Package !! ROM !! FLASH !! colspan="2" | [[SC_EEPROM|EEPROM]] !! RAM
| R9 || PQ1 ||
! DEH-R10xx<br>[[DECR-1000]] !! [[SKU Models Nonretail|Prototypes]] !! [[CECHAxx]]<br>[[CECHBxx]] !! [[CECHCxx]]<br>[[CECHExx]] !! [[CECHGxx]] !! [[CECHHxx]] !! [[CECHJxx]]<br>[[CECHKxx]] !! [[DECR-1400]]
|-
|-
! style="width:115px; border-top:hidden" | !! style="width:35px; border-top:hidden" | !! style="width:55px; border-top:hidden" | !! style="width:30px; border-top:hidden" | !! style="width:60px; border-top:hidden" | !! style="width:40px; border-top:hidden" | !! style="width:40px; border-top:hidden" | !! style="width:35px" | Total !! style="width:35px" | Used !! style="width:35px; border-top:hidden" |
| R8 || RSX_FBVDD_SEL ||
! [[TMU-510]]<br>[[TMU-520]] !! <!--[[MPU-501]]<br>-->[[COOKIE-13]]<br>[[COK-001 (Prototype)|COK Proto]] !! [[COK-001]] !! [[COK-002]] !! [[SEM-001]] !! [[DIA-001]] !! [[DIA-002]] !! [[DEB-001]]
|-
|-
| colspan="18" style="padding:1px" |  
| P16 || UART0_TxD || rowspan="4" | Port P || Serial Transmit
|-
|-
! [[CXR713F120A]]
| P15 || UART0_RxD || Serial Receive
| colspan="3" style="text-align:center; background:#999; color:#fff" | <abbr title="Depends of the syscon firmware version installed in it">ANY</abbr> || rowspan="8" | [[Template:Syscon pinout BGA 200 pads|BGA 200]] || <abbr title="0x20000>128KB</abbr> || <abbr title="0x60000>384KB</abbr> || rowspan="4" | <abbr title="0x8000>32KB</abbr> || rowspan="3" | <abbr title="0x8000>32KB</abbr> || rowspan="8" | <abbr title="0x10000>64KB</abbr> || {{yes}}, factory || {{yes}}, factory || {{YES}} || {{YES}} || {{YES}} || {{YES}} || {{YES}} || {{YES}}
|-
|-
! [[CXR713120-201GB]]
| R16 || SEL1_I2C_SCL ||
| 0B8E || v1.0.0_k1 || 2006 || rowspan="7" | <abbr title="0x60000>384KB</abbr> || rowspan="7" style="text-align:center; background:lightgrey;" | N/A || {{YES}} ? || {{YES}} ? || {{yes}}, factory || {{no}} || {{no}} || {{no}} || {{no}} || {{no}}
|-
|-
! [[CXR713120-202GB]]
| R15 || SEL1_I2C_SDA ||
| 0C16 || v1.1.3_k1 || 2006 || {{YES}} ? || {{YES}} ? || {{YES}} || {{yes}}, factory || {{no}} || {{no}} || {{no}} || {{no}}
|-
|-
! [[CXR713120-203GB]]
| D1 || SEL0_I2C_SCL || rowspan="10" | Port O
| 0D52 || v1.2.3_k1 || 2007 || rowspan="5" | <abbr title="0x5000>20KB</abbr> || {{YES}} ? || {{YES}} ? || {{YES}} || {{YES}} || {{yes}}, factory || {{no}} || {{no}} || {{no}}
|-
|-
! [[CXR714120-301GB]]
| C1 || SEL0_I2C_SDA ||
| 0DBF || v1.3.3_k1 || 2007 || rowspan="4" | <abbr title="0x5000>20KB</abbr> || {{YES}} ? || {{YES}} ? || {{YES}} || {{yes}}, <abbr title="Found in a CECHE01 MG (Metal Gear Solid 4 edition)">rare</abbr> || {{yes}}, factory || {{yes}}, factory || {{no}} || {{no}}
|-
|-
! [[CXR714120-302GB]]
| G4 || PO7 ||
| 0E69 || v1.4.4_k2 || 2007 || {{YES}} ? || {{YES}} ? || {{YES}} || {{YES}} || {{YES}} || {{YES}} || {{yes}}, factory || {{yes}}, factory
|-
|-
! [[CXR714120-303GB]]
| F4 || HDMI_RST0 ||
| 0F29 || v1.5.0_k2 || 2009 || {{YES}} ? || {{YES}} ? || {{YES}} || {{yes}}, <abbr title="Found in a refurbished CECHCxx/COK-002 with a 65nm RSX">refurb</abbr> || {{YES}} || {{YES}} || {{YES}} || {{YES}}
|-
|-
! [[CXR714120-304GB]]
| G5 || PO5 ||
| 0F38 || v1.5.1_k2 || 2010 || {{YES}} ? || {{YES}} ? || {{yes}}, <abbr title="Found in a refurbished CECHAxx/COK-001 with a 40nm RSX">refurb</abbr> || {{YES}} || {{YES}} || {{yes}}, <abbr title="Found in a refurbished CECHHxx/DIA-001 with a 40nm RSX">refurb</abbr> || {{YES}} || {{YES}}
|}
 
{| class="wikitable" style="font-size:small; line-height:105%"
|-
|-
! colspan="10" | [[Sherwood]] [[Syscon Hardware|Syscons]] !! rowspan="17" style="padding:1px" | !! colspan="10" | [[SKU Models|PS3 model]] & [[Motherboard Revisions|Motherboard]] compatibility by [[Platform ID]]
| F5 || DISC_IN_MECHA ||
|-
|-
! Model !! [[Syscon Firmware|Rev.]] !! [[Syscon Firmware|Ver.]] !! <abbr title="Syscon Firmware build date">Year</abbr> !! Package !! ROM !! FLASH !! colspan="2" | [[SC_EEPROM|EEPROM]] !! RAM
| E4 || EJECT_MECHA ||
! [[SKU Models Nonretail|Prototypes]] !! [[CECHLxx]]<br>[[CECHMxx]]<br>[[CECHPxx]]<br>[[CECHQxx]] || [[SKU Models Nonretail|Prototypes]] || [[CECH-20xx]] !! [[CECH-21xx]] !! [[CECH-25xx]] !! [[SKU Models Nonretail|Prototypes]] || [[CECH-30xx]] !! [[CECH-40xx]] !! [[CECH-42xx]]<br>[[CECH-43xx]]
|-
|-
! style="width:115px; border-top:hidden" | !! style="width:35px; border-top:hidden" | !! style="width:55px; border-top:hidden" | !! style="width:30px; border-top:hidden" | !! style="width:60px; border-top:hidden" | !! style="width:40px; border-top:hidden" | !! style="width:40px; border-top:hidden" | !! style="width:35px" | Total !! style="width:35px" | Used !! style="width:35px; border-top:hidden" |
| D4 || /XDR_FET_RST ||
! [[VERTIGO-02|VERTIGO]]<br><small>prototype</small> !! [[VER-001]] !! [[SUR-00x#SURTEES-03|SURTEES]]<br><small>prototype</small> !! [[DYN-001]] !! [[SUR-001]] !! [[JTP-001]]<br>[[JSD-001]] !! [[MPX-001]]<br><small>prototype</small> !! [[KTE-001]] !! [[MSX-001]]<br>[[MPX-001]]<br>[[NPX-001]] !! [[PPX-001]]<br>[[PQX-001]]<br>[[RTX-001]]<br>[[REX-001]]
|-
|-
| colspan="18" style="padding:1px" |  
| E5 || /GX_VSRST ||
|-
|-
! [[Media:DEH-FH1500J-A_-_VERTIGO-02_-_Syscon_Hardware.jpg|D79F0073]]
| D5 || XCG_EN ||
| colspan="3" style="text-align:center; background:#999; color:#fff" | <abbr title="Depends of the syscon firmware version installed in it">ANY</abbr> || rowspan="7" | [[Template:Syscon pinout LQFP 128 pins|LQFP 128]] || rowspan="12" style="text-align:center; background:lightgrey;" | N/A || rowspan="3" | <abbr title="0x80000>512KB</abbr> || rowspan="12" style="text-align:center; background:lightgrey;" | N/A || rowspan="12" style="text-align:center; background:lightgrey;" | <abbr title="0x8000 Emulated inside FLASH">32KB</abbr> || rowspan="12" | <abbr title="0xC800>50KB</abbr> || {{yes}}, factory || {{YES}} || colspan="4" rowspan="3" style="text-align:center; background:#CC5555; color:#FFFFFF;" | No (<abbr title="Different HDMI/CEC handling">HDMI Incompatible</abbr>) || colspan="4" rowspan="7" style="text-align:center; background:#CC5555; color:#FFFFFF;" | No (different package)
|-
|-
! [[SW-301]]
| K2 || /VD_VINT1 || rowspan="11" | Port N ||
| 065D || 0.17.0 || 2008 || {{YES}} ? || {{yes}}, factory
|-
|-
! [[SW-302]]
| K1 || /VD_VINT0 ||
| <abbr title="Please help wiki by reporting this ID"><span style="background:#ff4444; color:#ffff00;">'''????'''</span></abbr> || <abbr title="Please help wiki by reporting this ID"><span style="background:#ff4444; color:#ffff00;">'''?.??.?'''</span></abbr> || 2008 || {{YES}} ? || {{yes}}, factory
|-
|-
! D79F0086
| J2 || /RSX_INT ||
| colspan="3" style="text-align:center; background:#999; color:#fff" | <abbr title="Depends of the syscon firmware version installed in it">ANY</abbr> || rowspan="9" | <abbr title="0xC0000>768KB</abbr> || colspan="2" rowspan="4" style="text-align:center; background:#CC5555; color:#FFFFFF;" | No (<abbr title="Different HDMI/CEC handling">HDMI Incompatible</abbr>) || {{yes}}, factory || {{YES}} || {{YES}} || {{YES}}
|-
|-
! [[SW2-301]]
| J1 || RSX_FLDO ||
| 0832 || 1.11.0 || 2009 || {{YES}} ? || {{yes}}, factory || {{no}} || {{no}}
|-
|-
! [[SW2-302]]
| H2 || PN6 ||
| 08A0 || 1.16.0 || 2009 || {{YES}} ? || {{YES}} || {{yes}}, factory || {{no}}
|-
|-
! [[SW2-303]]
| H1 || PN5 ||
| 08C2 || 1.21.0 || 2010 || {{YES}} ? || {{YES}} || {{YES}} || {{yes}}, factory
|-
|-
! [[Media:DEH-ML00AK-G_Board_4.jpg|D79F0123]]
| G2 || /RSX_RESET ||
| colspan="3" style="text-align:center; background:#999; color:#fff" | <abbr title="Depends of the syscon firmware version installed in it">ANY</abbr> || rowspan="5" | [[Template:Syscon pinout LQFP 100 pins|LQFP 100]] || colspan="6" rowspan="5" style="text-align:center; background:#CC5555; color:#FFFFFF;" | No (different package) || {{yes}}, factory || {{YES}} || {{YES}} || {{YES}}
|-
|-
! [[SW3-301]]
| G1 || RSX_SPI_CLK || rowspan="4" | RSX SPI Bus
| 0918 || 2.3.0 || 2011 || {{YES}} ? || {{yes}}, factory || {{no}} || {{no}}
|-
|-
! [[SW3-302]]
| F2 || RSX_SPI_DO
| 098F || 2.12.0 || 2012 || {{YES}} ? || {{YES}} || {{yes}}, factory || {{no}}
|-
|-
! [[SW3-303]]
| F1 || RSX_SPI_DI
| <abbr title="Please help wiki by reporting this ID"><span style="background:#ff4444; color:#ffff00;">'''????'''</span></abbr> || <abbr title="Please help wiki by reporting this ID"><span style="background:#ff4444; color:#ffff00;">'''?.??.?'''</span></abbr> || 2013 || {{YES}} ? || {{YES}} || ? || ?
|-
|-
! [[SW3-304]]
| E2 || /RSX_SPI_CS
| 09A4 || 2.21.0 || 2013 || {{YES}} ? || {{YES}} || {{YES}} || {{yes}}, factory
|}
|}
</div>


= Syscon Externalised Ports =
== Generation 2: SW-301 ==
Newer generation Syscons are first to be seen on PS3 FAT CECHL/VER-001 board up to CECHQ/VER-001


'''Note:''' for more specific information per model, see the links to each subpage in the Serialnumbers per SKU table.
<div style="float:right">[[File:SYSCON_GEN2.JPG|thumb|Photo of a newer generation Syscon as seen on a CECHL VER-001 board<br />Syscon 'SW-301' 2nd Generation (QFP Packaging)]]
<br /><br />[[File:Fp128b_pin_arrangement.png|thumb|QFP Package : 128 pins<br />Syscon 'SW-301' 2nd Generation<br />''pin 1 left bottom at mark, counter clockwise from south (pins 1-38) to east (pins 39-64), north (pins 65-102), west (103-128))'']]</div>


== Syscon UART packets ==
=== Pinout ===
 
<div style="height:465px; overflow:auto">
=== SCUART daemon (SCUARTD) packet structure ===
{|class="wikitable"
 
! Pin # !! Name !! Port !! Description
SCUARTD packets includes header of 0x3 bytes and optional payload (depending on the command).
|-
 
| 0 || || ||
Packet IDs are not important, they are used only by clients and processed by SCUART daemon. SCUART daemon opens terminal file /dev/ttyS0 and use it to send commands and receive responses.
|-
 
| 1 || || ||
{| class="wikitable"
|-
| 2 || || ||
|-
| 3 || || ||
|-
| 4 || || ||
|-
| 5 || || ||
|-
| 6 || || ||
|-
| 7 || || ||
|-
| 8 || || ||
|-
| 9 || || ||
|-
| 10 || || ||
|-
| 11 || || ||
|-
| 12 || || ||
|-
| 13 || || ||
|-
| 14 || || ||
|-
| 15 || || ||
|-
| 16 || || ||
|-
| 17 || || ||
|-
| 18 || || ||
|-
| 19 || || ||
|-
| 20 || || ||
|-
| 21 || || ||
|-
| 22 || || ||
|-
| 23 || || ||
|-
| 24 || || ||
|-
| 25 || || ||
|-
| 26 || || ||
|-
| 27 || || ||
|-
| 28 || || ||
|-
| 29 || || ||
|-
| 30 || || ||
|-
| 31 || || ||
|-
| 32 || || ||
|-
| 33 || || ||Ground
|-
| 34 || || ||Ground
|-
| 35 || || ||
|-
| 36 || || ||
|-
| 37 || || ||
|-
| 38 || || ||
|-
| 39 || || ||
|-
| 40 || || ||
|-
| 41 || || ||
|-
| 42 || || ||
|-
|-
! Offset !! Size !! Description
| 43 || || ||
|-
|-
| 0x00 || 0x01 || Magic?
| 44 || || ||
|-
|-
| 0x01 || 0x01 || Payload size
| 45 || || ||
|-
|-
| 0x02 || 0x01 || Command
| 46 || || ||
|-
|-
| 0x03 || Payload size || Payload data
| 47 || || ||
|-
|-
|}
| 48 || || ||
 
=== Packets ===
 
{| class="wikitable"
! Packet ID !! Command/Action !! Description !! Notes
|-
|-
| 0x00 || '''version''' || Firmware version || Gets installed syscon's firmware version (Note: backup bank contains version 0.4.5_b4 !! On CEB-2030 it is 0.3.0 )
| 49 || || ||
|-
|-
| 0x01 || '''bringup''' || Bring up || <!--// Standby->ON (Remote Power ON using an UART package, from [[Communication Processor]] ?) //-->
| 50 || || ||
|-
|-
| 0x02 || '''shutdown''' || Shutdown || <!--// ON->Standby (Remote Power OFF using an UART package, from [[Communication Processor]] ?) //-->
| 51 || || ||
|-
|-
| 0x03 || '''firmud''' || Firmware update || Notifies about firmware update operation
| 52 || || ||
|-
|-
| 0x04 || '''bsn''' || Board Serial Number || Retrieves syscon's Board Serial Number
| 53 || || ||
|-
|-
| 0x05 || '''halt''' || Halt || Used at start of firmware update operation
| 54 || || ||
|-
|-
| 0x06 || '''cp ready''' || Communication Processor Ready || <!--// [[Communication Processor]] related, for [[SKU_Models_Nonretail#Reference_Tool_.28Tool.2FDECR.29 | Tool/DECR models]]  //-->
| 55 || || ||
|-
|-
| 0x07 || '''cp busy''' || Communication Processor Busy || <!--// [[Communication Processor]] related, for [[SKU_Models_Nonretail#Reference_Tool_.28Tool.2FDECR.29 | Tool/DECR models]] //-->
| 56 || || ||Ground
|-
|-
| 0x08 || '''cp reset''' || Communication Processor Reset || <!--// [[Communication Processor]] related, for [[SKU_Models_Nonretail#Reference_Tool_.28Tool.2FDECR.29 | Tool/DECR models]] //-->
| 57 || BUZZER || G ||
|-
|-
| 0x09 || '''bestat''' || Cell B.E. status || Retrieves Cell B.E. status
| 58 || || ||
|-
|-
| 0x0A || '''powersw''' || Power switch || toggles power switch button short pressing
| 59 || || ||
|-
|-
| 0x0B || '''resetsw''' || Reset switch || toggles reset switch button holding
| 60 || || ||
|-
|-
| 0x0C || '''bootbeep stat''' || Boot Beep Status ||
| 61 || || ||
|-
|-
| 0x0D || '''bootbeep on''' || Boot Beep On ||
| 62 || || ||
|-
|-
| 0x0E || '''bootbeep off''' || Boot Beep Off ||
| 63 || || ||
|-
|-
| 0x0F || ''Reset syscon'' || Reset Syscon || Resets syscon
| 64 || || ||
|-
|-
| 0x10 || '''xdrdiag info''' || XDR diagnostics Information ||
| 65 || || ||
|-
|-
| 0x11 || '''xdrdiag start''' || XDR diagnostics Start || Starts XDR diagnostics
| 66 || || ||
|-
|-
| 0x12 || '''xdrdiag result''' || XDR diagnostics Result || Gets a result of XDR diagnostics
| 67 || || ||
|-
|-
| 0x13 || '''xiodiag''' || XIO diagnostics || Starts XIO diagnostics and gets a result of it
| 68 || || ||
|-
|-
| 0x14 || '''fandiag''' || Fan diagnostics || Retrieves RPMs of fans
| 69 || || ||
|-
|-
| 0x15 || '''errlog''' || Error log || Retrieves a list of codes (with timestamps) of latest errors
| 70 || || ||
|-
|-
| 0x16 || ''Read line'' || Read Line ||
| 71 || || ||
|-
|-
| 0x17 || '''tmpforcp <zone ID>''' || Reference Tool's temperature For Communication Processor || Gets the temperature of reference tool
| 72 || || ||
|-
|-
| 0x18 || rowspan="8" colspan="3" style="background:lightgrey; color:#ff0000; text-align: center;" | Invalid CMDs
| 73 || || ||
|-
|-
| 0x19
| 74 || || ||
|-
|-
| 0x1A
| 75 || || ||
|-
|-
| 0x1B
| 76 || || ||
|-
|-
| 0x1C
| 77 || || ||
|-
|-
| 0x1D
| 78 || || ||
|-
|-
| 0x1E
| 79 || || ||
|-
|-
| 0x1F
| 80 || || ||
|-
|-
| 0x20 || '''cp beepremote''' || Communication Processor Beep Remote ||
| 81 || || ||
|-
|-
| 0x21 || '''cp beep2kn1n3''' || ||
| 82 || || ||
|-
|-
| 0x22 || '''cp beep2kn2n3''' || ||
| 83 || || ||
|-
|-
| ?? || '''csum''' || Checksum || Calculates the Checksum of something (No packet ID listing on scuartd)
| 84 || || ||
|-
|-
| ?? || '''osbo''' || ?Operating System Boot? || No idea what this does, but returns <pre>done</pre> when it's sent <!--Operative System Boot Order ?... something related with gameOS/otherOS boot flag ? -->
| 85 || || ||
|-
|-
| ?? || '''scopen''' || Syscon Open || returns SC_READY or ERROR 1
| 86 || || ||
|-
|-
| ?? || '''scclose''' || Syscon Close || ???
| 87 || || ||
|-
|-
| ?? || '''ejectsw''' || Eject Switch || toggles eject switch button pressing (3 beeps)
| 88 || || ||
|-
|-
|}
| 89 || || ||
 
=== Packets Logs ===
 
{| class="wikitable"
! Packet ID !! Command/Action !! Logs !! Notes
|-
|-
| 0x00 || '''version''' || version\nv1.0.4_c2\n  (END) ||
| 90 || || ||
|-
|-
| 0x01 || '''bringup''' || (END) ||
| 91 || || ||
|-
|-
| 0x02 || '''shutdown''' || Do nothing. (PowerOff State)\n (END) || Returns (END) if the system is on
| 92 || || ||
|-
|-
| 0x03 || '''firmud''' || Start...\nErase User Program Area\n  (END) || This will brick your SYSCON if you don't feed it any argument or feed to it the wrong argument!
| 93 || || ||
|-
|-
| 0x04 || '''bsn''' || bsn\nNANNNNNNNNNA\n  (END) || N is digit and A is char (removed for privacy)
| 94 || || ||
|-
|-
| 0x05 || '''halt''' || halt\n  (END) ||
| 95 || || ||
|-
|-
| 0x06 || '''cp ready''' || cp ready\nCP READY: OK\n  (END) ||  
| 96 || || ||
|-
|-
| 0x07 || '''cp busy''' || cp ready\nCP BUSY: OK\n  (END) || STATUS light blinks forever
| 97 || || ||
|-
|-
| 0x08 || '''cp reset''' || No response || Should reset CP to factory settings
| 98 || || ||
|-
|-
| 0x09 || '''bestat''' || (PowerOff State)\n (END) ||
| 99 || || ||
|-
|-
| 0x0A || '''powersw''' || (END) ||
| 100 || || ||
|-
|-
| 0x0B || '''resetsw''' || (END) ||
| 101 || || ||Ground
|-
|-
| 0x0C || '''bootbeep stat''' || BOOT BEEP: ON\n  (END) || when it's off BOOT BEEP status changes to OFF
| 102 || || ||
|-
|-
| 0x0D || '''bootbeep on''' || BOOT BEEP ON: DONE\n  (END) ||  
| 103 || || ||
|-
|-
| 0x0E || '''bootbeep off''' || BOOT BEEP OFF: DONE\n  (END) ||
| 104 || || ||
|-
|-
| 0x0F || '''Reset syscon''' || ||
| 105 || || ||
|-
|-
| 0x10 || '''xdrdiag info''' || 32\n  (END) ||
| 106 || || ||
|-
|-
| 0x11 || '''xdrdiag start''' || DIAG START\n  (END) ||
| 107 || || ||
|-
|-
| 0x12 || '''xdrdiag result''' || XDR OK\n  (END) || will return ERROR NOT STARTED if xdrdiag start wasn't run previously
| 108 || || ||
|-
|-
| 0x13 || '''xiodiag''' || 0 903\n  (END) ||
| 109 || || ||
|-
|-
| 0x14 || '''fandiag''' || ERROR FAN ACTIVE\n  (END) ||
| 110 || || ||
|-
|-
| 0x15 || '''errlog''' || ofst[ %d]:err_code:0x%08X, clock:0x%08X  YYYY/MM/DD HH:MM:SS || bunch of error logs. ends with (END) once they're over
| 111 || || ||
|-
|-
| 0x16 || '''Read line''' || ||
| 112 || || ||
|-
|-
| 0x17 || '''tmpforcp <zone ID>''' ||  
| 113 || || ||
|-
|-
| 0x20 || '''cp beepremote''' || (END) ||
| 114 || || ||
|-
|-
| 0x21 || '''cp beep2kn1n3''' || (END) || sends a beep different than SYSCON beep :)
| 115 || || ||
|-
|-
| 0x22 || '''cp beep2kn2n3''' || (END) || sends two beeps different than SYSCON beeps :)
| 116 || || ||
|-
|-
| rowspan="8" | ?? || rowspan="8" | '''csum''' || Checksum: [027460C9] [68269779] [C19A855E]\n  (END) || displays 3 hexadecimal numbers inside rect parenthesis. the numbers are always the same, except when syscon version changes (v1.0.5_c1)
| 117 || || ||
|-
|-
| Checksum: [02746F91] [682F04DA] [27688CF5]\n  (END) || Another response (v1.0.4_c2)
| 118 || || ||
|-
|-
| Checksum: [0274C877] [684DA659] [EA426BB1]\n  (END) || Another response (v1.0.4_c1)
| 119 || || ||
|-
|-
| Checksum: [027B4064] [6B450C64] [4FBF6DA3]\n  (END) || Another response (v1.0.3_c1)
| 120 || || ||
|-
|-
| Checksum: [027E1B71] [6CDA9F25] [E0C67065]\n  (END) || Another response (v1.0.1_c1)
| 121 || || ||
|-
|-
| Checksum: [02812855] [6E83917C] [D40F70A5]\n  (END) || Another response (v0.9.14_c1)
| 122 || || ||
|-
|-
| Checksum: [02835059] [6FC5C632] [BB9BBEC3]\n  (END) || Another response (v0.9.9_c1)
| 123 || || ||
|-
|-
| Checksum: [026F7951] [66CB09FF] [4EA06B56]\n  (END) || Another response (v0.8.4_c8)
| 124 || || ||
|-
|-
| ?? || '''osbo''' || done\n  (END) ||
| 125 || || ||
|-
|-
| ?? || '''scopen''' || SC_READY\nERROR 1\n\n*** Invalid Argument ***\n\n[mullion]$ ||
| 126 || FANPWM0 || G || Fan PWM Signal
|-
|-
| ?? || '''scclose''' || \n\n\nSC_SUCCESS\n\n[mullion]$ ||
| 127 || || ||
|-
|-
| 128 || || ||
|}
|}
</div>


=== Notes ===
== Generation 2-2: SW-302 ==
<div style="float:right">[[File:Syscon-sw302.jpg|thumb|Photo of rev2 subversion on CECHL<br />Syscon 'SW-302' 2-2nd Generation (QFP Packaging)]]</div>
Updated version as seen on CECHL (with the same pinout as SW-301)


* Some commands are unavailable on earlier firmwares, for example, tmpforcp is only supported on 1.3.3+.
=== Packaging ===
* Some commands are divided into several strings, the first part (if exists) describes a command group, the second part describes the actual command and other parts describes command arguments.
QFP Package : 128 pins
* Real syscon commands have an ASCII form (a bold text in the 2nd column) instead of bytes above.
* Packet with ID *0x03* notifies syscon and calls SX program (based on ZMODEM protocol) to send firmware, syscon have custom or original implementation of RX program to receive firmware. An implementation of ZMODEM protocol used by Sony: http://oss.sony.net/Products/Linux/Others/Download/DECR-1000/mips_fp_le-lrzsz-0.12.20-devtool.1.src.rpm


A start of syscon's update procedure:
[[File:Fp128b_pin_arrangement.png]]
* A CP development tool includes several scripts which are participated in syscon update procedure. It starts after a CP update via ''update_syscon.pl'' perl script.
* This script checks the current syscon's firmware version. If it is in mask rom then it skips an update procedure, if not it checks major/minor/release parts of both versions and if a new version is applicable then it launches ''scfirmup'' utility and pass the firmware file path as an argument.
* ''scfirmup'' is a stupid tool which prepares a connection to SCUARTD and sends an update packet with a file path inside it. There is no need to comment it, here is reimplementation: http://pastie.org/private/6h8mfeoics4mdxear7ayg


A syscon's update operation in '''SCUARTD''' consists of following steps:
''((V)(Q)FP 128 PIN numbering scheme''
* 1. Check if ''SX'' program presents in ''/usr/bin/sx''. It should be a regular file.
* 2. Check if specified firmware file is a regular file.
* 3. Halt syscon by sending command '''halt'''  to UART, then wait some time until it prints ''HALT: OK''.
* 4. Reset syscon by sending byte ''0x30'' to GPIO register '''SC_PI0_DIPSW''', byte ''0x30'' to GPIO register '''SC_RSTX''', waiting 1 second and writing byte ''0x31'' to GPIO register '''SC_RSTX'''.
* 5. Get current syscon's firmwave version by sending command '''version''' to UART. After receiving it, look for a character after the first ''_'' (underscore) symbol from the left side of string and if it equals to the character ''b'', then proceed to the next step, otherwise go to the (8) step. (It is possible to patch this step to allow upgrading or downgrading at will)
* 6. Prepare syscon for an update by sending command '''firmud''' to UART, then fork the current process; the current process won't finish until a message ''Done'' from UART arrives (it is the end of update operation).
* 7. In the forked process start ''SX'' program and pass firmware file path to it. ''SX'' program reads firmware file and transfer each chunk of it to syscon.
* 8. After successful update operation reset syscon (a different way) by sending byte ''0x31'' to GPIO register '''SC_PI0_DIPSW''', byte ''0x30'' to GPIO register '''SC_RSTX''', waiting 1 second and writing byte ''0x31'' to GPIO register '''SC_RSTX'''.


Notes:
''pin 1 left bottom at mark, counter clockwise from south (pins 1-38) to east (pins 39-64), north (pins 65-102), west (103-128))''
* It seems all scuartds checks firmware revision and probably syscon is updated only once (after factory).
* To be able to reflash it you need to patch ''SCUARTD'' or do a manual update without the use of ''SCUARTD''.
* You need to patch a single byte in ''SCUARTD'' to be able to flash any firmware (for example, to downgrade your syscon).
<syntaxhighlight lang="asm">
.text:00403A94: /* scuartd from CP 1.3.3 */
lb      $v1, 1($v0)
li      $v0, "b" /* 62 00 02 24 -> 63 00 02 24 */
bne    $v1, $v0, loc_4039F4
move    $a0, $zero
</syntaxhighlight>


* An actual firmware update process (without halting and resetting steps) takes about 1 minute.
=== Pinout ===
* You cannot install a corrupted firmware with scfirmup unless you corrupt the header! It seems there is a hash of sorts (possibly of the plaintext) in the header preventing scfirmup from installing something corrupt
* Updating SYSCON requires the DECR to be in standby mode! You cannot update it while it is on.
* Corrupting the header and the body will make firmup install the SYSCON update anyways! be careful not to do it!
* Should you brick SYSCON, here's a patch to "unbrick" it, do not use it unless you brick it though!
<syntaxhighlight lang="asm">
.text:004038C0:
lw      $a0, 4($s4)
li      $a1, 0x400000
nop
addiu  $a1, (aHalt - 0x400000)  # "halt"
la      $t9, scuartd_send_sccmd
nop
jalr    $t9 ; scuartd_send_sccmd
nop
lw      $gp, 0x1E8+var_1D8($sp)
bnez    $v0, loc_4039B4 /* 33 00 40 14 -> 33 00 40 10 */
li      $a0, 1
</syntaxhighlight>
* You can use this bruteforcer to try your luck when finding new packets: https://hastebin.com/vomogesaru.cpp


== Syscon UART ==
<div style="height:400px; overflow:auto">
{| class="wikitable"
{|class="wikitable"
! BGA !! Name !! Description
! Pin # !! Name !! Port !! Description
|-
| 0 || || ||
|-
| 1 || || ||
|-
| 2 || || ||
|-
| 3 || || ||
|-
| 4 || || ||
|-
|-
| P16 || UART0_TxD || Serial Transmit
| 5 || || ||
|-
|-
| P15 || UART0_RxD || Serial Receive
| 6 || || ||
|-
| 7 || || ||
|-
| 8 || || ||
|-
| 9 || || ||
|-
| 10 || || ||
|-
| 11 || || ||
|-
| 12 || || ||
|-
| 13 || || ||
|-
| 14 || || ||
|-
| 15 || || ||
|-
| 16 || || ||
|-
| 17 || || ||
|-
| 18 || || ||
|-
| 19 || || ||
|-
| 20 || || ||
|-
| 21 || || ||
|-
| 22 || || ||
|-
| 23 || || ||
|-
| 24 || || ||
|-
| 25 || || ||
|-
| 26 || || ||
|-
| 27 || || ||
|-
| 28 || || ||
|-
| 29 || || ||
|-
| 30 || || ||
|-
| 31 || || ||
|-
| 32 || || ||
|-
| 33 || || ||Ground
|-
| 34 || || ||Ground
|-
| 35 || || ||
|-
| 36 || || ||
|-
| 37 || || ||
|-
| 38 || || ||
|-
| 39 || || ||
|-
| 40 || || ||
|-
| 41 || || ||
|-
| 42 || || ||
|-
| 43 || || ||
|-
| 44 || || ||
|-
| 45 || || ||
|-
| 46 || || ||
|-
| 47 || || ||
|-
| 48 || || ||
|-
| 49 || || ||
|-
| 50 || || ||
|-
| 51 || || ||
|-
| 52 || || ||
|-
| 53 || || ||
|-
| 54 || || ||
|-
| 55 || || ||
|-
| 56 || || ||Ground
|-
| 57 || BUZZER || G ||
|-
| 58 || || ||
|-
| 59 || || ||
|-
| 60 || || ||
|-
| 61 || || ||
|-
| 62 || || ||
|-
| 63 || || ||
|-
| 64 || || ||
|-
| 65 || || ||
|-
| 66 || || ||
|-
| 67 || || ||
|-
| 68 || || ||
|-
| 69 || || ||
|-
| 70 || || ||
|-
| 71 || || ||
|-
| 72 || || ||
|-
| 73 || || ||
|-
| 74 || || ||
|-
| 75 || || ||
|-
| 76 || || ||
|-
| 77 || || ||
|-
| 78 || || ||
|-
| 79 || || ||
|-
| 80 || || ||
|-
| 81 || || ||
|-
| 82 || || ||
|-
| 83 || || ||
|-
| 84 || || ||
|-
| 85 || || ||
|-
| 86 || || ||
|-
| 87 || || ||
|-
| 88 || || ||
|-
| 89 || || ||
|-
| 90 || || ||
|-
| 91 || || ||
|-
| 92 || || ||
|-
| 93 || || ||
|-
| 94 || || ||
|-
| 95 || || ||
|-
| 96 || || ||
|-
| 97 || || ||
|-
| 98 || || ||
|-
| 99 || || ||
|-
| 100 || || ||
|-
| 101 || || ||Ground
|-
| 102 || || ||
|-
| 103 || || ||
|-
| 104 || || ||
|-
| 105 || || ||
|-
| 106 || || ||
|-
| 107 || || ||
|-
| 108 || || ||
|-
| 109 || || ||
|-
| 110 || || ||
|-
| 111 || || ||
|-
| 112 || || ||
|-
| 113 || || ||
|-
| 114 || || ||
|-
| 115 || || ||
|-
| 116 || || ||
|-
| 117 || || ||
|-
| 118 || || ||
|-
| 119 || || ||
|-
| 120 || || ||
|-
| 121 || || ||
|-
| 122 || || ||
|-
| 123 || || ||
|-
| 124 || || ||
|-
| 125 || || ||
|-
| 126 || FANPWM0 || G || Fan PWM Signal
|-
| 127 || || ||
|-
|-
| 128 || || ||
|}
|}
</div>


<gallery>
== Generation 3: SW2-301 ==
File:COK-001 SC UART testpads.jpg|[[COK-001]] SC UART testpads
<div style="float:right">[[File:SW2-301 0920KMOOT-ps3slim.jpg|thumb|Photo of an updated subversion of the newer generation Syscon on PS3 Slim<br />Syscon 'SW2-301' 3rd Generation (QFP Packaging)]]</div>
File:COK-002 SC UART testpads.jpg|[[COK-002]] SC UART testpads
Updated version (with the same pinout as SW-301) on the PS3 slim CECH-20..A/DYN-001 and later.
File:SEM-001 SC UART testpads.jpg|[[SEM-001]] SC UART testpads
File:DIA-001 SC UART testpads.jpg|[[DIA-001]] SC UART testpads
File:DIA-002 SC UART testpads.jpg|[[DIA-002]] SC UART testpads
File:VER-001 SC UART testpads.jpg|[[VER-001]] SC UART testpads
File:DYN-001 SC UART testpads.jpg|[[DYN-001]] SC UART testpads
File:SUR-001 SC and SB UART testpads.jpg|[[SUR-001]] SC and SB UART testpads
File:JTP-001 SC and SB UART testpads.jpg|[[JTP-001]] SC and SB UART testpads
File:JSD-001 SC and SB UART testpads.jpg|[[JSD-001]] SC and SB UART testpads
File:KTE-001 SC and SB UART testpads.jpg|[[KTE-001]] SC and SB UART testpads
File:SW3 SC UART testpads.jpg|SW3 SC UART testpads
</gallery>


You can attach a 3.3v TTL cable (LV-TTL) to the UART on syscon (UART0_TxD, UART0_RxD). Baud rate is 57600. There is a simple plaintext protocol involved. This varies on different syscon models. Example:
=== Packaging ===
QFP Package : 128 pins


'''<command>:<hash>'''
[[File:Fp128b_pin_arrangement.png]]


Where the hash is the sum of command bytes & 0xFF.
''((V)(Q)FP 128 PIN numbering scheme''


You should terminate commands with \r\n, the syscon messages are only terminated with \n.
''pin 1 left bottom at mark, counter clockwise from south (pins 1-38) to east (pins 39-64), north (pins 65-102), west (103-128))''


=== Samples ===
=== Pinout ===


Here are some of the commands/messages encountered:
<div style="height:400px; overflow:auto">
 
{|class="wikitable"
Messages:
! Pin # !! Name !! Port !! Description
<pre>Power applied (standby mode)
|-
OK 00000000:3A
| 0 || || ||
 
|-
Power on
| 1 || || ||
# (PowerOn State):7F
|-
 
| 2 || || ||
Power off (Hard shutdown)
|-
# (PowerOff State):DD
| 3 || || ||
 
|-
After Fan test:
| 4 || || ||
# (PowerOff State) (Fatal):36
|-
 
| 5 || || ||
No text, invalid hash:
|-
NG F0000002:4D</pre>
| 6 || || ||
 
|-
Commands:
| 7 || || ||
<pre>
|-
VER:ED
| 8 || || ||
OK 00000000 S1E 00 00 065D:A4
|-
OK 00000000 S1E 01 0B 00 0832:A3 (on DYN-001 board)
| 9 || || ||
OK 00000000 S1E 02 03 00 0918:9A (on KTE-001 board)
|-
 
| 10 || || ||
ERRLOG:CB
|-
OK 00000000:3A
| 11 || || ||
 
|-
DATE:1E
| 12 || || ||
NG F0000003:4E
|-
 
| 13 || || ||
C:F1:BUZ
|-
E:4F:NG F0000004
| 14 || || ||
E:50:NG F0000005 (in DIAG mode)
|-
 
| 15 || || ||
C:D0:CID
|-
E:50:NG F0000005
| 16 || || ||
 
|-
C:D0:CID GET
| 17 || || ||
E:50:NG F0000005
|-
 
| 18 || || ||
C:DA:EEP
|-
E:50:NG F0000005
| 19 || || ||
 
|-
C:DA:EEP GET
| 20 || || ||
E:50:NG F0000005
|-
 
| 21 || || ||
C:E6:EEP SET
|-
E:50:NG F0000005
| 22 || || ||
 
|-
C:D5:FAN
| 23 || || ||
E:50:NG F0000005
|-
 
| 24 || || ||
C:83:FAN START
|-
E:50:NG F0000005
| 25 || || ||
 
|-
C:3B:FAN STOP
| 26 || || ||
E:50:NG F0000005
|-
 
| 27 || || ||
C:F4:KSV
|-
E:50:NG F0000005
| 28 || || ||
 
|-
C:ED:REV
| 29 || || ||
E:50:NG F0000005
|-
 
| 30 || || ||
C:F8:SPU
|-
E:50:NG F0000005
| 31 || || ||
 
|-
C:FD:AUTH1
| 32 || || ||
0000802000000000003000309C0EDB3F
|-
E603EDB98A38DDC09400A2AB2DDE8CAB
| 33 || || ||Ground
0AECFE951FF7E2E8D8A7CF2202719F81
|-
2F36DE83B424C27063C274CB0000E46B
| 34 || || ||Ground
<Important Note: 0x40 bytes>
|-
                 
| 35 || || ||
E:5D:NG E00000C0
|-
 
| 36 || || ||
C:34:BOOT
|-
E:50:NG F0000005
| 37 || || ||
</pre>
|-
 
| 38 || || ||
See also [[Talk:System_Controller_Firmware#Syscon_commands|Syscon commands]].
|-
 
| 39 || || ||
Bruteforcing commands:<!--// LOL //--> http://pastebin.com/CNei0xbC
|-
 
| 40 || || ||
VERY IMPORTANT:
|-
* Max size of a command is 11 characters, 16 if you count with C:<hash>:
| 41 || || ||
* Sending a command with 11 chars results in NO OUTPUT
|-
* Sending a command with more than 11 chars results in NG F0000002
| 42 || || ||
* Max size of a command on DECR is 135, 140 if you count with C:<hash>:
|-
 
| 43 || || ||
== Pinouts ==
|-
See:
| 44 || || ||
*https://www.psdevwiki.com/ps3/Template:Syscon_pinout_BGA_200_pads
|-
*https://www.psdevwiki.com/ps3/Template:Syscon_pinout_LQFP_128_pins
| 45 || || ||
*https://www.psdevwiki.com/ps3/Template:Syscon_pinout_LQFP_100_pins
|-
 
| 46 || || ||
{| class="wikitable" style="float:left; margin:5px;"
|-
|+Syscon EEPROM (SPI)
| 47 || || ||
! BGA !! Name !! Description
|-
| 48 || || ||
|-
| 49 || || ||
|-
| 50 || || ||
|-
| 51 || || ||
|-
| 52 || || ||
|-
| 53 || || ||
|-
| 54 || || ||
|-
| 55 || || ||
|-
| 56 || || ||Ground
|-
| 57 || BUZZER || G ||
|-
| 58 || || ||
|-
| 59 || || ||
|-
| 60 || || ||
|-
| 61 || || ||
|-
| 62 || || ||
|-
| 63 || || ||
|-
| 64 || || ||
|-
| 65 || || ||
|-
| 66 || || ||
|-
| 67 || || ||
|-
| 68 || || ||
|-
| 69 || || ||
|-
| 70 || || ||
|-
| 71 || || ||
|-
| 72 || || ||
|-
| 73 || || ||
|-
| 74 || || ||
|-
| 75 || || ||
|-
| 76 || || ||
|-
| 77 || || ||
|-
| 78 || || ||
|-
| 79 || || ||
|-
| 80 || || ||
|-
| 81 || || ||
|-
| 82 || || ||
|-
| 83 || || ||
|-
| 84 || || ||
|-
| 85 || || ||
|-
| 86 || || ||
|-
| 87 || || ||
|-
|-
| F16 || CSB || Chip Select (needs to be low)
| 88 || || ||
|-
|-
| H16 || DO || Serial Data Output
| 89 || || ||
|-
|-
| G16 || DI || Serial Data Input
| 90 || || ||
|-
|-
| E16 || SKB || Serial Data Clock
| 91 || || ||
|-
|-
| J15 || WCB || Write Protect
| 92 || || ||
|-
|-
| J16 || RBB || Ready/Busy
| 93 || || ||
|-
|-
| G11 || VDDep || + 3.3V
| 94 || || ||
|-
|-
| C15 || VSSep || GND
| 95 || || ||
|-
|-
|}
| 96 || || ||
 
{| class="wikitable" style="float:left; margin:5px;"
|+Syscon BE SPI Bus
! BGA !! Name !! Description
|-
|-
| M2 || BE_SPI_CS || Chip Select
| 97 || || ||
|-
|-
| N2 || BE_SPI_DO || Serial Data Output
| 98 || || ||
|-
|-
| M1 || BE_SPI_DI || Serial Data Input
| 99 || || ||
|-
|-
| N1 || BE_SPI_CLK || Serial Data Clock
| 100 || || ||
|-
|-
| colspan="3" {{cellcolors|lightblue}}
| 101 || || ||Ground
|-
|-
| P2 || BE_RESET || CellBE Reset
| 102 || || ||
|-
|-
| P1 || BE_POWGOOD  || CellBE PowerGood
| 103 || || ||
|-
|-
| T2 || BE_INT || CellBE Interrupt
| 104 || || ||
|-
|-
|}
| 105 || || ||
 
{| class="wikitable" style="float:left; margin:5px;"
|+Syscon RSX SPI Bus
! BGA !! Name !! Description
|-
|-
| E2 || RSX_SPI_CS || Chip Select
| 106 || || ||
|-
|-
| F2 || RSX_SPI_DO || Serial Data Output
| 107 || || ||
|-
|-
| F1 || RSX_SPI_DI || Serial Data Input
| 108 || || ||
|-
|-
| G1 || RSX_SPI_CLK || Serial Data Clock
| 109 || || ||
|-
|-
| colspan="3" {{cellcolors|lightblue}}
| 110 || || ||
|-
|-
| G2 || RSX_RESET || RSX Reset
| 111 || || ||
|-
|-
| J2 || RSX_INT || RSX Interrupt
| 112 || || ||
|-
|-
|}
| 113 || || ||
 
{| class="wikitable" style="float:left; margin:5px;"
|+Syscon SB SPI Bus
! BGA !! Name !! Description
|-
|-
| B9 || SB_SPI_CS || Chip Select
| 114 || || ||
|-
|-
| B8 || SB_SPI_DO || Serial Data Output
| 115 || || ||
|-
|-
| A9 || SB_SPI_DI || Serial Data Input
| 116 || || ||
|-
|-
| A8 || SB_SPI_CLK || Serial Data Clock
| 117 || || ||
|-
|-
| colspan="3" {{cellcolors|lightblue}}
| 118 || || ||
|-
|-
| D11 || SB_RESET || SB Reset
| 119 || || ||
|-
|-
| D9 || SB_INT || SB Interrupt
| 120 || || ||
|-
|-
|}
| 121 || || ||
 
{| class="wikitable" style="float:left; margin:5px;"
|+Syscon JTAG (disabled in factory after production on retail models)
! BGA !! Name !! Description
|-
|-
| L8 || JRTCK || Return Test Clock
| 122 || || ||
|-
|-
| K8 || JTCK || Test Clock
| 123 || || ||
|-
|-
| K9 || JTDO || Test Data Out
| 124 || || ||
|-
|-
| L9 || JTMS || Test Mode State / Test Mode Select
| 125 || || ||
|-
|-
| K7 || JTDI || Test Data In
| 126 || FANPWM0 || G || Fan PWM Signal
|-
|-
| L7 || JNTRST || Test Reset
| 127 || || ||
|-
|-
| 128 || || ||
|}
|}
</div>


= Testpads and alternative solder points =
*The identification of the syscon UART testpads can be made by grouping the motherboard models in a similar way we was doing with the [[Teensy%2B%2B_2.0#Schematics_by_motherboard_.28retail.29| layouts]] of the hardware flashers, there are 7 retail testpads layouts:
**Layout 1 = COK-001, COK-002 (fat, mullion, NAND)
**Layout 2 = SEM-001 (fat, mullion, NAND)
**Layout 3 = DIA-001, DIA-002 (fat, mullion, NOR)
**Layout 4 = VER-001 (fat, sherwood, NOR)
**Layout 5 = DYN-001 (slim, sherwood, NOR)
**Layout 6 = SUR-001, JTP-001, JSD-001, KTE-001 (slim, sherwood, NOR)
**Layout 7 = MSX-001, MPX-001, NPX-001, PPX-001, PQX-001, RTX-001, REX-001 (superslim, sherwood, NOR/eMMC)


== DIA-001 and DIA-002 ==
== CECHG01 Pictures - SEM-001 ==
This points are availables to intercept signals by soldering wires, attaching probes, osciloscopes, etc... The photos are only orientatives to follow the traces, there's no need to remove the SYSCON to intercept this signals so can be done while its working
=== Topside Pictures ===
<div style="float:right">[[File:syscon_top_cechg01.jpg|thumbnail|Syscon Top Pinouts<br />CECHG01/SEM-001]]</div>
<br /><br /><br /><br /><br /><br /><br /><br /><br />


All this points has been hardware reverse engineered from a [[CECHHxx|CECHH02]]/[[DIA-00x#DIA-001|DIA-001]] motherboard
== CECHG01 Pictures - SEM-001 ==
{{clear}}
=== Bottomside Pictures ===
<div style="float:right">[[File:syscon_bottom_cechg01.jpg|thumbnail|Syscon Bottom Pinouts<br />CECHG01/SEM-001]]</div>
<br /><br /><br /><br /><br /><br /><br /><br /><br />


== CECHH02/DIA-001 Pinout ==
=== Topside Pinout ===
=== Topside Pinout ===
<div style="float:right">[[File:syscon_top.jpg|thumbnail|Syscon Top Pinouts<br />[[CECHHxx|CECHH02]]/[[DIA-00x#DIA-001|DIA-001]]]]</div>
<div style="float:right">[[File:syscon_top.jpg|thumbnail|Syscon Top Pinouts<br />CECHH02/DIA-001]]</div>


{|class="wikitable"
{|class="wikitable"
Line 722: Line 1,381:


=== Bottomside Pinout ===
=== Bottomside Pinout ===
<div style="float:right">[[File:DIA-001 SysCon EPROM Interface.png|thumbnail|[[DIA-001]] [[CECHHxx]] [[SC EEPROM]] Interface]]<br />[[File:syscon_bottom.jpg|thumbnail|Syscon Bottom Pinouts<br />[[CECHHxx|CECHH02]]/[[DIA-00x#DIA-001|DIA-001]]]]<br />[[File:Syscon uart soldered on dia-002.jpg|thumbnail|Syscon UART soldered<br />[[CECHJxx]]/[[CECHKxx]] [[DIA-00x#DIA-002|DIA-002]]]]</div>
<div style="float:right">[[File:syscon_bottom.jpg|thumbnail|Syscon Bottom Pinouts<br />CECHH02/DIA-001]]</div>


{|class="wikitable"
{|class="wikitable"
Line 817: Line 1,476:
|Unknown
|Unknown
|}
|}
{{Motherboard Components}}<noinclude>[[Category:Main]]</noinclude>
Please note that all contributions to PS3 Developer wiki are considered to be released under the GNU Free Documentation License 1.2 (see PS3 Developer wiki:Copyrights for details). If you do not want your writing to be edited mercilessly and redistributed at will, then do not submit it here.
You are also promising us that you wrote this yourself, or copied it from a public domain or similar free resource. Do not submit copyrighted work without permission!

To protect the wiki against automated edit spam, we kindly ask you to solve the following hCaptcha:

Cancel Editing help (opens in new window)