-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel…
…/git/broonie/regmap * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap: regulator: Convert tps65023 to use regmap API regmap: Add SPI bus support regmap: Add I2C bus support regmap: Add generic non-memory mapped register access API
- Loading branch information
Showing
11 changed files
with
778 additions
and
70 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -168,4 +168,6 @@ config SYS_HYPERVISOR | |
bool | ||
default n | ||
|
||
source "drivers/base/regmap/Kconfig" | ||
|
||
endmenu |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
# Generic register map support. There are no user servicable options here, | ||
# this is an API intended to be used by other kernel subsystems. These | ||
# subsystems should select the appropriate symbols. | ||
|
||
config REGMAP | ||
default y if (REGMAP_I2C || REGMAP_SPI) | ||
bool | ||
|
||
config REGMAP_I2C | ||
tristate | ||
|
||
config REGMAP_SPI | ||
tristate |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
obj-$(CONFIG_REGMAP) += regmap.o | ||
obj-$(CONFIG_REGMAP_I2C) += regmap-i2c.o | ||
obj-$(CONFIG_REGMAP_SPI) += regmap-spi.o |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
/* | ||
* Register map access API - I2C support | ||
* | ||
* Copyright 2011 Wolfson Microelectronics plc | ||
* | ||
* Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#include <linux/regmap.h> | ||
#include <linux/i2c.h> | ||
#include <linux/module.h> | ||
#include <linux/init.h> | ||
|
||
static int regmap_i2c_write(struct device *dev, const void *data, size_t count) | ||
{ | ||
struct i2c_client *i2c = to_i2c_client(dev); | ||
int ret; | ||
|
||
ret = i2c_master_send(i2c, data, count); | ||
if (ret == count) | ||
return 0; | ||
else if (ret < 0) | ||
return ret; | ||
else | ||
return -EIO; | ||
} | ||
|
||
static int regmap_i2c_gather_write(struct device *dev, | ||
const void *reg, size_t reg_size, | ||
const void *val, size_t val_size) | ||
{ | ||
struct i2c_client *i2c = to_i2c_client(dev); | ||
struct i2c_msg xfer[2]; | ||
int ret; | ||
|
||
/* If the I2C controller can't do a gather tell the core, it | ||
* will substitute in a linear write for us. | ||
*/ | ||
if (!i2c_check_functionality(i2c->adapter, I2C_FUNC_PROTOCOL_MANGLING)) | ||
return -ENOTSUPP; | ||
|
||
xfer[0].addr = i2c->addr; | ||
xfer[0].flags = 0; | ||
xfer[0].len = reg_size; | ||
xfer[0].buf = (void *)reg; | ||
|
||
xfer[1].addr = i2c->addr; | ||
xfer[1].flags = I2C_M_NOSTART; | ||
xfer[1].len = val_size; | ||
xfer[1].buf = (void *)val; | ||
|
||
ret = i2c_transfer(i2c->adapter, xfer, 2); | ||
if (ret == 2) | ||
return 0; | ||
if (ret < 0) | ||
return ret; | ||
else | ||
return -EIO; | ||
} | ||
|
||
static int regmap_i2c_read(struct device *dev, | ||
const void *reg, size_t reg_size, | ||
void *val, size_t val_size) | ||
{ | ||
struct i2c_client *i2c = to_i2c_client(dev); | ||
struct i2c_msg xfer[2]; | ||
int ret; | ||
|
||
xfer[0].addr = i2c->addr; | ||
xfer[0].flags = 0; | ||
xfer[0].len = reg_size; | ||
xfer[0].buf = (void *)reg; | ||
|
||
xfer[1].addr = i2c->addr; | ||
xfer[1].flags = I2C_M_RD; | ||
xfer[1].len = val_size; | ||
xfer[1].buf = val; | ||
|
||
ret = i2c_transfer(i2c->adapter, xfer, 2); | ||
if (ret == 2) | ||
return 0; | ||
else if (ret < 0) | ||
return ret; | ||
else | ||
return -EIO; | ||
} | ||
|
||
static struct regmap_bus regmap_i2c = { | ||
.type = &i2c_bus_type, | ||
.write = regmap_i2c_write, | ||
.gather_write = regmap_i2c_gather_write, | ||
.read = regmap_i2c_read, | ||
.owner = THIS_MODULE, | ||
}; | ||
|
||
/** | ||
* regmap_init_i2c(): Initialise register map | ||
* | ||
* @i2c: Device that will be interacted with | ||
* @config: Configuration for register map | ||
* | ||
* The return value will be an ERR_PTR() on error or a valid pointer to | ||
* a struct regmap. | ||
*/ | ||
struct regmap *regmap_init_i2c(struct i2c_client *i2c, | ||
const struct regmap_config *config) | ||
{ | ||
return regmap_init(&i2c->dev, ®map_i2c, config); | ||
} | ||
EXPORT_SYMBOL_GPL(regmap_init_i2c); | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,72 @@ | ||
/* | ||
* Register map access API - SPI support | ||
* | ||
* Copyright 2011 Wolfson Microelectronics plc | ||
* | ||
* Author: Mark Brown <broonie@opensource.wolfsonmicro.com> | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2 as | ||
* published by the Free Software Foundation. | ||
*/ | ||
|
||
#include <linux/regmap.h> | ||
#include <linux/spi/spi.h> | ||
#include <linux/init.h> | ||
|
||
static int regmap_spi_write(struct device *dev, const void *data, size_t count) | ||
{ | ||
struct spi_device *spi = to_spi_device(dev); | ||
|
||
return spi_write(spi, data, count); | ||
} | ||
|
||
static int regmap_spi_gather_write(struct device *dev, | ||
const void *reg, size_t reg_len, | ||
const void *val, size_t val_len) | ||
{ | ||
struct spi_device *spi = to_spi_device(dev); | ||
struct spi_message m; | ||
struct spi_transfer t[2] = { { .tx_buf = reg, .len = reg_len, }, | ||
{ .tx_buf = val, .len = val_len, }, }; | ||
|
||
spi_message_init(&m); | ||
spi_message_add_tail(&t[0], &m); | ||
spi_message_add_tail(&t[1], &m); | ||
|
||
return spi_sync(spi, &m); | ||
} | ||
|
||
static int regmap_spi_read(struct device *dev, | ||
const void *reg, size_t reg_size, | ||
void *val, size_t val_size) | ||
{ | ||
struct spi_device *spi = to_spi_device(dev); | ||
|
||
return spi_write_then_read(spi, reg, reg_size, val, val_size); | ||
} | ||
|
||
static struct regmap_bus regmap_spi = { | ||
.type = &spi_bus_type, | ||
.write = regmap_spi_write, | ||
.gather_write = regmap_spi_gather_write, | ||
.read = regmap_spi_read, | ||
.owner = THIS_MODULE, | ||
.read_flag_mask = 0x80, | ||
}; | ||
|
||
/** | ||
* regmap_init_spi(): Initialise register map | ||
* | ||
* @spi: Device that will be interacted with | ||
* @config: Configuration for register map | ||
* | ||
* The return value will be an ERR_PTR() on error or a valid pointer to | ||
* a struct regmap. | ||
*/ | ||
struct regmap *regmap_init_spi(struct spi_device *spi, | ||
const struct regmap_config *config) | ||
{ | ||
return regmap_init(&spi->dev, ®map_spi, config); | ||
} | ||
EXPORT_SYMBOL_GPL(regmap_init_spi); |
Oops, something went wrong.