1 // SPDX-License-Identifier: GPL-2.0-only
2 #include <linux/gpio/driver.h>
3 #include <linux/module.h>
4 #include <linux/platform_device.h>
5 #include <linux/delay.h>
6 #include <asm/mach-rtl838x/mach-rtl838x.h>
8 /* RTL8231 registers for LED control */
9 #define RTL8231_LED_FUNC0 0x0000
10 #define RTL8231_GPIO_PIN_SEL(gpio) ((0x0002) + ((gpio) >> 4))
11 #define RTL8231_GPIO_DIR(gpio) ((0x0005) + ((gpio) >> 4))
12 #define RTL8231_GPIO_DATA(gpio) ((0x001C) + ((gpio) >> 4))
13 #define RTL8231_GPIO_PIN_SEL0 0x0002
14 #define RTL8231_GPIO_PIN_SEL1 0x0003
15 #define RTL8231_GPIO_PIN_SEL2 0x0004
16 #define RTL8231_GPIO_IO_SEL0 0x0005
17 #define RTL8231_GPIO_IO_SEL1 0x0006
18 #define RTL8231_GPIO_IO_SEL2 0x0007
20 #define MDC_WAIT { int i; for (i = 0; i < 2; i++); }
21 #define I2C_WAIT { int i; for (i = 0; i < 5; i++); }
23 struct rtl838x_gpios
{
40 extern struct mutex smi_lock
;
42 u32
rtl838x_rtl8231_read(u8 bus_id
, u32 reg
)
49 /* Calculate read register address */
50 t
= (bus_id
<< 2) | (reg
<< 7);
52 mutex_lock(&smi_lock
);
53 /* Set execution bit: cleared when operation completed */
55 sw_w32(t
, RTL838X_EXT_GPIO_INDRT_ACCESS
);
56 do { /* TODO: Return 0x80000000 if timeout */
57 t
= sw_r32(RTL838X_EXT_GPIO_INDRT_ACCESS
);
59 pr_debug("%s: %x, %x, %x\n", __func__
, bus_id
, reg
, (t
& 0xffff0000) >> 16);
61 mutex_unlock(&smi_lock
);
62 return (t
& 0xffff0000) >> 16;
65 int rtl838x_rtl8231_write(u8 bus_id
, u32 reg
, u32 data
)
69 pr_debug("%s: %x, %x, %x\n", __func__
, bus_id
, reg
, data
);
74 mutex_lock(&smi_lock
);
75 t
= (bus_id
<< 2) | (reg
<< 7) | (data
<< 16);
79 /* Set execution bit: cleared when operation completed */
81 sw_w32(t
, RTL838X_EXT_GPIO_INDRT_ACCESS
);
82 do { /* TODO: Return -1 if timeout */
83 t
= sw_r32(RTL838X_EXT_GPIO_INDRT_ACCESS
);
86 mutex_unlock(&smi_lock
);
90 static int rtl8231_pin_dir(u8 bus_id
, u32 gpio
, u32 dir
)
97 int pin_sel_addr
= RTL8231_GPIO_PIN_SEL(gpio
);
98 int pin_dir_addr
= RTL8231_GPIO_DIR(gpio
);
104 pin_dir_addr
= pin_sel_addr
;
107 /* Select GPIO function for pin */
108 v
= rtl838x_rtl8231_read(bus_id
, pin_sel_addr
);
109 if (v
& 0x80000000) {
110 pr_err("Error reading RTL8231\n");
113 rtl838x_rtl8231_write(bus_id
, pin_sel_addr
, v
| (1 << pin
));
115 v
= rtl838x_rtl8231_read(bus_id
, pin_dir_addr
);
116 if (v
& 0x80000000) {
117 pr_err("Error reading RTL8231\n");
120 rtl838x_rtl8231_write(bus_id
, pin_dir_addr
,
121 (v
& ~(1 << dpin
)) | (dir
<< dpin
));
125 static int rtl8231_pin_dir_get(u8 bus_id
, u32 gpio
, u32
*dir
)
132 int pin_dir_addr
= RTL8231_GPIO_DIR(gpio
);
136 pin_dir_addr
= RTL8231_GPIO_PIN_SEL(gpio
);
140 v
= rtl838x_rtl8231_read(bus_id
, pin_dir_addr
);
148 static int rtl8231_pin_set(u8 bus_id
, u32 gpio
, u32 data
)
150 u32 v
= rtl838x_rtl8231_read(bus_id
, RTL8231_GPIO_DATA(gpio
));
152 if (v
& 0x80000000) {
153 pr_err("Error reading RTL8231\n");
156 rtl838x_rtl8231_write(bus_id
, RTL8231_GPIO_DATA(gpio
),
157 (v
& ~(1 << (gpio
% 16))) | (data
<< (gpio
% 16)));
161 static int rtl8231_pin_get(u8 bus_id
, u32 gpio
, u16
*state
)
163 u32 v
= rtl838x_rtl8231_read(bus_id
, RTL8231_GPIO_DATA(gpio
));
165 if (v
& 0x80000000) {
166 pr_err("Error reading RTL8231\n");
174 static int rtl838x_direction_input(struct gpio_chip
*gc
, unsigned int offset
)
176 struct rtl838x_gpios
*gpios
= gpiochip_get_data(gc
);
178 pr_debug("%s: %d\n", __func__
, offset
);
181 rtl838x_w32_mask(1 << offset
, 0, RTL838X_GPIO_PABC_DIR
);
185 /* Internal LED driver does not support input */
186 if (offset
>= 32 && offset
< 64)
189 if (offset
>= 64 && offset
< 100 && gpios
->bus_id
>= 0)
190 return rtl8231_pin_dir(gpios
->bus_id
, offset
- 64, 1);
195 static int rtl838x_direction_output(struct gpio_chip
*gc
, unsigned int offset
, int value
)
197 struct rtl838x_gpios
*gpios
= gpiochip_get_data(gc
);
199 pr_debug("%s: %d\n", __func__
, offset
);
201 rtl838x_w32_mask(0, 1 << offset
, RTL838X_GPIO_PABC_DIR
);
203 /* LED for PWR and SYS driver is direction output by default */
204 if (offset
>= 32 && offset
< 64)
207 if (offset
>= 64 && offset
< 100 && gpios
->bus_id
>= 0)
208 return rtl8231_pin_dir(gpios
->bus_id
, offset
- 64, 0);
212 static int rtl838x_get_direction(struct gpio_chip
*gc
, unsigned int offset
)
215 struct rtl838x_gpios
*gpios
= gpiochip_get_data(gc
);
217 pr_debug("%s: %d\n", __func__
, offset
);
219 v
= rtl838x_r32(RTL838X_GPIO_PABC_DIR
);
220 if (v
& (1 << offset
))
225 /* LED driver for PWR and SYS is direction output by default */
226 if (offset
>= 32 && offset
< 64)
229 if (offset
>= 64 && offset
< 100 && gpios
->bus_id
>= 0) {
230 rtl8231_pin_dir_get(gpios
->bus_id
, offset
- 64, &v
);
237 static int rtl838x_gpio_get(struct gpio_chip
*gc
, unsigned int offset
)
242 struct rtl838x_gpios
*gpios
= gpiochip_get_data(gc
);
244 pr_debug("%s: %d\n", __func__
, offset
);
246 /* Internal GPIO of the RTL8380 */
248 v
= rtl838x_r32(RTL838X_GPIO_PABC_DATA
);
249 if (v
& (1 << offset
))
254 /* LED driver for PWR and SYS */
255 if (offset
>= 32 && offset
< 64) {
256 v
= sw_r32(RTL838X_LED_GLB_CTRL
);
257 if (v
& (1 << (offset
-32)))
262 /* Indirect access GPIO with RTL8231 */
263 if (offset
>= 64 && offset
< 100 && gpios
->bus_id
>= 0) {
264 rtl8231_pin_get(gpios
->bus_id
, offset
- 64, &state
);
265 if (state
& (1 << (offset
% 16)))
270 bit
= (offset
- 100) % 32;
271 if (offset
>= 100 && offset
< 132) {
272 if (sw_r32(RTL838X_LED1_SW_P_EN_CTRL
) & (1 << bit
))
276 if (offset
>= 132 && offset
< 164) {
277 if (sw_r32(RTL838X_LED1_SW_P_EN_CTRL
) & (1 << bit
))
281 if (offset
>= 164 && offset
< 196) {
282 if (sw_r32(RTL838X_LED1_SW_P_EN_CTRL
) & (1 << bit
))
289 void rtl838x_gpio_set(struct gpio_chip
*gc
, unsigned int offset
, int value
)
292 struct rtl838x_gpios
*gpios
= gpiochip_get_data(gc
);
294 pr_debug("rtl838x_set: %d, value: %d\n", offset
, value
);
295 /* Internal GPIO of the RTL8380 */
298 rtl838x_w32_mask(0, 1 << offset
, RTL838X_GPIO_PABC_DATA
);
300 rtl838x_w32_mask(1 << offset
, 0, RTL838X_GPIO_PABC_DATA
);
303 /* LED driver for PWR and SYS */
304 if (offset
>= 32 && offset
< 64) {
307 sw_w32_mask(0, 1 << bit
, RTL838X_LED_GLB_CTRL
);
309 sw_w32_mask(1 << bit
, 0, RTL838X_LED_GLB_CTRL
);
313 /* Indirect access GPIO with RTL8231 */
314 if (offset
>= 64 && offset
< 100 && gpios
->bus_id
>= 0) {
315 rtl8231_pin_set(gpios
->bus_id
, offset
- 64, value
);
319 bit
= (offset
- 100) % 32;
321 if (offset
>= 100 && offset
< 132
322 && offset
>= (100 + gpios
->min_led
)
323 && offset
< (100 + gpios
->min_led
+ gpios
->num_leds
)) {
325 sw_w32_mask(7, 5, RTL838X_LED_SW_P_CTRL(bit
));
327 sw_w32_mask(7, 0, RTL838X_LED_SW_P_CTRL(bit
));
329 if (offset
>= 132 && offset
< 164
330 && offset
>= (132 + gpios
->min_led
)
331 && offset
< (132 + gpios
->min_led
+ gpios
->num_leds
)) {
333 sw_w32_mask(7 << 3, 5 << 3, RTL838X_LED_SW_P_CTRL(bit
));
335 sw_w32_mask(7 << 3, 0, RTL838X_LED_SW_P_CTRL(bit
));
337 if (offset
>= 164 && offset
< 196
338 && offset
>= (164 + gpios
->min_led
)
339 && offset
< (164 + gpios
->min_led
+ gpios
->num_leds
)) {
341 sw_w32_mask(7 << 6, 5 << 6, RTL838X_LED_SW_P_CTRL(bit
));
343 sw_w32_mask(7 << 6, 0, RTL838X_LED_SW_P_CTRL(bit
));
345 __asm__
volatile ("sync");
348 int rtl8231_init(struct rtl838x_gpios
*gpios
)
351 u8 bus_id
= gpios
->bus_id
;
353 pr_info("%s called\n", __func__
);
355 /* Enable RTL8231 indirect access mode */
356 sw_w32_mask(0, 1, RTL838X_EXTRA_GPIO_CTRL
);
357 sw_w32_mask(3, 1, RTL838X_DMY_REG5
);
359 /* Enable RTL8231 via GPIO_A1 line */
360 rtl838x_w32_mask(0, 1 << RTL838X_GPIO_A1
, RTL838X_GPIO_PABC_DIR
);
361 rtl838x_w32_mask(0, 1 << RTL838X_GPIO_A1
, RTL838X_GPIO_PABC_DATA
);
362 mdelay(50); /* wait 50ms for reset */
364 /*Select GPIO functionality for pins 0-15, 16-31 and 32-37 */
365 rtl838x_rtl8231_write(bus_id
, RTL8231_GPIO_PIN_SEL(0), 0xffff);
366 rtl838x_rtl8231_write(bus_id
, RTL8231_GPIO_PIN_SEL(16), 0xffff);
367 rtl838x_rtl8231_write(bus_id
, RTL8231_GPIO_PIN_SEL2
, 0x03ff);
369 v
= rtl838x_rtl8231_read(bus_id
, RTL8231_LED_FUNC0
);
370 pr_info("RTL8231 led function now: %x\n", v
);
375 static void smi_write_bit(struct rtl838x_gpios
*gpios
, u32 bit
)
378 rtl838x_w32_mask(0, 1 << gpios
->smi_data
, RTL838X_GPIO_PABC_DATA
);
380 rtl838x_w32_mask(1 << gpios
->smi_data
, 0, RTL838X_GPIO_PABC_DATA
);
383 rtl838x_w32_mask(1 << gpios
->smi_clock
, 0, RTL838X_GPIO_PABC_DATA
);
385 rtl838x_w32_mask(0, 1 << gpios
->smi_clock
, RTL838X_GPIO_PABC_DATA
);
388 static int smi_read_bit(struct rtl838x_gpios
*gpios
)
393 rtl838x_w32_mask(1 << gpios
->smi_clock
, 0, RTL838X_GPIO_PABC_DATA
);
395 rtl838x_w32_mask(0, 1 << gpios
->smi_clock
, RTL838X_GPIO_PABC_DATA
);
397 v
= rtl838x_r32(RTL838X_GPIO_PABC_DATA
);
398 if (v
& (1 << gpios
->smi_data
))
403 /* Tri-state of MDIO line */
404 static void smi_z(struct rtl838x_gpios
*gpios
)
406 /* MDIO pin to input */
407 rtl838x_w32_mask(1 << gpios
->smi_data
, 0, RTL838X_GPIO_PABC_DIR
);
409 rtl838x_w32_mask(1 << gpios
->smi_clock
, 0, RTL838X_GPIO_PABC_DATA
);
411 rtl838x_w32_mask(0, 1 << gpios
->smi_clock
, RTL838X_GPIO_PABC_DATA
);
414 static void smi_write_bits(struct rtl838x_gpios
*gpios
, u32 data
, int len
)
418 smi_write_bit(gpios
, data
& (1 << len
));
422 static void smi_read_bits(struct rtl838x_gpios
*gpios
, int len
, u32
*data
)
429 v
|= smi_read_bit(gpios
);
434 /* Bit-banged verson of SMI write access, caller must hold smi_lock */
435 int rtl8380_smi_write(struct rtl838x_gpios
*gpios
, u16 reg
, u32 data
)
437 u16 bus_id
= gpios
->bus_id
;
439 /* Set clock and data pins on RTL838X to output */
440 rtl838x_w32_mask(0, 1 << gpios
->smi_clock
, RTL838X_GPIO_PABC_DIR
);
441 rtl838x_w32_mask(0, 1 << gpios
->smi_data
, RTL838X_GPIO_PABC_DIR
);
443 /* Write start bits */
444 smi_write_bits(gpios
, 0xffffffff, 32);
446 smi_write_bits(gpios
, 0x5, 4); /* ST and write OP */
448 smi_write_bits(gpios
, bus_id
, 5); /* 5 bits: phy address */
449 smi_write_bits(gpios
, reg
, 5); /* 5 bits: register address */
451 smi_write_bits(gpios
, 0x2, 2); /* TURNAROUND */
453 smi_write_bits(gpios
, data
, 16); /* 16 bits: data*/
460 /* Bit-banged verson of SMI read access, caller must hold smi_lock */
461 int rtl8380_smi_read(struct rtl838x_gpios
*gpios
, u16 reg
, u32
*data
)
463 u16 bus_id
= gpios
->bus_id
;
465 /* Set clock and data pins on RTL838X to output */
466 rtl838x_w32_mask(0, 1 << gpios
->smi_clock
, RTL838X_GPIO_PABC_DIR
);
467 rtl838x_w32_mask(0, 1 << gpios
->smi_data
, RTL838X_GPIO_PABC_DIR
);
469 /* Write start bits */
470 smi_write_bits(gpios
, 0xffffffff, 32);
472 smi_write_bits(gpios
, 0x6, 4); /* ST and read OP */
474 smi_write_bits(gpios
, bus_id
, 5); /* 5 bits: phy address */
475 smi_write_bits(gpios
, reg
, 5); /* 5 bits: register address */
477 smi_z(gpios
); /* TURNAROUND */
479 smi_read_bits(gpios
, 16, data
);
483 static void i2c_pin_set(struct rtl838x_gpios
*gpios
, int pin
, u32 data
)
487 rtl8380_smi_read(gpios
, RTL8231_GPIO_DATA(pin
), &v
);
489 v
&= ~(1 << (pin
% 16));
491 v
|= (1 << (pin
% 16));
492 rtl8380_smi_write(gpios
, RTL8231_GPIO_DATA(pin
), v
);
495 static void i2c_pin_get(struct rtl838x_gpios
*gpios
, int pin
, u32
*data
)
499 rtl8380_smi_read(gpios
, RTL8231_GPIO_DATA(pin
), &v
);
500 if (v
& (1 << (pin
% 16))) {
507 static void i2c_pin_dir(struct rtl838x_gpios
*gpios
, int pin
, u16 direction
)
511 rtl8380_smi_read(gpios
, RTL8231_GPIO_DIR(pin
), &v
);
512 if (direction
) // Output
513 v
&= ~(1 << (pin
% 16));
515 v
|= (1 << (pin
% 16));
516 rtl8380_smi_write(gpios
, RTL8231_GPIO_DIR(pin
), v
);
519 static void i2c_start(struct rtl838x_gpios
*gpios
)
521 i2c_pin_dir(gpios
, gpios
->i2c_sda
, 0); /* Output */
522 i2c_pin_dir(gpios
, gpios
->i2c_sdc
, 0); /* Output */
524 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 1);
526 i2c_pin_set(gpios
, gpios
->i2c_sda
, 1);
528 i2c_pin_set(gpios
, gpios
->i2c_sda
, 0);
530 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 0);
534 static void i2c_stop(struct rtl838x_gpios
*gpios
)
537 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 1);
538 i2c_pin_set(gpios
, gpios
->i2c_sda
, 0);
541 i2c_pin_set(gpios
, gpios
->i2c_sda
, 1);
543 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 0);
545 i2c_pin_dir(gpios
, gpios
->i2c_sda
, 1); /* Input */
546 i2c_pin_dir(gpios
, gpios
->i2c_sdc
, 1); /* Input */
549 static void i2c_read_bits(struct rtl838x_gpios
*gpios
, int len
, u32
*data
)
556 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 1);
558 i2c_pin_get(gpios
, gpios
->i2c_sda
, &t
);
560 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 0);
566 static void i2c_write_bits(struct rtl838x_gpios
*gpios
, u32 data
, int len
)
570 i2c_pin_set(gpios
, gpios
->i2c_sda
, data
& (1 << len
));
572 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 1);
574 i2c_pin_set(gpios
, gpios
->i2c_sdc
, 0);
579 /* This initializes direct external GPIOs via the RTL8231 */
580 int rtl8380_rtl8321_init(struct rtl838x_gpios
*gpios
)
583 int mdc
= gpios
->smi_clock
;
584 int mdio
= gpios
->smi_data
;
586 pr_info("Configuring SMI: Clock %d, Data %d\n", mdc
, mdio
);
587 sw_w32_mask(0, 0x2, RTL838X_IO_DRIVING_ABILITY_CTRL
);
589 /* Enter simulated GPIO mode */
590 sw_w32_mask(1, 0, RTL838X_EXTRA_GPIO_CTRL
);
592 /* MDIO clock to 2.6MHz */
593 sw_w32_mask(0x3 << 8, 0, RTL838X_EXTRA_GPIO_CTRL
);
595 /* Configure SMI clock and data GPIO pins */
596 rtl838x_w32_mask((1 << mdc
) | (1 << mdio
), 0, RTL838X_GPIO_PABC_CNR
);
597 rtl838x_w32_mask(0, (1 << mdc
) | (1 << mdio
), RTL838X_GPIO_PABC_DIR
);
599 rtl8380_smi_write(gpios
, RTL8231_GPIO_PIN_SEL0
, 0xffff);
600 rtl8380_smi_write(gpios
, RTL8231_GPIO_PIN_SEL1
, 0xffff);
601 rtl8380_smi_read(gpios
, RTL8231_GPIO_PIN_SEL2
, &v
);
603 rtl8380_smi_write(gpios
, RTL8231_GPIO_PIN_SEL2
, v
);
605 rtl8380_smi_write(gpios
, RTL8231_GPIO_IO_SEL0
, 0xffff);
606 rtl8380_smi_write(gpios
, RTL8231_GPIO_IO_SEL1
, 0xffff);
607 rtl8380_smi_read(gpios
, RTL8231_GPIO_IO_SEL2
, &v
);
609 rtl8380_smi_write(gpios
, RTL8231_GPIO_PIN_SEL2
, v
);
614 void rtl8380_led_test(u32 mask
)
617 u32 mode_sel
= sw_r32(RTL838X_LED_MODE_SEL
);
618 u32 led_gbl
= sw_r32(RTL838X_LED_GLB_CTRL
);
619 u32 led_p_en
= sw_r32(RTL838X_LED_P_EN_CTRL
);
621 /* 2 Leds for ports 0-23 and 24-27, 3 would be 0x7 */
622 sw_w32_mask(0x3f, 0x3 | (0x3 << 3), RTL838X_LED_GLB_CTRL
);
623 /* Enable all leds */
624 sw_w32(0xFFFFFFF, RTL838X_LED_P_EN_CTRL
);
626 /* Enable software control of all leds */
627 sw_w32(0xFFFFFFF, RTL838X_LED_SW_CTRL
);
628 sw_w32(0xFFFFFFF, RTL838X_LED0_SW_P_EN_CTRL
);
629 sw_w32(0xFFFFFFF, RTL838X_LED1_SW_P_EN_CTRL
);
630 sw_w32(0x0000000, RTL838X_LED2_SW_P_EN_CTRL
);
632 for (i
= 0; i
< 28; i
++) {
634 sw_w32(5 | (5 << 3) | (5 << 6),
635 RTL838X_LED_SW_P_CTRL(i
));
639 sw_w32(led_p_en
, RTL838X_LED_P_EN_CTRL
);
640 /* Disable software control of all leds */
641 sw_w32(0x0000000, RTL838X_LED_SW_CTRL
);
642 sw_w32(0x0000000, RTL838X_LED0_SW_P_EN_CTRL
);
643 sw_w32(0x0000000, RTL838X_LED1_SW_P_EN_CTRL
);
644 sw_w32(0x0000000, RTL838X_LED2_SW_P_EN_CTRL
);
646 sw_w32(led_gbl
, RTL838X_LED_GLB_CTRL
);
647 sw_w32(mode_sel
, RTL838X_LED_MODE_SEL
);
650 void take_port_leds(struct rtl838x_gpios
*gpios
)
652 int leds_per_port
= gpios
->leds_per_port
;
653 int mode
= gpios
->led_mode
;
655 pr_info("%s, %d, %x\n", __func__
, leds_per_port
, mode
);
656 pr_debug("Bootloader settings: %x %x %x\n",
657 sw_r32(RTL838X_LED0_SW_P_EN_CTRL
),
658 sw_r32(RTL838X_LED1_SW_P_EN_CTRL
),
659 sw_r32(RTL838X_LED2_SW_P_EN_CTRL
)
662 pr_debug("led glb: %x, sel %x\n",
663 sw_r32(RTL838X_LED_GLB_CTRL
), sw_r32(RTL838X_LED_MODE_SEL
));
664 pr_debug("RTL838X_LED_P_EN_CTRL: %x", sw_r32(RTL838X_LED_P_EN_CTRL
));
665 pr_debug("RTL838X_LED_MODE_CTRL: %x", sw_r32(RTL838X_LED_MODE_CTRL
));
667 sw_w32_mask(3, 0, RTL838X_LED_MODE_SEL
);
668 sw_w32(mode
, RTL838X_LED_MODE_CTRL
);
670 /* Enable software control of all leds */
671 sw_w32(0xFFFFFFF, RTL838X_LED_SW_CTRL
);
672 sw_w32(0xFFFFFFF, RTL838X_LED_P_EN_CTRL
);
674 sw_w32(0x0000000, RTL838X_LED0_SW_P_EN_CTRL
);
675 sw_w32(0x0000000, RTL838X_LED1_SW_P_EN_CTRL
);
676 sw_w32(0x0000000, RTL838X_LED2_SW_P_EN_CTRL
);
678 sw_w32_mask(0x3f, 0, RTL838X_LED_GLB_CTRL
);
679 switch (leds_per_port
) {
681 sw_w32_mask(0, 0x7 | (0x7 << 3), RTL838X_LED_GLB_CTRL
);
682 sw_w32(0xFFFFFFF, RTL838X_LED2_SW_P_EN_CTRL
);
685 sw_w32_mask(0, 0x3 | (0x3 << 3), RTL838X_LED_GLB_CTRL
);
686 sw_w32(0xFFFFFFF, RTL838X_LED1_SW_P_EN_CTRL
);
689 sw_w32_mask(0, 0x1 | (0x1 << 3), RTL838X_LED_GLB_CTRL
);
690 sw_w32(0xFFFFFFF, RTL838X_LED0_SW_P_EN_CTRL
);
693 pr_err("No LEDS configured for software control\n");
697 static const struct of_device_id rtl838x_gpio_of_match
[] = {
698 { .compatible
= "realtek,rtl838x-gpio" },
702 MODULE_DEVICE_TABLE(of
, rtl838x_gpio_of_match
);
704 static int rtl838x_gpio_probe(struct platform_device
*pdev
)
706 struct device
*dev
= &pdev
->dev
;
707 struct device_node
*np
= dev
->of_node
;
708 struct rtl838x_gpios
*gpios
;
712 pr_info("Probing RTL838X GPIOs\n");
715 dev_err(&pdev
->dev
, "No DT found\n");
719 gpios
= devm_kzalloc(dev
, sizeof(*gpios
), GFP_KERNEL
);
723 gpios
->id
= sw_r32(RTL838X_MODEL_NAME_INFO
) >> 16;
727 pr_debug("Found RTL8332M GPIO\n");
730 pr_debug("Found RTL8380M GPIO\n");
733 pr_debug("Found RTL8381M GPIO\n");
736 pr_debug("Found RTL8382M GPIO\n");
739 pr_err("Unknown GPIO chip id (%04x)\n", gpios
->id
);
746 * 32-63, LED control register
747 * 64-99: external RTL8231
748 * 100-131: PORT-LED 0
749 * 132-163: PORT-LED 1
750 * 164-195: PORT-LED 2
752 gpios
->gc
.ngpio
= 196;
753 gpios
->gc
.label
= "rtl838x";
754 gpios
->gc
.parent
= dev
;
755 gpios
->gc
.owner
= THIS_MODULE
;
756 gpios
->gc
.can_sleep
= true;
760 gpios
->gc
.direction_input
= rtl838x_direction_input
;
761 gpios
->gc
.direction_output
= rtl838x_direction_output
;
762 gpios
->gc
.set
= rtl838x_gpio_set
;
763 gpios
->gc
.get
= rtl838x_gpio_get
;
764 gpios
->gc
.get_direction
= rtl838x_get_direction
;
766 if (!of_property_read_u8(np
, "indirect-access-bus-id", &indirect_bus_id
)) {
767 gpios
->bus_id
= indirect_bus_id
;
770 if (!of_property_read_u8(np
, "smi-bus-id", &indirect_bus_id
)) {
771 gpios
->bus_id
= indirect_bus_id
;
772 gpios
->smi_clock
= RTL838X_GPIO_A2
;
773 gpios
->smi_data
= RTL838X_GPIO_A3
;
776 rtl8380_rtl8321_init(gpios
);
779 if (of_property_read_bool(np
, "take-port-leds")) {
780 if (of_property_read_u32(np
, "leds-per-port", &gpios
->leds_per_port
))
781 gpios
->leds_per_port
= 2;
782 if (of_property_read_u32(np
, "led-mode", &gpios
->led_mode
))
783 gpios
->led_mode
= (0x1ea << 15) | 0x1ea;
784 if (of_property_read_u32(np
, "num-leds", &gpios
->num_leds
))
785 gpios
->num_leds
= 32;
786 if (of_property_read_u32(np
, "min-led", &gpios
->min_led
))
788 take_port_leds(gpios
);
791 err
= devm_gpiochip_add_data(dev
, &gpios
->gc
, gpios
);
796 static struct platform_driver rtl838x_gpio_driver
= {
798 .name
= "rtl838x-gpio",
799 .of_match_table
= rtl838x_gpio_of_match
,
801 .probe
= rtl838x_gpio_probe
,
804 module_platform_driver(rtl838x_gpio_driver
);
806 MODULE_DESCRIPTION("Realtek RTL838X GPIO API support");
807 MODULE_LICENSE("GPL v2");