ath10k: pci: make host_ce_config_wlan[] more readable
[cascardo/linux.git] / drivers / power / charger-manager.c
index fefc39f..e30e847 100644 (file)
@@ -12,6 +12,8 @@
  * published by the Free Software Foundation.
 **/
 
+#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
+
 #include <linux/io.h>
 #include <linux/module.h>
 #include <linux/irq.h>
@@ -195,8 +197,8 @@ static bool is_charging(struct charger_manager *cm)
                                cm->charger_stat[i],
                                POWER_SUPPLY_PROP_ONLINE, &val);
                if (ret) {
-                       dev_warn(cm->dev, "Cannot read ONLINE value from %s.\n",
-                                       cm->desc->psy_charger_stat[i]);
+                       dev_warn(cm->dev, "Cannot read ONLINE value from %s\n",
+                                cm->desc->psy_charger_stat[i]);
                        continue;
                }
                if (val.intval == 0)
@@ -210,8 +212,8 @@ static bool is_charging(struct charger_manager *cm)
                                cm->charger_stat[i],
                                POWER_SUPPLY_PROP_STATUS, &val);
                if (ret) {
-                       dev_warn(cm->dev, "Cannot read STATUS value from %s.\n",
-                                       cm->desc->psy_charger_stat[i]);
+                       dev_warn(cm->dev, "Cannot read STATUS value from %s\n",
+                                cm->desc->psy_charger_stat[i]);
                        continue;
                }
                if (val.intval == POWER_SUPPLY_STATUS_FULL ||
@@ -289,7 +291,7 @@ static bool is_polling_required(struct charger_manager *cm)
                return is_charging(cm);
        default:
                dev_warn(cm->dev, "Incorrect polling_mode (%d)\n",
-                       cm->desc->polling_mode);
+                        cm->desc->polling_mode);
        }
 
        return false;
@@ -331,9 +333,8 @@ static int try_charger_enable(struct charger_manager *cm, bool enable)
 
                        err = regulator_enable(desc->charger_regulators[i].consumer);
                        if (err < 0) {
-                               dev_warn(cm->dev,
-                                       "Cannot enable %s regulator\n",
-                                       desc->charger_regulators[i].regulator_name);
+                               dev_warn(cm->dev, "Cannot enable %s regulator\n",
+                                        desc->charger_regulators[i].regulator_name);
                        }
                }
        } else {
@@ -350,9 +351,8 @@ static int try_charger_enable(struct charger_manager *cm, bool enable)
 
                        err = regulator_disable(desc->charger_regulators[i].consumer);
                        if (err < 0) {
-                               dev_warn(cm->dev,
-                                       "Cannot disable %s regulator\n",
-                                       desc->charger_regulators[i].regulator_name);
+                               dev_warn(cm->dev, "Cannot disable %s regulator\n",
+                                        desc->charger_regulators[i].regulator_name);
                        }
                }
 
@@ -365,9 +365,8 @@ static int try_charger_enable(struct charger_manager *cm, bool enable)
                                    desc->charger_regulators[i].consumer)) {
                                regulator_force_disable(
                                        desc->charger_regulators[i].consumer);
-                               dev_warn(cm->dev,
-                                       "Disable regulator(%s) forcibly.\n",
-                                       desc->charger_regulators[i].regulator_name);
+                               dev_warn(cm->dev, "Disable regulator(%s) forcibly\n",
+                                        desc->charger_regulators[i].regulator_name);
                        }
                }
        }
@@ -450,7 +449,7 @@ static void uevent_notify(struct charger_manager *cm, const char *event)
        strncpy(env_str, event, UEVENT_BUF_SIZE);
        kobject_uevent(&cm->dev->kobj, KOBJ_CHANGE);
 
