summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDamien George <damien@micropython.org>2023-10-10 11:59:13 +1100
committerDamien George <damien@micropython.org>2023-10-20 17:40:17 +1100
commitcdd9ad8d62cd69714665c086a9bebba92772afc3 (patch)
tree9a185abe2eeb6957848d969f1ff90f295046a15c
parenta2d7e0da0b7b4e822cb12390424e912ae0f13a18 (diff)
extmod/machine_i2s: Factor I2S.shift method.
It's exactly the same for all four port implementations. Signed-off-by: Damien George <damien@micropython.org>
-rw-r--r--extmod/machine_i2s.c62
-rw-r--r--ports/esp32/machine_i2s.c62
-rw-r--r--ports/mimxrt/machine_i2s.c62
-rw-r--r--ports/rp2/machine_i2s.c62
-rw-r--r--ports/stm32/machine_i2s.c62
5 files changed, 62 insertions, 248 deletions
diff --git a/extmod/machine_i2s.c b/extmod/machine_i2s.c
index 79ddfb20d..e101d70dd 100644
--- a/extmod/machine_i2s.c
+++ b/extmod/machine_i2s.c
@@ -309,6 +309,68 @@ STATIC mp_obj_t machine_i2s_deinit(mp_obj_t self_in) {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_1(machine_i2s_deinit_obj, machine_i2s_deinit);
+// Shift() is typically used as a volume control.
+// shift=1 increases volume by 6dB, shift=-1 decreases volume by 6dB
+STATIC mp_obj_t machine_i2s_shift(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
+ enum { ARG_buf, ARG_bits, ARG_shift};
+ static const mp_arg_t allowed_args[] = {
+ { MP_QSTR_buf, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} },
+ { MP_QSTR_bits, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
+ { MP_QSTR_shift, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
+ };
+
+ // parse args
+ mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
+ mp_arg_parse_all(n_args, pos_args, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
+
+ mp_buffer_info_t bufinfo;
+ mp_get_buffer_raise(args[ARG_buf].u_obj, &bufinfo, MP_BUFFER_RW);
+
+ int16_t *buf_16 = bufinfo.buf;
+ int32_t *buf_32 = bufinfo.buf;
+
+ uint8_t bits = args[ARG_bits].u_int;
+ int8_t shift = args[ARG_shift].u_int;
+
+ uint32_t num_audio_samples;
+ switch (bits) {
+ case 16:
+ num_audio_samples = bufinfo.len / sizeof(uint16_t);
+ break;
+
+ case 32:
+ num_audio_samples = bufinfo.len / sizeof(uint32_t);
+ break;
+
+ default:
+ mp_raise_ValueError(MP_ERROR_TEXT("invalid bits"));
+ break;
+ }
+
+ for (uint32_t i = 0; i < num_audio_samples; i++) {
+ switch (bits) {
+ case 16:
+ if (shift >= 0) {
+ buf_16[i] = buf_16[i] << shift;
+ } else {
+ buf_16[i] = buf_16[i] >> abs(shift);
+ }
+ break;
+ case 32:
+ if (shift >= 0) {
+ buf_32[i] = buf_32[i] << shift;
+ } else {
+ buf_32[i] = buf_32[i] >> abs(shift);
+ }
+ break;
+ }
+ }
+
+ return mp_const_none;
+}
+STATIC MP_DEFINE_CONST_FUN_OBJ_KW(machine_i2s_shift_fun_obj, 0, machine_i2s_shift);
+STATIC MP_DEFINE_CONST_STATICMETHOD_OBJ(machine_i2s_shift_obj, MP_ROM_PTR(&machine_i2s_shift_fun_obj));
+
STATIC const mp_rom_map_elem_t machine_i2s_locals_dict_table[] = {
// Methods
{ MP_ROM_QSTR(MP_QSTR_init), MP_ROM_PTR(&machine_i2s_init_obj) },
diff --git a/ports/esp32/machine_i2s.c b/ports/esp32/machine_i2s.c
index 12294adbb..054ddb90c 100644
--- a/ports/esp32/machine_i2s.c
+++ b/ports/esp32/machine_i2s.c
@@ -572,68 +572,6 @@ STATIC mp_obj_t machine_i2s_irq(mp_obj_t self_in, mp_obj_t handler) {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_2(machine_i2s_irq_obj, machine_i2s_irq);
-// Shift() is typically used as a volume control.
-// shift=1 increases volume by 6dB, shift=-1 decreases volume by 6dB
-STATIC mp_obj_t machine_i2s_shift(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
- enum { ARG_buf, ARG_bits, ARG_shift};
- static const mp_arg_t allowed_args[] = {
- { MP_QSTR_buf, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = mp_const_none} },
- { MP_QSTR_bits, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- { MP_QSTR_shift, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- };
-
- // parse args
- mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
- mp_arg_parse_all(n_args, pos_args, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
-
- mp_buffer_info_t bufinfo;
- mp_get_buffer_raise(args[ARG_buf].u_obj, &bufinfo, MP_BUFFER_RW);
-
- int16_t *buf_16 = bufinfo.buf;
- int32_t *buf_32 = bufinfo.buf;
-
- uint8_t bits = args[ARG_bits].u_int;
- int8_t shift = args[ARG_shift].u_int;
-
- uint32_t num_audio_samples;
- switch (bits) {
- case 16:
- num_audio_samples = bufinfo.len / 2;
- break;
-
- case 32:
- num_audio_samples = bufinfo.len / 4;
- break;
-
- default:
- mp_raise_ValueError(MP_ERROR_TEXT("invalid bits"));
- break;
- }
-
- for (uint32_t i = 0; i < num_audio_samples; i++) {
- switch (bits) {
- case 16:
- if (shift >= 0) {
- buf_16[i] = buf_16[i] << shift;
- } else {
- buf_16[i] = buf_16[i] >> abs(shift);
- }
- break;
- case 32:
- if (shift >= 0) {
- buf_32[i] = buf_32[i] << shift;
- } else {
- buf_32[i] = buf_32[i] >> abs(shift);
- }
- break;
- }
- }
-
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_KW(machine_i2s_shift_fun_obj, 0, machine_i2s_shift);
-STATIC MP_DEFINE_CONST_STATICMETHOD_OBJ(machine_i2s_shift_obj, MP_ROM_PTR(&machine_i2s_shift_fun_obj));
-
MP_REGISTER_ROOT_POINTER(struct _machine_i2s_obj_t *machine_i2s_obj[I2S_NUM_AUTO]);
#endif // MICROPY_PY_MACHINE_I2S
diff --git a/ports/mimxrt/machine_i2s.c b/ports/mimxrt/machine_i2s.c
index e704e4f1e..5ed6588bb 100644
--- a/ports/mimxrt/machine_i2s.c
+++ b/ports/mimxrt/machine_i2s.c
@@ -830,68 +830,6 @@ STATIC mp_obj_t machine_i2s_irq(mp_obj_t self_in, mp_obj_t handler) {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_2(machine_i2s_irq_obj, machine_i2s_irq);
-// Shift() is typically used as a volume control.
-// shift=1 increases volume by 6dB, shift=-1 decreases volume by 6dB
-STATIC mp_obj_t machine_i2s_shift(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
- enum { ARG_buf, ARG_bits, ARG_shift};
- static const mp_arg_t allowed_args[] = {
- { MP_QSTR_buf, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} },
- { MP_QSTR_bits, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- { MP_QSTR_shift, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- };
-
- // parse args
- mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
- mp_arg_parse_all(n_args, pos_args, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
-
- mp_buffer_info_t bufinfo;
- mp_get_buffer_raise(args[ARG_buf].u_obj, &bufinfo, MP_BUFFER_RW);
-
- int16_t *buf_16 = bufinfo.buf;
- int32_t *buf_32 = bufinfo.buf;
-
- uint8_t bits = args[ARG_bits].u_int;
- int8_t shift = args[ARG_shift].u_int;
-
- uint32_t num_audio_samples;
- switch (bits) {
- case 16:
- num_audio_samples = bufinfo.len / sizeof(uint16_t);
- break;
-
- case 32:
- num_audio_samples = bufinfo.len / sizeof(uint32_t);
- break;
-
- default:
- mp_raise_ValueError(MP_ERROR_TEXT("invalid bits"));
- break;
- }
-
- for (uint32_t i = 0; i < num_audio_samples; i++) {
- switch (bits) {
- case 16:
- if (shift >= 0) {
- buf_16[i] = buf_16[i] << shift;
- } else {
- buf_16[i] = buf_16[i] >> abs(shift);
- }
- break;
- case 32:
- if (shift >= 0) {
- buf_32[i] = buf_32[i] << shift;
- } else {
- buf_32[i] = buf_32[i] >> abs(shift);
- }
- break;
- }
- }
-
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_KW(machine_i2s_shift_fun_obj, 0, machine_i2s_shift);
-STATIC MP_DEFINE_CONST_STATICMETHOD_OBJ(machine_i2s_shift_obj, MP_ROM_PTR(&machine_i2s_shift_fun_obj));
-
MP_REGISTER_ROOT_POINTER(struct _machine_i2s_obj_t *machine_i2s_obj[MICROPY_HW_I2S_NUM]);
#endif // MICROPY_PY_MACHINE_I2S
diff --git a/ports/rp2/machine_i2s.c b/ports/rp2/machine_i2s.c
index 84b22aef1..524139012 100644
--- a/ports/rp2/machine_i2s.c
+++ b/ports/rp2/machine_i2s.c
@@ -703,66 +703,4 @@ STATIC mp_obj_t machine_i2s_irq(mp_obj_t self_in, mp_obj_t handler) {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_2(machine_i2s_irq_obj, machine_i2s_irq);
-// Shift() is typically used as a volume control.
-// shift=1 increases volume by 6dB, shift=-1 decreases volume by 6dB
-STATIC mp_obj_t machine_i2s_shift(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
- enum { ARG_buf, ARG_bits, ARG_shift};
- static const mp_arg_t allowed_args[] = {
- { MP_QSTR_buf, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} },
- { MP_QSTR_bits, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- { MP_QSTR_shift, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- };
-
- // parse args
- mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
- mp_arg_parse_all(n_args, pos_args, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
-
- mp_buffer_info_t bufinfo;
- mp_get_buffer_raise(args[ARG_buf].u_obj, &bufinfo, MP_BUFFER_RW);
-
- int16_t *buf_16 = bufinfo.buf;
- int32_t *buf_32 = bufinfo.buf;
-
- uint8_t bits = args[ARG_bits].u_int;
- int8_t shift = args[ARG_shift].u_int;
-
- uint32_t num_audio_samples;
- switch (bits) {
- case 16:
- num_audio_samples = bufinfo.len / sizeof(uint16_t);
- break;
-
- case 32:
- num_audio_samples = bufinfo.len / sizeof(uint32_t);
- break;
-
- default:
- mp_raise_ValueError(MP_ERROR_TEXT("invalid bits"));
- break;
- }
-
- for (uint32_t i = 0; i < num_audio_samples; i++) {
- switch (bits) {
- case 16:
- if (shift >= 0) {
- buf_16[i] = buf_16[i] << shift;
- } else {
- buf_16[i] = buf_16[i] >> abs(shift);
- }
- break;
- case 32:
- if (shift >= 0) {
- buf_32[i] = buf_32[i] << shift;
- } else {
- buf_32[i] = buf_32[i] >> abs(shift);
- }
- break;
- }
- }
-
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_KW(machine_i2s_shift_fun_obj, 0, machine_i2s_shift);
-STATIC MP_DEFINE_CONST_STATICMETHOD_OBJ(machine_i2s_shift_obj, MP_ROM_PTR(&machine_i2s_shift_fun_obj));
-
MP_REGISTER_ROOT_POINTER(void *machine_i2s_obj[2]);
diff --git a/ports/stm32/machine_i2s.c b/ports/stm32/machine_i2s.c
index a2ac973ad..b42120e1b 100644
--- a/ports/stm32/machine_i2s.c
+++ b/ports/stm32/machine_i2s.c
@@ -679,68 +679,6 @@ STATIC mp_obj_t machine_i2s_irq(mp_obj_t self_in, mp_obj_t handler) {
}
STATIC MP_DEFINE_CONST_FUN_OBJ_2(machine_i2s_irq_obj, machine_i2s_irq);
-// Shift() is typically used as a volume control.
-// shift=1 increases volume by 6dB, shift=-1 decreases volume by 6dB
-STATIC mp_obj_t machine_i2s_shift(size_t n_args, const mp_obj_t *pos_args, mp_map_t *kw_args) {
- enum { ARG_buf, ARG_bits, ARG_shift};
- static const mp_arg_t allowed_args[] = {
- { MP_QSTR_buf, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = MP_OBJ_NULL} },
- { MP_QSTR_bits, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- { MP_QSTR_shift, MP_ARG_REQUIRED | MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = -1} },
- };
-
- // parse args
- mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)];
- mp_arg_parse_all(n_args, pos_args, kw_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
-
- mp_buffer_info_t bufinfo;
- mp_get_buffer_raise(args[ARG_buf].u_obj, &bufinfo, MP_BUFFER_RW);
-
- int16_t *buf_16 = bufinfo.buf;
- int32_t *buf_32 = bufinfo.buf;
-
- uint8_t bits = args[ARG_bits].u_int;
- int8_t shift = args[ARG_shift].u_int;
-
- uint32_t num_audio_samples;
- switch (bits) {
- case 16:
- num_audio_samples = bufinfo.len / sizeof(uint16_t);
- break;
-
- case 32:
- num_audio_samples = bufinfo.len / sizeof(uint32_t);
- break;
-
- default:
- mp_raise_ValueError(MP_ERROR_TEXT("invalid bits"));
- break;
- }
-
- for (uint32_t i = 0; i < num_audio_samples; i++) {
- switch (bits) {
- case 16:
- if (shift >= 0) {
- buf_16[i] = buf_16[i] << shift;
- } else {
- buf_16[i] = buf_16[i] >> abs(shift);
- }
- break;
- case 32:
- if (shift >= 0) {
- buf_32[i] = buf_32[i] << shift;
- } else {
- buf_32[i] = buf_32[i] >> abs(shift);
- }
- break;
- }
- }
-
- return mp_const_none;
-}
-STATIC MP_DEFINE_CONST_FUN_OBJ_KW(machine_i2s_shift_fun_obj, 0, machine_i2s_shift);
-STATIC MP_DEFINE_CONST_STATICMETHOD_OBJ(machine_i2s_shift_obj, MP_ROM_PTR(&machine_i2s_shift_fun_obj));
-
MP_REGISTER_ROOT_POINTER(struct _machine_i2s_obj_t *machine_i2s_obj[MICROPY_HW_MAX_I2S]);
#endif // MICROPY_PY_MACHINE_I2S