[BACK]Return to aparams.h CVS log [TXT][DIR] Up to [local] / src / usr.bin / aucat

Annotation of src/usr.bin/aucat/aparams.h, Revision 1.12

1.12    ! ratchov     1: /*     $OpenBSD: aparams.h,v 1.11 2010/11/05 16:42:17 ratchov Exp $    */
1.1       ratchov     2: /*
                      3:  * Copyright (c) 2008 Alexandre Ratchov <alex@caoua.org>
                      4:  *
                      5:  * Permission to use, copy, modify, and distribute this software for any
                      6:  * purpose with or without fee is hereby granted, provided that the above
                      7:  * copyright notice and this permission notice appear in all copies.
                      8:  *
                      9:  * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
                     10:  * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
                     11:  * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
                     12:  * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
                     13:  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
                     14:  * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
                     15:  * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
                     16:  */
                     17: #ifndef APARAMS_H
                     18: #define APARAMS_H
                     19:
                     20: #include <sys/param.h>
                     21:
1.2       ratchov    22: #define NCHAN_MAX      16              /* max channel in a stream */
                     23: #define RATE_MIN       4000            /* min sample rate */
                     24: #define RATE_MAX       192000          /* max sample rate */
                     25: #define BITS_MIN       1               /* min bits per sample */
1.1       ratchov    26: #define BITS_MAX       32              /* max bits per sample */
                     27:
1.2       ratchov    28: /*
1.6       ratchov    29:  * Maximum size of the encording string (the longest possible
                     30:  * encoding is ``s24le3msb'').
1.2       ratchov    31:  */
                     32: #define ENCMAX 10
                     33:
1.1       ratchov    34: /*
1.6       ratchov    35:  * Default bytes per sample for the given bits per sample.
1.2       ratchov    36:  */
                     37: #define APARAMS_BPS(bits) (((bits) <= 8) ? 1 : (((bits) <= 16) ? 2 : 4))
                     38:
                     39: /*
1.6       ratchov    40:  * Encoding specification.
1.1       ratchov    41:  */
                     42: struct aparams {
1.12    ! ratchov    43:        unsigned int bps;               /* bytes per sample */
        !            44:        unsigned int bits;              /* actually used bits */
        !            45:        unsigned int le;                /* 1 if little endian, 0 if big endian */
        !            46:        unsigned int sig;               /* 1 if signed, 0 if unsigned */
        !            47:        unsigned int msb;               /* 1 if msb justified, 0 if lsb justified */
        !            48:        unsigned int cmin, cmax;        /* provided/consumed channels */
        !            49:        unsigned int rate;              /* frames per second */
1.1       ratchov    50: };
                     51:
                     52: /*
                     53:  * Samples are numbers in the interval [-1, 1[, note that 1, the upper
1.10      ratchov    54:  * boundary is excluded. We represent them as signed fixed point numbers
                     55:  * of ADATA_BITS. We also assume that 2^(ADATA_BITS - 1) fits in a int.
1.1       ratchov    56:  */
1.11      ratchov    57: #ifndef ADATA_BITS
1.10      ratchov    58: #define ADATA_BITS                     16
1.11      ratchov    59: #endif
1.10      ratchov    60: #define ADATA_LE                       (BYTE_ORDER == LITTLE_ENDIAN)
                     61: #define ADATA_UNIT                     (1 << (ADATA_BITS - 1))
                     62:
1.11      ratchov    63: #if ADATA_BITS == 16
                     64:
1.9       ratchov    65: typedef short adata_t;
1.10      ratchov    66:
1.9       ratchov    67: #define ADATA_MUL(x,y)         (((int)(x) * (int)(y)) >> (ADATA_BITS - 1))
                     68: #define ADATA_MULDIV(x,y,z)    ((int)(x) * (int)(y) / (int)(z))
1.11      ratchov    69:
                     70: #elif ADATA_BITS == 24
                     71:
                     72: typedef int adata_t;
                     73:
                     74: #if defined(__i386__) && defined(__GNUC__)
                     75:
                     76: static inline int
                     77: fp24_mul(int x, int a)
                     78: {
                     79:        int res;
                     80:
                     81:        asm volatile (
                     82:                "imull  %2\n\t"
                     83:                "shrdl $23, %%edx, %%eax\n\t"
                     84:                : "=a" (res)
                     85:                : "a" (x), "r" (a)
                     86:                : "%edx"
                     87:                );
                     88:        return res;
                     89: }
                     90:
                     91: static inline int
                     92: fp24_muldiv(int x, int a, int b)
                     93: {
                     94:        int res;
                     95:
                     96:        asm volatile (
                     97:                "imull %2\n\t"
                     98:                "idivl %3\n\t"
                     99:                : "=a" (res)
                    100:                : "a" (x), "d" (a), "r" (b)
                    101:                );
                    102:        return res;
                    103: }
                    104:
                    105: #define ADATA_MUL(x,y)         fp24_mul(x, y)
                    106: #define ADATA_MULDIV(x,y,z)    fp24_muldiv(x, y, z);
                    107:
                    108: #elif defined(__amd64__) || defined(__sparc64__)
                    109:
                    110: #define ADATA_MUL(x,y)         \
                    111:        ((int)(((long long)(x) * (long long)(y)) >> (ADATA_BITS - 1)))
                    112: #define ADATA_MULDIV(x,y,z)    \
                    113:        ((int)((long long)(x) * (long long)(y) / (long long)(z)))
                    114:
                    115: #else
                    116: #error "no 24-bit code for this architecture"
                    117: #endif
                    118:
                    119: #else
                    120: #error "only 16-bit and 24-bit precisions are supported"
                    121: #endif
1.4       ratchov   122:
                    123: #define MIDI_MAXCTL            127
1.9       ratchov   124: #define MIDI_TO_ADATA(m)       (aparams_ctltovol[m] << (ADATA_BITS - 16))
1.4       ratchov   125:
                    126: extern int aparams_ctltovol[128];
1.7       ratchov   127: extern struct aparams aparams_none;
1.1       ratchov   128:
1.12    ! ratchov   129: void aparams_init(struct aparams *, unsigned int, unsigned int, unsigned int);
1.8       ratchov   130: void aparams_dbg(struct aparams *);
1.3       ratchov   131: int aparams_eqrate(struct aparams *, struct aparams *);
                    132: int aparams_eqenc(struct aparams *, struct aparams *);
1.1       ratchov   133: int aparams_eq(struct aparams *, struct aparams *);
1.3       ratchov   134: int aparams_subset(struct aparams *, struct aparams *);
1.5       ratchov   135: void aparams_grow(struct aparams *, struct aparams *);
1.12    ! ratchov   136: unsigned int aparams_bpf(struct aparams *);
1.2       ratchov   137: int aparams_strtoenc(struct aparams *, char *);
                    138: int aparams_enctostr(struct aparams *, char *);
                    139: void aparams_copyenc(struct aparams *, struct aparams *);
1.1       ratchov   140:
                    141: #endif /* !defined(APARAMS_H) */