2022-07-13 17:40:48 +02:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2022 Intel Corporation.
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ZEPHYR_DRIVERS_DMA_INTEL_ADSP_HDA_COMMON_H_
|
|
|
|
#define ZEPHYR_DRIVERS_DMA_INTEL_ADSP_HDA_COMMON_H_
|
|
|
|
|
|
|
|
#define INTEL_ADSP_HDA_MAX_CHANNELS DT_PROP(DT_NODELABEL(hda_host_out), dma_channels)
|
|
|
|
|
2023-07-18 11:59:49 +02:00
|
|
|
/* Minimum recommended FPI increment */
|
|
|
|
#define INTEL_HDA_MIN_FPI_INCREMENT_FOR_INTERRUPT 32
|
|
|
|
|
2022-07-13 17:40:48 +02:00
|
|
|
#include <zephyr/drivers/dma.h>
|
2022-12-14 10:42:45 +01:00
|
|
|
#include <zephyr/pm/device.h>
|
|
|
|
#include <zephyr/pm/device_runtime.h>
|
2022-07-13 17:40:48 +02:00
|
|
|
|
|
|
|
struct intel_adsp_hda_dma_data {
|
|
|
|
struct dma_context ctx;
|
|
|
|
|
|
|
|
ATOMIC_DEFINE(channels_atomic, INTEL_ADSP_HDA_MAX_CHANNELS);
|
|
|
|
};
|
|
|
|
|
|
|
|
struct intel_adsp_hda_dma_cfg {
|
|
|
|
uint32_t base;
|
2022-08-16 18:15:57 +02:00
|
|
|
uint32_t regblock_size;
|
2022-07-13 17:40:48 +02:00
|
|
|
uint32_t dma_channels;
|
|
|
|
enum dma_channel_direction direction;
|
2023-07-18 11:59:49 +02:00
|
|
|
void (*irq_config)(void);
|
2022-07-13 17:40:48 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_host_in_config(const struct device *dev,
|
|
|
|
uint32_t channel,
|
|
|
|
struct dma_config *dma_cfg);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_host_out_config(const struct device *dev,
|
|
|
|
uint32_t channel,
|
|
|
|
struct dma_config *dma_cfg);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_link_in_config(const struct device *dev,
|
|
|
|
uint32_t channel,
|
|
|
|
struct dma_config *dma_cfg);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_link_out_config(const struct device *dev,
|
|
|
|
uint32_t channel,
|
|
|
|
struct dma_config *dma_cfg);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_link_reload(const struct device *dev, uint32_t channel,
|
|
|
|
uint32_t src, uint32_t dst, size_t size);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_host_reload(const struct device *dev, uint32_t channel,
|
|
|
|
uint32_t src, uint32_t dst, size_t size);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_status(const struct device *dev, uint32_t channel,
|
|
|
|
struct dma_status *stat);
|
|
|
|
|
|
|
|
bool intel_adsp_hda_dma_chan_filter(const struct device *dev, int channel,
|
|
|
|
void *filter_param);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_start(const struct device *dev, uint32_t channel);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_stop(const struct device *dev, uint32_t channel);
|
|
|
|
|
|
|
|
int intel_adsp_hda_dma_init(const struct device *dev);
|
|
|
|
|
2022-10-26 16:14:36 +02:00
|
|
|
int intel_adsp_hda_dma_get_attribute(const struct device *dev, uint32_t type, uint32_t *value);
|
2022-07-13 17:40:48 +02:00
|
|
|
|
2023-07-18 11:59:49 +02:00
|
|
|
void intel_adsp_hda_dma_isr(void);
|
|
|
|
|
2022-12-14 10:42:45 +01:00
|
|
|
#ifdef CONFIG_PM_DEVICE
|
|
|
|
int intel_adsp_hda_dma_pm_action(const struct device *dev, enum pm_device_action action);
|
|
|
|
#endif
|
|
|
|
|
2022-07-13 17:40:48 +02:00
|
|
|
#endif /* ZEPHYR_DRIVERS_DMA_INTEL_ADSP_HDA_COMMON_H_ */
|