Lines Matching +full:sync +full:- +full:in +full:- +full:gpios
1 // SPDX-License-Identifier: GPL-2.0+
3 // soc-ac97.c -- ALSA SoC Audio Layer AC97 support
11 // with code, comments and ideas from :-
46 .ops = NULL, /* Gets initialized in snd_soc_set_ac97_ops() */
59 return gpio_priv->component; in gpio_to_component()
65 return -EINVAL; in snd_soc_ac97_gpio_request()
75 dev_dbg(component->dev, "set gpio %d to output\n", offset); in snd_soc_ac97_gpio_direction_in()
87 dev_dbg(component->dev, "get gpio %d : %d\n", offset, in snd_soc_ac97_gpio_get()
99 gpio_priv->gpios_set &= ~(1 << offset); in snd_soc_ac97_gpio_set()
100 gpio_priv->gpios_set |= (!!value) << offset; in snd_soc_ac97_gpio_set()
102 gpio_priv->gpios_set); in snd_soc_ac97_gpio_set()
103 dev_dbg(component->dev, "set gpio %d to %d\n", offset, !!value); in snd_soc_ac97_gpio_set()
111 dev_dbg(component->dev, "set gpio %d to output\n", offset); in snd_soc_ac97_gpio_direction_out()
134 gpio_priv = devm_kzalloc(component->dev, sizeof(*gpio_priv), GFP_KERNEL); in snd_soc_ac97_init_gpio()
136 return -ENOMEM; in snd_soc_ac97_init_gpio()
137 ac97->gpio_priv = gpio_priv; in snd_soc_ac97_init_gpio()
138 gpio_priv->component = component; in snd_soc_ac97_init_gpio()
139 gpio_priv->gpio_chip = snd_soc_ac97_gpio_chip; in snd_soc_ac97_init_gpio()
140 gpio_priv->gpio_chip.ngpio = AC97_NUM_GPIOS; in snd_soc_ac97_init_gpio()
141 gpio_priv->gpio_chip.parent = component->dev; in snd_soc_ac97_init_gpio()
142 gpio_priv->gpio_chip.base = -1; in snd_soc_ac97_init_gpio()
144 ret = gpiochip_add_data(&gpio_priv->gpio_chip, gpio_priv); in snd_soc_ac97_init_gpio()
146 dev_err(component->dev, "Failed to add GPIOs: %d\n", ret); in snd_soc_ac97_init_gpio()
152 gpiochip_remove(&ac97->gpio_priv->gpio_chip); in snd_soc_ac97_free_gpio()
167 * snd_soc_alloc_ac97_component() - Allocate new a AC'97 device
171 * it. The caller is responsible to either call device_add(&ac97->dev) to
172 * register the device, or to call put_device(&ac97->dev) to free the device.
174 * Returns: A snd_ac97 device or a PTR_ERR in case of an error.
182 return ERR_PTR(-ENOMEM); in snd_soc_alloc_ac97_component()
184 ac97->bus = &soc_ac97_bus; in snd_soc_alloc_ac97_component()
185 ac97->num = 0; in snd_soc_alloc_ac97_component()
187 ac97->dev.bus = &ac97_bus_type; in snd_soc_alloc_ac97_component()
188 ac97->dev.parent = component->card->dev; in snd_soc_alloc_ac97_component()
189 ac97->dev.release = soc_ac97_device_release; in snd_soc_alloc_ac97_component()
191 dev_set_name(&ac97->dev, "%d-%d:%s", in snd_soc_alloc_ac97_component()
192 component->card->snd_card->number, 0, in snd_soc_alloc_ac97_component()
193 component->name); in snd_soc_alloc_ac97_component()
195 device_initialize(&ac97->dev); in snd_soc_alloc_ac97_component()
202 * snd_soc_new_ac97_component - initailise AC97 device
207 * Initialises AC97 component resources for use by ad-hoc devices only.
228 dev_err(component->dev, "Failed to reset AC97 device: %d\n", in snd_soc_new_ac97_component()
234 ret = device_add(&ac97->dev); in snd_soc_new_ac97_component()
245 put_device(&ac97->dev); in snd_soc_new_ac97_component()
251 * snd_soc_free_ac97_component - free AC97 component device
259 device_del(&ac97->dev); in snd_soc_free_ac97_component()
260 ac97->bus = NULL; in snd_soc_free_ac97_component()
261 put_device(&ac97->dev); in snd_soc_free_ac97_component()
314 cfg->pctl = p; in snd_soc_ac97_parse_pinctl()
316 state = pinctrl_lookup_state(p, "ac97-reset"); in snd_soc_ac97_parse_pinctl()
318 dev_err(dev, "Can't find pinctrl state ac97-reset\n"); in snd_soc_ac97_parse_pinctl()
321 cfg->pstate_reset = state; in snd_soc_ac97_parse_pinctl()
323 state = pinctrl_lookup_state(p, "ac97-warm-reset"); in snd_soc_ac97_parse_pinctl()
325 dev_err(dev, "Can't find pinctrl state ac97-warm-reset\n"); in snd_soc_ac97_parse_pinctl()
328 cfg->pstate_warm_reset = state; in snd_soc_ac97_parse_pinctl()
330 state = pinctrl_lookup_state(p, "ac97-running"); in snd_soc_ac97_parse_pinctl()
332 dev_err(dev, "Can't find pinctrl state ac97-running\n"); in snd_soc_ac97_parse_pinctl()
335 cfg->pstate_run = state; in snd_soc_ac97_parse_pinctl()
337 gpio = of_get_named_gpio(dev->of_node, "ac97-gpios", 0); in snd_soc_ac97_parse_pinctl()
339 dev_err(dev, "Can't find ac97-sync gpio\n"); in snd_soc_ac97_parse_pinctl()
342 ret = devm_gpio_request(dev, gpio, "AC97 link sync"); in snd_soc_ac97_parse_pinctl()
344 dev_err(dev, "Failed requesting ac97-sync gpio\n"); in snd_soc_ac97_parse_pinctl()
347 cfg->gpio_sync = gpio; in snd_soc_ac97_parse_pinctl()
349 gpio = of_get_named_gpio(dev->of_node, "ac97-gpios", 1); in snd_soc_ac97_parse_pinctl()
351 dev_err(dev, "Can't find ac97-sdata gpio %d\n", gpio); in snd_soc_ac97_parse_pinctl()
356 dev_err(dev, "Failed requesting ac97-sdata gpio\n"); in snd_soc_ac97_parse_pinctl()
359 cfg->gpio_sdata = gpio; in snd_soc_ac97_parse_pinctl()
361 gpio = of_get_named_gpio(dev->of_node, "ac97-gpios", 2); in snd_soc_ac97_parse_pinctl()
363 dev_err(dev, "Can't find ac97-reset gpio\n"); in snd_soc_ac97_parse_pinctl()
368 dev_err(dev, "Failed requesting ac97-reset gpio\n"); in snd_soc_ac97_parse_pinctl()
371 cfg->gpio_reset = gpio; in snd_soc_ac97_parse_pinctl()
385 return -EBUSY; in snd_soc_set_ac97_ops()
395 * snd_soc_set_ac97_ops_of_reset - Set ac97 ops with generic ac97 reset functions
405 struct device *dev = &pdev->dev; in snd_soc_set_ac97_ops_of_reset()
417 ops->warm_reset = snd_soc_ac97_warm_reset; in snd_soc_set_ac97_ops_of_reset()
418 ops->reset = snd_soc_ac97_reset; in snd_soc_set_ac97_ops_of_reset()