18c2ecf20Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0 */ 28c2ecf20Sopenharmony_ci/* 38c2ecf20Sopenharmony_ci * Vidtv serves as a reference DVB driver and helps validate the existing APIs 48c2ecf20Sopenharmony_ci * in the media subsystem. It can also aid developers working on userspace 58c2ecf20Sopenharmony_ci * applications. 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * This file contains the code for an AES3 (also known as AES/EBU) encoder. 88c2ecf20Sopenharmony_ci * It is based on EBU Tech 3250 and SMPTE 302M technical documents. 98c2ecf20Sopenharmony_ci * 108c2ecf20Sopenharmony_ci * This encoder currently supports 16bit AES3 subframes using 16bit signed 118c2ecf20Sopenharmony_ci * integers. 128c2ecf20Sopenharmony_ci * 138c2ecf20Sopenharmony_ci * Note: AU stands for Access Unit, and AAU stands for Audio Access Unit 148c2ecf20Sopenharmony_ci * 158c2ecf20Sopenharmony_ci * Copyright (C) 2020 Daniel W. S. Almeida 168c2ecf20Sopenharmony_ci */ 178c2ecf20Sopenharmony_ci 188c2ecf20Sopenharmony_ci#ifndef VIDTV_S302M_H 198c2ecf20Sopenharmony_ci#define VIDTV_S302M_H 208c2ecf20Sopenharmony_ci 218c2ecf20Sopenharmony_ci#include <linux/types.h> 228c2ecf20Sopenharmony_ci 238c2ecf20Sopenharmony_ci#include "vidtv_encoder.h" 248c2ecf20Sopenharmony_ci 258c2ecf20Sopenharmony_ci/* see SMPTE 302M 2007 clause 7.3 */ 268c2ecf20Sopenharmony_ci#define VIDTV_S302M_BUF_SZ 65024 278c2ecf20Sopenharmony_ci 288c2ecf20Sopenharmony_ci/* see ETSI TS 102 154 v.1.2.1 clause 7.3.5 */ 298c2ecf20Sopenharmony_ci#define VIDTV_S302M_FORMAT_IDENTIFIER 0x42535344 308c2ecf20Sopenharmony_ci 318c2ecf20Sopenharmony_ci/** 328c2ecf20Sopenharmony_ci * struct vidtv_s302m_ctx - s302m encoder context. 338c2ecf20Sopenharmony_ci * @enc: A pointer to the containing encoder structure. 348c2ecf20Sopenharmony_ci * @frame_index: The current frame in a block 358c2ecf20Sopenharmony_ci * @au_count: The total number of access units encoded up to now 368c2ecf20Sopenharmony_ci * @last_duration: Duration of the tone currently being played 378c2ecf20Sopenharmony_ci * @note_offset: Position at the music tone array 388c2ecf20Sopenharmony_ci * @last_tone: Tone currently being played 398c2ecf20Sopenharmony_ci */ 408c2ecf20Sopenharmony_cistruct vidtv_s302m_ctx { 418c2ecf20Sopenharmony_ci struct vidtv_encoder *enc; 428c2ecf20Sopenharmony_ci u32 frame_index; 438c2ecf20Sopenharmony_ci u32 au_count; 448c2ecf20Sopenharmony_ci int last_duration; 458c2ecf20Sopenharmony_ci unsigned int note_offset; 468c2ecf20Sopenharmony_ci enum musical_notes last_tone; 478c2ecf20Sopenharmony_ci}; 488c2ecf20Sopenharmony_ci 498c2ecf20Sopenharmony_ci/* 508c2ecf20Sopenharmony_ci * struct vidtv_smpte_s302m_es - s302m MPEG Elementary Stream header. 518c2ecf20Sopenharmony_ci * 528c2ecf20Sopenharmony_ci * See SMPTE 302M 2007 table 1. 538c2ecf20Sopenharmony_ci */ 548c2ecf20Sopenharmony_cistruct vidtv_smpte_s302m_es { 558c2ecf20Sopenharmony_ci /* 568c2ecf20Sopenharmony_ci * 578c2ecf20Sopenharmony_ci * audio_packet_size:16; 588c2ecf20Sopenharmony_ci * num_channels:2; 598c2ecf20Sopenharmony_ci * channel_identification:8; 608c2ecf20Sopenharmony_ci * bits_per_sample:2; // 0x0 for 16bits 618c2ecf20Sopenharmony_ci * zero:4; 628c2ecf20Sopenharmony_ci */ 638c2ecf20Sopenharmony_ci __be32 bitfield; 648c2ecf20Sopenharmony_ci} __packed; 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_cistruct vidtv_s302m_frame_16 { 678c2ecf20Sopenharmony_ci u8 data[5]; 688c2ecf20Sopenharmony_ci} __packed; 698c2ecf20Sopenharmony_ci 708c2ecf20Sopenharmony_ci/** 718c2ecf20Sopenharmony_ci * struct vidtv_s302m_encoder_init_args - Args for the s302m encoder. 728c2ecf20Sopenharmony_ci * 738c2ecf20Sopenharmony_ci * @name: A name to identify this particular instance 748c2ecf20Sopenharmony_ci * @src_buf: The source buffer, encoder will default to a sine wave if this is NULL. 758c2ecf20Sopenharmony_ci * @src_buf_sz: The size of the source buffer. 768c2ecf20Sopenharmony_ci * @es_pid: The MPEG Elementary Stream PID to use. 778c2ecf20Sopenharmony_ci * @sync: Attempt to synchronize audio with this video encoder, if not NULL. 788c2ecf20Sopenharmony_ci * @last_sample_cb: A callback called when the encoder runs out of data. 798c2ecf20Sopenharmony_ci * @head: Add to this chain 808c2ecf20Sopenharmony_ci */ 818c2ecf20Sopenharmony_cistruct vidtv_s302m_encoder_init_args { 828c2ecf20Sopenharmony_ci char *name; 838c2ecf20Sopenharmony_ci void *src_buf; 848c2ecf20Sopenharmony_ci u32 src_buf_sz; 858c2ecf20Sopenharmony_ci u16 es_pid; 868c2ecf20Sopenharmony_ci struct vidtv_encoder *sync; 878c2ecf20Sopenharmony_ci void (*last_sample_cb)(u32 sample_no); 888c2ecf20Sopenharmony_ci 898c2ecf20Sopenharmony_ci struct vidtv_encoder *head; 908c2ecf20Sopenharmony_ci}; 918c2ecf20Sopenharmony_ci 928c2ecf20Sopenharmony_cistruct vidtv_encoder 938c2ecf20Sopenharmony_ci*vidtv_s302m_encoder_init(struct vidtv_s302m_encoder_init_args args); 948c2ecf20Sopenharmony_ci 958c2ecf20Sopenharmony_civoid vidtv_s302m_encoder_destroy(struct vidtv_encoder *encoder); 968c2ecf20Sopenharmony_ci 978c2ecf20Sopenharmony_ci#endif /* VIDTV_S302M_H */ 98