1 // SPDX-License-Identifier: GPL-2.0+
3 * common reset-controller functions for B&R boards
5 * Copyright (C) 2019 Hannes Schmelzer <oe5hpm@oevsv.at>
6 * B&R Industrial Automation GmbH - http://www.br-automation.com/ *
12 #include <dm/uclass.h>
13 #include "br_resetc.h"
15 /* I2C Address of controller */
16 #define RSTCTRL_ADDR_PSOC 0x75
17 #define RSTCTRL_ADDR_STM32 0x60
19 #define BMODE_DEFAULTAR 0
20 #define BMODE_SERVICE 2
25 #if CONFIG_IS_ENABLED(LCD) && !CONFIG_IS_ENABLED(DM_VIDEO)
27 #define LCD_SETCURSOR(x, y) lcd_position_cursor(x, y)
28 #define LCD_PUTS(x) lcd_puts(x)
30 #define LCD_SETCURSOR(x, y)
32 #endif /* CONFIG_LCD */
34 static const char *bootmodeascii[16] = {
35 "BOOT", "reserved", "reserved", "reserved",
36 "RUN", "reserved", "reserved", "reserved",
37 "reserved", "reserved", "reserved", "reserved",
38 "PME", "reserved", "reserved", "DIAG",
42 struct udevice *i2cdev;
46 static struct br_reset_t resetc;
48 __weak int board_boot_key(void)
53 __weak void board_boot_led(unsigned int on)
57 static int resetc_init(void)
59 struct udevice *i2cbus;
62 rc = uclass_get_device_by_seq(UCLASS_I2C, 0, &i2cbus);
64 printf("Cannot find I2C bus #0!\n");
69 rc = dm_i2c_probe(i2cbus,
70 RSTCTRL_ADDR_PSOC, 0, &resetc.i2cdev);
73 rc = dm_i2c_probe(i2cbus,
74 RSTCTRL_ADDR_STM32, 0, &resetc.i2cdev);
78 printf("Warning: cannot probe BuR resetcontroller!\n");
83 int br_resetc_regget(u8 reg, u8 *dst)
93 return dm_i2c_read(resetc.i2cdev, reg, dst, 1);
96 int br_resetc_regset(u8 reg, u8 val)
99 u16 regw = (val << 8) | val;
108 return dm_i2c_write(resetc.i2cdev, reg, (u8 *)®w, 2);
110 return dm_i2c_write(resetc.i2cdev, reg, (u8 *)®w, 1);
113 int br_resetc_bmode(void)
119 unsigned int bmode = 0;
127 rc = dm_i2c_read(resetc.i2cdev, RSTCTRL_ENHSTATUS, ®b, 1);
129 printf("WARN: cannot read ENHSTATUS from resetcontroller!\n");
133 rc = dm_i2c_read(resetc.i2cdev, RSTCTRL_SCRATCHREG0, &scr, 1);
135 printf("WARN: cannot read SCRATCHREG from resetcontroller!\n");
141 /* special bootmode from resetcontroller */
144 } else if (regb & 0x8) {
145 bmode = BMODE_DEFAULTAR;
146 } else if (board_boot_key() != 0) {
153 ("release KEY to enter SERVICE-mode. ");
157 ("release KEY to enter DIAGNOSE-mode. ");
161 ("release KEY to enter BOOT-mode. ");
166 if (board_boot_key() == 0)
175 bmode = BMODE_DEFAULTAR;
181 bmode = BMODE_SERVICE;
184 } else if ((regb & 0x1) || scr == 0xCC) {
194 LCD_PUTS("entering PME-Mode (netscript). ");
197 case BMODE_DEFAULTAR:
198 LCD_PUTS("entering BOOT-mode. ");
202 LCD_PUTS("entering DIAGNOSE-mode. ");
206 LCD_PUTS("entering SERVICE mode. ");
210 LCD_PUTS("loading OS... ");
218 rc = dm_i2c_write(resetc.i2cdev, RSTCTRL_SCRATCHREG0,
221 rc = dm_i2c_write(resetc.i2cdev, RSTCTRL_SCRATCHREG0,
225 printf("WARN: cannot write into resetcontroller!\n");
228 printf("Reset: PSOC controller\n");
230 printf("Reset: STM32 controller\n");
232 printf("Mode: %s\n", bootmodeascii[regw & 0x0F]);
233 env_set_ulong("b_mode", regw & 0x0F);