Home
last modified time | relevance | path

Searched refs:madera (Results 1 – 25 of 34) sorted by relevance

12

/linux-6.1.9/drivers/mfd/ !
Dmadera-core.c211 static int madera_wait_for_boot_noack(struct madera *madera) in madera_wait_for_boot_noack() argument
225 regmap_read(madera->regmap, MADERA_IRQ1_RAW_STATUS_1, &val); in madera_wait_for_boot_noack()
230 regmap_read(madera->regmap, MADERA_IRQ1_RAW_STATUS_1, &val); in madera_wait_for_boot_noack()
234 dev_err(madera->dev, "Polling BOOT_DONE_STS timed out\n"); in madera_wait_for_boot_noack()
241 static int madera_wait_for_boot(struct madera *madera) in madera_wait_for_boot() argument
243 int ret = madera_wait_for_boot_noack(madera); in madera_wait_for_boot()
249 regmap_write(madera->regmap, MADERA_IRQ1_STATUS_1, in madera_wait_for_boot()
252 pm_runtime_mark_last_busy(madera->dev); in madera_wait_for_boot()
257 static int madera_soft_reset(struct madera *madera) in madera_soft_reset() argument
261 ret = regmap_write(madera->regmap, MADERA_SOFTWARE_RESET, 0); in madera_soft_reset()
[all …]
Dmadera.h14 struct madera;
19 int madera_dev_init(struct madera *madera);
20 int madera_dev_exit(struct madera *madera);
28 int cs47l15_patch(struct madera *madera);
34 int cs47l35_patch(struct madera *madera);
40 int cs47l85_patch(struct madera *madera);
46 int cs47l90_patch(struct madera *madera);
52 int cs47l92_patch(struct madera *madera);
Dmadera-i2c.c23 struct madera *madera; in madera_i2c_probe() local
87 madera = devm_kzalloc(&i2c->dev, sizeof(*madera), GFP_KERNEL); in madera_i2c_probe()
88 if (!madera) in madera_i2c_probe()
91 madera->regmap = devm_regmap_init_i2c(i2c, regmap_16bit_config); in madera_i2c_probe()
92 if (IS_ERR(madera->regmap)) { in madera_i2c_probe()
93 ret = PTR_ERR(madera->regmap); in madera_i2c_probe()
99 madera->regmap_32bit = devm_regmap_init_i2c(i2c, regmap_32bit_config); in madera_i2c_probe()
100 if (IS_ERR(madera->regmap_32bit)) { in madera_i2c_probe()
101 ret = PTR_ERR(madera->regmap_32bit); in madera_i2c_probe()
107 madera->type = type; in madera_i2c_probe()
[all …]
Dmadera-spi.c23 struct madera *madera; in madera_spi_probe() local
87 madera = devm_kzalloc(&spi->dev, sizeof(*madera), GFP_KERNEL); in madera_spi_probe()
88 if (!madera) in madera_spi_probe()
91 madera->regmap = devm_regmap_init_spi(spi, regmap_16bit_config); in madera_spi_probe()
92 if (IS_ERR(madera->regmap)) { in madera_spi_probe()
93 ret = PTR_ERR(madera->regmap); in madera_spi_probe()
99 madera->regmap_32bit = devm_regmap_init_spi(spi, regmap_32bit_config); in madera_spi_probe()
100 if (IS_ERR(madera->regmap_32bit)) { in madera_spi_probe()
101 ret = PTR_ERR(madera->regmap_32bit); in madera_spi_probe()
107 madera->type = type; in madera_spi_probe()
[all …]
DMakefile78 madera-objs := madera-core.o
80 madera-objs += cs47l15-tables.o
83 madera-objs += cs47l35-tables.o
86 madera-objs += cs47l85-tables.o
89 madera-objs += cs47l90-tables.o
92 madera-objs += cs47l92-tables.o
94 obj-$(CONFIG_MFD_MADERA) += madera.o
95 obj-$(CONFIG_MFD_MADERA_I2C) += madera-i2c.o
96 obj-$(CONFIG_MFD_MADERA_SPI) += madera-spi.o
Dcs47l92-tables.c92 int cs47l92_patch(struct madera *madera) in cs47l92_patch() argument
96 ret = regmap_register_patch(madera->regmap, in cs47l92_patch()
100 dev_err(madera->dev, in cs47l92_patch()
105 ret = regmap_register_patch(madera->regmap_32bit, in cs47l92_patch()
109 dev_err(madera->dev, in cs47l92_patch()
Dcs47l85-tables.c311 int cs47l85_patch(struct madera *madera) in cs47l85_patch() argument
318 switch (madera->rev) { in cs47l85_patch()
336 ret = regmap_register_patch(madera->regmap, patch16, num16); in cs47l85_patch()
338 dev_err(madera->dev, in cs47l85_patch()
343 ret = regmap_register_patch(madera->regmap_32bit, patch32, num32); in cs47l85_patch()
345 dev_err(madera->dev, in cs47l85_patch()
Dcs47l15-tables.c31 int cs47l15_patch(struct madera *madera) in cs47l15_patch() argument
35 ret = regmap_register_patch(madera->regmap, in cs47l15_patch()
39 dev_err(madera->dev, in cs47l15_patch()
/linux-6.1.9/drivers/gpio/ !
Dgpio-madera.c18 struct madera *madera; member
27 struct madera *madera = madera_gpio->madera; in madera_gpio_get_direction() local
32 ret = regmap_read(madera->regmap, MADERA_GPIO1_CTRL_2 + reg_offset, in madera_gpio_get_direction()
46 struct madera *madera = madera_gpio->madera; in madera_gpio_direction_in() local
49 return regmap_update_bits(madera->regmap, in madera_gpio_direction_in()
57 struct madera *madera = madera_gpio->madera; in madera_gpio_get() local
62 ret = regmap_read(madera->regmap, MADERA_GPIO1_CTRL_1 + reg_offset, in madera_gpio_get()
74 struct madera *madera = madera_gpio->madera; in madera_gpio_direction_out() local
79 ret = regmap_update_bits(madera->regmap, in madera_gpio_direction_out()
85 return regmap_update_bits(madera->regmap, in madera_gpio_direction_out()
[all …]
/linux-6.1.9/drivers/irqchip/ !
Dirq-madera.c103 struct madera *madera = dev_get_drvdata(dev->parent); in madera_suspend() local
105 dev_dbg(madera->irq_dev, "Suspend, disabling IRQ\n"); in madera_suspend()
112 disable_irq(madera->irq); in madera_suspend()
119 struct madera *madera = dev_get_drvdata(dev->parent); in madera_suspend_noirq() local
121 dev_dbg(madera->irq_dev, "No IRQ suspend, reenabling IRQ\n"); in madera_suspend_noirq()
124 enable_irq(madera->irq); in madera_suspend_noirq()
131 struct madera *madera = dev_get_drvdata(dev->parent); in madera_resume_noirq() local
133 dev_dbg(madera->irq_dev, "No IRQ resume, disabling IRQ\n"); in madera_resume_noirq()
139 disable_irq(madera->irq); in madera_resume_noirq()
146 struct madera *madera = dev_get_drvdata(dev->parent); in madera_resume() local
[all …]
/linux-6.1.9/sound/soc/codecs/ !
Dmadera.c143 dev_err(_fll->madera->dev, "FLL%d: " fmt, _fll->id, ##__VA_ARGS__)
145 dev_warn(_fll->madera->dev, "FLL%d: " fmt, _fll->id, ##__VA_ARGS__)
147 dev_dbg(_fll->madera->dev, "FLL%d: " fmt, _fll->id, ##__VA_ARGS__)
171 struct madera *madera = priv->madera; in madera_clk_ev() local
176 ret = regmap_read(madera->regmap, w->reg, &val); in madera_clk_ev()
178 dev_err(madera->dev, "Failed to check clock source: %d\n", ret); in madera_clk_ev()
198 return clk_prepare_enable(madera->mclk[clk_idx].clk); in madera_clk_ev()
200 clk_disable_unprepare(madera->mclk[clk_idx].clk); in madera_clk_ev()
210 struct madera *madera = priv->madera; in madera_spin_sysclk() local
215 if (pm_runtime_suspended(madera->dev)) in madera_spin_sysclk()
[all …]
Dcs47l92.c61 struct madera *madera = priv->madera; in cs47l92_put_demux() local
82 ret = regmap_read(madera->regmap, MADERA_OUTPUT_ENABLES_1, &cur); in cs47l92_put_demux()
84 dev_warn(madera->dev, "Failed to read outputs: %d\n", ret); in cs47l92_put_demux()
87 ret = regmap_update_bits(madera->regmap, MADERA_OUTPUT_ENABLES_1, in cs47l92_put_demux()
90 dev_warn(madera->dev, "Failed to disable outputs: %d\n", ret); in cs47l92_put_demux()
94 ret = regmap_update_bits(madera->regmap, MADERA_OUTPUT_ENABLES_1, in cs47l92_put_demux()
97 dev_err(madera->dev, "Failed to set OUT3 demux: %d\n", ret); in cs47l92_put_demux()
99 out_mono = madera->pdata.codec.out_mono[2 + mux]; in cs47l92_put_demux()
103 dev_warn(madera->dev, in cs47l92_put_demux()
107 ret = regmap_update_bits(madera->regmap, MADERA_OUTPUT_ENABLES_1, in cs47l92_put_demux()
[all …]
Dcs47l15.c75 struct madera *madera = priv->madera; in cs47l15_adsp_power_ev() local
79 ret = regmap_read(madera->regmap, MADERA_DSP_CLOCK_2, &freq); in cs47l15_adsp_power_ev()
81 dev_err(madera->dev, in cs47l15_adsp_power_ev()
1242 struct madera *madera = priv->madera; in cs47l15_open() local
1248 dev_err(madera->dev, in cs47l15_open()
1261 struct madera *madera = priv->madera; in cs47l15_adsp2_irq() local
1266 dev_err(madera->dev, "Spurious compressed data IRQ\n"); in cs47l15_adsp2_irq()
1280 struct madera *madera = cs47l15->core.madera; in cs47l15_component_probe() local
1283 snd_soc_component_init_regmap(component, madera->regmap); in cs47l15_component_probe()
1285 mutex_lock(&madera->dapm_ptr_lock); in cs47l15_component_probe()
[all …]
Dcs47l35.c93 struct madera *madera = priv->madera; in cs47l35_adsp_power_ev() local
97 ret = regmap_read(madera->regmap, MADERA_DSP_CLOCK_1, &freq); in cs47l35_adsp_power_ev()
99 dev_err(madera->dev, in cs47l35_adsp_power_ev()
1506 struct madera *madera = priv->madera; in cs47l35_open() local
1514 dev_err(madera->dev, in cs47l35_open()
1527 struct madera *madera = priv->madera; in cs47l35_adsp2_irq() local
1538 blocking_notifier_call_chain(&madera->notifier, in cs47l35_adsp2_irq()
1545 dev_err(madera->dev, "Spurious compressed data IRQ\n"); in cs47l35_adsp2_irq()
1559 struct madera *madera = cs47l35->core.madera; in cs47l35_component_probe() local
1562 snd_soc_component_init_regmap(component, madera->regmap); in cs47l35_component_probe()
[all …]
Dmadera.h107 struct madera;
122 struct madera *madera; member
159 struct madera *madera; member
410 int madera_init_fll(struct madera *madera, int id, int base,
443 struct madera *madera = priv->madera; in madera_register_notifier() local
445 return blocking_notifier_chain_register(&madera->notifier, nb); in madera_register_notifier()
453 struct madera *madera = priv->madera; in madera_unregister_notifier() local
455 return blocking_notifier_chain_unregister(&madera->notifier, nb); in madera_unregister_notifier()
Dcs47l90.c117 struct madera *madera = priv->madera; in cs47l90_adsp_power_ev() local
121 ret = regmap_read(madera->regmap, MADERA_DSP_CLOCK_2, &freq); in cs47l90_adsp_power_ev()
123 dev_err(madera->dev, in cs47l90_adsp_power_ev()
2367 struct madera *madera = priv->madera; in cs47l90_open() local
2375 dev_err(madera->dev, in cs47l90_open()
2388 struct madera *madera = priv->madera; in cs47l90_adsp2_irq() local
2399 blocking_notifier_call_chain(&madera->notifier, in cs47l90_adsp2_irq()
2406 dev_err(madera->dev, "Spurious compressed data IRQ\n"); in cs47l90_adsp2_irq()
2416 struct madera *madera = cs47l90->core.madera; in cs47l90_component_probe() local
2419 snd_soc_component_init_regmap(component, madera->regmap); in cs47l90_component_probe()
[all …]
Dcs47l85.c117 struct madera *madera = priv->madera; in cs47l85_adsp_power_ev() local
121 ret = regmap_read(madera->regmap, MADERA_DSP_CLOCK_1, &freq); in cs47l85_adsp_power_ev()
123 dev_err(madera->dev, in cs47l85_adsp_power_ev()
2448 struct madera *madera = priv->madera; in cs47l85_open() local
2456 dev_err(madera->dev, in cs47l85_open()
2469 struct madera *madera = priv->madera; in cs47l85_adsp2_irq() local
2480 blocking_notifier_call_chain(&madera->notifier, in cs47l85_adsp2_irq()
2487 dev_err(madera->dev, "Spurious compressed data IRQ\n"); in cs47l85_adsp2_irq()
2497 struct madera *madera = cs47l85->core.madera; in cs47l85_component_probe() local
2500 snd_soc_component_init_regmap(component, madera->regmap); in cs47l85_component_probe()
[all …]
/linux-6.1.9/include/linux/irqchip/ !
Dirq-madera.h94 static inline int madera_get_irq_mapping(struct madera *madera, int irq) in madera_get_irq_mapping() argument
96 if (!madera->irq_dev) in madera_get_irq_mapping()
99 return regmap_irq_get_virq(madera->irq_data, irq); in madera_get_irq_mapping()
102 static inline int madera_request_irq(struct madera *madera, int irq, in madera_request_irq() argument
106 irq = madera_get_irq_mapping(madera, irq); in madera_request_irq()
114 static inline void madera_free_irq(struct madera *madera, int irq, void *data) in madera_free_irq() argument
116 irq = madera_get_irq_mapping(madera, irq); in madera_free_irq()
123 static inline int madera_set_irq_wake(struct madera *madera, int irq, int on) in madera_set_irq_wake() argument
125 irq = madera_get_irq_mapping(madera, irq); in madera_set_irq_wake()
/linux-6.1.9/drivers/pinctrl/cirrus/ !
DMakefile5 pinctrl-madera-objs := pinctrl-madera-core.o
7 pinctrl-madera-objs += pinctrl-cs47l15.o
10 pinctrl-madera-objs += pinctrl-cs47l35.o
13 pinctrl-madera-objs += pinctrl-cs47l85.o
16 pinctrl-madera-objs += pinctrl-cs47l90.o
19 pinctrl-madera-objs += pinctrl-cs47l92.o
22 obj-$(CONFIG_PINCTRL_MADERA) += pinctrl-madera.o
Dpinctrl-madera-core.c524 ret = regmap_read(priv->madera->regmap, reg, &conf[0]); in madera_pin_dbg_show()
528 ret = regmap_read(priv->madera->regmap, reg + 1, &conf[1]); in madera_pin_dbg_show()
614 struct madera *madera = priv->madera; in madera_mux_set_mux() local
643 ret = regmap_update_bits(madera->regmap, reg, in madera_mux_set_mux()
661 ret = regmap_update_bits(madera->regmap, in madera_mux_set_mux()
679 struct madera *madera = priv->madera; in madera_gpio_set_direction() local
689 ret = regmap_update_bits(madera->regmap, reg, MADERA_GP1_DIR_MASK, val); in madera_gpio_set_direction()
701 struct madera *madera = priv->madera; in madera_gpio_request_enable() local
706 ret = regmap_update_bits(madera->regmap, reg, MADERA_GP1_FN_MASK, 1); in madera_gpio_request_enable()
718 struct madera *madera = priv->madera; in madera_gpio_disable_free() local
[all …]
Dpinctrl-madera.h25 struct madera *madera; member
/linux-6.1.9/drivers/regulator/ !
Darizona-micsupp.c346 struct madera *madera = dev_get_drvdata(pdev->dev.parent); in madera_micsupp_probe() local
353 micsupp->regmap = madera->regmap; in madera_micsupp_probe()
354 micsupp->dapm = &madera->dapm; in madera_micsupp_probe()
355 micsupp->dev = madera->dev; in madera_micsupp_probe()
359 &madera->pdata.micvdd); in madera_micsupp_probe()
Darizona-ldo1.c354 struct madera *madera = dev_get_drvdata(pdev->dev.parent); in madera_ldo1_probe() local
363 ldo1->regmap = madera->regmap; in madera_ldo1_probe()
368 &madera->pdata.ldo1, in madera_ldo1_probe()
373 madera->internal_dcvdd = !external_dcvdd; in madera_ldo1_probe()
/linux-6.1.9/Documentation/devicetree/bindings/mfd/ !
Dcirrus,madera.yaml4 $id: http://devicetree.org/schemas/mfd/cirrus,madera.yaml#
18 bindings/pinctrl/cirrus,madera.yaml
20 bindings/sound/cirrus,madera.yaml
23 - $ref: /schemas/pinctrl/cirrus,madera.yaml#
25 - $ref: /schemas/sound/cirrus,madera.yaml#
233 #include <dt-bindings/sound/madera.h>
/linux-6.1.9/Documentation/devicetree/bindings/sound/ !
Dcirrus,madera.yaml4 $id: http://devicetree.org/schemas/sound/cirrus,madera.yaml#
17 Documentation/devicetree/bindings/mfd/cirrus,madera.yaml
21 include/dt-bindings/sound/madera.h

12