annotate src/libvorbis-1.3.3/lib/synthesis.c @ 127:7867fa7e1b6b

Current fftw source
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 18 Oct 2016 13:40:26 +0100
parents 98c1576536ae
children
rev   line source
cannam@86 1 /********************************************************************
cannam@86 2 * *
cannam@86 3 * THIS FILE IS PART OF THE OggVorbis SOFTWARE CODEC SOURCE CODE. *
cannam@86 4 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS *
cannam@86 5 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
cannam@86 6 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING. *
cannam@86 7 * *
cannam@86 8 * THE OggVorbis SOURCE CODE IS (C) COPYRIGHT 1994-2009 *
cannam@86 9 * by the Xiph.Org Foundation http://www.xiph.org/ *
cannam@86 10 * *
cannam@86 11 ********************************************************************
cannam@86 12
cannam@86 13 function: single-block PCM synthesis
cannam@86 14 last mod: $Id: synthesis.c 17474 2010-09-30 03:41:41Z gmaxwell $
cannam@86 15
cannam@86 16 ********************************************************************/
cannam@86 17
cannam@86 18 #include <stdio.h>
cannam@86 19 #include <ogg/ogg.h>
cannam@86 20 #include "vorbis/codec.h"
cannam@86 21 #include "codec_internal.h"
cannam@86 22 #include "registry.h"
cannam@86 23 #include "misc.h"
cannam@86 24 #include "os.h"
cannam@86 25
cannam@86 26 int vorbis_synthesis(vorbis_block *vb,ogg_packet *op){
cannam@86 27 vorbis_dsp_state *vd= vb ? vb->vd : 0;
cannam@86 28 private_state *b= vd ? vd->backend_state : 0;
cannam@86 29 vorbis_info *vi= vd ? vd->vi : 0;
cannam@86 30 codec_setup_info *ci= vi ? vi->codec_setup : 0;
cannam@86 31 oggpack_buffer *opb=vb ? &vb->opb : 0;
cannam@86 32 int type,mode,i;
cannam@86 33
cannam@86 34 if (!vd || !b || !vi || !ci || !opb) {
cannam@86 35 return OV_EBADPACKET;
cannam@86 36 }
cannam@86 37
cannam@86 38 /* first things first. Make sure decode is ready */
cannam@86 39 _vorbis_block_ripcord(vb);
cannam@86 40 oggpack_readinit(opb,op->packet,op->bytes);
cannam@86 41
cannam@86 42 /* Check the packet type */
cannam@86 43 if(oggpack_read(opb,1)!=0){
cannam@86 44 /* Oops. This is not an audio data packet */
cannam@86 45 return(OV_ENOTAUDIO);
cannam@86 46 }
cannam@86 47
cannam@86 48 /* read our mode and pre/post windowsize */
cannam@86 49 mode=oggpack_read(opb,b->modebits);
cannam@86 50 if(mode==-1){
cannam@86 51 return(OV_EBADPACKET);
cannam@86 52 }
cannam@86 53
cannam@86 54 vb->mode=mode;
cannam@86 55 if(!ci->mode_param[mode]){
cannam@86 56 return(OV_EBADPACKET);
cannam@86 57 }
cannam@86 58
cannam@86 59 vb->W=ci->mode_param[mode]->blockflag;
cannam@86 60 if(vb->W){
cannam@86 61
cannam@86 62 /* this doesn;t get mapped through mode selection as it's used
cannam@86 63 only for window selection */
cannam@86 64 vb->lW=oggpack_read(opb,1);
cannam@86 65 vb->nW=oggpack_read(opb,1);
cannam@86 66 if(vb->nW==-1){
cannam@86 67 return(OV_EBADPACKET);
cannam@86 68 }
cannam@86 69 }else{
cannam@86 70 vb->lW=0;
cannam@86 71 vb->nW=0;
cannam@86 72 }
cannam@86 73
cannam@86 74 /* more setup */
cannam@86 75 vb->granulepos=op->granulepos;
cannam@86 76 vb->sequence=op->packetno;
cannam@86 77 vb->eofflag=op->e_o_s;
cannam@86 78
cannam@86 79 /* alloc pcm passback storage */
cannam@86 80 vb->pcmend=ci->blocksizes[vb->W];
cannam@86 81 vb->pcm=_vorbis_block_alloc(vb,sizeof(*vb->pcm)*vi->channels);
cannam@86 82 for(i=0;i<vi->channels;i++)
cannam@86 83 vb->pcm[i]=_vorbis_block_alloc(vb,vb->pcmend*sizeof(*vb->pcm[i]));
cannam@86 84
cannam@86 85 /* unpack_header enforces range checking */
cannam@86 86 type=ci->map_type[ci->mode_param[mode]->mapping];
cannam@86 87
cannam@86 88 return(_mapping_P[type]->inverse(vb,ci->map_param[ci->mode_param[mode]->
cannam@86 89 mapping]));
cannam@86 90 }
cannam@86 91
cannam@86 92 /* used to track pcm position without actually performing decode.
cannam@86 93 Useful for sequential 'fast forward' */
cannam@86 94 int vorbis_synthesis_trackonly(vorbis_block *vb,ogg_packet *op){
cannam@86 95 vorbis_dsp_state *vd=vb->vd;
cannam@86 96 private_state *b=vd->backend_state;
cannam@86 97 vorbis_info *vi=vd->vi;
cannam@86 98 codec_setup_info *ci=vi->codec_setup;
cannam@86 99 oggpack_buffer *opb=&vb->opb;
cannam@86 100 int mode;
cannam@86 101
cannam@86 102 /* first things first. Make sure decode is ready */
cannam@86 103 _vorbis_block_ripcord(vb);
cannam@86 104 oggpack_readinit(opb,op->packet,op->bytes);
cannam@86 105
cannam@86 106 /* Check the packet type */
cannam@86 107 if(oggpack_read(opb,1)!=0){
cannam@86 108 /* Oops. This is not an audio data packet */
cannam@86 109 return(OV_ENOTAUDIO);
cannam@86 110 }
cannam@86 111
cannam@86 112 /* read our mode and pre/post windowsize */
cannam@86 113 mode=oggpack_read(opb,b->modebits);
cannam@86 114 if(mode==-1)return(OV_EBADPACKET);
cannam@86 115
cannam@86 116 vb->mode=mode;
cannam@86 117 if(!ci->mode_param[mode]){
cannam@86 118 return(OV_EBADPACKET);
cannam@86 119 }
cannam@86 120
cannam@86 121 vb->W=ci->mode_param[mode]->blockflag;
cannam@86 122 if(vb->W){
cannam@86 123 vb->lW=oggpack_read(opb,1);
cannam@86 124 vb->nW=oggpack_read(opb,1);
cannam@86 125 if(vb->nW==-1) return(OV_EBADPACKET);
cannam@86 126 }else{
cannam@86 127 vb->lW=0;
cannam@86 128 vb->nW=0;
cannam@86 129 }
cannam@86 130
cannam@86 131 /* more setup */
cannam@86 132 vb->granulepos=op->granulepos;
cannam@86 133 vb->sequence=op->packetno;
cannam@86 134 vb->eofflag=op->e_o_s;
cannam@86 135
cannam@86 136 /* no pcm */
cannam@86 137 vb->pcmend=0;
cannam@86 138 vb->pcm=NULL;
cannam@86 139
cannam@86 140 return(0);
cannam@86 141 }
cannam@86 142
cannam@86 143 long vorbis_packet_blocksize(vorbis_info *vi,ogg_packet *op){
cannam@86 144 codec_setup_info *ci=vi->codec_setup;
cannam@86 145 oggpack_buffer opb;
cannam@86 146 int mode;
cannam@86 147
cannam@86 148 oggpack_readinit(&opb,op->packet,op->bytes);
cannam@86 149
cannam@86 150 /* Check the packet type */
cannam@86 151 if(oggpack_read(&opb,1)!=0){
cannam@86 152 /* Oops. This is not an audio data packet */
cannam@86 153 return(OV_ENOTAUDIO);
cannam@86 154 }
cannam@86 155
cannam@86 156 {
cannam@86 157 int modebits=0;
cannam@86 158 int v=ci->modes;
cannam@86 159 while(v>1){
cannam@86 160 modebits++;
cannam@86 161 v>>=1;
cannam@86 162 }
cannam@86 163
cannam@86 164 /* read our mode and pre/post windowsize */
cannam@86 165 mode=oggpack_read(&opb,modebits);
cannam@86 166 }
cannam@86 167 if(mode==-1)return(OV_EBADPACKET);
cannam@86 168 return(ci->blocksizes[ci->mode_param[mode]->blockflag]);
cannam@86 169 }
cannam@86 170
cannam@86 171 int vorbis_synthesis_halfrate(vorbis_info *vi,int flag){
cannam@86 172 /* set / clear half-sample-rate mode */
cannam@86 173 codec_setup_info *ci=vi->codec_setup;
cannam@86 174
cannam@86 175 /* right now, our MDCT can't handle < 64 sample windows. */
cannam@86 176 if(ci->blocksizes[0]<=64 && flag)return -1;
cannam@86 177 ci->halfrate_flag=(flag?1:0);
cannam@86 178 return 0;
cannam@86 179 }
cannam@86 180
cannam@86 181 int vorbis_synthesis_halfrate_p(vorbis_info *vi){
cannam@86 182 codec_setup_info *ci=vi->codec_setup;
cannam@86 183 return ci->halfrate_flag;
cannam@86 184 }