oleavr-rgl-a500-mini-linux-.../drivers/power/axp_power/axp20/virtual20_dev.c
Ole André Vadla Ravnås 169c65d57e Initial commit
2022-05-07 01:01:45 +02:00

91 lines
1.5 KiB
C

#include <linux/init.h>
#include <linux/device.h>
#include <linux/platform_device.h>
#include <linux/regulator/machine.h>
#include <linux/i2c.h>
#include <linux/power_supply.h>
#include <linux/module.h>
static struct platform_device virt[] = {
{
.name = "reg-20-cs-dcdc2",
.id = -1,
.dev = {
.platform_data = "axp20_dcdc2",
}
},
{
.name = "reg-20-cs-dcdc3",
.id = -1,
.dev = {
.platform_data = "axp20_dcdc3",
}
},
{
.name = "reg-20-cs-ldo1",
.id = -1,
.dev = {
.platform_data = "axp20_ldo1",
}
},
{
.name = "reg-20-cs-ldo2",
.id = -1,
.dev = {
.platform_data = "axp20_ldo2",
}
},
{
.name = "reg-20-cs-ldo3",
.id = -1,
.dev = {
.platform_data = "axp20_ldo3",
}
},
{
.name = "reg-20-cs-ldo4",
.id = -1,
.dev = {
.platform_data = "axp20_ldo4",
}
},
{
.name = "reg-20-cs-ldoio0",
.id = -1,
.dev = {
.platform_data = "axp20_ldoio0",
}
},
};
static int __init virtual_init(void)
{
int j, ret;
for (j = 0; j < ARRAY_SIZE(virt); j++) {
ret = platform_device_register(&virt[j]);
if (ret)
goto creat_devices_failed;
}
return 0;
creat_devices_failed:
while (j--)
platform_device_register(&virt[j]);
return ret;
}
module_init(virtual_init);
static void __exit virtual_exit(void)
{
int j;
for (j = ARRAY_SIZE(virt) - 1; j >= 0; j--)
platform_device_unregister(&virt[j]);
}
module_exit(virtual_exit);
MODULE_DESCRIPTION("X-POWERS axp regulator test");
MODULE_AUTHOR("Weijin Zhong");
MODULE_LICENSE("GPL");