diff options
author | Dmitry Eremin-Solenikov <dbaryshkov@gmail.com> | 2012-05-29 05:37:43 -0400 |
---|---|---|
committer | Anton Vorontsov <cbouatmailru@gmail.com> | 2012-06-21 01:45:10 -0400 |
commit | 7384737588165e268887be09ad05c8664625dc43 (patch) | |
tree | 68d5eda1ee434ff09ad30823a03e4629cc2503e3 /drivers | |
parent | ecb7a8ebdc4b063715d5a37919f9118c3f1031a8 (diff) |
test_power: Add support for USB AC source
Usually a device has both AC plug and UDC plug usable for charging.
Provide both AC sources.
Signed-off-by: Dmitry Eremin-Solenikov <dmitry_eremin@mentor.com>
Signed-off-by: Anton Vorontsov <cbouatmailru@gmail.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/power/test_power.c | 48 |
1 files changed, 46 insertions, 2 deletions
diff --git a/drivers/power/test_power.c b/drivers/power/test_power.c index b527c93bf2f3..99aec3b38b23 100644 --- a/drivers/power/test_power.c +++ b/drivers/power/test_power.c | |||
@@ -22,6 +22,7 @@ | |||
22 | #include <linux/vermagic.h> | 22 | #include <linux/vermagic.h> |
23 | 23 | ||
24 | static int ac_online = 1; | 24 | static int ac_online = 1; |
25 | static int usb_online = 1; | ||
25 | static int battery_status = POWER_SUPPLY_STATUS_DISCHARGING; | 26 | static int battery_status = POWER_SUPPLY_STATUS_DISCHARGING; |
26 | static int battery_health = POWER_SUPPLY_HEALTH_GOOD; | 27 | static int battery_health = POWER_SUPPLY_HEALTH_GOOD; |
27 | static int battery_present = 1; /* true */ | 28 | static int battery_present = 1; /* true */ |
@@ -42,6 +43,20 @@ static int test_power_get_ac_property(struct power_supply *psy, | |||
42 | return 0; | 43 | return 0; |
43 | } | 44 | } |
44 | 45 | ||
46 | static int test_power_get_usb_property(struct power_supply *psy, | ||
47 | enum power_supply_property psp, | ||
48 | union power_supply_propval *val) | ||
49 | { | ||
50 | switch (psp) { | ||
51 | case POWER_SUPPLY_PROP_ONLINE: | ||
52 | val->intval = usb_online; | ||
53 | break; | ||
54 | default: | ||
55 | return -EINVAL; | ||
56 | } | ||
57 | return 0; | ||
58 | } | ||
59 | |||
45 | static int test_power_get_battery_property(struct power_supply *psy, | 60 | static int test_power_get_battery_property(struct power_supply *psy, |
46 | enum power_supply_property psp, | 61 | enum power_supply_property psp, |
47 | union power_supply_propval *val) | 62 | union power_supply_propval *val) |
@@ -135,6 +150,14 @@ static struct power_supply test_power_supplies[] = { | |||
135 | .properties = test_power_battery_props, | 150 | .properties = test_power_battery_props, |
136 | .num_properties = ARRAY_SIZE(test_power_battery_props), | 151 | .num_properties = ARRAY_SIZE(test_power_battery_props), |
137 | .get_property = test_power_get_battery_property, | 152 | .get_property = test_power_get_battery_property, |
153 | }, { | ||
154 | .name = "test_usb", | ||
155 | .type = POWER_SUPPLY_TYPE_USB, | ||
156 | .supplied_to = test_power_ac_supplied_to, | ||
157 | .num_supplicants = ARRAY_SIZE(test_power_ac_supplied_to), | ||
158 | .properties = test_power_ac_props, | ||
159 | .num_properties = ARRAY_SIZE(test_power_ac_props), | ||
160 | .get_property = test_power_get_usb_property, | ||
138 | }, | 161 | }, |
139 | }; | 162 | }; |
140 | 163 | ||
@@ -167,6 +190,7 @@ static void __exit test_power_exit(void) | |||
167 | 190 | ||
168 | /* Let's see how we handle changes... */ | 191 | /* Let's see how we handle changes... */ |
169 | ac_online = 0; | 192 | ac_online = 0; |
193 | usb_online = 0; | ||
170 | battery_status = POWER_SUPPLY_STATUS_DISCHARGING; | 194 | battery_status = POWER_SUPPLY_STATUS_DISCHARGING; |
171 | for (i = 0; i < ARRAY_SIZE(test_power_supplies); i++) | 195 | for (i = 0; i < ARRAY_SIZE(test_power_supplies); i++) |
172 | power_supply_changed(&test_power_supplies[i]); | 196 | power_supply_changed(&test_power_supplies[i]); |
@@ -275,6 +299,19 @@ static int param_get_ac_online(char *buffer, const struct kernel_param *kp) | |||
275 | return strlen(buffer); | 299 | return strlen(buffer); |
276 | } | 300 | } |
277 | 301 | ||
302 | static int param_set_usb_online(const char *key, const struct kernel_param *kp) | ||
303 | { | ||
304 | usb_online = map_get_value(map_ac_online, key, usb_online); | ||
305 | power_supply_changed(&test_power_supplies[2]); | ||
306 | return 0; | ||
307 | } | ||
308 | |||
309 | static int param_get_usb_online(char *buffer, const struct kernel_param *kp) | ||
310 | { | ||
311 | strcpy(buffer, map_get_key(map_ac_online, usb_online, "unknown")); | ||
312 | return strlen(buffer); | ||
313 | } | ||
314 | |||
278 | static int param_set_battery_status(const char *key, | 315 | static int param_set_battery_status(const char *key, |
279 | const struct kernel_param *kp) | 316 | const struct kernel_param *kp) |
280 | { | 317 | { |
@@ -350,13 +387,16 @@ static int param_set_battery_capacity(const char *key, | |||
350 | 387 | ||
351 | #define param_get_battery_capacity param_get_int | 388 | #define param_get_battery_capacity param_get_int |
352 | 389 | ||
353 | |||
354 | |||
355 | static struct kernel_param_ops param_ops_ac_online = { | 390 | static struct kernel_param_ops param_ops_ac_online = { |
356 | .set = param_set_ac_online, | 391 | .set = param_set_ac_online, |
357 | .get = param_get_ac_online, | 392 | .get = param_get_ac_online, |
358 | }; | 393 | }; |
359 | 394 | ||
395 | static struct kernel_param_ops param_ops_usb_online = { | ||
396 | .set = param_set_usb_online, | ||
397 | .get = param_get_usb_online, | ||
398 | }; | ||
399 | |||
360 | static struct kernel_param_ops param_ops_battery_status = { | 400 | static struct kernel_param_ops param_ops_battery_status = { |
361 | .set = param_set_battery_status, | 401 | .set = param_set_battery_status, |
362 | .get = param_get_battery_status, | 402 | .get = param_get_battery_status, |
@@ -384,6 +424,7 @@ static struct kernel_param_ops param_ops_battery_capacity = { | |||
384 | 424 | ||
385 | 425 | ||
386 | #define param_check_ac_online(name, p) __param_check(name, p, void); | 426 | #define param_check_ac_online(name, p) __param_check(name, p, void); |
427 | #define param_check_usb_online(name, p) __param_check(name, p, void); | ||
387 | #define param_check_battery_status(name, p) __param_check(name, p, void); | 428 | #define param_check_battery_status(name, p) __param_check(name, p, void); |
388 | #define param_check_battery_present(name, p) __param_check(name, p, void); | 429 | #define param_check_battery_present(name, p) __param_check(name, p, void); |
389 | #define param_check_battery_technology(name, p) __param_check(name, p, void); | 430 | #define param_check_battery_technology(name, p) __param_check(name, p, void); |
@@ -394,6 +435,9 @@ static struct kernel_param_ops param_ops_battery_capacity = { | |||
394 | module_param(ac_online, ac_online, 0644); | 435 | module_param(ac_online, ac_online, 0644); |
395 | MODULE_PARM_DESC(ac_online, "AC charging state <on|off>"); | 436 | MODULE_PARM_DESC(ac_online, "AC charging state <on|off>"); |
396 | 437 | ||
438 | module_param(usb_online, usb_online, 0644); | ||
439 | MODULE_PARM_DESC(usb_online, "USB charging state <on|off>"); | ||
440 | |||
397 | module_param(battery_status, battery_status, 0644); | 441 | module_param(battery_status, battery_status, 0644); |
398 | MODULE_PARM_DESC(battery_status, | 442 | MODULE_PARM_DESC(battery_status, |
399 | "battery status <charging|discharging|not-charging|full>"); | 443 | "battery status <charging|discharging|not-charging|full>"); |