Lines Matching refs:aio
21 #include "aio.h"
88 * @aio: the AIO device pointer
96 * in each drivers (see: aio-i2s.c).
101 static const struct uniphier_aio_spec *find_spec(struct uniphier_aio *aio,
105 const struct uniphier_aio_chip_spec *chip_spec = aio->chip->chip_spec;
120 * @aio: the AIO device pointer
128 static int find_divider(struct uniphier_aio *aio, int pll_id, unsigned int freq)
135 if (!is_valid_pll(aio->chip, pll_id))
138 pll = &aio->chip->plls[pll_id];
149 struct uniphier_aio *aio = uniphier_priv(dai);
150 struct device *dev = &aio->chip->pdev->dev;
195 for (pll_id = 0; pll_id < aio->chip->num_plls; pll_id++) {
196 div_id = find_divider(aio, pll_id, freq);
198 aio->plldiv = div_id;
202 if (pll_id == aio->chip->num_plls) {
210 aio->pll_out = pll_id;
212 aio->pll_in = pll_id;
221 struct uniphier_aio *aio = uniphier_priv(dai);
224 if (!is_valid_pll(aio->chip, pll_id))
227 ret = aio_chip_set_pll(aio->chip, pll_id, freq_out);
236 struct uniphier_aio *aio = uniphier_priv(dai);
237 struct device *dev = &aio->chip->pdev->dev;
243 aio->fmt = fmt & SND_SOC_DAIFMT_FORMAT_MASK;
257 struct uniphier_aio *aio = uniphier_priv(dai);
258 struct uniphier_aio_sub *sub = &aio->sub[substream->stream];
275 struct uniphier_aio *aio = uniphier_priv(dai);
276 struct uniphier_aio_sub *sub = &aio->sub[substream->stream];
285 struct uniphier_aio *aio = uniphier_priv(dai);
286 struct uniphier_aio_sub *sub = &aio->sub[substream->stream];
287 struct device *dev = &aio->chip->pdev->dev;
323 struct uniphier_aio *aio = uniphier_priv(dai);
324 struct uniphier_aio_sub *sub = &aio->sub[substream->stream];
334 struct uniphier_aio *aio = uniphier_priv(dai);
335 struct uniphier_aio_sub *sub = &aio->sub[substream->stream];
388 struct uniphier_aio *aio = uniphier_priv(dai);
391 for (i = 0; i < ARRAY_SIZE(aio->sub); i++) {
392 struct uniphier_aio_sub *sub = &aio->sub[i];
395 spec = find_spec(aio, dai->name, i);
405 aio_iecout_set_enable(aio->chip, true);
406 aio_chip_init(aio->chip);
407 aio->chip->active = 1;
415 struct uniphier_aio *aio = uniphier_priv(dai);
417 aio->chip->active = 0;
425 struct uniphier_aio *aio = uniphier_priv(dai);
430 aio->chip->num_wup_aios--;
431 if (!aio->chip->num_wup_aios) {
432 reset_control_assert(aio->chip->rst);
433 clk_disable_unprepare(aio->chip->clk);
448 struct uniphier_aio *aio = uniphier_priv(dai);
454 if (!aio->chip->active)
457 if (!aio->chip->num_wup_aios) {
458 ret = clk_prepare_enable(aio->chip->clk);
462 ret = reset_control_deassert(aio->chip->rst);
467 aio_iecout_set_enable(aio->chip, true);
468 aio_chip_init(aio->chip);
470 for (i = 0; i < ARRAY_SIZE(aio->sub); i++) {
471 struct uniphier_aio_sub *sub = &aio->sub[i];
486 aio->chip->num_wup_aios++;
491 if (!aio->chip->num_wup_aios)
492 reset_control_assert(aio->chip->rst);
494 if (!aio->chip->num_wup_aios)
495 clk_disable_unprepare(aio->chip->clk);
617 .name = "uniphier-aio",
646 chip->clk = devm_clk_get(dev, "aio");
650 chip->rst = devm_reset_control_get_shared(dev, "aio");
673 struct uniphier_aio *aio = &chip->aios[i];
675 aio->chip = chip;
676 aio->fmt = SND_SOC_DAIFMT_I2S;
678 for (j = 0; j < ARRAY_SIZE(aio->sub); j++) {
679 struct uniphier_aio_sub *sub = &aio->sub[j];
681 sub->aio = aio;