Blame src/pcm/pcm_dmix_generic.c

Packit Service db8eaa
#if 0
Packit Service db8eaa
//#if defined(__i386__) || defined(__x86_64__)
Packit Service db8eaa
#define LOCK_PREFIX "lock ; "
Packit Service db8eaa
#define ARCH_ADD(p,a)					\
Packit Service db8eaa
	__asm__ __volatile__(LOCK_PREFIX "addl %1,%0"	\
Packit Service db8eaa
			     :"=m" (*p)			\
Packit Service db8eaa
			     :"ir" (a), "m" (*p))
Packit Service db8eaa
struct __xchg_dummy { unsigned long a[100]; };
Packit Service db8eaa
#define __xg(x) ((struct __xchg_dummy *)(x))
Packit Service db8eaa
static inline unsigned long __cmpxchg(volatile void *ptr, unsigned long old,
Packit Service db8eaa
				      unsigned long new, int size)
Packit Service db8eaa
{
Packit Service db8eaa
	unsigned long prev;
Packit Service db8eaa
	switch (size) {
Packit Service db8eaa
	case 1:
Packit Service db8eaa
		__asm__ __volatile__(LOCK_PREFIX "cmpxchgb %b1,%2"
Packit Service db8eaa
				     : "=a"(prev)
Packit Service db8eaa
				     : "q"(new), "m"(*__xg(ptr)), "0"(old)
Packit Service db8eaa
				     : "memory");
Packit Service db8eaa
		return prev;
Packit Service db8eaa
	case 2:
Packit Service db8eaa
		__asm__ __volatile__(LOCK_PREFIX "cmpxchgw %w1,%2"
Packit Service db8eaa
				     : "=a"(prev)
Packit Service db8eaa
				     : "q"(new), "m"(*__xg(ptr)), "0"(old)
Packit Service db8eaa
				     : "memory");
Packit Service db8eaa
		return prev;
Packit Service db8eaa
	case 4:
Packit Service db8eaa
		__asm__ __volatile__(LOCK_PREFIX "cmpxchgl %1,%2"
Packit Service db8eaa
				     : "=a"(prev)
Packit Service db8eaa
				     : "q"(new), "m"(*__xg(ptr)), "0"(old)
Packit Service db8eaa
				     : "memory");
Packit Service db8eaa
		return prev;
Packit Service db8eaa
	}
Packit Service db8eaa
	return old;
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
#define ARCH_CMPXCHG(ptr,o,n)\
Packit Service db8eaa
	((__typeof__(*(ptr)))__cmpxchg((ptr),(unsigned long)(o),\
Packit Service db8eaa
					(unsigned long)(n),sizeof(*(ptr))))
Packit Service db8eaa
#define IS_CONCURRENT	1	/* check race */
Packit Service db8eaa
#endif
Packit Service db8eaa
Packit Service db8eaa
#ifndef ARCH_ADD
Packit Service db8eaa
#define ARCH_ADD(p,a) (*(p) += (a))
Packit Service db8eaa
#define ARCH_CMPXCHG(p,a,b) (*(p)) /* fake */
Packit Service db8eaa
#define IS_CONCURRENT	0	/* no race check */
Packit Service db8eaa
#endif
Packit Service db8eaa
Packit Service db8eaa
#if IS_CONCURRENT
Packit Service db8eaa
static void mix_areas_16(unsigned int size,
Packit Service db8eaa
			 volatile signed short *dst, signed short *src,
Packit Service db8eaa
			 volatile signed int *sum, size_t dst_step,
Packit Service db8eaa
			 size_t src_step, size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample, old_sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src;
Packit Service db8eaa
		old_sample = *sum;
Packit Service db8eaa
		if (ARCH_CMPXCHG(dst, 0, 1) == 0)
Packit Service db8eaa
			sample -= old_sample;
Packit Service db8eaa
		ARCH_ADD(sum, sample);
Packit Service db8eaa
		do {
Packit Service db8eaa
			old_sample = *sum;
Packit Service db8eaa
			if (old_sample > 0x7fff)
Packit Service db8eaa
				sample = 0x7fff;
Packit Service db8eaa
			else if (old_sample < -0x8000)
Packit Service db8eaa
				sample = -0x8000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample = old_sample;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		} while (IS_CONCURRENT && *sum != old_sample);
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed short *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed short *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *)   ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void mix_areas_32(unsigned int size,
Packit Service db8eaa
			 volatile signed int *dst, signed int *src,
Packit Service db8eaa
			 volatile signed int *sum, size_t dst_step,
Packit Service db8eaa
			 size_t src_step, size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample, old_sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src >> 8;
Packit Service db8eaa
		old_sample = *sum;
Packit Service db8eaa
		if (ARCH_CMPXCHG(dst, 0, 1) == 0)
Packit Service db8eaa
			sample -= old_sample;
Packit Service db8eaa
		ARCH_ADD(sum, sample);
Packit Service db8eaa
		do {
Packit Service db8eaa
			old_sample = *sum;
Packit Service db8eaa
			if (old_sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffffff;
Packit Service db8eaa
			else if (old_sample < -0x800000)
Packit Service db8eaa
				sample = -0x80000000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample = old_sample * 256;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		} while (IS_CONCURRENT && *sum != old_sample);
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed int *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed int *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void mix_select_callbacks(snd_pcm_direct_t *dmix)
Packit Service db8eaa
{
Packit Service db8eaa
	dmix->u.dmix.mix_areas_16 = mix_areas_16;
Packit Service db8eaa
	dmix->u.dmix.mix_areas_32 = mix_areas_32;
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
#else
Packit Service db8eaa
Packit Service db8eaa
/* non-concurrent version, supporting both endians */
Packit Service db8eaa
#define generic_dmix_supported_format \
Packit Service db8eaa
	((1ULL << SND_PCM_FORMAT_S16_LE) | (1ULL << SND_PCM_FORMAT_S32_LE) |\
Packit Service db8eaa
	 (1ULL << SND_PCM_FORMAT_S16_BE) | (1ULL << SND_PCM_FORMAT_S32_BE) |\
Packit Service db8eaa
	 (1ULL << SND_PCM_FORMAT_S24_LE) | (1ULL << SND_PCM_FORMAT_S24_3LE) | \
Packit Service db8eaa
	 (1ULL << SND_PCM_FORMAT_U8))
Packit Service db8eaa
Packit Service db8eaa
#include "bswap.h"
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_areas_16_native(unsigned int size,
Packit Service db8eaa
					volatile signed short *dst,
Packit Service db8eaa
					signed short *src,
Packit Service db8eaa
					volatile signed int *sum,
Packit Service db8eaa
					size_t dst_step,
Packit Service db8eaa
					size_t src_step,
Packit Service db8eaa
					size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			*dst = *src;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7fff)
Packit Service db8eaa
				sample = 0x7fff;
Packit Service db8eaa
			else if (sample < -0x8000)
Packit Service db8eaa
				sample = -0x8000;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed short *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed short *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *)   ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_16_native(unsigned int size,
Packit Service db8eaa
					  volatile signed short *dst,
Packit Service db8eaa
					  signed short *src,
Packit Service db8eaa
					  volatile signed int *sum,
Packit Service db8eaa
					  size_t dst_step,
Packit Service db8eaa
					  size_t src_step,
Packit Service db8eaa
					  size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = -sample;
Packit Service db8eaa
			*dst = -sample;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7fff)
Packit Service db8eaa
				sample = 0x7fff;
Packit Service db8eaa
			else if (sample < -0x8000)
Packit Service db8eaa
				sample = -0x8000;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed short *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed short *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *)   ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_areas_32_native(unsigned int size,
Packit Service db8eaa
					volatile signed int *dst,
Packit Service db8eaa
					signed int *src,
Packit Service db8eaa
					volatile signed int *sum,
Packit Service db8eaa
					size_t dst_step,
Packit Service db8eaa
					size_t src_step,
Packit Service db8eaa
					size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src >> 8;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			*dst = *src;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x80000000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample *= 256;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed int *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed int *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_32_native(unsigned int size,
Packit Service db8eaa
					  volatile signed int *dst,
Packit Service db8eaa
					  signed int *src,
Packit Service db8eaa
					  volatile signed int *sum,
Packit Service db8eaa
					  size_t dst_step,
Packit Service db8eaa
					  size_t src_step,
Packit Service db8eaa
					  size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = *src >> 8;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = -sample;
Packit Service db8eaa
			*dst = -*src;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x80000000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample *= 256;
Packit Service db8eaa
			*dst = sample;
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed int *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed int *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_areas_16_swap(unsigned int size,
Packit Service db8eaa
				      volatile signed short *dst,
Packit Service db8eaa
				      signed short *src,
Packit Service db8eaa
				      volatile signed int *sum,
Packit Service db8eaa
				      size_t dst_step,
Packit Service db8eaa
				      size_t src_step,
Packit Service db8eaa
				      size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = (signed short) bswap_16(*src);
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			*dst = *src;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7fff)
Packit Service db8eaa
				sample = 0x7fff;
Packit Service db8eaa
			else if (sample < -0x8000)
Packit Service db8eaa
				sample = -0x8000;
Packit Service db8eaa
			*dst = (signed short) bswap_16((signed short) sample);
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed short *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed short *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *)   ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_16_swap(unsigned int size,
Packit Service db8eaa
				        volatile signed short *dst,
Packit Service db8eaa
				        signed short *src,
Packit Service db8eaa
				        volatile signed int *sum,
Packit Service db8eaa
				        size_t dst_step,
Packit Service db8eaa
				        size_t src_step,
Packit Service db8eaa
				        size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = (signed short) bswap_16(*src);
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = -sample;
Packit Service db8eaa
			*dst = (signed short) bswap_16((signed short) -sample);
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7fff)
Packit Service db8eaa
				sample = 0x7fff;
Packit Service db8eaa
			else if (sample < -0x8000)
Packit Service db8eaa
				sample = -0x8000;
Packit Service db8eaa
			*dst = (signed short) bswap_16((signed short) sample);
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed short *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed short *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *)   ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_areas_32_swap(unsigned int size,
Packit Service db8eaa
				      volatile signed int *dst,
Packit Service db8eaa
				      signed int *src,
Packit Service db8eaa
				      volatile signed int *sum,
Packit Service db8eaa
				      size_t dst_step,
Packit Service db8eaa
				      size_t src_step,
Packit Service db8eaa
				      size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = bswap_32(*src) >> 8;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			*dst = *src;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x80000000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample *= 256;
Packit Service db8eaa
			*dst = bswap_32(sample);
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed int *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed int *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_32_swap(unsigned int size,
Packit Service db8eaa
				        volatile signed int *dst,
Packit Service db8eaa
				        signed int *src,
Packit Service db8eaa
				        volatile signed int *sum,
Packit Service db8eaa
				        size_t dst_step,
Packit Service db8eaa
				        size_t src_step,
Packit Service db8eaa
				        size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = bswap_32(*src) >> 8;
Packit Service db8eaa
		if (! *dst) {
Packit Service db8eaa
			*sum = -sample;
Packit Service db8eaa
			*dst = bswap_32(-sample);
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x80000000;
Packit Service db8eaa
			else
Packit Service db8eaa
				sample *= 256;
Packit Service db8eaa
			*dst = bswap_32(sample);
Packit Service db8eaa
		}
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		src = (signed int *) ((char *)src + src_step);
Packit Service db8eaa
		dst = (signed int *) ((char *)dst + dst_step);
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
/* always little endian */
Packit Service db8eaa
static void generic_mix_areas_24(unsigned int size,
Packit Service db8eaa
				 volatile unsigned char *dst,
Packit Service db8eaa
				 unsigned char *src,
Packit Service db8eaa
				 volatile signed int *sum,
Packit Service db8eaa
				 size_t dst_step,
Packit Service db8eaa
				 size_t src_step,
Packit Service db8eaa
				 size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = src[0] | (src[1] << 8) | (((signed char *)src)[2] << 16);
Packit Service db8eaa
		if (!(dst[0] | dst[1] | dst[2])) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x800000;
Packit Service db8eaa
		}
Packit Service db8eaa
		dst[0] = sample;
Packit Service db8eaa
		dst[1] = sample >> 8;
Packit Service db8eaa
		dst[2] = sample >> 16;
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		dst += dst_step;
Packit Service db8eaa
		src += src_step;
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_24(unsigned int size,
Packit Service db8eaa
				   volatile unsigned char *dst,
Packit Service db8eaa
				   unsigned char *src,
Packit Service db8eaa
				   volatile signed int *sum,
Packit Service db8eaa
				   size_t dst_step,
Packit Service db8eaa
				   size_t src_step,
Packit Service db8eaa
				   size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	register signed int sample;
Packit Service db8eaa
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		sample = src[0] | (src[1] << 8) | (((signed char *)src)[2] << 16);
Packit Service db8eaa
		if (!(dst[0] | dst[1] | dst[2])) {
Packit Service db8eaa
			sample = -sample;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7fffff)
Packit Service db8eaa
				sample = 0x7fffff;
Packit Service db8eaa
			else if (sample < -0x800000)
Packit Service db8eaa
				sample = -0x800000;
Packit Service db8eaa
		}
Packit Service db8eaa
		dst[0] = sample;
Packit Service db8eaa
		dst[1] = sample >> 8;
Packit Service db8eaa
		dst[2] = sample >> 16;
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		dst += dst_step;
Packit Service db8eaa
		src += src_step;
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_areas_u8(unsigned int size,
Packit Service db8eaa
				 volatile unsigned char *dst,
Packit Service db8eaa
				 unsigned char *src,
Packit Service db8eaa
				 volatile signed int *sum,
Packit Service db8eaa
				 size_t dst_step,
Packit Service db8eaa
				 size_t src_step,
Packit Service db8eaa
				 size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		register int sample = *src - 0x80;
Packit Service db8eaa
		if (*dst == 0x80) {
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			sample += *sum;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
			if (sample > 0x7f)
Packit Service db8eaa
				sample = 0x7f;
Packit Service db8eaa
			else if (sample < -0x80)
Packit Service db8eaa
				sample = -0x80;
Packit Service db8eaa
		}
Packit Service db8eaa
		*dst = sample + 0x80;
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		dst += dst_step;
Packit Service db8eaa
		src += src_step;
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
static void generic_remix_areas_u8(unsigned int size,
Packit Service db8eaa
				   volatile unsigned char *dst,
Packit Service db8eaa
				   unsigned char *src,
Packit Service db8eaa
				   volatile signed int *sum,
Packit Service db8eaa
				   size_t dst_step,
Packit Service db8eaa
				   size_t src_step,
Packit Service db8eaa
				   size_t sum_step)
Packit Service db8eaa
{
Packit Service db8eaa
	for (;;) {
Packit Service db8eaa
		register int sample = *src - 0x80;
Packit Service db8eaa
		if (*dst == 0x80) {
Packit Service db8eaa
			sample = -sample;
Packit Service db8eaa
			*sum = sample;
Packit Service db8eaa
		} else {
Packit Service db8eaa
			*sum = sample = *sum - sample;
Packit Service db8eaa
			if (sample > 0x7f)
Packit Service db8eaa
				sample = 0x7f;
Packit Service db8eaa
			else if (sample < -0x80)
Packit Service db8eaa
				sample = -0x80;
Packit Service db8eaa
		}
Packit Service db8eaa
		*dst = sample + 0x80;
Packit Service db8eaa
		if (!--size)
Packit Service db8eaa
			return;
Packit Service db8eaa
		dst += dst_step;
Packit Service db8eaa
		src += src_step;
Packit Service db8eaa
		sum = (signed int *) ((char *)sum + sum_step);
Packit Service db8eaa
	}
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
Packit Service db8eaa
static void generic_mix_select_callbacks(snd_pcm_direct_t *dmix)
Packit Service db8eaa
{
Packit Service db8eaa
	if (snd_pcm_format_cpu_endian(dmix->shmptr->s.format)) {
Packit Service db8eaa
		dmix->u.dmix.mix_areas_16 = generic_mix_areas_16_native;
Packit Service db8eaa
		dmix->u.dmix.mix_areas_32 = generic_mix_areas_32_native;
Packit Service db8eaa
		dmix->u.dmix.remix_areas_16 = generic_remix_areas_16_native;
Packit Service db8eaa
		dmix->u.dmix.remix_areas_32 = generic_remix_areas_32_native;
Packit Service db8eaa
	} else {
Packit Service db8eaa
		dmix->u.dmix.mix_areas_16 = generic_mix_areas_16_swap;
Packit Service db8eaa
		dmix->u.dmix.mix_areas_32 = generic_mix_areas_32_swap;
Packit Service db8eaa
		dmix->u.dmix.remix_areas_16 = generic_remix_areas_16_swap;
Packit Service db8eaa
		dmix->u.dmix.remix_areas_32 = generic_remix_areas_32_swap;
Packit Service db8eaa
	}
Packit Service db8eaa
	dmix->u.dmix.mix_areas_24 = generic_mix_areas_24;
Packit Service db8eaa
	dmix->u.dmix.mix_areas_u8 = generic_mix_areas_u8;
Packit Service db8eaa
	dmix->u.dmix.remix_areas_24 = generic_remix_areas_24;
Packit Service db8eaa
	dmix->u.dmix.remix_areas_u8 = generic_remix_areas_u8;
Packit Service db8eaa
	dmix->u.dmix.use_sem = 1;
Packit Service db8eaa
}
Packit Service db8eaa
Packit Service db8eaa
#endif