-       dev_info(cm->dev, event);
+       dev_info(cm->dev, "%s\n", event);
 }
 
 /**
@@ -478,7 +477,7 @@ static void fullbatt_vchk(struct work_struct *work)
 
        err = get_batt_uV(cm, &batt_uV);
        if (err) {
-               dev_err(cm->dev, "%s: get_batt_uV error(%d).\n", __func__, err);
+               dev_err(cm->dev, "%s: get_batt_uV error(%d)\n", __func__, err);
                return;
        }
 
@@ -486,7 +485,7 @@ static void fullbatt_vchk(struct work_struct *work)
        if (diff < 0)
                return;
 
-       dev_info(cm->dev, "VBATT dropped %duV after full-batt.\n", diff);
+       dev_info(cm->dev, "VBATT dropped %duV after full-batt\n", diff);
 
        if (diff > desc->fullbatt_vchkdrop_uV) {
                try_charger_restart(cm);
@@ -519,7 +518,7 @@ static int check_charging_duration(struct charger_manager *cm)
                duration = curr - cm->charging_start_time;
 
                if (duration > desc->charging_max_duration_ms) {
-                       dev_info(cm->dev, "Charging duration exceed %lldms",
+                       dev_info(cm->dev, "Charging duration exceed %lldms\n",
                                 desc->charging_max_duration_ms);
                        uevent_notify(cm, "Discharging");
                        try_charger_enable(cm, false);
@@ -530,9 +529,9 @@ static int check_charging_duration(struct charger_manager *cm)
 
                if (duration > desc->charging_max_duration_ms &&
                                is_ext_pwr_online(cm)) {
-                       dev_info(cm->dev, "DisCharging duration exceed %lldms",
+                       dev_info(cm->dev, "Discharging duration exceed %lldms\n",
                                 desc->discharging_max_duration_ms);
-                       uevent_notify(cm, "Recharing");
+                       uevent_notify(cm, "Recharging");
                        try_charger_enable(cm, true);
                        ret = true;
                }
@@ -579,7 +578,7 @@ static bool _cm_monitor(struct charger_manager *cm)
         */
        } else if (!cm->emergency_stop && check_charging_duration(cm)) {
                dev_dbg(cm->dev,
-                       "Charging/Discharging duration is out of range");
+                       "Charging/Discharging duration is out of range\n");
        /*
         * Check dropped voltage of battery. If battery voltage is more
         * dropped than fullbatt_vchkdrop_uV after fully charged state,
@@ -595,7 +594,7 @@ static bool _cm_monitor(struct charger_manager *cm)
         */
        } else if (!cm->emergency_stop && is_full_charged(cm) &&
                        cm->charger_enabled) {
-               dev_info(cm->dev, "EVENT_HANDLE: Battery Fully Charged.\n");
+               dev_info(cm->dev, "EVENT_HANDLE: Battery Fully Charged\n");
                uevent_notify(cm, default_event_names[CM_EVENT_BATT_FULL]);
 
                try_charger_enable(cm, false);
@@ -725,7 +724,7 @@ static void fullbatt_handler(struct charger_manager *cm)
                cm->fullbatt_vchk_jiffies_at = 1;
 
 out:
-       dev_info(cm->dev, "EVENT_HANDLE: Battery Fully Charged.\n");
+       dev_info(cm->dev, "EVENT_HANDLE: Battery Fully Charged\n");
        uevent_notify(cm, default_event_names[CM_EVENT_BATT_FULL]);
 }
 
@@ -972,7 +971,7 @@ static bool cm_setup_timer(void)
        mutex_unlock(&cm_list_mtx);
 
        if (wakeup_ms < UINT_MAX && wakeup_ms > 0) {
-               pr_info("Charger Manager wakeup timer: %u ms.\n", wakeup_ms);
+               pr_info("Charger Manager wakeup timer: %u ms\n", wakeup_ms);
                if (rtc_dev) {
                        struct rtc_wkalrm tmp;
                        unsigned long time, now;
@@ -1005,8 +1004,7 @@ static bool cm_setup_timer(void)
                                ret = false;
                        }
 
-                       pr_info("Waking up after %lu secs.\n",
-                                       time - now);
+                       pr_info("Waking up after %lu secs\n", time - now);
 
                        rtc_time_to_tm(time, &tmp.time);
                        rtc_set_alarm(rtc_dev, &tmp);
@@ -1101,7 +1099,7 @@ int setup_charger_manager(struct charger_global_desc *gd)
        g_desc = NULL;
 
        if (!gd->rtc_only_wakeup) {
-               pr_err("The callback rtc_only_wakeup is not given.\n");
+               pr_err("The callback rtc_only_wakeup is not given\n");
                return -EINVAL;
        }
 
@@ -1112,7 +1110,7 @@ int setup_charger_manager(struct charger_global_desc *gd)
                        /* Retry at probe. RTC may be not registered yet */
                }
        } else {
-               pr_warn("No wakeup timer is given for charger manager."
+               pr_warn("No wakeup timer is given for charger manager.  "
                        "In-suspend monitoring won't work.\n");
        }
 
@@ -1138,13 +1136,13 @@ static void charger_extcon_work(struct work_struct *work)
                                        cable->min_uA, cable->max_uA);
                if (ret < 0) {
                        pr_err("Cannot set current limit of %s (%s)\n",
-                               cable->charger->regulator_name, cable->name);
+                              cable->charger->regulator_name, cable->name);
                        return;
                }
 
                pr_info("Set current limit of %s : %duA ~ %duA\n",
-                                       cable->charger->regulator_name,
-                                       cable->min_uA, cable->max_uA);
+                       cable->charger->regulator_name,
+                       cable->min_uA, cable->max_uA);
        }
 
        try_charger_enable(cable->cm, cable->attached);
@@ -1210,9 +1208,8 @@ static int charger_extcon_init(struct charger_manager *cm,
        ret = extcon_register_interest(&cable->extcon_dev,
                        cable->extcon_name, cable->name, &cable->nb);
        if (ret < 0) {
-               pr_info("Cannot register extcon_dev for %s(cable: %s).\n",
-                               cable->extcon_name,
-                               cable->name);
+               pr_info("Cannot register extcon_dev for %s(cable: %s)\n",
+                       cable->extcon_name, cable->name);
                ret = -EINVAL;
        }
 
@@ -1242,11 +1239,10 @@ static int charger_manager_register_extcon(struct charger_manager *cm)
 
                charger->consumer = regulator_get(cm->dev,
                                        charger->regulator_name);
-               if (charger->consumer == NULL) {
-                       dev_err(cm->dev, "Cannot find charger(%s)n",
-                                       charger->regulator_name);
-                       ret = -EINVAL;
-                       goto err;
+               if (IS_ERR(charger->consumer)) {
+                       dev_err(cm->dev, "Cannot find charger(%s)\n",
+                               charger->regulator_name);
+                       return PTR_ERR(charger->consumer);
                }
                charger->cm = cm;
 
@@ -1255,8 +1251,8 @@ static int charger_manager_register_extcon(struct charger_manager *cm)
 
                        ret = charger_extcon_init(cm, cable);
                        if (ret < 0) {
-                               dev_err(cm->dev, "Cannot initialize charger(%s)n",
-                                               charger->regulator_name);
+                               dev_err(cm->dev, "Cannot initialize charger(%s)\n",
+                                       charger->regulator_name);
                                goto err;
                        }
                        cable->charger = charger;
@@ -1347,10 +1343,8 @@ static ssize_t charger_externally_control_store(struct device *dev,
                }
        } else {
                dev_warn(cm->dev,
-                       "'%s' regulator should be controlled "
-                       "in charger-manager because charger-manager "
-                       "must need at least one charger for charging\n",
-                       charger->regulator_name);
+                        "'%s' regulator should be controlled in charger-manager because charger-manager must need at least one charger for charging\n",
+                        charger->regulator_name);
        }
 
        return count;
@@ -1386,8 +1380,6 @@ static int charger_manager_register_sysfs(struct charger_manager *cm)
                snprintf(buf, 10, "charger.%d", i);
                str = kzalloc(sizeof(char) * (strlen(buf) + 1), GFP_KERNEL);
                if (!str) {
-                       dev_err(cm->dev, "Cannot allocate memory: %s\n",
-                                       charger->regulator_name);
                        ret = -ENOMEM;
                        goto err;
                }
@@ -1423,26 +1415,21 @@ static int charger_manager_register_sysfs(struct charger_manager *cm)
                                !chargers_externally_control)
                        chargers_externally_control = 0;
 
