1 // SPDX-License-Identifier: GPL-2.0
3 * LED Driver for SGI Octane machines
7 #include <linux/module.h>
8 #include <linux/kernel.h>
9 #include <linux/platform_device.h>
10 #include <linux/leds.h>
12 #define IP30_LED_SYSTEM 0
13 #define IP30_LED_FAULT 1
16 struct led_classdev cdev
;
20 static void ip30led_set(struct led_classdev
*led_cdev
,
21 enum led_brightness value
)
23 struct ip30_led
*led
= container_of(led_cdev
, struct ip30_led
, cdev
);
25 writel(value
, led
->reg
);
28 static int ip30led_create(struct platform_device
*pdev
, int num
)
31 struct ip30_led
*data
;
33 res
= platform_get_resource(pdev
, IORESOURCE_MEM
, num
);
37 data
= devm_kzalloc(&pdev
->dev
, sizeof(*data
), GFP_KERNEL
);
41 data
->reg
= devm_ioremap_resource(&pdev
->dev
, res
);
42 if (IS_ERR(data
->reg
))
43 return PTR_ERR(data
->reg
);
48 data
->cdev
.name
= "white:power";
51 data
->cdev
.name
= "red:fault";
57 data
->cdev
.brightness
= readl(data
->reg
);
58 data
->cdev
.max_brightness
= 1;
59 data
->cdev
.brightness_set
= ip30led_set
;
61 return devm_led_classdev_register(&pdev
->dev
, &data
->cdev
);
64 static int ip30led_probe(struct platform_device
*pdev
)
68 ret
= ip30led_create(pdev
, IP30_LED_SYSTEM
);
72 return ip30led_create(pdev
, IP30_LED_FAULT
);
75 static struct platform_driver ip30led_driver
= {
76 .probe
= ip30led_probe
,
82 module_platform_driver(ip30led_driver
);
84 MODULE_AUTHOR("Thomas Bogendoerfer <tbogendoerfer@suse.de>");
85 MODULE_DESCRIPTION("SGI Octane LED driver");
86 MODULE_LICENSE("GPL");
87 MODULE_ALIAS("platform:ip30-leds");