Lines Matching +full:pre +full:- +full:verified
1 /* SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause) */
19 #include "sof-priv.h"
22 ((sdev)->pdata->desc->ops)
26 if (sdev->pdata->desc->ops_init) in sof_ops_init()
27 return sdev->pdata->desc->ops_init(sdev); in sof_ops_init()
34 if (sdev->pdata->desc->ops_free) in sof_ops_free()
35 sdev->pdata->desc->ops_free(sdev); in sof_ops_free()
38 /* Mandatory operations are verified during probing */
43 if (sof_ops(sdev)->probe_early) in snd_sof_probe_early()
44 return sof_ops(sdev)->probe_early(sdev); in snd_sof_probe_early()
51 return sof_ops(sdev)->probe(sdev); in snd_sof_probe()
56 if (sof_ops(sdev)->remove) in snd_sof_remove()
57 sof_ops(sdev)->remove(sdev); in snd_sof_remove()
62 if (sof_ops(sdev)->remove_late) in snd_sof_remove_late()
63 sof_ops(sdev)->remove_late(sdev); in snd_sof_remove_late()
68 if (sof_ops(sdev)->shutdown) in snd_sof_shutdown()
69 return sof_ops(sdev)->shutdown(sdev); in snd_sof_shutdown()
82 return sof_ops(sdev)->run(sdev); in snd_sof_dsp_run()
87 if (sof_ops(sdev)->stall) in snd_sof_dsp_stall()
88 return sof_ops(sdev)->stall(sdev, core_mask); in snd_sof_dsp_stall()
95 if (sof_ops(sdev)->reset) in snd_sof_dsp_reset()
96 return sof_ops(sdev)->reset(sdev); in snd_sof_dsp_reset()
104 if (core > sdev->num_cores - 1) { in snd_sof_dsp_core_get()
105 dev_err(sdev->dev, "invalid core id: %d for num_cores: %d\n", core, in snd_sof_dsp_core_get()
106 sdev->num_cores); in snd_sof_dsp_core_get()
107 return -EINVAL; in snd_sof_dsp_core_get()
110 if (sof_ops(sdev)->core_get) { in snd_sof_dsp_core_get()
114 if (sdev->dsp_core_ref_count[core] > 0) { in snd_sof_dsp_core_get()
115 sdev->dsp_core_ref_count[core]++; in snd_sof_dsp_core_get()
120 ret = sof_ops(sdev)->core_get(sdev, core); in snd_sof_dsp_core_get()
125 sdev->dsp_core_ref_count[core]++; in snd_sof_dsp_core_get()
128 sdev->enabled_cores_mask |= BIT(core); in snd_sof_dsp_core_get()
130 dev_dbg(sdev->dev, "Core %d powered up\n", core); in snd_sof_dsp_core_get()
138 if (core > sdev->num_cores - 1) { in snd_sof_dsp_core_put()
139 dev_err(sdev->dev, "invalid core id: %d for num_cores: %d\n", core, in snd_sof_dsp_core_put()
140 sdev->num_cores); in snd_sof_dsp_core_put()
141 return -EINVAL; in snd_sof_dsp_core_put()
144 if (sof_ops(sdev)->core_put) { in snd_sof_dsp_core_put()
148 if (--(sdev->dsp_core_ref_count[core]) > 0) in snd_sof_dsp_core_put()
152 ret = sof_ops(sdev)->core_put(sdev, core); in snd_sof_dsp_core_put()
157 sdev->enabled_cores_mask &= ~BIT(core); in snd_sof_dsp_core_put()
159 dev_dbg(sdev->dev, "Core %d powered down\n", core); in snd_sof_dsp_core_put()
165 /* pre/post fw load */
168 if (sof_ops(sdev)->pre_fw_run) in snd_sof_dsp_pre_fw_run()
169 return sof_ops(sdev)->pre_fw_run(sdev); in snd_sof_dsp_pre_fw_run()
176 if (sof_ops(sdev)->post_fw_run) in snd_sof_dsp_post_fw_run()
177 return sof_ops(sdev)->post_fw_run(sdev); in snd_sof_dsp_post_fw_run()
186 if (sof_ops(sdev)->parse_platform_ext_manifest) in snd_sof_dsp_parse_platform_ext_manifest()
187 return sof_ops(sdev)->parse_platform_ext_manifest(sdev, hdr); in snd_sof_dsp_parse_platform_ext_manifest()
195 * snd_sof_dsp_get_bar_index - Maps a section type with a BAR index
200 * Returns the corresponding BAR index (a positive integer) or -EINVAL
205 if (sof_ops(sdev)->get_bar_index) in snd_sof_dsp_get_bar_index()
206 return sof_ops(sdev)->get_bar_index(sdev, type); in snd_sof_dsp_get_bar_index()
208 return sdev->mmio_bar; in snd_sof_dsp_get_bar_index()
213 if (sof_ops(sdev)->get_mailbox_offset) in snd_sof_dsp_get_mailbox_offset()
214 return sof_ops(sdev)->get_mailbox_offset(sdev); in snd_sof_dsp_get_mailbox_offset()
216 dev_err(sdev->dev, "error: %s not defined\n", __func__); in snd_sof_dsp_get_mailbox_offset()
217 return -EOPNOTSUPP; in snd_sof_dsp_get_mailbox_offset()
223 if (sof_ops(sdev)->get_window_offset) in snd_sof_dsp_get_window_offset()
224 return sof_ops(sdev)->get_window_offset(sdev, id); in snd_sof_dsp_get_window_offset()
226 dev_err(sdev->dev, "error: %s not defined\n", __func__); in snd_sof_dsp_get_window_offset()
227 return -EOPNOTSUPP; in snd_sof_dsp_get_window_offset()
232 if (sof_ops(sdev)->resume) in snd_sof_dsp_resume()
233 return sof_ops(sdev)->resume(sdev); in snd_sof_dsp_resume()
241 if (sof_ops(sdev)->suspend) in snd_sof_dsp_suspend()
242 return sof_ops(sdev)->suspend(sdev, target_state); in snd_sof_dsp_suspend()
249 if (sof_ops(sdev)->runtime_resume) in snd_sof_dsp_runtime_resume()
250 return sof_ops(sdev)->runtime_resume(sdev); in snd_sof_dsp_runtime_resume()
257 if (sof_ops(sdev)->runtime_suspend) in snd_sof_dsp_runtime_suspend()
258 return sof_ops(sdev)->runtime_suspend(sdev); in snd_sof_dsp_runtime_suspend()
265 if (sof_ops(sdev)->runtime_idle) in snd_sof_dsp_runtime_idle()
266 return sof_ops(sdev)->runtime_idle(sdev); in snd_sof_dsp_runtime_idle()
273 if (sof_ops(sdev)->set_hw_params_upon_resume) in snd_sof_dsp_hw_params_upon_resume()
274 return sof_ops(sdev)->set_hw_params_upon_resume(sdev); in snd_sof_dsp_hw_params_upon_resume()
280 if (sof_ops(sdev)->set_clk) in snd_sof_dsp_set_clk()
281 return sof_ops(sdev)->set_clk(sdev, freq); in snd_sof_dsp_set_clk()
292 mutex_lock(&sdev->power_state_access); in snd_sof_dsp_set_power_state()
294 if (sof_ops(sdev)->set_power_state) in snd_sof_dsp_set_power_state()
295 ret = sof_ops(sdev)->set_power_state(sdev, target_state); in snd_sof_dsp_set_power_state()
297 mutex_unlock(&sdev->power_state_access); in snd_sof_dsp_set_power_state()
309 if (sof_ops(sdev) && sof_ops(sdev)->debugfs_add_region_item) in snd_sof_debugfs_add_region_item()
310 return sof_ops(sdev)->debugfs_add_region_item(sdev, blk_type, offset, in snd_sof_debugfs_add_region_item()
320 if (sof_ops(sdev)->write8) in snd_sof_dsp_write8()
321 sof_ops(sdev)->write8(sdev, sdev->bar[bar] + offset, value); in snd_sof_dsp_write8()
323 writeb(value, sdev->bar[bar] + offset); in snd_sof_dsp_write8()
329 if (sof_ops(sdev)->write) in snd_sof_dsp_write()
330 sof_ops(sdev)->write(sdev, sdev->bar[bar] + offset, value); in snd_sof_dsp_write()
332 writel(value, sdev->bar[bar] + offset); in snd_sof_dsp_write()
338 if (sof_ops(sdev)->write64) in snd_sof_dsp_write64()
339 sof_ops(sdev)->write64(sdev, sdev->bar[bar] + offset, value); in snd_sof_dsp_write64()
341 writeq(value, sdev->bar[bar] + offset); in snd_sof_dsp_write64()
347 if (sof_ops(sdev)->read8) in snd_sof_dsp_read8()
348 return sof_ops(sdev)->read8(sdev, sdev->bar[bar] + offset); in snd_sof_dsp_read8()
350 return readb(sdev->bar[bar] + offset); in snd_sof_dsp_read8()
356 if (sof_ops(sdev)->read) in snd_sof_dsp_read()
357 return sof_ops(sdev)->read(sdev, sdev->bar[bar] + offset); in snd_sof_dsp_read()
359 return readl(sdev->bar[bar] + offset); in snd_sof_dsp_read()
365 if (sof_ops(sdev)->read64) in snd_sof_dsp_read64()
366 return sof_ops(sdev)->read64(sdev, sdev->bar[bar] + offset); in snd_sof_dsp_read64()
368 return readq(sdev->bar[bar] + offset); in snd_sof_dsp_read64()
387 return sof_ops(sdev)->block_read(sdev, blk_type, offset, dest, bytes); in snd_sof_dsp_block_read()
394 return sof_ops(sdev)->block_write(sdev, blk_type, offset, src, bytes); in snd_sof_dsp_block_write()
401 if (sof_ops(sdev)->mailbox_read) in snd_sof_dsp_mailbox_read()
402 sof_ops(sdev)->mailbox_read(sdev, offset, dest, bytes); in snd_sof_dsp_mailbox_read()
408 if (sof_ops(sdev)->mailbox_write) in snd_sof_dsp_mailbox_write()
409 sof_ops(sdev)->mailbox_write(sdev, offset, src, bytes); in snd_sof_dsp_mailbox_write()
416 return sof_ops(sdev)->send_msg(sdev, msg); in snd_sof_dsp_send_msg()
424 if (sof_ops(sdev) && sof_ops(sdev)->pcm_open) in snd_sof_pcm_platform_open()
425 return sof_ops(sdev)->pcm_open(sdev, substream); in snd_sof_pcm_platform_open()
435 if (sof_ops(sdev) && sof_ops(sdev)->pcm_close) in snd_sof_pcm_platform_close()
436 return sof_ops(sdev)->pcm_close(sdev, substream); in snd_sof_pcm_platform_close()
448 if (sof_ops(sdev) && sof_ops(sdev)->pcm_hw_params) in snd_sof_pcm_platform_hw_params()
449 return sof_ops(sdev)->pcm_hw_params(sdev, substream, params, in snd_sof_pcm_platform_hw_params()
460 if (sof_ops(sdev) && sof_ops(sdev)->pcm_hw_free) in snd_sof_pcm_platform_hw_free()
461 return sof_ops(sdev)->pcm_hw_free(sdev, substream); in snd_sof_pcm_platform_hw_free()
471 if (sof_ops(sdev) && sof_ops(sdev)->pcm_trigger) in snd_sof_pcm_platform_trigger()
472 return sof_ops(sdev)->pcm_trigger(sdev, substream, cmd); in snd_sof_pcm_platform_trigger()
480 dev_dbg(sdev->dev, "loading firmware\n"); in snd_sof_load_firmware()
482 return sof_ops(sdev)->load_firmware(sdev); in snd_sof_load_firmware()
490 return sof_ops(sdev)->ipc_msg_data(sdev, sps, p, sz); in snd_sof_ipc_msg_data()
498 if (sof_ops(sdev) && sof_ops(sdev)->set_stream_data_offset) in snd_sof_set_stream_data_offset()
499 return sof_ops(sdev)->set_stream_data_offset(sdev, sps, in snd_sof_set_stream_data_offset()
510 if (sof_ops(sdev) && sof_ops(sdev)->pcm_pointer) in snd_sof_pcm_platform_pointer()
511 return sof_ops(sdev)->pcm_pointer(sdev, substream); in snd_sof_pcm_platform_pointer()
520 if (sof_ops(sdev) && sof_ops(sdev)->pcm_ack) in snd_sof_pcm_platform_ack()
521 return sof_ops(sdev)->pcm_ack(sdev, substream); in snd_sof_pcm_platform_ack()
531 if (sof_ops(sdev) && sof_ops(sdev)->get_dai_frame_counter) in snd_sof_pcm_get_dai_frame_counter()
532 return sof_ops(sdev)->get_dai_frame_counter(sdev, component, in snd_sof_pcm_get_dai_frame_counter()
543 if (sof_ops(sdev) && sof_ops(sdev)->get_host_byte_counter) in snd_sof_pcm_get_host_byte_counter()
544 return sof_ops(sdev)->get_host_byte_counter(sdev, component, in snd_sof_pcm_get_host_byte_counter()
554 if (sof_ops(sdev) && sof_ops(sdev)->machine_register) in snd_sof_machine_register()
555 return sof_ops(sdev)->machine_register(sdev, pdata); in snd_sof_machine_register()
563 if (sof_ops(sdev) && sof_ops(sdev)->machine_unregister) in snd_sof_machine_unregister()
564 sof_ops(sdev)->machine_unregister(sdev, pdata); in snd_sof_machine_unregister()
570 if (sof_ops(sdev) && sof_ops(sdev)->machine_select) in snd_sof_machine_select()
571 return sof_ops(sdev)->machine_select(sdev); in snd_sof_machine_select()
580 if (sof_ops(sdev) && sof_ops(sdev)->set_mach_params) in snd_sof_set_mach_params()
581 sof_ops(sdev)->set_mach_params(mach, sdev); in snd_sof_set_mach_params()
587 if (sof_ops(sdev) && sof_ops(sdev)->is_chain_dma_supported) in snd_sof_is_chain_dma_supported()
588 return sof_ops(sdev)->is_chain_dma_supported(sdev, dai_type); in snd_sof_is_chain_dma_supported()
594 * snd_sof_dsp_register_poll_timeout - Periodically poll an address
601 * tight-loops). Should be less than ~20ms since usleep_range
602 * is used (see Documentation/timers/timers-howto.rst).
605 * Returns 0 on success and -ETIMEDOUT upon a timeout. In either
620 dev_dbg(sdev->dev, \
628 dev_dbg(sdev->dev, \
636 (cond) ? 0 : -ETIMEDOUT; \