diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-03 14:40:58 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-07-03 14:40:58 -0400 |
commit | a6e6d863cf68bba886acfe47dbdc8f245cce588f (patch) | |
tree | cf6a408da597c5e39def6a28c38d117c5899eef8 /include/linux/regmap.h | |
parent | 60b5adffb4f3e4b4c1978959f24e8e531b2ef3cb (diff) | |
parent | 7bc8c4c37aea74332b16ffb5412a8ad355d508ce (diff) |
Merge tag 'regmap-v3.11' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap
Pull regmap updates from Mark Brown:
"A small but useful set of regmap updates this time around:
- An abstraction for bitfields within a register map contributed by
Srinivas Kandagatla, allowing drivers to cope more easily when
hardware designers randomly move things about (mainly when talking
to things like system controllers).
- Changes from Lars-Peter Clausen to allow the MMIO regmap to be used
from hard IRQ context.
- Small improvements to the cache infrastructure and performance,
including a default cache sync operation so now all regmaps can
sync easily.
There's also a pinctrl driver making use of the new bitfield API,
merged here for dependency reasons. There will be a simple add/add
conflict with the pinctrl tree as a result."
* tag 'regmap-v3.11' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regmap:
pinctrl: st: Remove unnecessary use of of_match_ptr macro
pinctrl: st: fix return value check
pinctrl: st: Add pinctrl and pinconf support.
regmap: debugfs: Suppress cache for partial register files
regmap: Add regmap_field APIs
regmap: core: Cache all registers by default when cache is enabled
regmap: Implemented default cache sync operation
regmap: Make regmap-mmio usable from atomic contexts
regmap: regcache: Fixup locking for custom lock callbacks
regmap: debugfs: Fix return from regmap_debugfs_get_dump_start
regmap: debugfs: Don't mark lockdep as broken due to debugfs write
regmap: rbtree: Use range information to allocate nodes
regmap: rbtree: Factor out node allocation
regmap: Make regmap_check_range_table() a public API
regmap: Add support for discarding parts of the register cache
Diffstat (limited to 'include/linux/regmap.h')
-rw-r--r-- | include/linux/regmap.h | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/include/linux/regmap.h b/include/linux/regmap.h index 02d84e24b7c2..75981d0b57dc 100644 --- a/include/linux/regmap.h +++ b/include/linux/regmap.h | |||
@@ -23,6 +23,7 @@ struct irq_domain; | |||
23 | struct spi_device; | 23 | struct spi_device; |
24 | struct regmap; | 24 | struct regmap; |
25 | struct regmap_range_cfg; | 25 | struct regmap_range_cfg; |
26 | struct regmap_field; | ||
26 | 27 | ||
27 | /* An enum of all the supported cache types */ | 28 | /* An enum of all the supported cache types */ |
28 | enum regcache_type { | 29 | enum regcache_type { |
@@ -394,10 +395,15 @@ bool regmap_can_raw_write(struct regmap *map); | |||
394 | int regcache_sync(struct regmap *map); | 395 | int regcache_sync(struct regmap *map); |
395 | int regcache_sync_region(struct regmap *map, unsigned int min, | 396 | int regcache_sync_region(struct regmap *map, unsigned int min, |
396 | unsigned int max); | 397 | unsigned int max); |
398 | int regcache_drop_region(struct regmap *map, unsigned int min, | ||
399 | unsigned int max); | ||
397 | void regcache_cache_only(struct regmap *map, bool enable); | 400 | void regcache_cache_only(struct regmap *map, bool enable); |
398 | void regcache_cache_bypass(struct regmap *map, bool enable); | 401 | void regcache_cache_bypass(struct regmap *map, bool enable); |
399 | void regcache_mark_dirty(struct regmap *map); | 402 | void regcache_mark_dirty(struct regmap *map); |
400 | 403 | ||
404 | bool regmap_check_range_table(struct regmap *map, unsigned int reg, | ||
405 | const struct regmap_access_table *table); | ||
406 | |||
401 | int regmap_register_patch(struct regmap *map, const struct reg_default *regs, | 407 | int regmap_register_patch(struct regmap *map, const struct reg_default *regs, |
402 | int num_regs); | 408 | int num_regs); |
403 | 409 | ||
@@ -412,6 +418,36 @@ bool regmap_reg_in_ranges(unsigned int reg, | |||
412 | unsigned int nranges); | 418 | unsigned int nranges); |
413 | 419 | ||
414 | /** | 420 | /** |
421 | * Description of an register field | ||
422 | * | ||
423 | * @reg: Offset of the register within the regmap bank | ||
424 | * @lsb: lsb of the register field. | ||
425 | * @reg: msb of the register field. | ||
426 | */ | ||
427 | struct reg_field { | ||
428 | unsigned int reg; | ||
429 | unsigned int lsb; | ||
430 | unsigned int msb; | ||
431 | }; | ||
432 | |||
433 | #define REG_FIELD(_reg, _lsb, _msb) { \ | ||
434 | .reg = _reg, \ | ||
435 | .lsb = _lsb, \ | ||
436 | .msb = _msb, \ | ||
437 | } | ||
438 | |||
439 | struct regmap_field *regmap_field_alloc(struct regmap *regmap, | ||
440 | struct reg_field reg_field); | ||
441 | void regmap_field_free(struct regmap_field *field); | ||
442 | |||
443 | struct regmap_field *devm_regmap_field_alloc(struct device *dev, | ||
444 | struct regmap *regmap, struct reg_field reg_field); | ||
445 | void devm_regmap_field_free(struct device *dev, struct regmap_field *field); | ||
446 | |||
447 | int regmap_field_read(struct regmap_field *field, unsigned int *val); | ||
448 | int regmap_field_write(struct regmap_field *field, unsigned int val); | ||
449 | |||
450 | /** | ||
415 | * Description of an IRQ for the generic regmap irq_chip. | 451 | * Description of an IRQ for the generic regmap irq_chip. |
416 | * | 452 | * |
417 | * @reg_offset: Offset of the status/mask register within the bank | 453 | * @reg_offset: Offset of the status/mask register within the bank |
@@ -562,6 +598,13 @@ static inline int regcache_sync_region(struct regmap *map, unsigned int min, | |||
562 | return -EINVAL; | 598 | return -EINVAL; |
563 | } | 599 | } |
564 | 600 | ||
601 | static inline int regcache_drop_region(struct regmap *map, unsigned int min, | ||
602 | unsigned int max) | ||
603 | { | ||
604 | WARN_ONCE(1, "regmap API is disabled"); | ||
605 | return -EINVAL; | ||
606 | } | ||
607 | |||
565 | static inline void regcache_cache_only(struct regmap *map, bool enable) | 608 | static inline void regcache_cache_only(struct regmap *map, bool enable) |
566 | { | 609 | { |
567 | WARN_ONCE(1, "regmap API is disabled"); | 610 | WARN_ONCE(1, "regmap API is disabled"); |