98 lines
2.6 KiB
C
98 lines
2.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Vidtv serves as a reference DVB driver and helps validate the existing APIs
|
|
* in the media subsystem. It can also aid developers working on userspace
|
|
* applications.
|
|
*
|
|
* This file contains the code for an AES3 (also known as AES/EBU) encoder.
|
|
* It is based on EBU Tech 3250 and SMPTE 302M technical documents.
|
|
*
|
|
* This encoder currently supports 16bit AES3 subframes using 16bit signed
|
|
* integers.
|
|
*
|
|
* Note: AU stands for Access Unit, and AAU stands for Audio Access Unit
|
|
*
|
|
* Copyright (C) 2020 Daniel W. S. Almeida
|
|
*/
|
|
|
|
#ifndef VIDTV_S302M_H
|
|
#define VIDTV_S302M_H
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include "vidtv_encoder.h"
|
|
|
|
/* see SMPTE 302M 2007 clause 7.3 */
|
|
#define VIDTV_S302M_BUF_SZ 65024
|
|
|
|
/* see ETSI TS 102 154 v.1.2.1 clause 7.3.5 */
|
|
#define VIDTV_S302M_FORMAT_IDENTIFIER 0x42535344
|
|
|
|
/**
|
|
* struct vidtv_s302m_ctx - s302m encoder context.
|
|
* @enc: A pointer to the containing encoder structure.
|
|
* @frame_index: The current frame in a block
|
|
* @au_count: The total number of access units encoded up to now
|
|
* @last_duration: Duration of the tone currently being played
|
|
* @note_offset: Position at the music tone array
|
|
* @last_tone: Tone currently being played
|
|
*/
|
|
struct vidtv_s302m_ctx {
|
|
struct vidtv_encoder *enc;
|
|
u32 frame_index;
|
|
u32 au_count;
|
|
int last_duration;
|
|
unsigned int note_offset;
|
|
enum musical_notes last_tone;
|
|
};
|
|
|
|
/*
|
|
* struct vidtv_smpte_s302m_es - s302m MPEG Elementary Stream header.
|
|
*
|
|
* See SMPTE 302M 2007 table 1.
|
|
*/
|
|
struct vidtv_smpte_s302m_es {
|
|
/*
|
|
*
|
|
* audio_packet_size:16;
|
|
* num_channels:2;
|
|
* channel_identification:8;
|
|
* bits_per_sample:2; // 0x0 for 16bits
|
|
* zero:4;
|
|
*/
|
|
__be32 bitfield;
|
|
} __packed;
|
|
|
|
struct vidtv_s302m_frame_16 {
|
|
u8 data[5];
|
|
} __packed;
|
|
|
|
/**
|
|
* struct vidtv_s302m_encoder_init_args - Args for the s302m encoder.
|
|
*
|
|
* @name: A name to identify this particular instance
|
|
* @src_buf: The source buffer, encoder will default to a sine wave if this is NULL.
|
|
* @src_buf_sz: The size of the source buffer.
|
|
* @es_pid: The MPEG Elementary Stream PID to use.
|
|
* @sync: Attempt to synchronize audio with this video encoder, if not NULL.
|
|
* @last_sample_cb: A callback called when the encoder runs out of data.
|
|
* @head: Add to this chain
|
|
*/
|
|
struct vidtv_s302m_encoder_init_args {
|
|
char *name;
|
|
void *src_buf;
|
|
u32 src_buf_sz;
|
|
u16 es_pid;
|
|
struct vidtv_encoder *sync;
|
|
void (*last_sample_cb)(u32 sample_no);
|
|
|
|
struct vidtv_encoder *head;
|
|
};
|
|
|
|
struct vidtv_encoder
|
|
*vidtv_s302m_encoder_init(struct vidtv_s302m_encoder_init_args args);
|
|
|
|
void vidtv_s302m_encoder_destroy(struct vidtv_encoder *encoder);
|
|
|
|
#endif /* VIDTV_S302M_H */
|