Blame libcelt/header.c

Packit 664db3
/* (C) 2008 Jean-Marc Valin, CSIRO
Packit 664db3
*/
Packit 664db3
/*
Packit 664db3
   Redistribution and use in source and binary forms, with or without
Packit 664db3
   modification, are permitted provided that the following conditions
Packit 664db3
   are met:
Packit 664db3
   
Packit 664db3
   - Redistributions of source code must retain the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer.
Packit 664db3
   
Packit 664db3
   - Redistributions in binary form must reproduce the above copyright
Packit 664db3
   notice, this list of conditions and the following disclaimer in the
Packit 664db3
   documentation and/or other materials provided with the distribution.
Packit 664db3
   
Packit 664db3
   - Neither the name of the Xiph.org Foundation nor the names of its
Packit 664db3
   contributors may be used to endorse or promote products derived from
Packit 664db3
   this software without specific prior written permission.
Packit 664db3
   
Packit 664db3
   THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 664db3
   ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 664db3
   LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 664db3
   A PARTICULAR PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR
Packit 664db3
   CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
Packit 664db3
   EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
Packit 664db3
   PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
Packit 664db3
   PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
Packit 664db3
   LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
Packit 664db3
   NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
Packit 664db3
   SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 664db3
*/
Packit 664db3
Packit 664db3
#ifdef HAVE_CONFIG_H
Packit 664db3
#include "config.h"
Packit 664db3
#endif
Packit 664db3
Packit 664db3
#include "celt_header.h"
Packit 664db3
#include "os_support.h"
Packit 664db3
#include "modes.h"
Packit 664db3
Packit 664db3
/*typedef struct {
Packit 664db3
   char         codec_id[8];
Packit 664db3
   char         codec_version[20];
Packit 664db3
   celt_int32_t version_id;
Packit 664db3
   celt_int32_t header_size;
Packit 664db3
   celt_int32_t mode;
Packit 664db3
   celt_int32_t sample_rate;
Packit 664db3
   celt_int32_t nb_channels;
Packit 664db3
   celt_int32_t bytes_per_packet;
Packit 664db3
   celt_int32_t extra_headers;
Packit 664db3
} CELT051Header;*/
Packit 664db3
Packit 664db3
static  celt_uint32_t
Packit 664db3
_le_32 (celt_uint32_t i)
Packit 664db3
{
Packit 664db3
   celt_uint32_t ret=i;
Packit 664db3
#ifdef WORDS_BIGENDIAN
Packit 664db3
   ret =  (i>>24);
Packit 664db3
   ret += (i>>8) & 0x0000ff00;
Packit 664db3
   ret += (i<<8) & 0x00ff0000;
Packit 664db3
   ret += (i<<24);
Packit 664db3
#endif
Packit 664db3
   return ret;
Packit 664db3
}
Packit 664db3
Packit 664db3
void celt051_header_init(CELT051Header *header, const CELTMode *m)
Packit 664db3
{
Packit 664db3
   CELT_COPY(header->codec_id, "CELT    ", 8);
Packit 664db3
   CELT_COPY(header->codec_version, "experimental        ", 20);
Packit 664db3
Packit 664db3
   celt051_mode_info(m, CELT_GET_BITSTREAM_VERSION, &header->version_id);
Packit 664db3
   header->header_size = 56;
Packit 664db3
   header->sample_rate = m->Fs;
Packit 664db3
   header->nb_channels = m->nbChannels;
Packit 664db3
   header->frame_size = m->mdctSize;
Packit 664db3
   header->overlap = m->overlap;
Packit 664db3
   header->bytes_per_packet = -1;
Packit 664db3
   header->extra_headers = 0;
Packit 664db3
}
Packit 664db3
Packit 664db3
int celt051_header_to_packet(const CELT051Header *header, unsigned char *packet, celt_uint32_t size)
Packit 664db3
{
Packit 664db3
   celt_int32_t * h;
Packit 664db3
Packit 664db3
   if (size < 56) return CELT_BAD_ARG; /* FAIL */
Packit 664db3
Packit 664db3
   CELT_MEMSET(packet, 0, sizeof(*header));
Packit 664db3
   /* FIXME: Do it in an alignment-safe manner */
Packit 664db3
Packit 664db3
   /* Copy ident and version */
Packit 664db3
   CELT_COPY(packet, (unsigned char*)header, 28);
Packit 664db3
Packit 664db3
   /* Copy the int32 fields */
Packit 664db3
   h = (celt_int32_t*)(packet+28);
Packit 664db3
   *h++ = _le_32 (header->version_id);
Packit 664db3
   *h++ = _le_32 (header->header_size);
Packit 664db3
   *h++ = _le_32 (header->sample_rate);
Packit 664db3
   *h++ = _le_32 (header->nb_channels);
Packit 664db3
   *h++ = _le_32 (header->frame_size);
Packit 664db3
   *h++ = _le_32 (header->overlap);
Packit 664db3
   *h++ = _le_32 (header->bytes_per_packet);
Packit 664db3
   *h++ = _le_32 (header->extra_headers);
Packit 664db3
Packit 664db3
   return sizeof(*header);
Packit 664db3
}
Packit 664db3
Packit 664db3
int celt051_header_from_packet(const unsigned char *packet, celt_uint32_t size, CELT051Header *header)
Packit 664db3
{
Packit 664db3
   CELT_COPY((unsigned char*)header, packet, sizeof(*header));
Packit 664db3
   return sizeof(*header);
Packit 664db3
}
Packit 664db3