-               dev_info(cm->dev, "'%s' regulator's externally_control"
-                               "is %d\n", charger->regulator_name,
-                               charger->externally_control);
+               dev_info(cm->dev, "'%s' regulator's externally_control is %d\n",
+                        charger->regulator_name, charger->externally_control);
 
                ret = sysfs_create_group(&cm->charger_psy.dev->kobj,
                                        &charger->attr_g);
                if (ret < 0) {
-                       dev_err(cm->dev, "Cannot create sysfs entry"
-                                       "of %s regulator\n",
-                                       charger->regulator_name);
+                       dev_err(cm->dev, "Cannot create sysfs entry of %s regulator\n",
+                               charger->regulator_name);
                        ret = -EINVAL;
                        goto err;
                }
        }
 
        if (chargers_externally_control) {
-               dev_err(cm->dev, "Cannot register regulator because "
-                               "charger-manager must need at least "
-                               "one charger for charging battery\n");
-
+               dev_err(cm->dev, "Cannot register regulator because charger-manager must need at least one charger for charging battery\n");
                ret = -EINVAL;
                goto err;
        }
@@ -1463,7 +1450,7 @@ static int charger_manager_probe(struct platform_device *pdev)
                rtc_dev = rtc_class_open(g_desc->rtc_name);
                if (IS_ERR_OR_NULL(rtc_dev)) {
                        rtc_dev = NULL;
-                       dev_err(&pdev->dev, "Cannot get RTC %s.\n",
+                       dev_err(&pdev->dev, "Cannot get RTC %s\n",
                                g_desc->rtc_name);
                        ret = -ENODEV;
                        goto err_alloc;
@@ -1471,14 +1458,13 @@ static int charger_manager_probe(struct platform_device *pdev)
        }
 
        if (!desc) {
-               dev_err(&pdev->dev, "No platform data (desc) found.\n");
+               dev_err(&pdev->dev, "No platform data (desc) found\n");
                ret = -ENODEV;
                goto err_alloc;
        }
 
        cm = kzalloc(sizeof(struct charger_manager), GFP_KERNEL);
        if (!cm) {
-               dev_err(&pdev->dev, "Cannot allocate memory.\n");
                ret = -ENOMEM;
                goto err_alloc;
        }
@@ -1487,7 +1473,6 @@ static int charger_manager_probe(struct platform_device *pdev)
        cm->dev = &pdev->dev;
        cm->desc = kmemdup(desc, sizeof(struct charger_desc), GFP_KERNEL);
        if (!cm->desc) {
-               dev_err(&pdev->dev, "Cannot allocate memory.\n");
                ret = -ENOMEM;
                goto err_alloc_desc;
        }
@@ -1498,33 +1483,28 @@ static int charger_manager_probe(struct platform_device *pdev)
         * Users may intentionally ignore those two features.
         */
        if (desc->fullbatt_uV == 0) {
-               dev_info(&pdev->dev, "Ignoring full-battery voltage threshold"
-                                       " as it is not supplied.");
+               dev_info(&pdev->dev, "Ignoring full-battery voltage threshold as it is not supplied\n");
        }
        if (!desc->fullbatt_vchkdrop_ms || !desc->fullbatt_vchkdrop_uV) {
-               dev_info(&pdev->dev, "Disabling full-battery voltage drop "
-                               "checking mechanism as it is not supplied.");
+               dev_info(&pdev->dev, "Disabling full-battery voltage drop checking mechanism as it is not supplied\n");
                desc->fullbatt_vchkdrop_ms = 0;
                desc->fullbatt_vchkdrop_uV = 0;
        }
        if (desc->fullbatt_soc == 0) {
-               dev_info(&pdev->dev, "Ignoring full-battery soc(state of"
-                                       " charge) threshold as it is not"
-                                       " supplied.");
+               dev_info(&pdev->dev, "Ignoring full-battery soc(state of charge) threshold as it is not supplied\n");
        }
        if (desc->fullbatt_full_capacity == 0) {
-               dev_info(&pdev->dev, "Ignoring full-battery full capacity"
-                                       " threshold as it is not supplied.");
+               dev_info(&pdev->dev, "Ignoring full-battery full capacity threshold as it is not supplied\n");
        }
 
        if (!desc->charger_regulators || desc->num_charger_regulators < 1) {
                ret = -EINVAL;
-               dev_err(&pdev->dev, "charger_regulators undefined.\n");
+               dev_err(&pdev->dev, "charger_regulators undefined\n");
                goto err_no_charger;
        }
 
        if (!desc->psy_charger_stat || !desc->psy_charger_stat[0]) {
-               dev_err(&pdev->dev, "No power supply defined.\n");
+               dev_err(&pdev->dev, "No power supply defined\n");
                ret = -EINVAL;
                goto err_no_charger_stat;
        }
@@ -1544,9 +1524,8 @@ static int charger_manager_probe(struct platform_device *pdev)
                cm->charger_stat[i] = power_supply_get_by_name(
                                        desc->psy_charger_stat[i]);
                if (!cm->charger_stat[i]) {
-                       dev_err(&pdev->dev, "Cannot find power supply "
-                                       "\"%s\"\n",
-                                       desc->psy_charger_stat[i]);
+                       dev_err(&pdev->dev, "Cannot find power supply \"%s\"\n",
+                               desc->psy_charger_stat[i]);
                        ret = -ENODEV;
                        goto err_chg_stat;
                }
@@ -1555,7 +1534,7 @@ static int charger_manager_probe(struct platform_device *pdev)
        cm->fuel_gauge = power_supply_get_by_name(desc->psy_fuel_gauge);
        if (!cm->fuel_gauge) {
                dev_err(&pdev->dev, "Cannot find power supply \"%s\"\n",
-                               desc->psy_fuel_gauge);
+                       desc->psy_fuel_gauge);
                ret = -ENODEV;
                goto err_chg_stat;
        }
