Skip to content

Commit

Permalink
Merge pull request #7 from COVESA/new_api/aaf
Browse files Browse the repository at this point in the history
Migrated AAF PCM format to new API
  • Loading branch information
kamelfakihh authored Jun 25, 2024
2 parents 34ba2ff + 568382d commit de87d01
Show file tree
Hide file tree
Showing 12 changed files with 470 additions and 363 deletions.
2 changes: 1 addition & 1 deletion build_all.sh
Original file line number Diff line number Diff line change
Expand Up @@ -13,4 +13,4 @@ meson compile -C build/ \
examples/cvf/cvf-talker \
examples/cvf/cvf-listener \
examples/ieciidc/ieciidc-talker \
examples/ieciidc/ieciidc-listener
examples/ieciidc/ieciidc-listener
4 changes: 2 additions & 2 deletions examples/aaf/aaf-listener.c
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@
#include <inttypes.h>

#include "avtp.h"
#include "avtp_aaf.h"
#include "avtp/aaf/PcmStream.h"
#include "common.h"
#include "avtp/CommonHeader.h"

Expand Down Expand Up @@ -420,4 +420,4 @@ int main(int argc, char *argv[])
close(sk_fd);
close(timer_fd);
return 1;
}
}
4 changes: 2 additions & 2 deletions examples/aaf/aaf-talker.c
Original file line number Diff line number Diff line change
Expand Up @@ -65,7 +65,7 @@
#include <unistd.h>

#include "avtp.h"
#include "avtp_aaf.h"
#include "avtp/aaf/PcmStream.h"
#include "common.h"
#include "avtp/CommonHeader.h"

Expand Down Expand Up @@ -237,4 +237,4 @@ int main(int argc, char *argv[])
err:
close(fd);
return 1;
}
}
2 changes: 1 addition & 1 deletion examples/crf/crf-listener.c
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@

#include "avtp.h"
#include "avtp/Crf.h"
#include "avtp_aaf.h"
#include "avtp/aaf/PcmStream.h"
#include "common.h"
#include "avtp/CommonHeader.h"

Expand Down
89 changes: 89 additions & 0 deletions include/avtp/aaf/CommonStream.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,89 @@
/*
* Copyright (c) 2024, COVESA
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of COVESA nor the names of its contributors may be
* used to endorse or promote products derived from this software without
* specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* SPDX-License-Identifier: BSD-3-Clause
*/

/**
* @file
* This file contains the fields descriptions of the IEEE 1722 AAF common stream PDUs and
* functions to invoke corresponding parser and deparser.
*/

#pragma once

#include <stdint.h>

#include "avtp/Defines.h"

#define AVTP_AAF_COMMON_STREAM_HEADER_LEN (6 * AVTP_QUADLET_SIZE)

typedef struct {
uint8_t header[AVTP_AAF_COMMON_STREAM_HEADER_LEN];
uint8_t payload[0];
} Avtp_AafCommonStream_t;

typedef enum {
AVTP_AAF_COMMON_STREAM_FIELD_SUBTYPE,
AVTP_AAF_COMMON_STREAM_FIELD_SV,
AVTP_AAF_COMMON_STREAM_FIELD_VERSION,
AVTP_AAF_COMMON_STREAM_FIELD_MR,
AVTP_AAF_COMMON_STREAM_FIELD_TV,
AVTP_AAF_COMMON_STREAM_FIELD_SEQUENCE_NUM,
AVTP_AAF_COMMON_STREAM_FIELD_TU,
AVTP_AAF_COMMON_STREAM_FIELD_STREAM_ID,
AVTP_AAF_COMMON_STREAM_FIELD_AVTP_TIMESTAMP,
AVTP_AAF_COMMON_STREAM_FIELD_FORMAT,
AVTP_AAF_COMMON_STREAM_FIELD_AAF_FORMAT_SPECIFIC_DATA_1,
AVTP_AAF_COMMON_STREAM_FIELD_STREAM_DATA_LENGTH,
AVTP_AAF_COMMON_STREAM_FIELD_AFSD,
AVTP_AAF_COMMON_STREAM_FIELD_SP,
AVTP_AAF_COMMON_STREAM_FIELD_EVT,
AVTP_AAF_COMMON_STREAM_FIELD_AAF_FORMAT_SPECIFIC_DATA_2,
AVTP_AAF_COMMON_STREAM_FIELD_MAX
} Avtp_AafCommonStreamFields_t;

