nrf5/modules/machine: Updating timer module to use new hal. Adding new parameters to the init to set period, mode and callback.

This commit is contained in:
Glenn Ruben Bakke 2017-05-31 22:27:41 +02:00 committed by glennrub
parent f49f20a24e
commit 6ddaba532a
1 changed files with 37 additions and 14 deletions

View File

@ -38,6 +38,9 @@
typedef struct _machine_timer_obj_t { typedef struct _machine_timer_obj_t {
mp_obj_base_t base; mp_obj_base_t base;
hal_timer_conf_t * p_config; hal_timer_conf_t * p_config;
mp_obj_t callback;
mp_int_t period;
mp_int_t mode;
} machine_timer_obj_t; } machine_timer_obj_t;
static hal_timer_conf_t timer_config0 = {.id = 0}; static hal_timer_conf_t timer_config0 = {.id = 0};
@ -49,7 +52,7 @@ static hal_timer_conf_t timer_config3 = {.id = 3};
static hal_timer_conf_t timer_config4 = {.id = 4}; static hal_timer_conf_t timer_config4 = {.id = 4};
#endif #endif
STATIC const machine_timer_obj_t machine_timer_obj[] = { STATIC machine_timer_obj_t machine_timer_obj[] = {
{{&machine_timer_type}, &timer_config0}, {{&machine_timer_type}, &timer_config0},
{{&machine_timer_type}, &timer_config1}, {{&machine_timer_type}, &timer_config1},
{{&machine_timer_type}, &timer_config2}, {{&machine_timer_type}, &timer_config2},
@ -59,7 +62,21 @@ STATIC const machine_timer_obj_t machine_timer_obj[] = {
#endif #endif
}; };
STATIC void hal_interrupt_handle(uint8_t id) {
machine_timer_obj_t * self = &machine_timer_obj[id];
mp_call_function_1(self->callback, self);
if (self != NULL) {
hal_timer_stop(id);
if (self->mode == 1) {
hal_timer_start(id);
}
}
}
void timer_init0(void) { void timer_init0(void) {
hal_timer_callback_set(hal_interrupt_handle);
} }
STATIC int timer_find(mp_obj_t id) { STATIC int timer_find(mp_obj_t id) {
@ -81,14 +98,12 @@ STATIC void timer_print(const mp_print_t *print, mp_obj_t o, mp_print_kind_t kin
/******************************************************************************/ /******************************************************************************/
/* MicroPython bindings for machine API */ /* MicroPython bindings for machine API */
// for make_new
enum {
ARG_NEW_id,
};
STATIC mp_obj_t machine_timer_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args) { STATIC mp_obj_t machine_timer_make_new(const mp_obj_type_t *type, size_t n_args, size_t n_kw, const mp_obj_t *all_args) {
static const mp_arg_t allowed_args[] = { static const mp_arg_t allowed_args[] = {
{ MP_QSTR_id, MP_ARG_OBJ, {.u_obj = MP_OBJ_NEW_SMALL_INT(-1)} }, { MP_QSTR_id, MP_ARG_OBJ, {.u_obj = MP_OBJ_NEW_SMALL_INT(-1)} },
{ MP_QSTR_period, MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = 1000} },
{ MP_QSTR_mode, MP_ARG_KW_ONLY | MP_ARG_INT, {.u_int = 1} },
{ MP_QSTR_callback, MP_ARG_KW_ONLY | MP_ARG_OBJ, {.u_obj = mp_const_none} },
}; };
// parse args // parse args
@ -96,7 +111,7 @@ STATIC mp_obj_t machine_timer_make_new(const mp_obj_type_t *type, size_t n_args,
mp_arg_parse_all_kw_array(n_args, n_kw, all_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args); mp_arg_parse_all_kw_array(n_args, n_kw, all_args, MP_ARRAY_SIZE(allowed_args), allowed_args, args);
// get static peripheral object // get static peripheral object
int timer_id = timer_find(args[ARG_NEW_id].u_obj); int timer_id = timer_find(args[0].u_obj);
#if MICROPY_PY_MACHINE_SOFT_PWM #if MICROPY_PY_MACHINE_SOFT_PWM
if (timer_id == 1) { if (timer_id == 1) {
@ -105,7 +120,15 @@ STATIC mp_obj_t machine_timer_make_new(const mp_obj_type_t *type, size_t n_args,
} }
#endif #endif
const machine_timer_obj_t *self = &machine_timer_obj[timer_id]; machine_timer_obj_t *self = &machine_timer_obj[timer_id];
self->p_config->period = args[1].u_int;
self->mode = args[2].u_int;
if (args[3].u_obj != mp_const_none) {
self->callback = args[3].u_obj;
}
hal_timer_init(self->p_config); hal_timer_init(self->p_config);
@ -115,22 +138,22 @@ STATIC mp_obj_t machine_timer_make_new(const mp_obj_type_t *type, size_t n_args,
/// \method start(period) /// \method start(period)
/// Start the timer. /// Start the timer.
/// ///
STATIC mp_obj_t machine_timer_start(mp_obj_t self_in, mp_obj_t period_in) { STATIC mp_obj_t machine_timer_start(mp_obj_t self_in) {
machine_timer_obj_t * self = MP_OBJ_TO_PTR(self_in); machine_timer_obj_t * self = MP_OBJ_TO_PTR(self_in);
(void)self;
// hal_timer_start(id); hal_timer_start(self->p_config->id);
return mp_const_none; return mp_const_none;
} }
STATIC MP_DEFINE_CONST_FUN_OBJ_2(machine_timer_start_obj, machine_timer_start); STATIC MP_DEFINE_CONST_FUN_OBJ_1(machine_timer_start_obj, machine_timer_start);
/// \method stop() /// \method stop()
/// Stop the timer. /// Stop the timer.
/// ///
STATIC mp_obj_t machine_timer_stop(mp_obj_t self_in) { STATIC mp_obj_t machine_timer_stop(mp_obj_t self_in) {
machine_timer_obj_t * self = MP_OBJ_TO_PTR(self_in); machine_timer_obj_t * self = MP_OBJ_TO_PTR(self_in);
(void)self;
// hal_timer_stop(id); hal_timer_stop(self->p_config->id);
return mp_const_none; return mp_const_none;
} }