File: codec_l8.c

package info (click to toggle)
rat 4.2.22-2.2
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 2,896 kB
  • ctags: 3,717
  • sloc: ansic: 36,542; tcl: 2,740; sh: 2,675; makefile: 295
file content (125 lines) | stat: -rw-r--r-- 3,884 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
/*
 * FILE:    codec_l8.c
 * AUTHORS: Orion Hodson
 *
 * Copyright (c) 1998-2001 University College London
 * All rights reserved.
 */
 
#ifndef HIDE_SOURCE_STRINGS
static const char cvsid[] = 
	"$Id: codec_l8.c,v 1.1 2001/01/11 21:41:16 ucacoxh Exp $";
#endif /* HIDE_SOURCE_STRINGS */

#include "config_unix.h"
#include "config_win32.h"
#include "memory.h"
#include "util.h"
#include "debug.h"
#include "audio_types.h"
#include "codec_types.h"
#include "codec_l8.h"

/* Note payload numbers are dynamic and selected so:
 * (a) we always have one codec that can be used at each sample rate and freq
 * (b) to backwards match earlier releases.
 */

static codec_format_t cs[] = {
        {"Linear-8", "L8-8K-Mono",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 160, {DEV_S16,  8000, 16, 1, 160 * BYTES_PER_SAMPLE}}, /* 20  ms */
        {"Linear-8", "L8-8K-Stereo",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 320, {DEV_S16,  8000, 16, 2, 2 * 160 * BYTES_PER_SAMPLE}}, /* 20  ms */
        {"Linear-8", "L8-16K-Mono",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 160, {DEV_S16,  16000, 16, 1, 160 * BYTES_PER_SAMPLE}}, /* 10 ms */
        {"Linear-8", "L8-16K-Stereo",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 320, {DEV_S16,  16000, 16, 2, 2 * 160 * BYTES_PER_SAMPLE}}, /* 10 ms */
        {"Linear-8", "L8-32K-Mono",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 160, {DEV_S16,  32000, 16, 1, 160 * BYTES_PER_SAMPLE}}, /* 5 ms */
        {"Linear-8", "L8-32K-Stereo",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 320, {DEV_S16,  32000, 16, 2, 2 * 160 * BYTES_PER_SAMPLE}}, /* 5 ms */
        {"Linear-8", "L8-44K-Mono",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 160, {DEV_S16,  44100, 16, 1, 160 * BYTES_PER_SAMPLE}}, /* 3.6 ms */
        {"Linear-8", "L8-44K-Stereo",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 320, {DEV_S16,  44100, 16, 2, 2 * 160 * BYTES_PER_SAMPLE}}, /* 3.6 ms */
        {"Linear-8", "L8-48K-Mono",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 160, {DEV_S16,  48000, 16, 1, 160 * BYTES_PER_SAMPLE}}, /* 3.3 ms */
        {"Linear-8", "L8-48K-Stereo",  
         "Linear 8 uncompressed audio.", 
         CODEC_PAYLOAD_DYNAMIC, 0, 320, {DEV_S16,  48000, 16, 2, 2 * 160 * BYTES_PER_SAMPLE}} /* 3.3 ms */
};

#define L8_NUM_FORMATS sizeof(cs)/sizeof(codec_format_t)

uint16_t
l8_get_formats_count()
{
        return (uint16_t)L8_NUM_FORMATS;
}

const codec_format_t *
l8_get_format(uint16_t idx)
{
        assert(idx < L8_NUM_FORMATS);
        return &cs[idx];
}

/*
 * "From draft-ietf-avt-profile-09.txt
 *
 * 4.5.12 L8
 *
 * L8 denotes linear audio data samples, using 8-bits of precision with
 * an offset of 128, that is, the most negative signal is encoded as
 * zero."
 */

int
l8_encode(uint16_t idx, u_char *state, sample *src, coded_unit *out)
{
	uint8_t		*dst;
	uint32_t	i, samples;

        assert(idx < L8_NUM_FORMATS);
        UNUSED(state);

        out->state     = NULL;
        out->state_len = 0;
        out->data_len  = cs[idx].mean_coded_frame_size;
        out->data      = (u_char*)block_alloc(out->data_len);

        samples	= out->data_len;
	dst	= (uint8_t*)out->data;
	for (i = 0; i < samples; i++) {
		dst[i] = (uint8_t)((src[i] >> 8) + 128);
	}
        return samples;
}

int
l8_decode(uint16_t idx, u_char *state, coded_unit *in, sample *dst)
{
        int samples, i;
        uint8_t *src;

        assert(idx < L8_NUM_FORMATS);
        UNUSED(state);

        samples	= in->data_len;
	src	= (uint8_t*)in->data;
	for (i = 0; i < samples; i++) {
		dst[i] = (((sample)src[i]) - 128) << 8;
	}
        return samples;
}