ar8327_led_register(struct ar8327_led *aled)
{
int ret;
+ struct led_init_data init_data = {
+ .fwnode = aled->fwnode
+ };
- ret = led_classdev_register(NULL, &aled->cdev);
+ ret = led_classdev_register_ext(NULL, &aled->cdev, &init_data);
if (ret < 0)
return ret;
aled->led_num = led_info->led_num;
aled->active_low = led_info->active_low;
aled->mode = led_info->mode;
+ aled->fwnode = led_info->fwnode;
if (aled->mode == AR8327_LED_MODE_HW)
aled->enable_hw_mode = true;
const __be32 *paddr;
int len;
int i;
+ struct device_node *leds, *child;
paddr = of_get_property(np, "qca,ar8327-initvals", &len);
if (!paddr || len < (2 * sizeof(*paddr)))
}
}
+ leds = of_get_child_by_name(np, "leds");
+ if (!leds)
+ return 0;
+
+ data->leds = kvcalloc(of_get_child_count(leds), sizeof(void *),
+ GFP_KERNEL);
+ if (!data->leds)
+ return -ENOMEM;
+
+ for_each_available_child_of_node(leds, child) {
+ u32 reg = 0, mode = 0;
+ struct ar8327_led_info info;
+ int ret;
+
+ ret = of_property_read_u32(child, "reg", ®);
+ if (ret) {
+ pr_err("ar8327: LED %s is missing reg node\n", child->name);
+ continue;
+ }
+
+ of_property_read_u32(child, "qca,led-mode", &mode);
+
+ info = (struct ar8327_led_info) {
+ .name = of_get_property(child, "label", NULL) ? : child->name,
+ .fwnode = of_fwnode_handle(child),
+ .active_low = of_property_read_bool(child, "active-low"),
+ .led_num = (enum ar8327_led_num) reg,
+ .mode = (enum ar8327_led_mode) mode
+ };
+ ar8327_led_create(priv, &info);
+ }
+
+ of_node_put(leds);
return 0;
}
#else