/**
* Returns the value of an an AVTP AAF common stream field as specified in the IEEE 1722 Specification.
*
* @param pdu Pointer to the first bit of an 1722 AVTP PDU.
* @param field Specifies the position of the data field to be read
* @param value Pointer to location to store the value.
* @returns This function returns 0 if the data field was successfully read from
* the 1722 AVTP PDU.
*/
int Avtp_AafCommonStream_GetField(Avtp_AafCommonStream_t* pdu, Avtp_AafCommonStreamFields_t field, uint64_t* value);

/**
* Sets the value of an an AVTP AAF common stream field as specified in the IEEE 1722 Specification.
*
* @param pdu Pointer to the first bit of an 1722 AVTP PDU.
* @param field Specifies the position of the data field to be read
* @param value Pointer to location to store the value.
* @returns This function returns 0 if the data field was successfully set in
* the 1722 AVTP PDU.
*/
int Avtp_AafCommonStream_SetField(Avtp_AafCommonStream_t* pdu, Avtp_AafCommonStreamFields_t field, uint64_t value);
181 changes: 181 additions & 0 deletions include/avtp/aaf/PcmStream.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,181 @@
/*
* Copyright (c) 2024, COVESA
* Copyright (c) 2019, Intel Corporation
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of COVESA, Intel Corporation nor the names of its
* contributors may be used to endorse or promote products derived from
* this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
* CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
* SPDX-License-Identifier: BSD-3-Clause
*/

#pragma once

#include <stdint.h>

#include "avtp/Defines.h"

#define AVTP_AAF_PCM_STREAM_HEADER_LEN (6 * AVTP_QUADLET_SIZE)

typedef struct {
uint8_t header[AVTP_AAF_PCM_STREAM_HEADER_LEN];
uint8_t payload[0];
} Avtp_AafPcmStream_t;

typedef enum {
AVTP_AAF_PCM_STREAM_FIELD_SUBTYPE,
AVTP_AAF_PCM_STREAM_FIELD_SV,
AVTP_AAF_PCM_STREAM_FIELD_VERSION,
AVTP_AAF_PCM_STREAM_FIELD_MR,
AVTP_AAF_PCM_STREAM_FIELD_TV,
AVTP_AAF_PCM_STREAM_FIELD_SEQUENCE_NUM,
AVTP_AAF_PCM_STREAM_FIELD_TU,
AVTP_AAF_PCM_STREAM_FIELD_STREAM_ID,
AVTP_AAF_PCM_STREAM_FIELD_AVTP_TIMESTAMP,
AVTP_AAF_PCM_STREAM_FIELD_FORMAT,
AVTP_AAF_PCM_STREAM_FIELD_NSR,
AVTP_AAF_PCM_STREAM_FIELD_CHANNELS_PER_FRAME,
AVTP_AAF_PCM_STREAM_FIELD_BIT_DEPTH,
AVTP_AAF_PCM_STREAM_FIELD_STREAM_DATA_LENGTH,
AVTP_AAF_PCM_STREAM_FIELD_SP,
AVTP_AAF_PCM_STREAM_FIELD_EVT,
AVTP_AAF_PCM_STREAM_FIELD_MAX
} Avtp_AafPcmStreamFields_t;

// AAF 'format' field values
typedef enum {
AVTP_AAF_FORMAT_USER = 0,
AVTP_AAF_FORMAT_FLOAT_32BIT,
AVTP_AAF_FORMAT_INT_32BIT,
AVTP_AAF_FORMAT_INT_24BIT,
AVTP_AAF_FORMAT_INT_16BIT,
AVTP_AAF_FORMAT_AES3_32BIT,
} Avtp_AafFormat_t;

typedef enum {
AVTP_AAF_PCM_NSR_USER = 0,
AVTP_AAF_PCM_NSR_8KHZ,
AVTP_AAF_PCM_NSR_16KHZ,
AVTP_AAF_PCM_NSR_32KHZ,
AVTP_AAF_PCM_NSR_44_1KHZ,
AVTP_AAF_PCM_NSR_48KHZ,
AVTP_AAF_PCM_NSR_88_2KHZ,
AVTP_AAF_PCM_NSR_96KHZ,
AVTP_AAF_PCM_NSR_176_4KHZ,
AVTP_AAF_PCM_NSR_192KHZ,
AVTP_AAF_PCM_NSR_24KHZ,
} Avtp_AafNsr_t;

// AAF 'sp' (sparse timestamp) field value
typedef enum {
AVTP_AAF_PCM_SP_NORMAL = 0,
AVTP_AAF_PCM_SP_SPARSE,
} Avtp_AafSp_t;

