pca953x.c 6.6 KB
Newer Older
1
/*
2
 *  pca953x.c - 4/8/16 bit I/O ports
3 4 5 6 7 8 9 10 11 12 13 14 15 16
 *
 *  Copyright (C) 2005 Ben Gardner <bgardner@wabtec.com>
 *  Copyright (C) 2007 Marvell International Ltd.
 *
 *  Derived from drivers/i2c/chips/pca9539.c
 *
 *  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; version 2 of the License.
 */

#include <linux/module.h>
#include <linux/init.h>
#include <linux/i2c.h>
17
#include <linux/i2c/pca953x.h>
18 19 20

#include <asm/gpio.h>

21 22 23 24
#define PCA953X_INPUT          0
#define PCA953X_OUTPUT         1
#define PCA953X_INVERT         2
#define PCA953X_DIRECTION      3
25

26
static const struct i2c_device_id pca953x_id[] = {
27 28 29 30 31 32
	{ "pca9534", 8, },
	{ "pca9535", 16, },
	{ "pca9536", 4, },
	{ "pca9537", 4, },
	{ "pca9538", 8, },
	{ "pca9539", 16, },
33
	{ "pca9554", 8, },
34 35
	{ "pca9555", 16, },
	{ "pca9557", 8, },
36
	{ "max7310", 8, },
37
	{ }
38
};
39
MODULE_DEVICE_TABLE(i2c, pca953x_id);
40

41
struct pca953x_chip {
42 43 44 45 46 47 48 49 50 51 52
	unsigned gpio_start;
	uint16_t reg_output;
	uint16_t reg_direction;

	struct i2c_client *client;
	struct gpio_chip gpio_chip;
};

/* NOTE:  we can't currently rely on fault codes to come from SMBus
 * calls, so we map all errors to EIO here and return zero otherwise.
 */
53
static int pca953x_write_reg(struct pca953x_chip *chip, int reg, uint16_t val)
54
{
55 56 57 58
	int ret;

	if (chip->gpio_chip.ngpio <= 8)
		ret = i2c_smbus_write_byte_data(chip->client, reg, val);
59
	else
60 61 62 63 64 65 66 67
		ret = i2c_smbus_write_word_data(chip->client, reg << 1, val);

	if (ret < 0) {
		dev_err(&chip->client->dev, "failed writing register\n");
		return -EIO;
	}

	return 0;
68 69
}

70
static int pca953x_read_reg(struct pca953x_chip *chip, int reg, uint16_t *val)
71 72 73
{
	int ret;

74 75 76 77 78
	if (chip->gpio_chip.ngpio <= 8)
		ret = i2c_smbus_read_byte_data(chip->client, reg);
	else
		ret = i2c_smbus_read_word_data(chip->client, reg << 1);

79 80 81 82 83 84 85 86 87
	if (ret < 0) {
		dev_err(&chip->client->dev, "failed reading register\n");
		return -EIO;
	}

	*val = (uint16_t)ret;
	return 0;
}

88
static int pca953x_gpio_direction_input(struct gpio_chip *gc, unsigned off)
89
{
90
	struct pca953x_chip *chip;
91 92 93
	uint16_t reg_val;
	int ret;

94
	chip = container_of(gc, struct pca953x_chip, gpio_chip);
95 96

	reg_val = chip->reg_direction | (1u << off);
97
	ret = pca953x_write_reg(chip, PCA953X_DIRECTION, reg_val);
98 99 100 101 102 103 104
	if (ret)
		return ret;

	chip->reg_direction = reg_val;
	return 0;
}

105
static int pca953x_gpio_direction_output(struct gpio_chip *gc,
106 107
		unsigned off, int val)
{
108
	struct pca953x_chip *chip;
109 110 111
	uint16_t reg_val;
	int ret;

112
	chip = container_of(gc, struct pca953x_chip, gpio_chip);
113 114 115 116 117 118 119

	/* set output level */
	if (val)
		reg_val = chip->reg_output | (1u << off);
	else
		reg_val = chip->reg_output & ~(1u << off);

120
	ret = pca953x_write_reg(chip, PCA953X_OUTPUT, reg_val);
121 122 123 124 125 126 127
	if (ret)
		return ret;

	chip->reg_output = reg_val;

	/* then direction */
	reg_val = chip->reg_direction & ~(1u << off);
128
	ret = pca953x_write_reg(chip, PCA953X_DIRECTION, reg_val);
129 130 131 132 133 134 135
	if (ret)
		return ret;

	chip->reg_direction = reg_val;
	return 0;
}

136
static int pca953x_gpio_get_value(struct gpio_chip *gc, unsigned off)
137
{
138
	struct pca953x_chip *chip;
139 140 141
	uint16_t reg_val;
	int ret;

142
	chip = container_of(gc, struct pca953x_chip, gpio_chip);
143

144
	ret = pca953x_read_reg(chip, PCA953X_INPUT, &reg_val);
145 146 147 148 149 150 151 152 153 154 155
	if (ret < 0) {
		/* NOTE:  diagnostic already emitted; that's all we should
		 * do unless gpio_*_value_cansleep() calls become different
		 * from their nonsleeping siblings (and report faults).
		 */
		return 0;
	}

	return (reg_val & (1u << off)) ? 1 : 0;
}

