Differences
This shows you the differences between two versions of the page.
Both sides previous revision Previous revision Next revision | Previous revision | ||
t1600g-52ps [2020/11/02 09:51] – andyboeh | t1600g-52ps [2022/09/04 20:18] (current) – andyboeh | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== TP-Link T1600G-52PS ====== | + | ====== TP-Link T1600G-52PS |
- | The TP-Link T1600G-52PS v4 48 + 4-port Gigabit L2 switch with PoE+. | + | The TP-Link T1600G-52PS v4 48 + 4-port Gigabit L2 switch with PoE+, also called TL-SG2452P. |
+ | |||
+ | Note: the v4 (and possibly v3) boards in this series are RTL83xx-based. However v1 is based on the Broadcom BCM53344/ | ||
===== Hardware ===== | ===== Hardware ===== | ||
Line 7: | Line 9: | ||
* Winbond 25Q256JVFQ (32MB flash) | * Winbond 25Q256JVFQ (32MB flash) | ||
* SEC K4B2G1646 BYMA (256MB RAM) | * SEC K4B2G1646 BYMA (256MB RAM) | ||
+ | * PoE daughter board: | ||
+ | * TI 9BAJJ6T ISO7741 digital isolator | ||
+ | * 12× TI TPS23861PW PSE controller | ||
4 Uplink ports are SFP cages which support 1000 Base-X mini GBIC modules. | 4 Uplink ports are SFP cages which support 1000 Base-X mini GBIC modules. | ||
Line 23: | Line 28: | ||
| Fan area; there is one FET marked P3056LS 1951 | {{: | | Fan area; there is one FET marked P3056LS 1951 | {{: | ||
| External PHY area; there is a RTL8214QF PHY for the SFP slots | {{: | | External PHY area; there is a RTL8214QF PHY for the SFP slots | {{: | ||
+ | | PoE daughter board detail | {{: | ||
There are no ICs on the bottom side of the PCB. | There are no ICs on the bottom side of the PCB. | ||
Line 32: | Line 38: | ||
==== OpenWrt Support ==== | ==== OpenWrt Support ==== | ||
- | OpenWrt support is currently WiP. There is serial access to the bootloader and the stock firmware image has been successfully decrypted. However, a new U-Boot is required | + | OpenWrt support is currently WiP. There is serial access to the bootloader and the stock firmware image has been successfully decrypted. However, a new U-Boot is recommended |
It might be possible to have upgrades from the stock web interface, but this depends on whether the RSA signature is actually verified or not - the relevant code is commented in the bootloader source code. | It might be possible to have upgrades from the stock web interface, but this depends on whether the RSA signature is actually verified or not - the relevant code is commented in the bootloader source code. | ||
+ | |||
+ | ==== Compiling a new bootloader ==== | ||
+ | |||
+ | In order to be able to boot an OpenWrt build, a new U-Boot with network support is required. This can be built from the GPL drop with the following commands: | ||
+ | |||
+ | * Patch package/ | ||
+ | * '' | ||
+ | * '' | ||
+ | * u-boot.bin is at '' | ||
+ | |||
+ | There is no need to change anything in the source code, as debug is enabled by default. To flash it, a SOIC-16 clip and flashing tool is required - a cheap WCH340-based SPI flasher works sufficiently: | ||
+ | |||
+ | < | ||
+ | Read Flash: | ||
+ | |||
+ | sudo flashrom -p ch341a_spi -r backup_t1600g.bin | ||
+ | |||
+ | Create new U-Boot: | ||
+ | |||
+ | truncate -s 32M u-boot_new.bin | ||
+ | |||
+ | Flash only U-Boot: | ||
+ | |||
+ | sudo flashrom -p ch341a_spi -l t1600g_layout.map -i boot -w u-boot_new.bin | ||
+ | </ | ||
+ | |||
+ | The map file looks like this: | ||
+ | |||
+ | < | ||
+ | 00000000: | ||
+ | 000E0000: | ||
+ | 00100000: | ||
+ | 00700000: | ||
+ | 01100000: | ||
+ | 01B00000: | ||
+ | 01F00000: | ||
+ | </ | ||
+ | |||
+ | ==== Fan Control ==== | ||
+ | |||
+ | The fan control was measured, but not all required GPIOs could be found. Only Full speed and medium speed are possible so far. | ||
+ | |||
+ | ==== Workarounds ==== | ||
+ | |||
+ | Until proper kernel driver support comes up, PoE support and LED support need some hacks: | ||
+ | |||
+ | ===== LEDs ===== | ||
+ | |||
+ | The following commands enable the port LEDs in automatic mode: | ||
+ | |||
+ | < | ||
+ | cd / | ||
+ | echo 0x0060f568 > led_glb_ctrl | ||
+ | echo 0x00007dea > led_set_0_1 | ||
+ | echo 0xffffffff > led_copr_pmask_ctrl_0 | ||
+ | echo 0x000fffff > led_copr_pmask_ctrl_1 | ||
+ | echo 0xffffffff > led_combo_ctrl_0 | ||
+ | echo 0x000fffff > led_combo_ctrl_1 | ||
+ | </ | ||
+ | |||
+ | ===== PoE ===== | ||
+ | |||
+ | The PoE modules and the kernel hwmon driver work, but the ICs are not in the correct mode during startup. In order to enable them, the package `i2c-tools` needs to installed and a startup script is required: | ||
+ | |||
+ | < | ||
+ | i2cset -y 0 0x30 0x12 0xff | ||
+ | for i in `seq 3 14`; do | ||
+ | echo 1 > / | ||
+ | echo 1 > / | ||
+ | echo 1 > / | ||
+ | echo 1 > / | ||
+ | done | ||
+ | </ | ||
===== References ===== | ===== References ===== | ||
* [[https:// | * [[https:// | ||
{{tag> | {{tag> |