Linux Audio

Check our new training course

Loading...
v5.9
 1// SPDX-License-Identifier: GPL-2.0
 2// Copyright(c) 2015-17 Intel Corporation.
 3
 4#include <linux/device.h>
 5#include <linux/mod_devicetable.h>
 6#include <linux/module.h>
 
 7#include <linux/soundwire/sdw.h>
 
 8#include "internal.h"
 9
10static int regmap_sdw_write(void *context, unsigned int reg, unsigned int val)
11{
12	struct device *dev = context;
13	struct sdw_slave *slave = dev_to_sdw_dev(dev);
 
 
 
14
15	return sdw_write(slave, reg, val);
16}
17
18static int regmap_sdw_read(void *context, unsigned int reg, unsigned int *val)
 
 
19{
20	struct device *dev = context;
21	struct sdw_slave *slave = dev_to_sdw_dev(dev);
22	int read;
23
24	read = sdw_read(slave, reg);
25	if (read < 0)
26		return read;
 
 
 
 
 
 
 
27
28	*val = read;
29	return 0;
30}
31
32static struct regmap_bus regmap_sdw = {
33	.reg_read = regmap_sdw_read,
34	.reg_write = regmap_sdw_write,
 
35	.reg_format_endian_default = REGMAP_ENDIAN_LITTLE,
36	.val_format_endian_default = REGMAP_ENDIAN_LITTLE,
37};
38
39static int regmap_sdw_config_check(const struct regmap_config *config)
40{
41	/* All register are 8-bits wide as per MIPI Soundwire 1.0 Spec */
42	if (config->val_bits != 8)
43		return -ENOTSUPP;
44
45	/* Registers are 32 bits wide */
46	if (config->reg_bits != 32)
47		return -ENOTSUPP;
48
49	if (config->pad_bits != 0)
 
 
 
 
50		return -ENOTSUPP;
51
52	return 0;
53}
54
55struct regmap *__regmap_init_sdw(struct sdw_slave *sdw,
56				 const struct regmap_config *config,
57				 struct lock_class_key *lock_key,
58				 const char *lock_name)
59{
60	int ret;
61
62	ret = regmap_sdw_config_check(config);
63	if (ret)
64		return ERR_PTR(ret);
65
66	return __regmap_init(&sdw->dev, &regmap_sdw,
67			&sdw->dev, config, lock_key, lock_name);
68}
69EXPORT_SYMBOL_GPL(__regmap_init_sdw);
70
71struct regmap *__devm_regmap_init_sdw(struct sdw_slave *sdw,
72				      const struct regmap_config *config,
73				      struct lock_class_key *lock_key,
74				      const char *lock_name)
75{
76	int ret;
77
78	ret = regmap_sdw_config_check(config);
79	if (ret)
80		return ERR_PTR(ret);
81
82	return __devm_regmap_init(&sdw->dev, &regmap_sdw,
83			&sdw->dev, config, lock_key, lock_name);
84}
85EXPORT_SYMBOL_GPL(__devm_regmap_init_sdw);
86
87MODULE_DESCRIPTION("Regmap SoundWire Module");
88MODULE_LICENSE("GPL v2");
v6.8
  1// SPDX-License-Identifier: GPL-2.0
  2// Copyright(c) 2015-17 Intel Corporation.
  3
  4#include <linux/device.h>
  5#include <linux/errno.h>
  6#include <linux/module.h>
  7#include <linux/regmap.h>
  8#include <linux/soundwire/sdw.h>
  9#include <linux/types.h>
 10#include "internal.h"
 11
 12static int regmap_sdw_write(void *context, const void *val_buf, size_t val_size)
 13{
 14	struct device *dev = context;
 15	struct sdw_slave *slave = dev_to_sdw_dev(dev);
 16	/* First word of buffer contains the destination address */
 17	u32 addr = le32_to_cpu(*(const __le32 *)val_buf);
 18	const u8 *val = val_buf;
 19
 20	return sdw_nwrite_no_pm(slave, addr, val_size - sizeof(addr), val + sizeof(addr));
 21}
 22
 23static int regmap_sdw_gather_write(void *context,
 24				   const void *reg_buf, size_t reg_size,
 25				   const void *val_buf, size_t val_size)
 26{
 27	struct device *dev = context;
 28	struct sdw_slave *slave = dev_to_sdw_dev(dev);
 29	u32 addr = le32_to_cpu(*(const __le32 *)reg_buf);
 30
 31	return sdw_nwrite_no_pm(slave, addr, val_size, val_buf);
 32}
 33
 34static int regmap_sdw_read(void *context,
 35			   const void *reg_buf, size_t reg_size,
 36			   void *val_buf, size_t val_size)
 37{
 38	struct device *dev = context;
 39	struct sdw_slave *slave = dev_to_sdw_dev(dev);
 40	u32 addr = le32_to_cpu(*(const __le32 *)reg_buf);
 41
 42	return sdw_nread_no_pm(slave, addr, val_size, val_buf);
 
 43}
 44
 45static const struct regmap_bus regmap_sdw = {
 46	.write = regmap_sdw_write,
 47	.gather_write = regmap_sdw_gather_write,
 48	.read = regmap_sdw_read,
 49	.reg_format_endian_default = REGMAP_ENDIAN_LITTLE,
 50	.val_format_endian_default = REGMAP_ENDIAN_LITTLE,
 51};
 52
 53static int regmap_sdw_config_check(const struct regmap_config *config)
 54{
 55	/* Register addresses are 32 bits wide */
 
 
 
 
 56	if (config->reg_bits != 32)
 57		return -ENOTSUPP;
 58
 59	if (config->pad_bits != 0)
 60		return -ENOTSUPP;
 61
 62	/* Only bulk writes are supported not multi-register writes */
 63	if (config->can_multi_write)
 64		return -ENOTSUPP;
 65
 66	return 0;
 67}
 68
 69struct regmap *__regmap_init_sdw(struct sdw_slave *sdw,
 70				 const struct regmap_config *config,
 71				 struct lock_class_key *lock_key,
 72				 const char *lock_name)
 73{
 74	int ret;
 75
 76	ret = regmap_sdw_config_check(config);
 77	if (ret)
 78		return ERR_PTR(ret);
 79
 80	return __regmap_init(&sdw->dev, &regmap_sdw,
 81			&sdw->dev, config, lock_key, lock_name);
 82}
 83EXPORT_SYMBOL_GPL(__regmap_init_sdw);
 84
 85struct regmap *__devm_regmap_init_sdw(struct sdw_slave *sdw,
 86				      const struct regmap_config *config,
 87				      struct lock_class_key *lock_key,
 88				      const char *lock_name)
 89{
 90	int ret;
 91
 92	ret = regmap_sdw_config_check(config);
 93	if (ret)
 94		return ERR_PTR(ret);
 95
 96	return __devm_regmap_init(&sdw->dev, &regmap_sdw,
 97			&sdw->dev, config, lock_key, lock_name);
 98}
 99EXPORT_SYMBOL_GPL(__devm_regmap_init_sdw);
100
101MODULE_DESCRIPTION("Regmap SoundWire Module");
102MODULE_LICENSE("GPL v2");