fixed temp module to allow for instance support

This commit is contained in:
Bander Ajba 2017-02-27 21:37:32 +03:00
parent 66542c34b9
commit e52ebb095c
3 changed files with 23 additions and 16 deletions

View File

@ -30,21 +30,18 @@
#ifdef HAL_TEMP_MODULE_ENABLED #ifdef HAL_TEMP_MODULE_ENABLED
void hal_temp_init(void) void hal_temp_init(void) {
{
// @note Workaround for PAN_028 rev2.0A anomaly 31 - TEMP: Temperature offset value has to be manually loaded to the TEMP module // @note Workaround for PAN_028 rev2.0A anomaly 31 - TEMP: Temperature offset value has to be manually loaded to the TEMP module
*(uint32_t *) 0x4000C504 = 0; *(uint32_t *) 0x4000C504 = 0;
} }
int32_t hal_temp_read(void) int32_t hal_temp_read(void) {
{
int32_t volatile temp; int32_t volatile temp;
hal_temp_init(); hal_temp_init();
NRF_TEMP->TASKS_START = 1; // Start the temperature measurement. NRF_TEMP->TASKS_START = 1; // Start the temperature measurement.
while (NRF_TEMP->EVENTS_DATARDY == 0) while (NRF_TEMP->EVENTS_DATARDY == 0) {
{
// Do nothing. // Do nothing.
} }

View File

@ -185,7 +185,7 @@ STATIC const mp_map_elem_t machine_module_globals_table[] = {
{ MP_OBJ_NEW_QSTR(MP_QSTR_PWM), (mp_obj_t)&machine_hard_pwm_type }, { MP_OBJ_NEW_QSTR(MP_QSTR_PWM), (mp_obj_t)&machine_hard_pwm_type },
#endif #endif
#if MICROPY_PY_MACHINE_TEMP #if MICROPY_PY_MACHINE_TEMP
{ MP_OBJ_NEW_QSTR(MP_QSTR_TEMP), (mp_obj_t)&machine_temp_type }, { MP_OBJ_NEW_QSTR(MP_QSTR_Temp), (mp_obj_t)&machine_temp_type },
#endif #endif
{ MP_OBJ_NEW_QSTR(MP_QSTR_HARD_RESET), MP_OBJ_NEW_SMALL_INT(PYB_RESET_HARD) }, { MP_OBJ_NEW_QSTR(MP_QSTR_HARD_RESET), MP_OBJ_NEW_SMALL_INT(PYB_RESET_HARD) },
{ MP_OBJ_NEW_QSTR(MP_QSTR_WDT_RESET), MP_OBJ_NEW_SMALL_INT(PYB_RESET_WDT) }, { MP_OBJ_NEW_QSTR(MP_QSTR_WDT_RESET), MP_OBJ_NEW_SMALL_INT(PYB_RESET_WDT) },

View File

@ -35,16 +35,22 @@
#if MICROPY_PY_MACHINE_TEMP #if MICROPY_PY_MACHINE_TEMP
typedef mp_obj_type_t machine_temp_type_t; typedef struct _machine_temp_obj_t {
mp_obj_base_t base;
} machine_temp_obj_t;
STATIC const machine_temp_obj_t machine_temp_obj;
#define TEMP_BASE (NRF_TEMP_Type *)NRF_TEMP
/// \method __str__() /// \method __str__()
/// Return a string describing the ADC object. /// Return a string describing the Temp object.
STATIC void machine_temp_print(const mp_print_t *print, mp_obj_t o, mp_print_kind_t kind) { STATIC void machine_temp_print(const mp_print_t *print, mp_obj_t o, mp_print_kind_t kind) {
machine_temp_type_t *self = o; machine_temp_obj_t *self = o;
(void)self; (void)self;
mp_printf(print, "TEMP"); mp_printf(print, "Temp.read()");
} }
/******************************************************************************/ /******************************************************************************/
@ -59,17 +65,21 @@ STATIC mp_obj_t machine_temp_make_new(const mp_obj_type_t *type, size_t n_args,
mp_arg_val_t args[MP_ARRAY_SIZE(allowed_args)]; mp_arg_val_t args[MP_ARRAY_SIZE(allowed_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);
const machine_temp_type_t *self = (machine_temp_type_t*) NRF_TEMP_BASE; machine_temp_obj_t *self = m_new_obj(machine_temp_obj_t);
self->base.type = &machine_temp_type;
return MP_OBJ_FROM_PTR(self); return MP_OBJ_FROM_PTR(self);
} }
/// \method read() /// \method read()
/// Get temperature. /// Get temperature.
mp_obj_t machine_temp_read(void) { STATIC mp_obj_t machine_temp_read(mp_uint_t n_args, const mp_obj_t *args) {
return MP_OBJ_NEW_SMALL_INT(hal_temp_read()); return MP_OBJ_NEW_SMALL_INT(hal_temp_read());
} }
STATIC MP_DEFINE_CONST_FUN_OBJ_0(mp_machine_temp_read_obj, machine_temp_read);
STATIC MP_DEFINE_CONST_FUN_OBJ_VAR_BETWEEN(mp_machine_temp_read_obj, 0, 1, machine_temp_read);
STATIC const mp_map_elem_t machine_temp_locals_dict_table[] = { STATIC const mp_map_elem_t machine_temp_locals_dict_table[] = {
// instance methods // instance methods
@ -81,7 +91,7 @@ STATIC MP_DEFINE_CONST_DICT(machine_temp_locals_dict, machine_temp_locals_dict_t
const mp_obj_type_t machine_temp_type = { const mp_obj_type_t machine_temp_type = {
{ &mp_type_type }, { &mp_type_type },
.name = MP_QSTR_TEMP, .name = MP_QSTR_Temp,
.make_new = machine_temp_make_new, .make_new = machine_temp_make_new,
.locals_dict = (mp_obj_t)&machine_temp_locals_dict, .locals_dict = (mp_obj_t)&machine_temp_locals_dict,
.print = machine_temp_print, .print = machine_temp_print,