diff options
-rw-r--r-- | sys/arch/macppc/dev/awacs.c | 58 | ||||
-rw-r--r-- | sys/arch/macppc/dev/i2s.c | 18 |
2 files changed, 40 insertions, 36 deletions
diff --git a/sys/arch/macppc/dev/awacs.c b/sys/arch/macppc/dev/awacs.c index 86b49f5b395..6f6a8215bb0 100644 --- a/sys/arch/macppc/dev/awacs.c +++ b/sys/arch/macppc/dev/awacs.c @@ -1,4 +1,4 @@ -/* $OpenBSD: awacs.c,v 1.22 2008/04/21 00:32:42 jakemsr Exp $ */ +/* $OpenBSD: awacs.c,v 1.23 2008/10/30 06:12:47 todd Exp $ */ /* $NetBSD: awacs.c,v 1.4 2001/02/26 21:07:51 wiz Exp $ */ /*- @@ -582,11 +582,15 @@ awacs_set_params(void *h, int setmode, int usemode, struct audio_params *play, p = mode == AUMODE_PLAY ? play : rec; - if (p->sample_rate < 4000 || p->sample_rate > 50000 || - (p->precision != 8 && p->precision != 16) || - (p->channels != 1 && p->channels != 2)) - return EINVAL; - + if (p->sample_rate < 4000) + p->sample_rate = 4000; + if (p->sample_rate > 50000) + p->sample_rate = 50000; + if (p->precision > 16) + p->precision = 16; + if (p->channels > 2) + p->channels = 2; + p->factor = 1; p->sw_code = NULL; awacs_write_reg(sc, AWACS_BYTE_SWAP, 0); @@ -594,47 +598,43 @@ awacs_set_params(void *h, int setmode, int usemode, struct audio_params *play, switch (p->encoding) { case AUDIO_ENCODING_SLINEAR_LE: - if (p->channels == 2 && p->precision == 16) { + if (p->percision != 16) + p->precision = 16; + if (p->channels == 2) p->sw_code = swap_bytes; - break; - } - if (p->channels == 1 && p->precision == 16) { + else { p->factor = 2; p->sw_code = swap_bytes_mts; - break; } - return (EINVAL); + break; case AUDIO_ENCODING_SLINEAR_BE: - if (p->channels == 2 && p->precision == 16) - break; - if (p->channels == 1 && p->precision == 16) { + if (p->precision != 16) + p->precision = 16; + if (p->channels == 1) { p->factor = 2; p->sw_code = noswap_bytes_mts; - break; } - return (EINVAL); + break; case AUDIO_ENCODING_ULINEAR_LE: - if (p->channels == 2 && p->precision == 16) { + if (p->precision != 16) + p->precision = 16; + if (p->channels == 2) p->sw_code = swap_bytes_change_sign16_be; - break; - } - if (p->channels == 1 && p->precision == 16) { + else { p->factor = 2; p->sw_code = swap_bytes_change_sign16_be_mts; - break; } - return (EINVAL); + break; case AUDIO_ENCODING_ULINEAR_BE: - if (p->channels == 2 && p->precision == 16) { + if (p->precision != 16) + p->precision = 16; + if (p->channels == 2) p->sw_code = change_sign16_be; - break; - } - if (p->channels == 1 && p->precision == 16) { + else { p->factor = 2; p->sw_code = change_sign16_be_mts; - break; } - return (EINVAL); + break; case AUDIO_ENCODING_ULAW: if (mode == AUMODE_PLAY) { p->factor = 2; diff --git a/sys/arch/macppc/dev/i2s.c b/sys/arch/macppc/dev/i2s.c index d77ea6b7d8b..e7ccfe87aeb 100644 --- a/sys/arch/macppc/dev/i2s.c +++ b/sys/arch/macppc/dev/i2s.c @@ -1,4 +1,4 @@ -/* $OpenBSD: i2s.c,v 1.14 2008/10/29 03:00:19 deraadt Exp $ */ +/* $OpenBSD: i2s.c,v 1.15 2008/10/30 06:12:47 todd Exp $ */ /* $NetBSD: i2s.c,v 1.1 2003/12/27 02:19:34 grant Exp $ */ /*- @@ -389,10 +389,14 @@ i2s_set_params(h, setmode, usemode, play, rec) p = mode == AUMODE_PLAY ? play : rec; - if (p->sample_rate < 4000 || p->sample_rate > 50000 || - (p->precision != 8 && p->precision != 16) || - (p->channels != 1 && p->channels != 2)) - return EINVAL; + if (p->sample_rate < 4000) + p->sample_rate = 4000; + if (p->sample_rate > 50000) + p->sample_rate = 50000; + if (p->precision > 16) + p->precision = 16; + if (p->channels > 2) + p->channels = 2; switch (p->encoding) { case AUDIO_ENCODING_SLINEAR_LE: @@ -868,9 +872,9 @@ i2s_set_rate(sc, rate) int timo; /* sanify */ - if (rate > 48000) + if (rate > (48000 + 44100) / 2) rate = 48000; - else if (rate < 44100) + else rate = 44100; switch (rate) { |