mirror of
https://git.openwrt.org/openwrt/openwrt.git
synced 2026-03-14 16:09:44 +01:00
realtek: rtl838x: fix non-functional reboot
RTL838x devices cannot reboot if the flash controller is driven in 4 byte mode. Unitlfdc3776("realtek: pcs: fix PLL_CML_CTRL for serdes 0/1") this bit was luckily cleared by a coding error. Since then the device cannot be rebooted anymore. Looking at the SDK one can see that this bit is reset short before the reboot happens. But we might need that in critical situations where there is no chance to do it right in time. As the RTL838x always ran with the bit disabled restore the old behaviour. This time implement it as a documented quirk so it does not get lost. Fixes:fdc3776("realtek: pcs: fix PLL_CML_CTRL for serdes 0/1") Signed-off-by: Markus Stockhausen <markus.stockhausen@gmx.de> Link: https://github.com/openwrt/openwrt/pull/22334 Signed-off-by: Robert Marko <robimarko@gmail.com>
This commit is contained in:
parent
5816d883ff
commit
b995f318b2
2 changed files with 15 additions and 2 deletions
|
|
@ -28,6 +28,7 @@
|
|||
|
||||
#define RTL838X_INT_RW_CTRL (0x0058)
|
||||
#define RTL838X_EXT_VERSION (0x00D0)
|
||||
#define RTL838X_PLL_CML_CTRL (0x0ff8)
|
||||
|
||||
#define RTL931X_LED_GLB_CTRL (0x0600)
|
||||
#define RTL931X_MAC_L2_GLOBAL_CTRL2 (0x1358)
|
||||
|
|
|
|||
|
|
@ -101,9 +101,21 @@ static int rtlsmp_register(void)
|
|||
|
||||
static void __init apply_early_quirks(void)
|
||||
{
|
||||
/* Open up write protected registers. Never mess with this elsewhere */
|
||||
if (soc_info.family == RTL8380_FAMILY_ID)
|
||||
if (soc_info.family == RTL8380_FAMILY_ID) {
|
||||
/*
|
||||
* Open up write protected registers. SDK opens/closes this whenever needed. For
|
||||
* simplicity always work with an "open" register set.
|
||||
*/
|
||||
sw_w32(0x3, RTL838X_INT_RW_CTRL);
|
||||
/*
|
||||
* Disable 4 byte address mode of flash controller. If this bit is not cleared
|
||||
* the watchdog cannot reset the SoC. The SDK changes this short before restart.
|
||||
* Until this quirk was implemented all RTL838x devices ran with this disabled
|
||||
* because of a coding error. As no issues were detected keep the behaviour
|
||||
* until more details are known.
|
||||
*/
|
||||
sw_w32_mask(BIT(30), 0, RTL838X_PLL_CML_CTRL);
|
||||
}
|
||||
}
|
||||
|
||||
static void __init apply_dts_quirks(void)
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue