gst_plugins_good/gst/law/alaw-encode.c
author hgs
Wed, 24 Mar 2010 18:04:17 -0500
changeset 16 8e837d1bf446
permissions -rw-r--r--
201009
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
16
hgs
parents:
diff changeset
     1
/* GStreamer PCM to A-Law conversion
hgs
parents:
diff changeset
     2
 * Copyright (C) 2000 by Abramo Bagnara <abramo@alsa-project.org>
hgs
parents:
diff changeset
     3
 *
hgs
parents:
diff changeset
     4
 * This library is free software; you can redistribute it and/or
hgs
parents:
diff changeset
     5
 * modify it under the terms of the GNU Library General Public
hgs
parents:
diff changeset
     6
 * License as published by the Free Software Foundation; either
hgs
parents:
diff changeset
     7
 * version 2.1 of the License, or (at your option) any later version.
hgs
parents:
diff changeset
     8
 *
hgs
parents:
diff changeset
     9
 * This library is distributed in the hope that it will be useful,
hgs
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
hgs
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
hgs
parents:
diff changeset
    12
 * Library General Public License for more details.
hgs
parents:
diff changeset
    13
 *
hgs
parents:
diff changeset
    14
 * You should have received a copy of the GNU Library General Public
hgs
parents:
diff changeset
    15
 * License along with this library; if not, write to the
hgs
parents:
diff changeset
    16
 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
hgs
parents:
diff changeset
    17
 * Boston, MA 02111-1307, USA.
hgs
parents:
diff changeset
    18
 */
hgs
parents:
diff changeset
    19
/**
hgs
parents:
diff changeset
    20
 * SECTION:element-alawenc
hgs
parents:
diff changeset
    21
 *
hgs
parents:
diff changeset
    22
 * This element encode alaw audio. Alaw coding is also known as G.711.
hgs
parents:
diff changeset
    23
 */
hgs
parents:
diff changeset
    24
hgs
parents:
diff changeset
    25
#ifdef HAVE_CONFIG_H
hgs
parents:
diff changeset
    26
#include "config.h"
hgs
parents:
diff changeset
    27
#endif
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#include "alaw-encode.h"
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
GST_DEBUG_CATEGORY_STATIC (alaw_enc_debug);
hgs
parents:
diff changeset
    32
#define GST_CAT_DEFAULT alaw_enc_debug
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
extern GstStaticPadTemplate alaw_enc_src_factory;
hgs
parents:
diff changeset
    35
extern GstStaticPadTemplate alaw_enc_sink_factory;
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
static GstFlowReturn gst_alaw_enc_chain (GstPad * pad, GstBuffer * buffer);
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
GST_BOILERPLATE (GstALawEnc, gst_alaw_enc, GstElement, GST_TYPE_ELEMENT);
hgs
parents:
diff changeset
    40
hgs
parents:
diff changeset
    41
/* some day we might have defines in gstconfig.h that tell us about the
hgs
parents:
diff changeset
    42
 * desired cpu/memory/binary size trade-offs */
hgs
parents:
diff changeset
    43
#define GST_ALAW_ENC_USE_TABLE
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
#ifdef GST_ALAW_ENC_USE_TABLE
hgs
parents:
diff changeset
    46
hgs
parents:
diff changeset
    47
static const guint8 alaw_encode[2048 + 1] = {
hgs
parents:
diff changeset
    48
  0xd5, 0xd4, 0xd7, 0xd6, 0xd1, 0xd0, 0xd3, 0xd2, 0xdd, 0xdc, 0xdf, 0xde,
hgs
parents:
diff changeset
    49
  0xd9, 0xd8, 0xdb, 0xda, 0xc5, 0xc4, 0xc7, 0xc6, 0xc1, 0xc0, 0xc3, 0xc2,
hgs
parents:
diff changeset
    50
  0xcd, 0xcc, 0xcf, 0xce, 0xc9, 0xc8, 0xcb, 0xca, 0xf5, 0xf5, 0xf4, 0xf4,
hgs
parents:
diff changeset
    51
  0xf7, 0xf7, 0xf6, 0xf6, 0xf1, 0xf1, 0xf0, 0xf0, 0xf3, 0xf3, 0xf2, 0xf2,
hgs
parents:
diff changeset
    52
  0xfd, 0xfd, 0xfc, 0xfc, 0xff, 0xff, 0xfe, 0xfe, 0xf9, 0xf9, 0xf8, 0xf8,
hgs
parents:
diff changeset
    53
  0xfb, 0xfb, 0xfa, 0xfa, 0xe5, 0xe5, 0xe5, 0xe5, 0xe4, 0xe4, 0xe4, 0xe4,
hgs
parents:
diff changeset
    54
  0xe7, 0xe7, 0xe7, 0xe7, 0xe6, 0xe6, 0xe6, 0xe6, 0xe1, 0xe1, 0xe1, 0xe1,
hgs
parents:
diff changeset
    55
  0xe0, 0xe0, 0xe0, 0xe0, 0xe3, 0xe3, 0xe3, 0xe3, 0xe2, 0xe2, 0xe2, 0xe2,
hgs
parents:
diff changeset
    56
  0xed, 0xed, 0xed, 0xed, 0xec, 0xec, 0xec, 0xec, 0xef, 0xef, 0xef, 0xef,
hgs
parents:
diff changeset
    57
  0xee, 0xee, 0xee, 0xee, 0xe9, 0xe9, 0xe9, 0xe9, 0xe8, 0xe8, 0xe8, 0xe8,
hgs
parents:
diff changeset
    58
  0xeb, 0xeb, 0xeb, 0xeb, 0xea, 0xea, 0xea, 0xea, 0x95, 0x95, 0x95, 0x95,
hgs
parents:
diff changeset
    59
  0x95, 0x95, 0x95, 0x95, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94, 0x94,
hgs
parents:
diff changeset
    60
  0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x97, 0x96, 0x96, 0x96, 0x96,
hgs
parents:
diff changeset
    61
  0x96, 0x96, 0x96, 0x96, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91, 0x91,
hgs
parents:
diff changeset
    62
  0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x90, 0x93, 0x93, 0x93, 0x93,
hgs
parents:
diff changeset
    63
  0x93, 0x93, 0x93, 0x93, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92, 0x92,
hgs
parents:
diff changeset
    64
  0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9d, 0x9c, 0x9c, 0x9c, 0x9c,
hgs
parents:
diff changeset
    65
  0x9c, 0x9c, 0x9c, 0x9c, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f, 0x9f,
hgs
parents:
diff changeset
    66
  0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x9e, 0x99, 0x99, 0x99, 0x99,
hgs
parents:
diff changeset
    67
  0x99, 0x99, 0x99, 0x99, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98, 0x98,
hgs
parents:
diff changeset
    68
  0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9b, 0x9a, 0x9a, 0x9a, 0x9a,
hgs
parents:
diff changeset
    69
  0x9a, 0x9a, 0x9a, 0x9a, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85,
hgs
parents:
diff changeset
    70
  0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x85, 0x84, 0x84, 0x84, 0x84,
hgs
parents:
diff changeset
    71
  0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84, 0x84,
hgs
parents:
diff changeset
    72
  0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87, 0x87,
hgs
parents:
diff changeset
    73
  0x87, 0x87, 0x87, 0x87, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86,
hgs
parents:
diff changeset
    74
  0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x86, 0x81, 0x81, 0x81, 0x81,
hgs
parents:
diff changeset
    75
  0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81, 0x81,
hgs
parents:
diff changeset
    76
  0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80,
hgs
parents:
diff changeset
    77
  0x80, 0x80, 0x80, 0x80, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83,
hgs
parents:
diff changeset
    78
  0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x83, 0x82, 0x82, 0x82, 0x82,
hgs
parents:
diff changeset
    79
  0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82, 0x82,
hgs
parents:
diff changeset
    80
  0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d, 0x8d,
hgs
parents:
diff changeset
    81
  0x8d, 0x8d, 0x8d, 0x8d, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c,
hgs
parents:
diff changeset
    82
  0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8c, 0x8f, 0x8f, 0x8f, 0x8f,
hgs
parents:
diff changeset
    83
  0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f, 0x8f,
hgs
parents:
diff changeset
    84
  0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e, 0x8e,
hgs
parents:
diff changeset
    85
  0x8e, 0x8e, 0x8e, 0x8e, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89,
hgs
parents:
diff changeset
    86
  0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x89, 0x88, 0x88, 0x88, 0x88,
hgs
parents:
diff changeset
    87
  0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88, 0x88,
hgs
parents:
diff changeset
    88
  0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b, 0x8b,
hgs
parents:
diff changeset
    89
  0x8b, 0x8b, 0x8b, 0x8b, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a,
hgs
parents:
diff changeset
    90
  0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0x8a, 0xb5, 0xb5, 0xb5, 0xb5,
hgs
parents:
diff changeset
    91
  0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5,
hgs
parents:
diff changeset
    92
  0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5, 0xb5,
hgs
parents:
diff changeset
    93
  0xb5, 0xb5, 0xb5, 0xb5, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
hgs
parents:
diff changeset
    94
  0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
hgs
parents:
diff changeset
    95
  0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4, 0xb4,
hgs
parents:
diff changeset
    96
  0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7,
hgs
parents:
diff changeset
    97
  0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7,
hgs
parents:
diff changeset
    98
  0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb7, 0xb6, 0xb6, 0xb6, 0xb6,
hgs
parents:
diff changeset
    99
  0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6,
hgs
parents:
diff changeset
   100
  0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6, 0xb6,
hgs
parents:
diff changeset
   101
  0xb6, 0xb6, 0xb6, 0xb6, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
hgs
parents:
diff changeset
   102
  0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
hgs
parents:
diff changeset
   103
  0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1, 0xb1,
hgs
parents:
diff changeset
   104
  0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0,
hgs
parents:
diff changeset
   105
  0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0,
hgs
parents:
diff changeset
   106
  0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb0, 0xb3, 0xb3, 0xb3, 0xb3,
hgs
parents:
diff changeset
   107
  0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3,
hgs
parents:
diff changeset
   108
  0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3, 0xb3,
hgs
parents:
diff changeset
   109
  0xb3, 0xb3, 0xb3, 0xb3, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
hgs
parents:
diff changeset
   110
  0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
hgs
parents:
diff changeset
   111
  0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2, 0xb2,
hgs
parents:
diff changeset
   112
  0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd,
hgs
parents:
diff changeset
   113
  0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd,
hgs
parents:
diff changeset
   114
  0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbd, 0xbc, 0xbc, 0xbc, 0xbc,
hgs
parents:
diff changeset
   115
  0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc,
hgs
parents:
diff changeset
   116
  0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc, 0xbc,
hgs
parents:
diff changeset
   117
  0xbc, 0xbc, 0xbc, 0xbc, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
hgs
parents:
diff changeset
   118
  0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
hgs
parents:
diff changeset
   119
  0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf, 0xbf,
hgs
parents:
diff changeset
   120
  0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe,
hgs
parents:
diff changeset
   121
  0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe,
hgs
parents:
diff changeset
   122
  0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xbe, 0xb9, 0xb9, 0xb9, 0xb9,
hgs
parents:
diff changeset
   123
  0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9,
hgs
parents:
diff changeset
   124
  0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9, 0xb9,
hgs
parents:
diff changeset
   125
  0xb9, 0xb9, 0xb9, 0xb9, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
hgs
parents:
diff changeset
   126
  0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
hgs
parents:
diff changeset
   127
  0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8, 0xb8,
hgs
parents:
diff changeset
   128
  0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb,
hgs
parents:
diff changeset
   129
  0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb,
hgs
parents:
diff changeset
   130
  0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xbb, 0xba, 0xba, 0xba, 0xba,
hgs
parents:
diff changeset
   131
  0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba,
hgs
parents:
diff changeset
   132
  0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba, 0xba,
hgs
parents:
diff changeset
   133
  0xba, 0xba, 0xba, 0xba, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
hgs
parents:
diff changeset
   134
  0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
hgs
parents:
diff changeset
   135
  0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
hgs
parents:
diff changeset
   136
  0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
hgs
parents:
diff changeset
   137
  0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5,
hgs
parents:
diff changeset
   138
  0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa5, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   139
  0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   140
  0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   141
  0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   142
  0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   143
  0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4, 0xa4,
hgs
parents:
diff changeset
   144
  0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
hgs
parents:
diff changeset
   145
  0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
hgs
parents:
diff changeset
   146
  0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
hgs
parents:
diff changeset
   147
  0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
hgs
parents:
diff changeset
   148
  0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7, 0xa7,
hgs
parents:
diff changeset
   149
  0xa7, 0xa7, 0xa7, 0xa7, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
hgs
parents:
diff changeset
   150
  0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
hgs
parents:
diff changeset
   151
  0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
hgs
parents:
diff changeset
   152
  0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
hgs
parents:
diff changeset
   153
  0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6,
hgs
parents:
diff changeset
   154
  0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa6, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   155
  0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   156
  0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   157
  0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   158
  0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   159
  0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1, 0xa1,
hgs
parents:
diff changeset
   160
  0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
hgs
parents:
diff changeset
   161
  0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
hgs
parents:
diff changeset
   162
  0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
hgs
parents:
diff changeset
   163
  0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
hgs
parents:
diff changeset
   164
  0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0, 0xa0,
hgs
parents:
diff changeset
   165
  0xa0, 0xa0, 0xa0, 0xa0, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
hgs
parents:
diff changeset
   166
  0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
hgs
parents:
diff changeset
   167
  0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
hgs
parents:
diff changeset
   168
  0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
hgs
parents:
diff changeset
   169
  0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3,
hgs
parents:
diff changeset
   170
  0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa3, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   171
  0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   172
  0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   173
  0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   174
  0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   175
  0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2, 0xa2,
hgs
parents:
diff changeset
   176
  0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
hgs
parents:
diff changeset
   177
  0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
hgs
parents:
diff changeset
   178
  0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
hgs
parents:
diff changeset
   179
  0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
hgs
parents:
diff changeset
   180
  0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad, 0xad,
hgs
parents:
diff changeset
   181
  0xad, 0xad, 0xad, 0xad, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
hgs
parents:
diff changeset
   182
  0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
hgs
parents:
diff changeset
   183
  0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
hgs
parents:
diff changeset
   184
  0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
hgs
parents:
diff changeset
   185
  0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac,
hgs
parents:
diff changeset
   186
  0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xac, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   187
  0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   188
  0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   189
  0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   190
  0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   191
  0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf, 0xaf,
hgs
parents:
diff changeset
   192
  0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
hgs
parents:
diff changeset
   193
  0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
hgs
parents:
diff changeset
   194
  0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
hgs
parents:
diff changeset
   195
  0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
hgs
parents:
diff changeset
   196
  0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae, 0xae,
hgs
parents:
diff changeset
   197
  0xae, 0xae, 0xae, 0xae, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
hgs
parents:
diff changeset
   198
  0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
hgs
parents:
diff changeset
   199
  0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
hgs
parents:
diff changeset
   200
  0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
hgs
parents:
diff changeset
   201
  0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9,
hgs
parents:
diff changeset
   202
  0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa9, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   203
  0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   204
  0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   205
  0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   206
  0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   207
  0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8, 0xa8,
hgs
parents:
diff changeset
   208
  0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
hgs
parents:
diff changeset
   209
  0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
hgs
parents:
diff changeset
   210
  0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
hgs
parents:
diff changeset
   211
  0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
hgs
parents:
diff changeset
   212
  0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab, 0xab,
hgs
parents:
diff changeset
   213
  0xab, 0xab, 0xab, 0xab, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
hgs
parents:
diff changeset
   214
  0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
hgs
parents:
diff changeset
   215
  0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
hgs
parents:
diff changeset
   216
  0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
hgs
parents:
diff changeset
   217
  0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
hgs
parents:
diff changeset
   218
  0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0x2a
hgs
parents:
diff changeset
   219
};
hgs
parents:
diff changeset
   220
hgs
parents:
diff changeset
   221
static inline guint8
hgs
parents:
diff changeset
   222
s16_to_alaw (gint16 pcm_val)
hgs
parents:
diff changeset
   223
{
hgs
parents:
diff changeset
   224
  if (pcm_val >= 0)
hgs
parents:
diff changeset
   225
    return alaw_encode[pcm_val / 16];
hgs
parents:
diff changeset
   226
  else
hgs
parents:
diff changeset
   227
    return (0x7F & alaw_encode[pcm_val / -16]);
hgs
parents:
diff changeset
   228
}
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
#else /* GST_ALAW_ENC_USE_TABLE */
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
/*
hgs
parents:
diff changeset
   233
 * s16_to_alaw() - Convert a 16-bit linear PCM value to 8-bit A-law
hgs
parents:
diff changeset
   234
 *
hgs
parents:
diff changeset
   235
 * s16_to_alaw() accepts an 16-bit integer and encodes it as A-law data.
hgs
parents:
diff changeset
   236
 *
hgs
parents:
diff changeset
   237
 *              Linear Input Code       Compressed Code
hgs
parents:
diff changeset
   238
 *      ------------------------        ---------------
hgs
parents:
diff changeset
   239
 *      0000000wxyza                    000wxyz
hgs
parents:
diff changeset
   240
 *      0000001wxyza                    001wxyz
hgs
parents:
diff changeset
   241
 *      000001wxyzab                    010wxyz
hgs
parents:
diff changeset
   242
 *      00001wxyzabc                    011wxyz
hgs
parents:
diff changeset
   243
 *      0001wxyzabcd                    100wxyz
hgs
parents:
diff changeset
   244
 *      001wxyzabcde                    101wxyz
hgs
parents:
diff changeset
   245
 *      01wxyzabcdef                    110wxyz
hgs
parents:
diff changeset
   246
 *      1wxyzabcdefg                    111wxyz
hgs
parents:
diff changeset
   247
 *
hgs
parents:
diff changeset
   248
 * For further information see John C. Bellamy's Digital Telephony, 1982,
hgs
parents:
diff changeset
   249
 * John Wiley & Sons, pps 98-111 and 472-476.
hgs
parents:
diff changeset
   250
 */
hgs
parents:
diff changeset
   251
hgs
parents:
diff changeset
   252
static inline gint
hgs
parents:
diff changeset
   253
val_seg (gint val)
hgs
parents:
diff changeset
   254
{
hgs
parents:
diff changeset
   255
  gint r = 1;
hgs
parents:
diff changeset
   256
hgs
parents:
diff changeset
   257
  val >>= 8;
hgs
parents:
diff changeset
   258
  if (val & 0xf0) {
hgs
parents:
diff changeset
   259
    val >>= 4;
hgs
parents:
diff changeset
   260
    r += 4;
hgs
parents:
diff changeset
   261
  }
hgs
parents:
diff changeset
   262
  if (val & 0x0c) {
hgs
parents:
diff changeset
   263
    val >>= 2;
hgs
parents:
diff changeset
   264
    r += 2;
hgs
parents:
diff changeset
   265
  }
hgs
parents:
diff changeset
   266
  if (val & 0x02)
hgs
parents:
diff changeset
   267
    r += 1;
hgs
parents:
diff changeset
   268
  return r;
hgs
parents:
diff changeset
   269
}
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
static inline guint8
hgs
parents:
diff changeset
   272
s16_to_alaw (gint pcm_val)
hgs
parents:
diff changeset
   273
{
hgs
parents:
diff changeset
   274
  gint seg;
hgs
parents:
diff changeset
   275
  guint8 mask;
hgs
parents:
diff changeset
   276
  guint8 aval;
hgs
parents:
diff changeset
   277
hgs
parents:
diff changeset
   278
  if (pcm_val >= 0) {
hgs
parents:
diff changeset
   279
    mask = 0xD5;
hgs
parents:
diff changeset
   280
  } else {
hgs
parents:
diff changeset
   281
    mask = 0x55;
hgs
parents:
diff changeset
   282
    pcm_val = -pcm_val;
hgs
parents:
diff changeset
   283
    if (pcm_val > 0x7fff)
hgs
parents:
diff changeset
   284
      pcm_val = 0x7fff;
hgs
parents:
diff changeset
   285
  }
hgs
parents:
diff changeset
   286
hgs
parents:
diff changeset
   287
  if (pcm_val < 256)
hgs
parents:
diff changeset
   288
    aval = pcm_val >> 4;
hgs
parents:
diff changeset
   289
  else {
hgs
parents:
diff changeset
   290
    /* Convert the scaled magnitude to segment number. */
hgs
parents:
diff changeset
   291
    seg = val_seg (pcm_val);
hgs
parents:
diff changeset
   292
    aval = (seg << 4) | ((pcm_val >> (seg + 3)) & 0x0f);
hgs
parents:
diff changeset
   293
  }
hgs
parents:
diff changeset
   294
  return aval ^ mask;
hgs
parents:
diff changeset
   295
}
hgs
parents:
diff changeset
   296
hgs
parents:
diff changeset
   297
#endif /* GST_ALAW_ENC_USE_TABLE */
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
static GstCaps *
hgs
parents:
diff changeset
   300
gst_alaw_enc_getcaps (GstPad * pad)
hgs
parents:
diff changeset
   301
{
hgs
parents:
diff changeset
   302
  GstALawEnc *alawenc;
hgs
parents:
diff changeset
   303
  GstPad *otherpad;
hgs
parents:
diff changeset
   304
  GstCaps *othercaps, *result;
hgs
parents:
diff changeset
   305
  const GstCaps *templ;
hgs
parents:
diff changeset
   306
  gchar *name;
hgs
parents:
diff changeset
   307
  gint i;
hgs
parents:
diff changeset
   308
hgs
parents:
diff changeset
   309
  alawenc = GST_ALAW_ENC (GST_PAD_PARENT (pad));
hgs
parents:
diff changeset
   310
hgs
parents:
diff changeset
   311
  /* figure out the name of the caps we are going to return */
hgs
parents:
diff changeset
   312
  if (pad == alawenc->srcpad) {
hgs
parents:
diff changeset
   313
    name = "audio/x-alaw";
hgs
parents:
diff changeset
   314
    otherpad = alawenc->sinkpad;
hgs
parents:
diff changeset
   315
  } else {
hgs
parents:
diff changeset
   316
    name = "audio/x-raw-int";
hgs
parents:
diff changeset
   317
    otherpad = alawenc->srcpad;
hgs
parents:
diff changeset
   318
  }
hgs
parents:
diff changeset
   319
  /* get caps from the peer, this can return NULL when there is no peer */
hgs
parents:
diff changeset
   320
  othercaps = gst_pad_peer_get_caps (otherpad);
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
  /* get the template caps to make sure we return something acceptable */
hgs
parents:
diff changeset
   323
  templ = gst_pad_get_pad_template_caps (pad);
hgs
parents:
diff changeset
   324
hgs
parents:
diff changeset
   325
  if (othercaps) {
hgs
parents:
diff changeset
   326
    /* there was a peer */
hgs
parents:
diff changeset
   327
    othercaps = gst_caps_make_writable (othercaps);
hgs
parents:
diff changeset
   328
hgs
parents:
diff changeset
   329
    /* go through the caps and remove the fields we don't want */
hgs
parents:
diff changeset
   330
    for (i = 0; i < gst_caps_get_size (othercaps); i++) {
hgs
parents:
diff changeset
   331
      GstStructure *structure;
hgs
parents:
diff changeset
   332
hgs
parents:
diff changeset
   333
      structure = gst_caps_get_structure (othercaps, i);
hgs
parents:
diff changeset
   334
hgs
parents:
diff changeset
   335
      /* adjust the name */
hgs
parents:
diff changeset
   336
      gst_structure_set_name (structure, name);
hgs
parents:
diff changeset
   337
hgs
parents:
diff changeset
   338
      if (pad == alawenc->srcpad) {
hgs
parents:
diff changeset
   339
        /* remove the fields we don't want */
hgs
parents:
diff changeset
   340
        gst_structure_remove_fields (structure, "width", "depth", "endianness",
hgs
parents:
diff changeset
   341
            "signed", NULL);
hgs
parents:
diff changeset
   342
      } else {
hgs
parents:
diff changeset
   343
        /* add fixed fields */
hgs
parents:
diff changeset
   344
        gst_structure_set (structure, "width", G_TYPE_INT, 16,
hgs
parents:
diff changeset
   345
            "depth", G_TYPE_INT, 16,
hgs
parents:
diff changeset
   346
            "endianness", G_TYPE_INT, G_BYTE_ORDER,
hgs
parents:
diff changeset
   347
            "signed", G_TYPE_BOOLEAN, TRUE, NULL);
hgs
parents:
diff changeset
   348
      }
hgs
parents:
diff changeset
   349
    }
hgs
parents:
diff changeset
   350
    /* filter against the allowed caps of the pad to return our result */
hgs
parents:
diff changeset
   351
    result = gst_caps_intersect (othercaps, templ);
hgs
parents:
diff changeset
   352
    gst_caps_unref (othercaps);
hgs
parents:
diff changeset
   353
  } else {
hgs
parents:
diff changeset
   354
    /* there was no peer, return the template caps */
hgs
parents:
diff changeset
   355
    result = gst_caps_copy (templ);
hgs
parents:
diff changeset
   356
  }
hgs
parents:
diff changeset
   357
hgs
parents:
diff changeset
   358
  return result;
hgs
parents:
diff changeset
   359
}
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
static gboolean
hgs
parents:
diff changeset
   362
gst_alaw_enc_setcaps (GstPad * pad, GstCaps * caps)
hgs
parents:
diff changeset
   363
{
hgs
parents:
diff changeset
   364
  GstALawEnc *alawenc;
hgs
parents:
diff changeset
   365
  GstPad *otherpad;
hgs
parents:
diff changeset
   366
  GstStructure *structure;
hgs
parents:
diff changeset
   367
  gboolean ret;
hgs
parents:
diff changeset
   368
  GstCaps *base_caps;
hgs
parents:
diff changeset
   369
hgs
parents:
diff changeset
   370
  alawenc = GST_ALAW_ENC (GST_PAD_PARENT (pad));
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
  structure = gst_caps_get_structure (caps, 0);
hgs
parents:
diff changeset
   373
  gst_structure_get_int (structure, "channels", &alawenc->channels);
hgs
parents:
diff changeset
   374
  gst_structure_get_int (structure, "rate", &alawenc->rate);
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
  if (pad == alawenc->sinkpad) {
hgs
parents:
diff changeset
   377
    otherpad = alawenc->srcpad;
hgs
parents:
diff changeset
   378
  } else {
hgs
parents:
diff changeset
   379
    otherpad = alawenc->sinkpad;
hgs
parents:
diff changeset
   380
  }
hgs
parents:
diff changeset
   381
hgs
parents:
diff changeset
   382
  base_caps = gst_caps_copy (gst_pad_get_pad_template_caps (otherpad));
hgs
parents:
diff changeset
   383
  structure = gst_caps_get_structure (base_caps, 0);
hgs
parents:
diff changeset
   384
  gst_structure_set (structure, "rate", G_TYPE_INT, alawenc->rate, NULL);
hgs
parents:
diff changeset
   385
  gst_structure_set (structure, "channels", G_TYPE_INT, alawenc->channels,
hgs
parents:
diff changeset
   386
      NULL);
hgs
parents:
diff changeset
   387
hgs
parents:
diff changeset
   388
  GST_DEBUG_OBJECT (alawenc, "rate=%d, channels=%d", alawenc->rate,
hgs
parents:
diff changeset
   389
      alawenc->channels);
hgs
parents:
diff changeset
   390
hgs
parents:
diff changeset
   391
  ret = gst_pad_set_caps (otherpad, base_caps);
hgs
parents:
diff changeset
   392
hgs
parents:
diff changeset
   393
  gst_caps_unref (base_caps);
hgs
parents:
diff changeset
   394
hgs
parents:
diff changeset
   395
  return ret;
hgs
parents:
diff changeset
   396
}
hgs
parents:
diff changeset
   397
hgs
parents:
diff changeset
   398
static void
hgs
parents:
diff changeset
   399
gst_alaw_enc_base_init (gpointer klass)
hgs
parents:
diff changeset
   400
{
hgs
parents:
diff changeset
   401
  GstElementClass *element_class = GST_ELEMENT_CLASS (klass);
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
  gst_element_class_add_pad_template (element_class,
hgs
parents:
diff changeset
   404
      gst_static_pad_template_get (&alaw_enc_src_factory));
hgs
parents:
diff changeset
   405
  gst_element_class_add_pad_template (element_class,
hgs
parents:
diff changeset
   406
      gst_static_pad_template_get (&alaw_enc_sink_factory));
hgs
parents:
diff changeset
   407
hgs
parents:
diff changeset
   408
  gst_element_class_set_details_simple (element_class,
hgs
parents:
diff changeset
   409
      "A Law audio encoder", "Codec/Encoder/Audio",
hgs
parents:
diff changeset
   410
      "Convert 16bit PCM to 8bit A law",
hgs
parents:
diff changeset
   411
      "Zaheer Abbas Merali <zaheerabbas at merali dot org>");
hgs
parents:
diff changeset
   412
hgs
parents:
diff changeset
   413
  GST_DEBUG_CATEGORY_INIT (alaw_enc_debug, "alawenc", 0, "A Law audio encoder");
hgs
parents:
diff changeset
   414
}
hgs
parents:
diff changeset
   415
hgs
parents:
diff changeset
   416
static void
hgs
parents:
diff changeset
   417
gst_alaw_enc_class_init (GstALawEncClass * klass)
hgs
parents:
diff changeset
   418
{
hgs
parents:
diff changeset
   419
  /* nothing to do here for now */
hgs
parents:
diff changeset
   420
}
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
static void
hgs
parents:
diff changeset
   423
gst_alaw_enc_init (GstALawEnc * alawenc, GstALawEncClass * klass)
hgs
parents:
diff changeset
   424
{
hgs
parents:
diff changeset
   425
  alawenc->sinkpad =
hgs
parents:
diff changeset
   426
      gst_pad_new_from_static_template (&alaw_enc_sink_factory, "sink");
hgs
parents:
diff changeset
   427
  gst_pad_set_setcaps_function (alawenc->sinkpad,
hgs
parents:
diff changeset
   428
      GST_DEBUG_FUNCPTR (gst_alaw_enc_setcaps));
hgs
parents:
diff changeset
   429
  gst_pad_set_getcaps_function (alawenc->sinkpad,
hgs
parents:
diff changeset
   430
      GST_DEBUG_FUNCPTR (gst_alaw_enc_getcaps));
hgs
parents:
diff changeset
   431
  gst_pad_set_chain_function (alawenc->sinkpad,
hgs
parents:
diff changeset
   432
      GST_DEBUG_FUNCPTR (gst_alaw_enc_chain));
hgs
parents:
diff changeset
   433
  gst_element_add_pad (GST_ELEMENT (alawenc), alawenc->sinkpad);
hgs
parents:
diff changeset
   434
hgs
parents:
diff changeset
   435
  alawenc->srcpad =
hgs
parents:
diff changeset
   436
      gst_pad_new_from_static_template (&alaw_enc_src_factory, "src");
hgs
parents:
diff changeset
   437
  gst_pad_set_setcaps_function (alawenc->srcpad,
hgs
parents:
diff changeset
   438
      GST_DEBUG_FUNCPTR (gst_alaw_enc_setcaps));
hgs
parents:
diff changeset
   439
  gst_pad_set_getcaps_function (alawenc->srcpad,
hgs
parents:
diff changeset
   440
      GST_DEBUG_FUNCPTR (gst_alaw_enc_getcaps));
hgs
parents:
diff changeset
   441
  gst_pad_use_fixed_caps (alawenc->srcpad);
hgs
parents:
diff changeset
   442
  gst_element_add_pad (GST_ELEMENT (alawenc), alawenc->srcpad);
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
  /* init rest */
hgs
parents:
diff changeset
   445
  alawenc->channels = 0;
hgs
parents:
diff changeset
   446
  alawenc->rate = 0;
hgs
parents:
diff changeset
   447
}
hgs
parents:
diff changeset
   448
hgs
parents:
diff changeset
   449
static GstFlowReturn
hgs
parents:
diff changeset
   450
