 4e7e2a2008
			
		
	
	
	4e7e2a2008
	
	
	
		
			
			* 'for-linus' of git://opensource.wolfsonmicro.com/regmap: (62 commits) mfd: Enable rbtree cache for wm831x devices regmap: Support some block operations on cached devices regmap: Allow caches for devices with no defaults regmap: Ensure rbtree syncs registers set to zero properly regmap: Allow rbtree to cache zero default values regmap: Warn on raw I/O as well as bulk reads that bypass cache regmap: Return a sensible error code if we fail to read the cache regmap: Use bsearch() to search the register defaults regmap: Fix doc comment regmap: Optimize the lookup path to use binary search regmap: Ensure we scream if we enable cache bypass/only at the same time regmap: Implement regcache_cache_bypass helper function regmap: Save/restore the bypass state upon syncing regmap: Lock the sync path, ensure we use the lockless _regmap_write() regmap: Fix apostrophe usage regmap: Make _regmap_write() global regmap: Fix lock used for regcache_cache_only() regmap: Grab the lock in regcache_cache_only() regmap: Modify map->cache_bypass directly regmap: Fix regcache_sync generic implementation ...
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			1.9 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			1.9 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * 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>
 | |
| #include <linux/module.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 = {
 | |
| 	.write = regmap_spi_write,
 | |
| 	.gather_write = regmap_spi_gather_write,
 | |
| 	.read = regmap_spi_read,
 | |
| 	.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);
 | |
| 
 | |
| MODULE_LICENSE("GPL");
 |