summaryrefslogtreecommitdiff
path: root/include/linux/power/bq2415x_charger.h
blob: fb6bf4d8aea80b3c97b881b370711abc6e98922e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
    bq2415x_charger.h - 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.
*/

#ifndef BQ2415X_CHARGER_H
#define BQ2415X_CHARGER_H

/*
  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.

*/

/* 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