gst_alaw_enc_chain (GstPad * pad, GstBuffer * buffer)
hgs
parents:
diff changeset
   451
{
hgs
parents:
diff changeset
   452
  GstALawEnc *alawenc;
hgs
parents:
diff changeset
   453
  gint16 *linear_data;
hgs
parents:
diff changeset
   454
  guint linear_size;
hgs
parents:
diff changeset
   455
  guint8 *alaw_data;
hgs
parents:
diff changeset
   456
  guint alaw_size;
hgs
parents:
diff changeset
   457
  GstBuffer *outbuf;
hgs
parents:
diff changeset
   458
  gint i;
hgs
parents:
diff changeset
   459
  GstFlowReturn ret;
hgs
parents:
diff changeset
   460
  GstClockTime timestamp, duration;
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
  alawenc = GST_ALAW_ENC (GST_PAD_PARENT (pad));
hgs
parents:
diff changeset
   463
hgs
parents:
diff changeset
   464
  if (G_UNLIKELY (alawenc->rate == 0 || alawenc->channels == 0))
hgs
parents:
diff changeset
   465
    goto not_negotiated;
hgs
parents:
diff changeset
   466
hgs
parents:
diff changeset
   467
  linear_data = (gint16 *) GST_BUFFER_DATA (buffer);
hgs
parents:
diff changeset
   468
  linear_size = GST_BUFFER_SIZE (buffer);
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
  alaw_size = linear_size / 2;
hgs
parents:
diff changeset
   471
hgs
parents:
diff changeset
   472
  timestamp = GST_BUFFER_TIMESTAMP (buffer);
hgs
parents:
diff changeset
   473
  duration = GST_BUFFER_DURATION (buffer);
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
  GST_LOG_OBJECT (alawenc, "buffer with ts=%" GST_TIME_FORMAT,
hgs
parents:
diff changeset
   476
      GST_TIME_ARGS (timestamp));
hgs
parents:
diff changeset
   477
hgs
parents:
diff changeset
   478
  ret =
hgs
parents:
diff changeset
   479
      gst_pad_alloc_buffer_and_set_caps (alawenc->srcpad,
hgs
parents:
diff changeset
   480
      GST_BUFFER_OFFSET_NONE, alaw_size, GST_PAD_CAPS (alawenc->srcpad),
hgs
parents:
diff changeset
   481
      &outbuf);
hgs
parents:
diff changeset
   482
  if (ret != GST_FLOW_OK)
hgs
parents:
diff changeset
   483
    goto done;
hgs
parents:
diff changeset
   484
hgs
parents:
diff changeset
   485
  if (duration == GST_CLOCK_TIME_NONE) {
hgs
parents:
diff changeset
   486
    duration = gst_util_uint64_scale_int (alaw_size,
hgs
parents:
diff changeset
   487
        GST_SECOND, alawenc->rate * alawenc->channels);
hgs
parents:
diff changeset
   488
  }
hgs
parents:
diff changeset
   489
hgs
parents:
diff changeset
   490
  if (GST_BUFFER_SIZE (outbuf) < alaw_size) {
hgs
parents:
diff changeset
   491
    /* pad-alloc can return a smaller buffer */
hgs
parents:
diff changeset
   492
    gst_buffer_unref (outbuf);
hgs
parents:
diff changeset
   493
    outbuf = gst_buffer_new_and_alloc (alaw_size);
hgs
parents:
diff changeset
   494
  }
hgs
parents:
diff changeset
   495
hgs
parents:
diff changeset
   496
  alaw_data = (guint8 *) GST_BUFFER_DATA (outbuf);
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
  /* copy discont flag */
hgs
parents:
diff changeset
   499
  if (GST_BUFFER_FLAG_IS_SET (buffer, GST_BUFFER_FLAG_DISCONT))
hgs
parents:
diff changeset
   500
    GST_BUFFER_FLAG_SET (outbuf, GST_BUFFER_FLAG_DISCONT);
hgs
parents:
diff changeset
   501
hgs
parents:
diff changeset
   502
  GST_BUFFER_TIMESTAMP (outbuf) = timestamp;
hgs
parents:
diff changeset
   503
  GST_BUFFER_DURATION (outbuf) = duration;
hgs
parents:
diff changeset
   504
hgs
parents:
diff changeset
   505
  gst_buffer_set_caps (outbuf, GST_PAD_CAPS (alawenc->srcpad));
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
  for (i = 0; i < alaw_size; i++) {
hgs
parents:
diff changeset
   508
    alaw_data[i] = s16_to_alaw (linear_data[i]);
hgs
parents:
diff changeset
   509
  }
hgs
parents:
diff changeset
   510
hgs
parents:
diff changeset
   511
  ret = gst_pad_push (alawenc->srcpad, outbuf);
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
done:
hgs
parents:
diff changeset
   514
hgs
parents:
diff changeset
   515
  gst_buffer_unref (buffer);
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
  return ret;
hgs
parents:
diff changeset
   518
hgs
parents:
diff changeset
   519
not_negotiated:
hgs
parents:
diff changeset
   520
  {
hgs
parents:
diff changeset
   521
    ret = GST_FLOW_NOT_NEGOTIATED;
hgs
parents:
diff changeset
   522
    goto done;
hgs
parents:
diff changeset
   523
  }
hgs
parents:
diff changeset
   524
}