156
static void pca953x_gpio_set_value(struct gpio_chip *gc, unsigned off, int val)
157
{
158
	struct pca953x_chip *chip;
159 160 161
	uint16_t reg_val;
	int ret;

162
	chip = container_of(gc, struct pca953x_chip, gpio_chip);
163 164 165 166 167 168

	if (val)
		reg_val = chip->reg_output | (1u << off);
	else
		reg_val = chip->reg_output & ~(1u << off);

169
	ret = pca953x_write_reg(chip, PCA953X_OUTPUT, reg_val);
170 171 172 173 174 175
	if (ret)
		return;

	chip->reg_output = reg_val;
}

176
static void pca953x_setup_gpio(struct pca953x_chip *chip, int gpios)
177 178 179 180 181
{
	struct gpio_chip *gc;

	gc = &chip->gpio_chip;

182 183 184 185
	gc->direction_input  = pca953x_gpio_direction_input;
	gc->direction_output = pca953x_gpio_direction_output;
	gc->get = pca953x_gpio_get_value;
	gc->set = pca953x_gpio_set_value;
186
	gc->can_sleep = 1;
187 188

	gc->base = chip->gpio_start;
189 190
	gc->ngpio = gpios;
	gc->label = chip->client->name;
D
David Brownell 已提交
191
	gc->dev = &chip->client->dev;
192
	gc->owner = THIS_MODULE;
193 194
}

195
static int __devinit pca953x_probe(struct i2c_client *client,
196
				   const struct i2c_device_id *id)
197
{
198 199
	struct pca953x_platform_data *pdata;
	struct pca953x_chip *chip;
200
	int ret;
201 202 203 204 205

	pdata = client->dev.platform_data;
	if (pdata == NULL)
		return -ENODEV;

206
	chip = kzalloc(sizeof(struct pca953x_chip), GFP_KERNEL);
207 208 209 210 211 212 213 214 215 216
	if (chip == NULL)
		return -ENOMEM;

	chip->client = client;

	chip->gpio_start = pdata->gpio_base;

	/* initialize cached registers from their original values.
	 * we can't share this chip with another i2c master.
	 */
217 218
	pca953x_setup_gpio(chip, id->driver_data);

219
	ret = pca953x_read_reg(chip, PCA953X_OUTPUT, &chip->reg_output);
220 221 222
	if (ret)
		goto out_failed;

223
	ret = pca953x_read_reg(chip, PCA953X_DIRECTION, &chip->reg_direction);
224 225 226 227
	if (ret)
		goto out_failed;

	/* set platform specific polarity inversion */
228
	ret = pca953x_write_reg(chip, PCA953X_INVERT, pdata->invert);
229 230 231
	if (ret)
		goto out_failed;

232 233

	ret = gpiochip_add(&chip->gpio_chip);
234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251
	if (ret)
		goto out_failed;

	if (pdata->setup) {
		ret = pdata->setup(client, chip->gpio_chip.base,
				chip->gpio_chip.ngpio, pdata->context);
		if (ret < 0)
			dev_warn(&client->dev, "setup failed, %d\n", ret);
	}

	i2c_set_clientdata(client, chip);
	return 0;

out_failed:
	kfree(chip);
	return ret;
}

252
static int pca953x_remove(struct i2c_client *client)
253
{
254 255
	struct pca953x_platform_data *pdata = client->dev.platform_data;
	struct pca953x_chip *chip = i2c_get_clientdata(client);
256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278
	int ret = 0;

	if (pdata->teardown) {
		ret = pdata->teardown(client, chip->gpio_chip.base,
				chip->gpio_chip.ngpio, pdata->context);
		if (ret < 0) {
			dev_err(&client->dev, "%s failed, %d\n",
					"teardown", ret);
			return ret;
		}
	}

	ret = gpiochip_remove(&chip->gpio_chip);
	if (ret) {
		dev_err(&client->dev, "%s failed, %d\n",
				"gpiochip_remove()", ret);
		return ret;
	}

	kfree(chip);
	return 0;
}

279
static struct i2c_driver pca953x_driver = {
280
	.driver = {
281
		.name	= "pca953x",
282
	},
283 284
	.probe		= pca953x_probe,
	.remove		= pca953x_remove,
285
	.id_table	= pca953x_id,
286 287
};

288
static int __init pca953x_init(void)
289
{
290
	return i2c_add_driver(&pca953x_driver);
291
}
292
module_init(pca953x_init);
293

294
static void __exit pca953x_exit(void)
295
{
296
	i2c_del_driver(&pca953x_driver);
297
}
298
module_exit(pca953x_exit);
299 300

MODULE_AUTHOR("eric miao <eric.miao@marvell.com>");
301
MODULE_DESCRIPTION("GPIO expander driver for PCA953x");
302
MODULE_LICENSE("GPL");