Skip to content

Commit

Permalink
module: add pointers to sink/src to module structure
Browse files Browse the repository at this point in the history
Sink and source is the main interface for DP processing
in current pipeline and the main interface for all
processing in pipeline 2.0

Pointers to them must be available to modules directly.

This commit adds pointers to sink/sources to module structure

Signed-off-by: Marcin Szkudlinski <[email protected]>
  • Loading branch information
marcinszkudlinski committed Aug 31, 2023
1 parent 0811950 commit 60e6db7
Show file tree
Hide file tree
Showing 2 changed files with 53 additions and 56 deletions.
101 changes: 45 additions & 56 deletions src/audio/module_adapter/module_adapter.c
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,8 @@
#include <sof/audio/component.h>
#include <sof/audio/ipc-config.h>
#include <sof/audio/module_adapter/module/generic.h>
#include <sof/audio/sink_api.h>
#include <sof/audio/source_api.h>
#include <sof/audio/pipeline.h>
#include <sof/common.h>
#include <sof/platform.h>
Expand Down Expand Up @@ -175,38 +177,32 @@ struct comp_dev *module_adapter_new(const struct comp_driver *drv,

static int module_adapter_sink_src_prepare(struct comp_dev *dev)
{
struct sof_sink *audio_sink[PLATFORM_MAX_STREAMS];
struct sof_source *audio_src[PLATFORM_MAX_STREAMS];
struct processing_module *mod = comp_get_drvdata(dev);
struct list_item *blist;
uint32_t num_of_sources = 0;
uint32_t num_of_sinks = 0;
int ret;
int i = 0;

/* acquire all sink and source buffers, get handlers to sink/source API */
/* get handlers to sink/source API from all buffers */
list_for_item(blist, &dev->bsink_list) {
struct comp_buffer *sink_buffer_uc;

sink_buffer_uc = container_of(blist, struct comp_buffer, source_list);
audio_sink[num_of_sinks] =
audio_stream_get_sink(&sink_buffer_uc->stream);
sink_reset_num_of_processed_bytes(audio_sink[num_of_sinks]);
num_of_sinks++;
struct comp_buffer *sink_buffer =
container_of(blist, struct comp_buffer, source_list);
mod->sinks[i] = audio_stream_get_sink(&sink_buffer->stream);
i++;
}
mod->num_of_sinks = i;

i = 0;
list_for_item(blist, &dev->bsource_list) {
struct comp_buffer *source_buffer_uc;
struct comp_buffer *source_buffer =
container_of(blist, struct comp_buffer, sink_list);

source_buffer_uc = container_of(blist, struct comp_buffer, sink_list);
audio_src[num_of_sources] =
audio_stream_get_source(&source_buffer_uc->stream);
source_reset_num_of_processed_bytes(audio_src[num_of_sources]);
num_of_sources++;
mod->sources[i] = audio_stream_get_source(&source_buffer->stream);
i++;
}
mod->num_of_sources = i;

/* Prepare module */
ret = module_prepare(mod, audio_src, num_of_sources, audio_sink, num_of_sinks);
ret = module_prepare(mod, mod->sources, mod->num_of_sources, mod->sinks, mod->num_of_sinks);

return ret;
}
Expand Down Expand Up @@ -276,6 +272,9 @@ int module_adapter_prepare(struct comp_dev *dev)
mod->period_bytes = audio_stream_period_bytes(&sink->stream, dev->frames);
comp_dbg(dev, "module_adapter_prepare(): got period_bytes = %u", mod->period_bytes);

mod->num_input_buffers = 0;
mod->num_output_buffers = 0;

/*
* compute number of input buffers and make the source_info shared if the module is on a
* different core than any of it's sources
Expand Down Expand Up @@ -492,7 +491,9 @@ int module_adapter_prepare(struct comp_dev *dev)

in_out_free:
rfree(mod->output_buffers);
mod->output_buffers = NULL;
rfree(mod->input_buffers);
mod->input_buffers = NULL;
return ret;
}

Expand Down Expand Up @@ -973,54 +974,33 @@ static int module_adapter_audio_stream_type_copy(struct comp_dev *dev)

static int module_adapter_sink_source_copy(struct comp_dev *dev)
{
struct sof_sink *audio_sink[PLATFORM_MAX_STREAMS];
struct sof_source *audio_src[PLATFORM_MAX_STREAMS];
struct processing_module *mod = comp_get_drvdata(dev);
struct list_item *blist;
uint32_t num_of_sources = 0;
uint32_t num_of_sinks = 0;
int ret;
int i = 0;

comp_dbg(dev, "module_adapter_sink_source_copy(): start");

/* acquire all sink and source buffers, get handlers to sink/source API */
list_for_item(blist, &dev->bsink_list) {
struct comp_buffer *sink_buffer;
/* reset number of processed bytes */
for (i = 0; i < mod->num_of_sources; i++)
source_reset_num_of_processed_bytes(mod->sources[i]);

sink_buffer = container_of(blist, struct comp_buffer, source_list);
audio_sink[num_of_sinks] =
audio_stream_get_sink(&sink_buffer->stream);
sink_reset_num_of_processed_bytes(audio_sink[num_of_sinks]);
num_of_sinks++;
}
for (i = 0; i < mod->num_of_sinks; i++)
sink_reset_num_of_processed_bytes(mod->sinks[i]);

list_for_item(blist, &dev->bsource_list) {
struct comp_buffer *source_buffer;

source_buffer = container_of(blist, struct comp_buffer, sink_list);
audio_src[num_of_sources] =
audio_stream_get_source(&source_buffer->stream);
source_reset_num_of_processed_bytes(audio_src[num_of_sources]);
num_of_sources++;
}

ret = module_process_sink_src(mod, audio_src, num_of_sources, audio_sink, num_of_sinks);
ret = module_process_sink_src(mod, mod->sources, mod->num_of_sources,
mod->sinks, mod->num_of_sinks);

if (ret != -ENOSPC && ret != -ENODATA && ret) {
comp_err(dev, "module_adapter_sink_source_copy() process failed with error: %x",
ret);
}

/* release all source buffers in reverse order */
for (i = num_of_sources - 1; i >= 0; i--) {
mod->total_data_consumed += source_get_num_of_processed_bytes(audio_src[i]);
}
/* count number of processed data. To be removed in pipeline 2.0 */
for (i = 0; i < mod->num_of_sources; i++)
mod->total_data_consumed += source_get_num_of_processed_bytes(mod->sources[i]);

/* release all sink buffers in reverse order */
for (i = num_of_sinks - 1; i >= 0 ; i--) {
mod->total_data_produced += sink_get_num_of_processed_bytes(audio_sink[i]);
}
for (i = 0; i < mod->num_of_sinks; i++)
mod->total_data_produced += sink_get_num_of_processed_bytes(mod->sinks[i]);

comp_dbg(dev, "module_adapter_sink_source_copy(): done");

Expand Down Expand Up @@ -1356,11 +1336,20 @@ int module_adapter_reset(struct comp_dev *dev)
for (i = 0; i < mod->num_input_buffers; i++)
rfree((__sparse_force void *)mod->input_buffers[i].data);
}
rfree(mod->output_buffers);
rfree(mod->input_buffers);
if (IS_PROCESSING_MODE_RAW_DATA(mod) || IS_PROCESSING_MODE_AUDIO_STREAM(mod)) {
rfree(mod->output_buffers);
rfree(mod->input_buffers);

mod->num_input_buffers = 0;
mod->num_output_buffers = 0;
mod->num_input_buffers = 0;
mod->num_output_buffers = 0;
}

