Home | History | Annotate | Download | only in audio_utils
      1 /*
      2  * Copyright (C) 2011 The Android Open Source Project
      3  *
      4  * Licensed under the Apache License, Version 2.0 (the "License");
      5  * you may not use this file except in compliance with the License.
      6  * You may obtain a copy of the License at
      7  *
      8  *      http://www.apache.org/licenses/LICENSE-2.0
      9  *
     10  * Unless required by applicable law or agreed to in writing, software
     11  * distributed under the License is distributed on an "AS IS" BASIS,
     12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     13  * See the License for the specific language governing permissions and
     14  * limitations under the License.
     15  */
     16 
     17 #include <audio_utils/primitives.h>
     18 
     19 void ditherAndClamp(int32_t* out, const int32_t *sums, size_t c)
     20 {
     21     size_t i;
     22     for (i=0 ; i<c ; i++) {
     23         int32_t l = *sums++;
     24         int32_t r = *sums++;
     25         int32_t nl = l >> 12;
     26         int32_t nr = r >> 12;
     27         l = clamp16(nl);
     28         r = clamp16(nr);
     29         *out++ = (r<<16) | (l & 0xFFFF);
     30     }
     31 }
     32 
     33 void memcpy_to_i16_from_u8(int16_t *dst, const uint8_t *src, size_t count)
     34 {
     35     dst += count;
     36     src += count;
     37     while (count--) {
     38         *--dst = (int16_t)(*--src - 0x80) << 8;
     39     }
     40 }
     41 
     42 void memcpy_to_u8_from_i16(uint8_t *dst, const int16_t *src, size_t count)
     43 {
     44     while (count--) {
     45         *dst++ = (*src++ >> 8) + 0x80;
     46     }
     47 }
     48 
     49 void memcpy_to_i16_from_i32(int16_t *dst, const int32_t *src, size_t count)
     50 {
     51     while (count--) {
     52         *dst++ = *src++ >> 16;
     53     }
     54 }
     55 
     56 void memcpy_to_i16_from_float(int16_t *dst, const float *src, size_t count)
     57 {
     58     while (count--) {
     59         float f = *src++;
     60         int16_t i;
     61         if (f > 1.0) {
     62             i = 32767;
     63         } else if (f < -1.0) {
     64             i = -32768;
     65         } else {
     66             // does not specifically handle NaN
     67             i = f * 32767.0;
     68         }
     69         *dst++ = i;
     70     }
     71 }
     72 
     73 void downmix_to_mono_i16_from_stereo_i16(int16_t *dst, const int16_t *src, size_t count)
     74 {
     75     while (count--) {
     76         *dst++ = (int16_t)(((int32_t)src[0] + (int32_t)src[1]) >> 1);
     77         src += 2;
     78     }
     79 }
     80 
     81 void upmix_to_stereo_i16_from_mono_i16(int16_t *dst, const int16_t *src, size_t count)
     82 {
     83     while (count--) {
     84         int32_t temp = *src++;
     85         dst[0] = temp;
     86         dst[1] = temp;
     87         dst += 2;
     88     }
     89 }
     90