1*df25739fSMilanka Ringwald /****************************************************************************** 2*df25739fSMilanka Ringwald * 3*df25739fSMilanka Ringwald * Copyright (C) 2014 The Android Open Source Project 4*df25739fSMilanka Ringwald * Copyright 2003 - 2004 Open Interface North America, Inc. All rights reserved. 5*df25739fSMilanka Ringwald * 6*df25739fSMilanka Ringwald * Licensed under the Apache License, Version 2.0 (the "License"); 7*df25739fSMilanka Ringwald * you may not use this file except in compliance with the License. 8*df25739fSMilanka Ringwald * You may obtain a copy of the License at: 9*df25739fSMilanka Ringwald * 10*df25739fSMilanka Ringwald * http://www.apache.org/licenses/LICENSE-2.0 11*df25739fSMilanka Ringwald * 12*df25739fSMilanka Ringwald * Unless required by applicable law or agreed to in writing, software 13*df25739fSMilanka Ringwald * distributed under the License is distributed on an "AS IS" BASIS, 14*df25739fSMilanka Ringwald * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 15*df25739fSMilanka Ringwald * See the License for the specific language governing permissions and 16*df25739fSMilanka Ringwald * limitations under the License. 17*df25739fSMilanka Ringwald * 18*df25739fSMilanka Ringwald ******************************************************************************/ 19*df25739fSMilanka Ringwald 20*df25739fSMilanka Ringwald #include <stdlib.h> 21*df25739fSMilanka Ringwald #include <oi_codec_sbc_private.h> 22*df25739fSMilanka Ringwald 23*df25739fSMilanka Ringwald /********************************************************************************** 24*df25739fSMilanka Ringwald $Revision: #1 $ 25*df25739fSMilanka Ringwald ***********************************************************************************/ 26*df25739fSMilanka Ringwald 27*df25739fSMilanka Ringwald PRIVATE OI_STATUS OI_CODEC_SBC_Alloc(OI_CODEC_SBC_COMMON_CONTEXT *common, 28*df25739fSMilanka Ringwald OI_UINT32 *codecDataAligned, 29*df25739fSMilanka Ringwald OI_UINT32 codecDataBytes, 30*df25739fSMilanka Ringwald OI_UINT8 maxChannels, 31*df25739fSMilanka Ringwald OI_UINT8 pcmStride) 32*df25739fSMilanka Ringwald { 33*df25739fSMilanka Ringwald int i; 34*df25739fSMilanka Ringwald size_t filterBufferCount; 35*df25739fSMilanka Ringwald size_t subdataSize; 36*df25739fSMilanka Ringwald OI_BYTE *codecData = (OI_BYTE*)codecDataAligned; 37*df25739fSMilanka Ringwald 38*df25739fSMilanka Ringwald if (maxChannels < 1 || maxChannels > 2) { 39*df25739fSMilanka Ringwald return OI_STATUS_INVALID_PARAMETERS; 40*df25739fSMilanka Ringwald } 41*df25739fSMilanka Ringwald 42*df25739fSMilanka Ringwald if (pcmStride < 1 || pcmStride > maxChannels) { 43*df25739fSMilanka Ringwald return OI_STATUS_INVALID_PARAMETERS; 44*df25739fSMilanka Ringwald } 45*df25739fSMilanka Ringwald 46*df25739fSMilanka Ringwald common->maxChannels = maxChannels; 47*df25739fSMilanka Ringwald common->pcmStride = pcmStride; 48*df25739fSMilanka Ringwald 49*df25739fSMilanka Ringwald /* Compute sizes needed for the memory regions, and bail if we don't have 50*df25739fSMilanka Ringwald * enough memory for them. */ 51*df25739fSMilanka Ringwald subdataSize = maxChannels * sizeof(common->subdata[0]) * SBC_MAX_BANDS * SBC_MAX_BLOCKS; 52*df25739fSMilanka Ringwald if (subdataSize > codecDataBytes) { 53*df25739fSMilanka Ringwald return OI_STATUS_OUT_OF_MEMORY; 54*df25739fSMilanka Ringwald } 55*df25739fSMilanka Ringwald 56*df25739fSMilanka Ringwald filterBufferCount = (codecDataBytes - subdataSize) / (sizeof(common->filterBuffer[0][0]) * SBC_MAX_BANDS * maxChannels); 57*df25739fSMilanka Ringwald if (filterBufferCount < SBC_CODEC_MIN_FILTER_BUFFERS) { 58*df25739fSMilanka Ringwald return OI_STATUS_OUT_OF_MEMORY; 59*df25739fSMilanka Ringwald } 60*df25739fSMilanka Ringwald common->filterBufferLen = filterBufferCount * SBC_MAX_BANDS; 61*df25739fSMilanka Ringwald 62*df25739fSMilanka Ringwald /* Allocate memory for the subband data */ 63*df25739fSMilanka Ringwald common->subdata = (OI_INT32*)codecData; 64*df25739fSMilanka Ringwald codecData += subdataSize; 65*df25739fSMilanka Ringwald OI_ASSERT(codecDataBytes >= subdataSize); 66*df25739fSMilanka Ringwald codecDataBytes -= subdataSize; 67*df25739fSMilanka Ringwald 68*df25739fSMilanka Ringwald /* Allocate memory for the synthesis buffers */ 69*df25739fSMilanka Ringwald for (i = 0; i < maxChannels; ++i) { 70*df25739fSMilanka Ringwald size_t allocSize = common->filterBufferLen * sizeof(common->filterBuffer[0][0]); 71*df25739fSMilanka Ringwald common->filterBuffer[i] = (SBC_BUFFER_T*)codecData; 72*df25739fSMilanka Ringwald OI_ASSERT(codecDataBytes >= allocSize); 73*df25739fSMilanka Ringwald codecData += allocSize; 74*df25739fSMilanka Ringwald codecDataBytes -= allocSize; 75*df25739fSMilanka Ringwald } 76*df25739fSMilanka Ringwald 77*df25739fSMilanka Ringwald return OI_OK; 78*df25739fSMilanka Ringwald } 79