Since the charger cables are related to power supply subsystem it
makes sense to define the properties associate with charger cables.
The properties include cable events and the input current. The cable
properties may come from different sources. Since they are associated
with power_supply subsystem, it make sense to unify the properties
in the power supply susbsyem layer.

Also a charger can support different types of charger sources (cables).
It make sense to define a field to inform the power supply subsystem
what kind of cable  a charger driver supports. Since a bitmask would
be the easy way to do define, it's good to have a enum which has
the bitmask definition for each cable types

Change-Id: Ia655c0924b7a5a845121342aa8f5d3840cccfbc4
Signed-off-by: Jenny TC <jenny...@intel.com>
---
 include/linux/power_supply.h |   38 ++++++++++++++++++++++++++++++++++++++
 1 file changed, 38 insertions(+)

diff --git a/include/linux/power_supply.h b/include/linux/power_supply.h
index ddeab05..c3ce514a 100644
--- a/include/linux/power_supply.h
+++ b/include/linux/power_supply.h
@@ -166,6 +166,43 @@ enum power_supply_type {
        POWER_SUPPLY_TYPE_USB_ACA,      /* Accessory Charger Adapters */
 };
 
+enum psy_charger_cable_event {
+       PSY_CHARGER_CABLE_EVENT_CONNECT = 0,
+       PSY_CHARGER_CABLE_EVENT_UPDATE,
+       PSY_CHARGER_CABLE_EVENT_RESUME,
+       PSY_CHARGER_CABLE_EVENT_SUSPEND,
+       PSY_CHARGER_CABLE_EVENT_DISCONNECT,
+};
+
+enum psy_charger_cable_type {
+       PSY_CHARGER_CABLE_TYPE_NONE = 0,
+       PSY_CHARGER_CABLE_TYPE_USB_SDP = 1 << 0,
+       PSY_CHARGER_CABLE_TYPE_USB_DCP = 1 << 1,
+       PSY_CHARGER_CABLE_TYPE_USB_CDP = 1 << 2,
+       PSY_CHARGER_CABLE_TYPE_USB_ACA = 1 << 3,
+       PSY_CHARGER_CABLE_TYPE_AC = 1 << 4,
+       PSY_CHARGER_CABLE_TYPE_ACA_DOCK = 1 << 5,
+       PSY_CHARGER_CABLE_TYPE_ACA_A = 1 << 6,
+       PSY_CHARGER_CABLE_TYPE_ACA_B = 1 << 7,
+       PSY_CHARGER_CABLE_TYPE_ACA_C = 1 << 8,
+       PSY_CHARGER_CABLE_TYPE_SE1 = 1 << 9,
+       PSY_CHARGER_CABLE_TYPE_MHL = 1 << 10,
+       PSY_CHARGER_CABLE_TYPE_B_DEVICE = 1 << 11,
+};
+
+struct psy_cable_props {
+       enum psy_charger_cable_event    chrg_evt;
+       enum psy_charger_cable_type     chrg_type;
+       unsigned int                    mA;     /* input current limit */
+};
+
+#define PSY_CHARGER_CABLE_TYPE_USB \
+       (PSY_CHARGER_CABLE_TYPE_USB_SDP | \
+       PSY_CHARGER_CABLE_TYPE_USB_DCP | \
+       PSY_CHARGER_CABLE_TYPE_USB_CDP | \
+       PSY_CHARGER_CABLE_TYPE_USB_ACA | \
+       PSY_CHARGER_CABLE_TYPE_ACA_DOCK)
+
 union power_supply_propval {
        int intval;
        const char *strval;
@@ -181,6 +218,7 @@ struct power_supply {
 
        char **supplied_to;
        size_t num_supplicants;
+       unsigned long supported_cables;
 
        char **supplied_from;
        size_t num_supplies;
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to