* '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");
 |