1 /* SPDX-License-Identifier: GPL-2.0 */
2 /*
3  * The Virtual DVB test driver serves as a reference DVB driver and helps
4  * validate the existing APIs in the media subsystem. It can also aid
5  * developers working on userspace applications.
6  *
7  * Copyright (C) 2020 Daniel W. S. Almeida
8  */
9 
10 #ifndef VIDTV_TS_H
11 #define VIDTV_TS_H
12 
13 #include <linux/types.h>
14 
15 #define TS_SYNC_BYTE 0x47
16 #define TS_PACKET_LEN 188
17 #define TS_PAYLOAD_LEN 184
18 #define TS_NULL_PACKET_PID 0x1fff
19 #define TS_CC_MAX_VAL 0x0f /* 4 bits */
20 #define TS_LAST_VALID_PID 8191
21 #define TS_FILL_BYTE 0xff /* the byte used in packet stuffing */
22 
23 struct vidtv_mpeg_ts_adaption {
24 	u8 length;
25 	struct {
26 		u8 extension:1;
27 		u8 private_data:1;
28 		u8 splicing_point:1;
29 		u8 OPCR:1;
30 		u8 PCR:1;
31 		u8 priority:1;
32 		u8 random_access:1;
33 		u8 discontinued:1;
34 	} __packed;
35 	u8 data[];
36 } __packed;
37 
38 struct vidtv_mpeg_ts {
39 	u8 sync_byte;
40 	__be16 bitfield; /* tei: 1, payload_start:1 priority: 1, pid:13 */
41 	struct {
42 		u8 continuity_counter:4;
43 		u8 payload:1;
44 		u8 adaptation_field:1;
45 		u8 scrambling:2;
46 	} __packed;
47 	struct vidtv_mpeg_ts_adaption adaption[];
48 } __packed;
49 
50 /**
51  * struct pcr_write_args - Arguments for the pcr_write_into function.
52  * @dest_buf: The buffer to write into.
53  * @dest_offset: The byte offset into the buffer.
54  * @pid: The TS PID for the PCR packets.
55  * @buf_sz: The size of the buffer in bytes.
56  * @continuity_counter: The TS continuity_counter.
57  * @pcr: A sample from the system clock.
58  */
59 struct pcr_write_args {
60 	void *dest_buf;
61 	u32 dest_offset;
62 	u16 pid;
63 	u32 buf_sz;
64 	u8 *continuity_counter;
65 	u64 pcr;
66 };
67 
68 /**
69  * struct null_packet_write_args - Arguments for the null_write_into function
70  * @dest_buf: The buffer to write into.
71  * @dest_offset: The byte offset into the buffer.
72  * @buf_sz: The size of the buffer in bytes.
73  * @continuity_counter: The TS continuity_counter.
74  */
75 struct null_packet_write_args {
76 	void *dest_buf;
77 	u32 dest_offset;
78 	u32 buf_sz;
79 	u8 *continuity_counter;
80 };
81 
82 /* Increment the continuity counter */
83 void vidtv_ts_inc_cc(u8 *continuity_counter);
84 
85 /**
86  * vidtv_ts_null_write_into - Write a TS null packet into a buffer.
87  * @args: the arguments to use when writing.
88  *
89  * This function will write a null packet into a buffer. This is usually used to
90  * pad TS streams.
91  *
92  * Return: The number of bytes written into the buffer.
93  */
94 u32 vidtv_ts_null_write_into(struct null_packet_write_args args);
95 
96 /**
97  * vidtv_ts_pcr_write_into - Write a PCR  packet into a buffer.
98  * @args: the arguments to use when writing.
99  *
100  * This function will write a PCR packet into a buffer. This is used to
101  * synchronize the clocks between encoders and decoders.
102  *
103  * Return: The number of bytes written into the buffer.
104  */
105 u32 vidtv_ts_pcr_write_into(struct pcr_write_args args);
106 
107 #endif //VIDTV_TS_H
108