Lines Matching +full:pin +full:- +full:val

1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Driver for BCM6328 memory-mapped LEDs, based on leds-syscon.c
59 * struct bcm6328_led - state container for bcm6328 based LEDs
63 * @pin: LED pin number
72 unsigned long pin; member
98 * bits [31:0] -> LEDs 8-23
99 * bits [47:32] -> LEDs 0-7
100 * bits [63:48] -> unused
102 static unsigned long bcm6328_pin2shift(unsigned long pin) in bcm6328_pin2shift() argument
104 if (pin < 8) in bcm6328_pin2shift()
105 return pin + 16; /* LEDs 0-7 (bits 47:32) */ in bcm6328_pin2shift()
107 return pin - 8; /* LEDs 8-23 (bits 31:0) */ in bcm6328_pin2shift()
113 unsigned long val, shift; in bcm6328_led_mode() local
115 shift = bcm6328_pin2shift(led->pin); in bcm6328_led_mode()
117 mode = led->mem + BCM6328_REG_MODE_HI; in bcm6328_led_mode()
119 mode = led->mem + BCM6328_REG_MODE_LO; in bcm6328_led_mode()
121 val = bcm6328_led_read(mode); in bcm6328_led_mode()
122 val &= ~(BCM6328_LED_MODE_MASK << BCM6328_LED_SHIFT(shift % 16)); in bcm6328_led_mode()
123 val |= (value << BCM6328_LED_SHIFT(shift % 16)); in bcm6328_led_mode()
124 bcm6328_led_write(mode, val); in bcm6328_led_mode()
134 spin_lock_irqsave(led->lock, flags); in bcm6328_led_set()
137 led->blink_leds[0] &= ~BIT(led->pin); in bcm6328_led_set()
138 led->blink_leds[1] &= ~BIT(led->pin); in bcm6328_led_set()
141 if ((led->active_low && value == LED_OFF) || in bcm6328_led_set()
142 (!led->active_low && value != LED_OFF)) in bcm6328_led_set()
147 spin_unlock_irqrestore(led->lock, flags); in bcm6328_led_set()
177 dev_dbg(led_cdev->dev, in bcm6328_blink_set()
179 return -EINVAL; in bcm6328_blink_set()
183 dev_dbg(led_cdev->dev, in bcm6328_blink_set()
186 return -EINVAL; in bcm6328_blink_set()
189 spin_lock_irqsave(led->lock, flags); in bcm6328_blink_set()
197 if (led->blink_leds[0] == 0 || in bcm6328_blink_set()
198 led->blink_leds[0] == BIT(led->pin) || in bcm6328_blink_set()
199 led->blink_delay[0] == delay) { in bcm6328_blink_set()
200 unsigned long val; in bcm6328_blink_set() local
203 led->blink_leds[0] |= BIT(led->pin); in bcm6328_blink_set()
206 led->blink_leds[1] &= ~BIT(led->pin); in bcm6328_blink_set()
209 led->blink_delay[0] = delay; in bcm6328_blink_set()
212 val = bcm6328_led_read(led->mem + BCM6328_REG_INIT); in bcm6328_blink_set()
213 val &= ~BCM6328_LED_BLINK1_MASK; in bcm6328_blink_set()
214 val |= (delay << BCM6328_LED_BLINK1_SHIFT); in bcm6328_blink_set()
215 bcm6328_led_write(led->mem + BCM6328_REG_INIT, val); in bcm6328_blink_set()
221 } else if (led->blink_leds[1] == 0 || in bcm6328_blink_set()
222 led->blink_leds[1] == BIT(led->pin) || in bcm6328_blink_set()
223 led->blink_delay[1] == delay) { in bcm6328_blink_set()
224 unsigned long val; in bcm6328_blink_set() local
227 led->blink_leds[0] &= ~BIT(led->pin); in bcm6328_blink_set()
230 led->blink_leds[1] |= BIT(led->pin); in bcm6328_blink_set()
233 led->blink_delay[1] = delay; in bcm6328_blink_set()
236 val = bcm6328_led_read(led->mem + BCM6328_REG_INIT); in bcm6328_blink_set()
237 val &= ~BCM6328_LED_BLINK2_MASK; in bcm6328_blink_set()
238 val |= (delay << BCM6328_LED_BLINK2_SHIFT); in bcm6328_blink_set()
239 bcm6328_led_write(led->mem + BCM6328_REG_INIT, val); in bcm6328_blink_set()
246 dev_dbg(led_cdev->dev, in bcm6328_blink_set()
248 rc = -EINVAL; in bcm6328_blink_set()
250 spin_unlock_irqrestore(led->lock, flags); in bcm6328_blink_set()
259 unsigned long flags, val; in bcm6328_hwled() local
262 val = bcm6328_led_read(mem + BCM6328_REG_HWDIS); in bcm6328_hwled()
263 val &= ~BIT(reg); in bcm6328_hwled()
264 bcm6328_led_write(mem + BCM6328_REG_HWDIS, val); in bcm6328_hwled()
267 /* Only LEDs 0-7 can be activity/link controlled */ in bcm6328_hwled()
271 cnt = of_property_count_elems_of_size(nc, "brcm,link-signal-sources", in bcm6328_hwled()
282 of_property_read_u32_index(nc, "brcm,link-signal-sources", i, in bcm6328_hwled()
291 val = bcm6328_led_read(addr); in bcm6328_hwled()
292 val |= (BIT(reg % 4) << (((sel % 4) * 4) + 16)); in bcm6328_hwled()
293 bcm6328_led_write(addr, val); in bcm6328_hwled()
298 "brcm,activity-signal-sources", in bcm6328_hwled()
309 of_property_read_u32_index(nc, "brcm,activity-signal-sources", in bcm6328_hwled()
318 val = bcm6328_led_read(addr); in bcm6328_hwled()
319 val |= (BIT(reg % 4) << ((sel % 4) * 4)); in bcm6328_hwled()
320 bcm6328_led_write(addr, val); in bcm6328_hwled()
334 unsigned long val, shift; in bcm6328_led() local
340 return -ENOMEM; in bcm6328_led()
342 led->pin = reg; in bcm6328_led()
343 led->mem = mem; in bcm6328_led()
344 led->lock = lock; in bcm6328_led()
345 led->blink_leds = blink_leds; in bcm6328_led()
346 led->blink_delay = blink_delay; in bcm6328_led()
348 if (of_property_read_bool(nc, "active-low")) in bcm6328_led()
349 led->active_low = true; in bcm6328_led()
356 led->cdev.brightness = LED_FULL; in bcm6328_led()
359 shift = bcm6328_pin2shift(led->pin); in bcm6328_led()
365 val = bcm6328_led_read(mode) >> BCM6328_LED_SHIFT(shift % 16); in bcm6328_led()
366 val &= BCM6328_LED_MODE_MASK; in bcm6328_led()
367 if ((led->active_low && val == BCM6328_LED_MODE_OFF) || in bcm6328_led()
368 (!led->active_low && val == BCM6328_LED_MODE_ON)) in bcm6328_led()
369 led->cdev.brightness = LED_FULL; in bcm6328_led()
371 led->cdev.brightness = LED_OFF; in bcm6328_led()
374 led->cdev.brightness = LED_OFF; in bcm6328_led()
377 bcm6328_led_set(&led->cdev, led->cdev.brightness); in bcm6328_led()
379 led->cdev.brightness_set = bcm6328_led_set; in bcm6328_led()
380 led->cdev.blink_set = bcm6328_blink_set; in bcm6328_led()
382 rc = devm_led_classdev_register_ext(dev, &led->cdev, &init_data); in bcm6328_led()
386 dev_dbg(dev, "registered LED %s\n", led->cdev.name); in bcm6328_led()
393 struct device *dev = &pdev->dev; in bcm6328_leds_probe()
394 struct device_node *np = dev_of_node(&pdev->dev); in bcm6328_leds_probe()
397 unsigned long val, *blink_leds, *blink_delay; in bcm6328_leds_probe() local
405 return -ENOMEM; in bcm6328_leds_probe()
410 return -ENOMEM; in bcm6328_leds_probe()
415 return -ENOMEM; in bcm6328_leds_probe()
423 val = bcm6328_led_read(mem + BCM6328_REG_INIT); in bcm6328_leds_probe()
424 val &= ~(BCM6328_INIT_MASK); in bcm6328_leds_probe()
425 if (of_property_read_bool(np, "brcm,serial-leds")) in bcm6328_leds_probe()
426 val |= BCM6328_SERIAL_LED_EN; in bcm6328_leds_probe()
427 if (of_property_read_bool(np, "brcm,serial-mux")) in bcm6328_leds_probe()
428 val |= BCM6328_SERIAL_LED_MUX; in bcm6328_leds_probe()
429 if (of_property_read_bool(np, "brcm,serial-clk-low")) in bcm6328_leds_probe()
430 val |= BCM6328_SERIAL_LED_CLK_NPOL; in bcm6328_leds_probe()
431 if (!of_property_read_bool(np, "brcm,serial-dat-low")) in bcm6328_leds_probe()
432 val |= BCM6328_SERIAL_LED_DATA_PPOL; in bcm6328_leds_probe()
433 if (!of_property_read_bool(np, "brcm,serial-shift-inv")) in bcm6328_leds_probe()
434 val |= BCM6328_SERIAL_LED_SHIFT_DIR; in bcm6328_leds_probe()
435 bcm6328_led_write(mem + BCM6328_REG_INIT, val); in bcm6328_leds_probe()
450 if (of_property_read_bool(child, "brcm,hardware-controlled")) in bcm6328_leds_probe()
464 { .compatible = "brcm,bcm6328-leds", },
472 .name = "leds-bcm6328",
483 MODULE_ALIAS("platform:leds-bcm6328");