@@ -1575,9 +1554,7 @@ static int charger_manager_probe(struct platform_device *pdev)
 
        if (!desc->charging_max_duration_ms ||
                        !desc->discharging_max_duration_ms) {
-               dev_info(&pdev->dev, "Cannot limit charging duration "
-                        "checking mechanism to prevent overcharge/overheat "
-                        "and control discharging duration");
+               dev_info(&pdev->dev, "Cannot limit charging duration checking mechanism to prevent overcharge/overheat and control discharging duration\n");
                desc->charging_max_duration_ms = 0;
                desc->discharging_max_duration_ms = 0;
        }
@@ -1598,7 +1575,6 @@ static int charger_manager_probe(struct platform_device *pdev)
                                NUM_CHARGER_PSY_OPTIONAL),
                                GFP_KERNEL);
        if (!cm->charger_psy.properties) {
-               dev_err(&pdev->dev, "Cannot allocate for psy properties.\n");
                ret = -ENOMEM;
                goto err_chg_stat;
        }
@@ -1636,8 +1612,8 @@ static int charger_manager_probe(struct platform_device *pdev)
 
        ret = power_supply_register(NULL, &cm->charger_psy);
        if (ret) {
-               dev_err(&pdev->dev, "Cannot register charger-manager with"
-                               " name \"%s\".\n", cm->charger_psy.name);
+               dev_err(&pdev->dev, "Cannot register charger-manager with name \"%s\"\n",
+                       cm->charger_psy.name);
                goto err_register;
        }
 
@@ -1689,7 +1665,9 @@ err_reg_extcon:
                charger = &desc->charger_regulators[i];
                for (j = 0; j < charger->num_cables; j++) {
                        struct charger_cable *cable = &charger->cables[j];
-                       extcon_unregister_interest(&cable->extcon_dev);
+                       /* Remove notifier block if only edev exists */
+                       if (cable->extcon_dev.edev)
+                               extcon_unregister_interest(&cable->extcon_dev);
                }
 
                regulator_put(desc->charger_regulators[i].consumer);
@@ -1948,7 +1926,7 @@ void cm_notify_event(struct power_supply *psy, enum cm_event_types type,
                uevent_notify(cm, msg ? msg : default_event_names[type]);
                break;
        default:
-               dev_err(cm->dev, "%s type not specified.\n", __func__);
+               dev_err(cm->dev, "%s: type not specified\n", __func__);
                break;
        }
 }