17d6f7fb0SSrinivas Kandagatla // SPDX-License-Identifier: GPL-2.0
27d6f7fb0SSrinivas Kandagatla // Copyright (c) 2017, Linaro Ltd.
37d6f7fb0SSrinivas Kandagatla 
47d6f7fb0SSrinivas Kandagatla #include <linux/regmap.h>
57d6f7fb0SSrinivas Kandagatla #include <linux/slimbus.h>
67d6f7fb0SSrinivas Kandagatla #include <linux/module.h>
77d6f7fb0SSrinivas Kandagatla 
87d6f7fb0SSrinivas Kandagatla #include "internal.h"
97d6f7fb0SSrinivas Kandagatla 
regmap_slimbus_write(void * context,const void * data,size_t count)10e76ad18bSSrinivas Kandagatla static int regmap_slimbus_write(void *context, const void *data, size_t count)
117d6f7fb0SSrinivas Kandagatla {
127d6f7fb0SSrinivas Kandagatla 	struct slim_device *sdev = context;
137d6f7fb0SSrinivas Kandagatla 
14e76ad18bSSrinivas Kandagatla 	return slim_write(sdev, *(u16 *)data, count - 2, (u8 *)data + 2);
157d6f7fb0SSrinivas Kandagatla }
167d6f7fb0SSrinivas Kandagatla 
regmap_slimbus_read(void * context,const void * reg,size_t reg_size,void * val,size_t val_size)17e76ad18bSSrinivas Kandagatla static int regmap_slimbus_read(void *context, const void *reg, size_t reg_size,
18e76ad18bSSrinivas Kandagatla 			       void *val, size_t val_size)
197d6f7fb0SSrinivas Kandagatla {
207d6f7fb0SSrinivas Kandagatla 	struct slim_device *sdev = context;
217d6f7fb0SSrinivas Kandagatla 
22e76ad18bSSrinivas Kandagatla 	return slim_read(sdev, *(u16 *)reg, val_size, val);
237d6f7fb0SSrinivas Kandagatla }
247d6f7fb0SSrinivas Kandagatla 
25*bd941dfaSRikard Falkeborn static const struct regmap_bus regmap_slimbus_bus = {
26e76ad18bSSrinivas Kandagatla 	.write = regmap_slimbus_write,
27e76ad18bSSrinivas Kandagatla 	.read = regmap_slimbus_read,
287d6f7fb0SSrinivas Kandagatla 	.reg_format_endian_default = REGMAP_ENDIAN_LITTLE,
297d6f7fb0SSrinivas Kandagatla 	.val_format_endian_default = REGMAP_ENDIAN_LITTLE,
307d6f7fb0SSrinivas Kandagatla };
317d6f7fb0SSrinivas Kandagatla 
regmap_get_slimbus(struct slim_device * slim,const struct regmap_config * config)327d6f7fb0SSrinivas Kandagatla static const struct regmap_bus *regmap_get_slimbus(struct slim_device *slim,
337d6f7fb0SSrinivas Kandagatla 					const struct regmap_config *config)
347d6f7fb0SSrinivas Kandagatla {
35cbdd39caSSrinivas Kandagatla 	if (config->val_bits == 8 && config->reg_bits == 16)
367d6f7fb0SSrinivas Kandagatla 		return &regmap_slimbus_bus;
377d6f7fb0SSrinivas Kandagatla 
387d6f7fb0SSrinivas Kandagatla 	return ERR_PTR(-ENOTSUPP);
397d6f7fb0SSrinivas Kandagatla }
407d6f7fb0SSrinivas Kandagatla 
__regmap_init_slimbus(struct slim_device * slimbus,const struct regmap_config * config,struct lock_class_key * lock_key,const char * lock_name)417d6f7fb0SSrinivas Kandagatla struct regmap *__regmap_init_slimbus(struct slim_device *slimbus,
427d6f7fb0SSrinivas Kandagatla 				     const struct regmap_config *config,
437d6f7fb0SSrinivas Kandagatla 				     struct lock_class_key *lock_key,
447d6f7fb0SSrinivas Kandagatla 				     const char *lock_name)
457d6f7fb0SSrinivas Kandagatla {
467d6f7fb0SSrinivas Kandagatla 	const struct regmap_bus *bus = regmap_get_slimbus(slimbus, config);
477d6f7fb0SSrinivas Kandagatla 
487d6f7fb0SSrinivas Kandagatla 	if (IS_ERR(bus))
497d6f7fb0SSrinivas Kandagatla 		return ERR_CAST(bus);
507d6f7fb0SSrinivas Kandagatla 
517d6f7fb0SSrinivas Kandagatla 	return __regmap_init(&slimbus->dev, bus, &slimbus->dev, config,
527d6f7fb0SSrinivas Kandagatla 			     lock_key, lock_name);
537d6f7fb0SSrinivas Kandagatla }
547d6f7fb0SSrinivas Kandagatla EXPORT_SYMBOL_GPL(__regmap_init_slimbus);
557d6f7fb0SSrinivas Kandagatla 
__devm_regmap_init_slimbus(struct slim_device * slimbus,const struct regmap_config * config,struct lock_class_key * lock_key,const char * lock_name)567d6f7fb0SSrinivas Kandagatla struct regmap *__devm_regmap_init_slimbus(struct slim_device *slimbus,
577d6f7fb0SSrinivas Kandagatla 					  const struct regmap_config *config,
587d6f7fb0SSrinivas Kandagatla 					  struct lock_class_key *lock_key,
597d6f7fb0SSrinivas Kandagatla 					  const char *lock_name)
607d6f7fb0SSrinivas Kandagatla {
617d6f7fb0SSrinivas Kandagatla 	const struct regmap_bus *bus = regmap_get_slimbus(slimbus, config);
627d6f7fb0SSrinivas Kandagatla 
637d6f7fb0SSrinivas Kandagatla 	if (IS_ERR(bus))
647d6f7fb0SSrinivas Kandagatla 		return ERR_CAST(bus);
657d6f7fb0SSrinivas Kandagatla 
667d6f7fb0SSrinivas Kandagatla 	return __devm_regmap_init(&slimbus->dev, bus, &slimbus, config,
677d6f7fb0SSrinivas Kandagatla 				  lock_key, lock_name);
687d6f7fb0SSrinivas Kandagatla }
697d6f7fb0SSrinivas Kandagatla EXPORT_SYMBOL_GPL(__devm_regmap_init_slimbus);
707d6f7fb0SSrinivas Kandagatla 
717d6f7fb0SSrinivas Kandagatla MODULE_LICENSE("GPL v2");
72