/**
* Initializes a AAF PCM stream PDU as specified in the IEEE 1722-2016 Specification.
*
* @param pdu Pointer to the first bit of a 1722 PDU.
*/
int Avtp_AafPcmStream_Init(Avtp_AafPcmStream_t* pdu);

/**
* Returns the value of an an AVTP AAF PCM stream field as specified in the IEEE 1722 Specification.
*
* @param pdu Pointer to the first bit of an 1722 AVTP PDU.
* @param field Specifies the position of the data field to be read
* @param value Pointer to location to store the value.
* @returns This function returns 0 if the data field was successfully read from
* the 1722 AVTP PDU.
*/
int Avtp_AafPcmStream_GetField(Avtp_AafPcmStream_t* pdu, Avtp_AafPcmStreamFields_t field, uint64_t* value);

/**
* Sets the value of an an AVTP AAF PCM stream field as specified in the IEEE 1722 Specification.
*
* @param pdu Pointer to the first bit of an 1722 AVTP PDU.
* @param field Specifies the position of the data field to be read
* @param value Pointer to location to store the value.
* @returns This function returns 0 if the data field was successfully set in
* the 1722 AVTP PDU.
*/
int Avtp_AafPcmStream_SetField(Avtp_AafPcmStream_t* pdu, Avtp_AafPcmStreamFields_t field, uint64_t value);

/******************************************************************************
* Legacy API (deprecated)
*****************************************************************************/

#define AVTP_AAF_FIELD_SV AVTP_AAF_PCM_STREAM_FIELD_SV
#define AVTP_AAF_FIELD_MR AVTP_AAF_PCM_STREAM_FIELD_MR
#define AVTP_AAF_FIELD_TV AVTP_AAF_PCM_STREAM_FIELD_TV
#define AVTP_AAF_FIELD_SEQ_NUM AVTP_AAF_PCM_STREAM_FIELD_SEQUENCE_NUM
#define AVTP_AAF_FIELD_TU AVTP_AAF_PCM_STREAM_FIELD_TU
#define AVTP_AAF_FIELD_STREAM_ID AVTP_AAF_PCM_STREAM_FIELD_STREAM_ID
#define AVTP_AAF_FIELD_TIMESTAMP AVTP_AAF_PCM_STREAM_FIELD_AVTP_TIMESTAMP
#define AVTP_AAF_FIELD_STREAM_DATA_LEN AVTP_AAF_PCM_STREAM_FIELD_STREAM_DATA_LENGTH
#define AVTP_AAF_FIELD_FORMAT AVTP_AAF_PCM_STREAM_FIELD_FORMAT
#define AVTP_AAF_FIELD_NSR AVTP_AAF_PCM_STREAM_FIELD_NSR
#define AVTP_AAF_FIELD_CHAN_PER_FRAME AVTP_AAF_PCM_STREAM_FIELD_CHANNELS_PER_FRAME
#define AVTP_AAF_FIELD_BIT_DEPTH AVTP_AAF_PCM_STREAM_FIELD_BIT_DEPTH
#define AVTP_AAF_FIELD_SP AVTP_AAF_PCM_STREAM_FIELD_SP
#define AVTP_AAF_FIELD_EVT AVTP_AAF_PCM_STREAM_FIELD_EVT
#define AVTP_AAF_FIELD_MAX AVTP_AAF_PCM_STREAM_FIELD_MAX

/**
* @deprecated
* Get value from AAF AVTPDU field.
* @pdu: Pointer to PDU struct.
* @field: PDU field to be retrieved.
* @val: Pointer to variable which the retrieved value should be saved.
*
* Returns:
* 0: Success.
* -EINVAL: If any argument is invalid.
*/
int avtp_aaf_pdu_get(void *pdu,
Avtp_AafPcmStreamFields_t field, uint64_t *val);

/**
* @deprecated
* Set value from AAF AVTPDU field.
* @pdu: Pointer to PDU struct.
* @field: PDU field to be set.
* @val: Value to be set.
*
* Returns:
* 0: Success.
* -EINVAL: If any argument is invalid.
*/
int avtp_aaf_pdu_set(void *pdu, Avtp_AafPcmStreamFields_t field,
uint64_t val);

/**
* @deprecated
* Initialize AAF AVTPDU. All AVTPDU fields are initialized with zero except
* 'subtype' (which is set to AVTP_SUBTYPE_AAF) and 'sv' (which is set to 1).
* @pdu: Pointer to PDU struct.
*
* Return values:
* 0: Success.
* -EINVAL: If any argument is invalid.
*/
int avtp_aaf_pdu_init(void *pdu);
Loading

0 comments on commit de87d01

Please sign in to comment.