-
Notifications
You must be signed in to change notification settings - Fork 322
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
pipeline 2.0 - introduce abstract audio_buffer api #9260
pipeline 2.0 - introduce abstract audio_buffer api #9260
Conversation
src/include/sof/audio/audio_stream.h
Outdated
*/ | ||
struct ring_buffer *ring_buffer_source; /**< source API shadow, an additional ring_buffer | ||
* at data out | ||
*/ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
not sure these two renames make sense, or at least they might deserve a separate commit. It's one thing to rename an API, but it doesn't necessarily mean, that all users have to be renamed too. If these members are only used by DP components, maybe we can keep their names? Or if you want to use these members for other cases too, then this should rather be a separate commit, but then maybe you also need to move them out of the #if
?
src/audio/ring_buffer.c
Outdated
@@ -0,0 +1,306 @@ | |||
// SPDX-License-Identifier: BSD-3-Clause |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this rename-and-modify unfortunately confused git enough to not recognise this as a rename any more. Maybe we can split this into two commits: first rename without modifying contents, then change the API itself? Or the other way round - doesn't matter. As it stands the only way to review this would be to download both files and to diff them manually
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed to 2 commits - one for rename + move, second for internal structures changes
src/include/sof/audio/audio_stream.h
Outdated
*/ | ||
struct sof_audio_buffer *shadow_buffer_source; /**< source API shadow, an additional buffer | ||
* at data output | ||
*/ |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
oookeeey, not sure why it's "shadow" but at least - yes, to reinforce my previous comment, I'd keep the "dp-buffer" name until here
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I changed "shadow" to "secondary", but keeping dp_queue here is not a good idea - double buffering it is not limited to ring_buffer a.k.a. dp_queue now
6cdf717
to
d060b70
Compare
Development is of course still in progress, but this PR looks like a good subset. Please proceed with review. |
src/audio/buffer.c
Outdated
@@ -272,8 +272,8 @@ void buffer_free(struct comp_buffer *buffer) | |||
/* In case some listeners didn't unregister from buffer's callbacks */ | |||
notifier_unregister_all(NULL, buffer); | |||
#if CONFIG_ZEPHYR_DP_SCHEDULER | |||
ring_buffer_free(buffer->stream.dp_queue_sink); | |||
ring_buffer_free(buffer->stream.dp_queue_source); | |||
ring_buffer_free_legacy(buffer->stream.dp_queue_sink); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
this "legacy" is introduced ONLY to make this commit compile (and probably work) - there was a function name collision.
The function is removed in the very next commit
8b1dad0
to
d40b53e
Compare
@marcinszkudlinski good stuff - CI looking good too, just a minor conflict. |
as to codestyle check failure: WARNING: please write a help paragraph that fully describes the config symbol I did, the symbol is fully described, but checkpatch is blind to this. |
dp_queue was created as a buffer to handle special needs for DP modules. However, in pipeline2.0 there will be more usecases for it - as in fact it is a lockless cross-core cached ring buffer. This commit does rename dp_queue to more adequate name It also moves the file to "buffers" directory, a place for all implementations of buffers in pipeline 2.0 The commit, however, does not change names of structures because git/github does not handle complex changes like rename and modification correctly Signed-off-by: Marcin Szkudlinski <[email protected]>
as a follow-up of a prev commit, internal structures should also be changed accordingly The commit, however, does not change names of variables in the code that use struct ring_buffer. Signed-off-by: Marcin Szkudlinski <[email protected]>
in pipeline2.0 there's more than one buffer type to be used for passing audio data from one module to another. However, each single buffer must provide same API. This commit introduces a common API for buffers and at the same time connects it to ring_buffer. Signed-off-by: Marcin Szkudlinski <[email protected]>
This commit removes all direct calls to ring_buffer (formerly dp_queue) from the code, replacing with a generic sof_audio_buffer API Only direct call that stays is creation of ring_buffer, yet it will soon be replaced also by a buffer factory Legacy API from ring buffer is also removed, as it should not be used anymore Signed-off-by: Marcin Szkudlinski <[email protected]>
This flag enables changes to new pipeline structure, known as pipeline2_0 It is required for certain new features, like DP_SCHEDULER. The changes are incremental and at the moment pipeline 2.0 is fully backward compatible with legacy platforms, however it generates some overhead in data and code, so it is useful to turn if off if not needed Signed-off-by: Marcin Szkudlinski <[email protected]>
d40b53e
to
a901325
Compare
rebased |
I missed one commit during rebase |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks god to me and cleans up the code. I was wondering whether this is really dependent on IPC4 (dp scheduling is, but also the ringbuffer/dpqueue)? Anyways, not a blockign item. Tests seem good. LNL hard to tell as this seems to hit thesofproject/linux#5098 .
This compilation failure seems relevant: |
return IPC4_FAILURE; | ||
} | ||
if (!cpu_is_me(sink->ipc_config.core)) | ||
if (ll_wait_finished_on_core(sink) < 0) { | ||
ll_unblock(cross_core_unbind); | ||
ll_unblock(cross_core_unbind, flags); | ||
return IPC4_FAILURE; | ||
} | ||
#else |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@marcinszkudlinski Can you check the CI build fail? I think you missed a few spots in helper.c wheere CONFIG_CROSS_CORE_STREAM is ifdeffed out and there's call to ll_block/ll_unblock.
Explicit usage of a local variable in a macro is not a good practice. Macros changed to use a variable as an argument + fix a warning "'flags' may be used uninitialized" Signed-off-by: Marcin Szkudlinski <[email protected]>
3c499f4
to
dbc9a92
Compare
One case of #9191 in https://sof-ci.01.org/sofpr/PR9260/build6422/devicetest/index.html , rest looks clean. Merging. |
This PR introduces an abstract struct sof_audio_buffer which should become a base abstract class for all buffer types in pipeline 2.0
PR should be neutral for all functionality
On the generic pipeline code there MUST NOT be any other usage of buffers but:
(with obvious exception for buffer creation - see concept of "buffer factory)
this PR change usage of DP_queue (renamed to ring_buffer) to match the above request