mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2026-04-21 06:46:38 -04:00
module-avb: es_builder: use the descriptor rather than a pointer to avoid overwriting it
This commit is contained in:
parent
2722d16303
commit
f0a33cddbd
1 changed files with 23 additions and 23 deletions
|
|
@ -18,7 +18,7 @@
|
|||
*/
|
||||
|
||||
/** The callback type used for the different entity descriptor */
|
||||
typedef void* (*es_builder_cb_t) (struct server *server, uint16_t type,
|
||||
typedef struct descriptor *(*es_builder_cb_t) (struct server *server, uint16_t type,
|
||||
uint16_t index, size_t size, void *ptr);
|
||||
|
||||
/** Structure holding all necessary cb
|
||||
|
|
@ -36,33 +36,33 @@ struct es_builder_st {
|
|||
* \brief The Entity keeps track of multiple things, the locks the current
|
||||
* configuration use for instance. That tragets the Milan V1.2 mode only
|
||||
*/
|
||||
static void *es_builder_desc_entity_milan_v12(struct server *server,
|
||||
static struct descriptor *es_builder_desc_entity_milan_v12(struct server *server,
|
||||
uint16_t type, uint16_t index, size_t size, void *ptr)
|
||||
{
|
||||
struct aecp_aem_entity_milan_state entity_state = {0};
|
||||
void *ptr_alloc;
|
||||
struct descriptor *desc;
|
||||
struct aecp_aem_entity_state *state =
|
||||
(struct aecp_aem_entity_state *) &entity_state;
|
||||
|
||||
memcpy(&state->desc, ptr, size);
|
||||
|
||||
ptr_alloc = server_add_descriptor(server, type, index, sizeof(entity_state),
|
||||
desc = server_add_descriptor(server, type, index, sizeof(entity_state),
|
||||
&entity_state);
|
||||
|
||||
if (!ptr_alloc) {
|
||||
if (!desc) {
|
||||
pw_log_error("Error during allocation\n");
|
||||
spa_assert(0);
|
||||
}
|
||||
|
||||
return ptr_alloc;
|
||||
return desc;
|
||||
}
|
||||
|
||||
/**
|
||||
* \brief A generic function to avoid code duplicate for the streams */
|
||||
static void *es_buidler_desc_stream_general_prepare(struct server *server,
|
||||
uint16_t type, uint16_t index, size_t size, void *ptr)
|
||||
static struct descriptor *es_buidler_desc_stream_general_prepare(struct server *server,
|
||||
uint16_t type, uint16_t index, size_t size, void *ptr)
|
||||
{
|
||||
void *ptr_alloc;
|
||||
struct descriptor *desc;
|
||||
struct stream *stream;
|
||||
enum spa_direction direction;
|
||||
|
||||
|
|
@ -72,14 +72,14 @@ static void *es_buidler_desc_stream_general_prepare(struct server *server,
|
|||
struct aecp_aem_stream_input_state stream_input = { 0 };
|
||||
|
||||
memcpy(&stream_input.desc, ptr, size);
|
||||
ptr_alloc = server_add_descriptor(server, type, index,
|
||||
desc = server_add_descriptor(server, type, index,
|
||||
sizeof(stream_input), &stream_input);
|
||||
if (!ptr_alloc) {
|
||||
if (!desc) {
|
||||
pw_log_error("Allocation failed\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
pstream_input = ptr_alloc;
|
||||
pstream_input = desc->ptr;
|
||||
stream = &pstream_input->stream;
|
||||
direction = SPA_DIRECTION_INPUT;
|
||||
break;
|
||||
|
|
@ -88,14 +88,14 @@ static void *es_buidler_desc_stream_general_prepare(struct server *server,
|
|||
struct aecp_aem_stream_output_state stream_output = { 0 };
|
||||
|
||||
memcpy(&stream_output.desc, ptr, size);
|
||||
ptr_alloc = server_add_descriptor(server, type, index,
|
||||
desc = server_add_descriptor(server, type, index,
|
||||
sizeof(stream_output), &stream_output);
|
||||
if (!ptr_alloc) {
|
||||
if (!desc) {
|
||||
pw_log_error("Allocation failed\n");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
pstream_output = ptr_alloc;
|
||||
pstream_output = desc->ptr;
|
||||
stream = &pstream_output->stream;
|
||||
direction = SPA_DIRECTION_OUTPUT;
|
||||
|
||||
|
|
@ -105,15 +105,17 @@ static void *es_buidler_desc_stream_general_prepare(struct server *server,
|
|||
return NULL;
|
||||
}
|
||||
|
||||
/**
|
||||
* In this place the stream register interanlly SRP / MVRP state machines
|
||||
*/
|
||||
if (!server_create_stream(server, stream, direction, index)) {
|
||||
pw_log_error("Could not create/initialize a stream");
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return ptr_alloc;
|
||||
return desc;
|
||||
}
|
||||
|
||||
|
||||
// Assign a ID to an specific builder
|
||||
#define HELPER_ES_BUIDLER(type, callback) \
|
||||
[type] = { .build_descriptor_cb = callback }
|
||||
|
|
@ -161,8 +163,7 @@ void es_builder_add_descriptor(struct server *server, uint16_t type,
|
|||
uint16_t index, size_t size, void *ptr_aem)
|
||||
{
|
||||
const struct es_builder_st *es_builder;
|
||||
void *desc_ptr;
|
||||
struct descriptor *d;
|
||||
struct descriptor *desc;
|
||||
enum avb_mode avb_mode;
|
||||
bool std_processing = false;
|
||||
|
||||
|
|
@ -195,9 +196,9 @@ void es_builder_add_descriptor(struct server *server, uint16_t type,
|
|||
spa_assert(0);
|
||||
}
|
||||
} else {
|
||||
desc_ptr = es_builder[type].build_descriptor_cb(server, type,
|
||||
desc = es_builder[type].build_descriptor_cb(server, type,
|
||||
index, size, ptr_aem);
|
||||
if (!desc_ptr) {
|
||||
if (!desc) {
|
||||
pw_log_error("Could not allocate specific descriptr "
|
||||
"%u at index %u the avb aem type\n",
|
||||
type, index);
|
||||
|
|
@ -205,7 +206,6 @@ void es_builder_add_descriptor(struct server *server, uint16_t type,
|
|||
spa_assert(0);
|
||||
}
|
||||
|
||||
d = (struct descriptor *) desc_ptr;
|
||||
d->size = size;
|
||||
desc->size = size;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue