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