if (IS_PROCESSING_MODE_SINK_SOURCE(mod)) {
for (int i = 0; i < mod->num_of_sources; i++)
mod->sources[i] = NULL;
for (int i = 0; i < mod->num_of_sinks; i++)
mod->sinks[i] = NULL;
}

mod->total_data_consumed = 0;
mod->total_data_produced = 0;
Expand Down
8 changes: 8 additions & 0 deletions src/include/sof/audio/module_adapter/module/generic.h
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@
#include <sof/audio/component.h>
#include <sof/ut.h>
#include <sof/lib/memory.h>
#include <sof/audio/sink_api.h>
#include <sof/audio/source_api.h>
#include "module_interface.h"

#if CONFIG_INTEL_MODULES
Expand Down Expand Up @@ -186,6 +188,12 @@ struct processing_module {
uint32_t period_bytes; /** pipeline period bytes */
uint32_t deep_buff_bytes; /**< copy start threshold */
uint32_t output_buffer_size; /**< size of local buffer to save produced samples */

/* sink and source handlers for the module */
struct sof_sink *sinks[MODULE_MAX_SOURCES];
struct sof_source *sources[MODULE_MAX_SOURCES];
uint32_t num_of_sources;
uint32_t num_of_sinks;
struct input_stream_buffer *input_buffers;
struct output_stream_buffer *output_buffers;
uint32_t num_input_buffers; /**< number of input buffers */
Expand Down

0 comments on commit 60e6db7

Please sign in to comment.