2012-11-03 03:18:11 +08:00
|
|
|
/*
|
2012-11-19 07:35:32 +08:00
|
|
|
* bq2415x charger driver
|
|
|
|
*
|
|
|
|
* Copyright (C) 2011-2012 Pali Rohár <pali.rohar@gmail.com>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
|
|
*/
|
2012-11-03 03:18:11 +08:00
|
|
|
|
|
|
|
#ifndef BQ2415X_CHARGER_H
|
|
|
|
#define BQ2415X_CHARGER_H
|
|
|
|
|
|
|
|
/*
|
2012-11-19 07:35:32 +08:00
|
|
|
* This is platform data for bq2415x chip. It contains default board
|
|
|
|
* voltages and currents which can be also later configured via sysfs. If
|
|
|
|
* value is -1 then default chip value (specified in datasheet) will be
|
|
|
|
* used.
|
|
|
|
*
|
|
|
|
* Value resistor_sense is needed for for configuring charge and
|
|
|
|
* termination current. It it is less or equal to zero, configuring charge
|
|
|
|
* and termination current will not be possible.
|
|
|
|
*
|
|
|
|
* Function set_mode_hook is needed for automode (setting correct current
|
|
|
|
* limit when charger is connected/disconnected or setting boost mode).
|
|
|
|
* When is NULL, automode function is disabled. When is not NULL, it must
|
|
|
|
* have this prototype:
|
|
|
|
*
|
|
|
|
* int (*set_mode_hook)(
|
|
|
|
* void (*hook)(enum bq2415x_mode mode, void *data),
|
|
|
|
* void *data)
|
|
|
|
*
|
|
|
|
* hook is hook function (see below) and data is pointer to driver private
|
|
|
|
* data
|
|
|
|
*
|
|
|
|
* bq2415x driver will call it as:
|
|
|
|
*
|
|
|
|
* platform_data->set_mode_hook(bq2415x_hook_function, bq2415x_device);
|
|
|
|
*
|
|
|
|
* Board/platform function set_mode_hook return non zero value when hook
|
|
|
|
* function was successful registered. Platform code should call that hook
|
|
|
|
* function (which get from pointer, with data) every time when charger
|
|
|
|
* was connected/disconnected or require to enable boost mode. bq2415x
|
|
|
|
* driver then will set correct current limit, enable/disable charger or
|
|
|
|
* boost mode.
|
|
|
|
*
|
|
|
|
* Hook function has this prototype:
|
|
|
|
*
|
|
|
|
* void hook(enum bq2415x_mode mode, void *data);
|
|
|
|
*
|
|
|
|
* mode is bq2415x mode (charger or boost)
|
|
|
|
* data is pointer to driver private data (which get from
|
|
|
|
* set_charger_type_hook)
|
|
|
|
*
|
|
|
|
* When bq driver is being unloaded, it call function:
|
|
|
|
*
|
|
|
|
* platform_data->set_mode_hook(NULL, NULL);
|
|
|
|
*
|
|
|
|
* (hook function and driver private data are NULL)
|
|
|
|
*
|
|
|
|
* After that board/platform code must not call driver hook function! It
|
|
|
|
* is possible that pointer to hook function will not be valid and calling
|
|
|
|
* will cause undefined result.
|
|
|
|
*/
|
2012-11-03 03:18:11 +08:00
|
|
|
|
|
|
|
/* Supported modes with maximal current limit */
|
|
|
|
enum bq2415x_mode {
|
|
|
|
BQ2415X_MODE_NONE, /* unknown or no charger (100mA) */
|
|
|
|
BQ2415X_MODE_HOST_CHARGER, /* usb host/hub charger (500mA) */
|
|
|
|
BQ2415X_MODE_DEDICATED_CHARGER, /* dedicated charger (unlimited) */
|
|
|
|
BQ2415X_MODE_BOOST, /* boost mode (charging disabled) */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct bq2415x_platform_data {
|
|
|
|
int current_limit; /* mA */
|
|
|
|
int weak_battery_voltage; /* mV */
|
|
|
|
int battery_regulation_voltage; /* mV */
|
|
|
|
int charge_current; /* mA */
|
|
|
|
int termination_current; /* mA */
|
|
|
|
int resistor_sense; /* m ohm */
|
|
|
|
int (*set_mode_hook)(void (*hook)(enum bq2415x_mode mode, void *data),
|
|
|
|
void *data);
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|