Add ARRAY_SIZE macro, and use it where possible.
This commit is contained in:
parent
d139c489ba
commit
6d3c5e4301
@ -128,7 +128,7 @@ MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_any_obj, mp_builtin_any);
|
|||||||
|
|
||||||
STATIC mp_obj_t mp_builtin_bin(mp_obj_t o_in) {
|
STATIC mp_obj_t mp_builtin_bin(mp_obj_t o_in) {
|
||||||
mp_obj_t args[] = { MP_OBJ_NEW_QSTR(MP_QSTR__brace_open__colon__hash_b_brace_close_), o_in };
|
mp_obj_t args[] = { MP_OBJ_NEW_QSTR(MP_QSTR__brace_open__colon__hash_b_brace_close_), o_in };
|
||||||
return mp_obj_str_format(sizeof(args) / sizeof(args[0]), args);
|
return mp_obj_str_format(ARRAY_SIZE(args), args);
|
||||||
}
|
}
|
||||||
|
|
||||||
MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_bin_obj, mp_builtin_bin);
|
MP_DEFINE_CONST_FUN_OBJ_1(mp_builtin_bin_obj, mp_builtin_bin);
|
||||||
|
@ -118,8 +118,8 @@ const mp_obj_dict_t mp_builtin_object_dict_obj = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_builtin_object_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_builtin_object_table),
|
||||||
.alloc = sizeof(mp_builtin_object_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_builtin_object_table),
|
||||||
.table = (mp_map_elem_t*)mp_builtin_object_table,
|
.table = (mp_map_elem_t*)mp_builtin_object_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -158,8 +158,8 @@ const mp_obj_dict_t mp_builtin_module_dict_obj = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_builtin_module_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_builtin_module_table),
|
||||||
.alloc = sizeof(mp_builtin_module_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_builtin_module_table),
|
||||||
.table = (mp_map_elem_t*)mp_builtin_module_table,
|
.table = (mp_map_elem_t*)mp_builtin_module_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -86,8 +86,8 @@ STATIC const mp_map_elem_t mp_constants_table[] = {
|
|||||||
STATIC const mp_map_t mp_constants_map = {
|
STATIC const mp_map_t mp_constants_map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_constants_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_constants_table),
|
||||||
.alloc = sizeof(mp_constants_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_constants_table),
|
||||||
.table = (mp_map_elem_t*)mp_constants_table,
|
.table = (mp_map_elem_t*)mp_constants_table,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -141,7 +141,7 @@ STATIC uint get_arg_reg(emit_inline_asm_t *emit, const char *op, mp_parse_node_t
|
|||||||
if (MP_PARSE_NODE_IS_ID(pn)) {
|
if (MP_PARSE_NODE_IS_ID(pn)) {
|
||||||
qstr reg_qstr = MP_PARSE_NODE_LEAF_ARG(pn);
|
qstr reg_qstr = MP_PARSE_NODE_LEAF_ARG(pn);
|
||||||
const char *reg_str = qstr_str(reg_qstr);
|
const char *reg_str = qstr_str(reg_qstr);
|
||||||
for (uint i = 0; i < sizeof(reg_name_table) / sizeof(reg_name_table[0]); i++) {
|
for (uint i = 0; i < ARRAY_SIZE(reg_name_table); i++) {
|
||||||
const reg_name_t *r = ®_name_table[i];
|
const reg_name_t *r = ®_name_table[i];
|
||||||
if (reg_str[0] == r->name[0] && reg_str[1] == r->name[1] && reg_str[2] == r->name[2] && (reg_str[2] == '\0' || reg_str[3] == '\0')) {
|
if (reg_str[0] == r->name[0] && reg_str[1] == r->name[1] && reg_str[2] == r->name[2] && (reg_str[2] == '\0' || reg_str[3] == '\0')) {
|
||||||
if (r->reg > max_reg) {
|
if (r->reg > max_reg) {
|
||||||
@ -260,7 +260,7 @@ STATIC void emit_inline_thumb_op(emit_inline_asm_t *emit, qstr op, int n_args, m
|
|||||||
asm_thumb_b_n(emit->as, label_num);
|
asm_thumb_b_n(emit->as, label_num);
|
||||||
} else if (op_str[0] == 'b' && op_len == 3) {
|
} else if (op_str[0] == 'b' && op_len == 3) {
|
||||||
uint cc = -1;
|
uint cc = -1;
|
||||||
for (uint i = 0; i < (sizeof cc_name_table) / (sizeof cc_name_table[0]); i++) {
|
for (uint i = 0; i < ARRAY_SIZE(cc_name_table); i++) {
|
||||||
if (op_str[1] == cc_name_table[i].name[0] && op_str[2] == cc_name_table[i].name[1]) {
|
if (op_str[1] == cc_name_table[i].name[0] && op_str[2] == cc_name_table[i].name[1]) {
|
||||||
cc = cc_name_table[i].cc;
|
cc = cc_name_table[i].cc;
|
||||||
}
|
}
|
||||||
|
@ -52,6 +52,11 @@ int m_get_total_bytes_allocated(void);
|
|||||||
int m_get_current_bytes_allocated(void);
|
int m_get_current_bytes_allocated(void);
|
||||||
int m_get_peak_bytes_allocated(void);
|
int m_get_peak_bytes_allocated(void);
|
||||||
|
|
||||||
|
/** array helpers ***********************************************/
|
||||||
|
|
||||||
|
// get the number of elements in a fixed-size array
|
||||||
|
#define ARRAY_SIZE(a) (sizeof(a) / sizeof((a)[0]))
|
||||||
|
|
||||||
/** unichar / UTF-8 *********************************************/
|
/** unichar / UTF-8 *********************************************/
|
||||||
|
|
||||||
typedef int unichar; // TODO
|
typedef int unichar; // TODO
|
||||||
|
@ -14,8 +14,8 @@ STATIC const mp_obj_dict_t mp_module_array_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_array_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_array_globals_table),
|
||||||
.alloc = sizeof(mp_module_array_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_array_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_array_globals_table,
|
.table = (mp_map_elem_t*)mp_module_array_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -116,8 +116,8 @@ STATIC const mp_obj_dict_t mp_module_cmath_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_cmath_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_cmath_globals_table),
|
||||||
.alloc = sizeof(mp_module_cmath_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_cmath_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_cmath_globals_table,
|
.table = (mp_map_elem_t*)mp_module_cmath_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -16,8 +16,8 @@ STATIC const mp_obj_dict_t mp_module_collections_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_collections_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_collections_globals_table),
|
||||||
.alloc = sizeof(mp_module_collections_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_collections_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_collections_globals_table,
|
.table = (mp_map_elem_t*)mp_module_collections_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -18,8 +18,8 @@ STATIC const mp_obj_dict_t mp_module_io_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_io_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_io_globals_table),
|
||||||
.alloc = sizeof(mp_module_io_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_io_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_io_globals_table,
|
.table = (mp_map_elem_t*)mp_module_io_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -145,8 +145,8 @@ STATIC const mp_obj_dict_t mp_module_math_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_math_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_math_globals_table),
|
||||||
.alloc = sizeof(mp_module_math_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_math_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_math_globals_table,
|
.table = (mp_map_elem_t*)mp_module_math_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -39,8 +39,8 @@ STATIC const mp_obj_dict_t mp_module_micropython_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_micropython_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_micropython_globals_table),
|
||||||
.alloc = sizeof(mp_module_micropython_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_micropython_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_micropython_globals_table,
|
.table = (mp_map_elem_t*)mp_module_micropython_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -98,8 +98,8 @@ STATIC const mp_obj_dict_t mp_module_struct_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_struct_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_struct_globals_table),
|
||||||
.alloc = sizeof(mp_module_struct_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_struct_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_struct_globals_table,
|
.table = (mp_map_elem_t*)mp_module_struct_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -49,8 +49,8 @@ STATIC const mp_obj_dict_t mp_module_sys_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_sys_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_sys_globals_table),
|
||||||
.alloc = sizeof(mp_module_sys_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_sys_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_sys_globals_table,
|
.table = (mp_map_elem_t*)mp_module_sys_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -167,7 +167,7 @@ STATIC const mp_arg_parse_t pyb_dac_write_timed_accepted_args[] = {
|
|||||||
{ MP_QSTR_freq, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
{ MP_QSTR_freq, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
||||||
{ MP_QSTR_mode, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = DMA_NORMAL} },
|
{ MP_QSTR_mode, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = DMA_NORMAL} },
|
||||||
};
|
};
|
||||||
#define PYB_DAC_WRITE_TIMED_NUM_ARGS (sizeof(pyb_dac_write_timed_accepted_args) / sizeof(pyb_dac_write_timed_accepted_args[0]))
|
#define PYB_DAC_WRITE_TIMED_NUM_ARGS ARRAY_SIZE(pyb_dac_write_timed_accepted_args)
|
||||||
|
|
||||||
mp_obj_t pyb_dac_write_timed(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
mp_obj_t pyb_dac_write_timed(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
pyb_dac_obj_t *self = args[0];
|
pyb_dac_obj_t *self = args[0];
|
||||||
|
@ -245,7 +245,7 @@ STATIC const mp_arg_parse_t pyb_extint_make_new_accepted_args[] = {
|
|||||||
{ MP_QSTR_pull, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
{ MP_QSTR_pull, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
||||||
{ MP_QSTR_callback, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_callback, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
};
|
};
|
||||||
#define PYB_EXTINT_MAKE_NEW_NUM_ARGS (sizeof(pyb_extint_make_new_accepted_args) / sizeof(pyb_extint_make_new_accepted_args[0]))
|
#define PYB_EXTINT_MAKE_NEW_NUM_ARGS ARRAY_SIZE(pyb_extint_make_new_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t extint_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const mp_obj_t *args) {
|
STATIC mp_obj_t extint_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const mp_obj_t *args) {
|
||||||
// type_in == extint_obj_type
|
// type_in == extint_obj_type
|
||||||
|
11
stmhal/i2c.c
11
stmhal/i2c.c
@ -157,7 +157,6 @@ STATIC const pyb_i2c_obj_t pyb_i2c_obj[] = {
|
|||||||
#endif
|
#endif
|
||||||
{{&pyb_i2c_type}, &I2CHandle2}
|
{{&pyb_i2c_type}, &I2CHandle2}
|
||||||
};
|
};
|
||||||
#define PYB_NUM_I2C (sizeof(pyb_i2c_obj) / sizeof(pyb_i2c_obj[0]))
|
|
||||||
|
|
||||||
STATIC void pyb_i2c_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in, mp_print_kind_t kind) {
|
STATIC void pyb_i2c_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||||
pyb_i2c_obj_t *self = self_in;
|
pyb_i2c_obj_t *self = self_in;
|
||||||
@ -183,7 +182,7 @@ STATIC const mp_arg_parse_t pyb_i2c_init_accepted_args[] = {
|
|||||||
{ MP_QSTR_baudrate, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 400000} },
|
{ MP_QSTR_baudrate, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 400000} },
|
||||||
{ MP_QSTR_gencall, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_BOOL, {.u_bool = false} },
|
{ MP_QSTR_gencall, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_BOOL, {.u_bool = false} },
|
||||||
};
|
};
|
||||||
#define PYB_I2C_INIT_NUM_ARGS (sizeof(pyb_i2c_init_accepted_args) / sizeof(pyb_i2c_init_accepted_args[0]))
|
#define PYB_I2C_INIT_NUM_ARGS ARRAY_SIZE(pyb_i2c_init_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_i2c_init_helper(const pyb_i2c_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_i2c_init_helper(const pyb_i2c_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// parse args
|
// parse args
|
||||||
@ -222,7 +221,7 @@ STATIC mp_obj_t pyb_i2c_make_new(mp_obj_t type_in, uint n_args, uint n_kw, const
|
|||||||
machine_int_t i2c_id = mp_obj_get_int(args[0]) - 1;
|
machine_int_t i2c_id = mp_obj_get_int(args[0]) - 1;
|
||||||
|
|
||||||
// check i2c number
|
// check i2c number
|
||||||
if (!(0 <= i2c_id && i2c_id < PYB_NUM_I2C && pyb_i2c_obj[i2c_id].i2c != NULL)) {
|
if (!(0 <= i2c_id && i2c_id < ARRAY_SIZE(pyb_i2c_obj) && pyb_i2c_obj[i2c_id].i2c != NULL)) {
|
||||||
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_ValueError, "I2C bus %d does not exist", i2c_id + 1));
|
nlr_raise(mp_obj_new_exception_msg_varg(&mp_type_ValueError, "I2C bus %d does not exist", i2c_id + 1));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -301,7 +300,7 @@ STATIC const mp_arg_parse_t pyb_i2c_send_accepted_args[] = {
|
|||||||
{ MP_QSTR_addr, MP_ARG_PARSE_INT, {.u_int = PYB_I2C_MASTER_ADDRESS} },
|
{ MP_QSTR_addr, MP_ARG_PARSE_INT, {.u_int = PYB_I2C_MASTER_ADDRESS} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_I2C_SEND_NUM_ARGS (sizeof(pyb_i2c_send_accepted_args) / sizeof(pyb_i2c_send_accepted_args[0]))
|
#define PYB_I2C_SEND_NUM_ARGS ARRAY_SIZE(pyb_i2c_send_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_i2c_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_i2c_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
pyb_i2c_obj_t *self = args[0];
|
pyb_i2c_obj_t *self = args[0];
|
||||||
@ -341,7 +340,7 @@ STATIC const mp_arg_parse_t pyb_i2c_recv_accepted_args[] = {
|
|||||||
{ MP_QSTR_addr, MP_ARG_PARSE_INT, {.u_int = PYB_I2C_MASTER_ADDRESS} },
|
{ MP_QSTR_addr, MP_ARG_PARSE_INT, {.u_int = PYB_I2C_MASTER_ADDRESS} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_I2C_RECV_NUM_ARGS (sizeof(pyb_i2c_recv_accepted_args) / sizeof(pyb_i2c_recv_accepted_args[0]))
|
#define PYB_I2C_RECV_NUM_ARGS ARRAY_SIZE(pyb_i2c_recv_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_i2c_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_i2c_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
pyb_i2c_obj_t *self = args[0];
|
pyb_i2c_obj_t *self = args[0];
|
||||||
@ -386,7 +385,7 @@ STATIC const mp_arg_parse_t pyb_i2c_mem_read_accepted_args[] = {
|
|||||||
{ MP_QSTR_memaddr, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
{ MP_QSTR_memaddr, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_INT, {.u_int = 0} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_I2C_MEM_READ_NUM_ARGS (sizeof(pyb_i2c_mem_read_accepted_args) / sizeof(pyb_i2c_mem_read_accepted_args[0]))
|
#define PYB_I2C_MEM_READ_NUM_ARGS ARRAY_SIZE(pyb_i2c_mem_read_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_i2c_mem_read(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_i2c_mem_read(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
pyb_i2c_obj_t *self = args[0];
|
pyb_i2c_obj_t *self = args[0];
|
||||||
|
@ -30,7 +30,7 @@ STATIC const pyb_led_obj_t pyb_led_obj[] = {
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
#define NUM_LEDS (sizeof(pyb_led_obj) / sizeof(pyb_led_obj[0]))
|
#define NUM_LEDS ARRAY_SIZE(pyb_led_obj)
|
||||||
|
|
||||||
void led_init(void) {
|
void led_init(void) {
|
||||||
/* GPIO structure */
|
/* GPIO structure */
|
||||||
|
@ -279,7 +279,7 @@ soft_reset:
|
|||||||
MP_OBJ_NEW_SMALL_INT(115200),
|
MP_OBJ_NEW_SMALL_INT(115200),
|
||||||
};
|
};
|
||||||
pyb_uart_global_debug = pyb_uart_type.make_new((mp_obj_t)&pyb_uart_type,
|
pyb_uart_global_debug = pyb_uart_type.make_new((mp_obj_t)&pyb_uart_type,
|
||||||
sizeof(args) / sizeof(args[0]),
|
ARRAY_SIZE(args),
|
||||||
0, args);
|
0, args);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
@ -167,8 +167,8 @@ STATIC const mp_obj_dict_t os_module_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(os_module_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(os_module_globals_table),
|
||||||
.alloc = sizeof(os_module_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(os_module_globals_table),
|
||||||
.table = (mp_map_elem_t*)os_module_globals_table,
|
.table = (mp_map_elem_t*)os_module_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -324,8 +324,8 @@ STATIC const mp_obj_dict_t pyb_module_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(pyb_module_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(pyb_module_globals_table),
|
||||||
.alloc = sizeof(pyb_module_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(pyb_module_globals_table),
|
||||||
.table = (mp_map_elem_t*)pyb_module_globals_table,
|
.table = (mp_map_elem_t*)pyb_module_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -105,8 +105,8 @@ STATIC const mp_obj_dict_t stm_module_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(stm_module_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(stm_module_globals_table),
|
||||||
.alloc = sizeof(stm_module_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(stm_module_globals_table),
|
||||||
.table = (mp_map_elem_t*)stm_module_globals_table,
|
.table = (mp_map_elem_t*)stm_module_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -33,8 +33,8 @@ STATIC const mp_obj_dict_t time_module_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(time_module_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(time_module_globals_table),
|
||||||
.alloc = sizeof(time_module_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(time_module_globals_table),
|
||||||
.table = (mp_map_elem_t*)time_module_globals_table,
|
.table = (mp_map_elem_t*)time_module_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
10
stmhal/spi.c
10
stmhal/spi.c
@ -158,7 +158,7 @@ STATIC const pyb_spi_obj_t pyb_spi_obj[] = {
|
|||||||
{{&pyb_spi_type}, NULL},
|
{{&pyb_spi_type}, NULL},
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
#define PYB_NUM_SPI (sizeof(pyb_spi_obj) / sizeof(pyb_spi_obj[0]))
|
#define PYB_NUM_SPI ARRAY_SIZE(pyb_spi_obj)
|
||||||
|
|
||||||
STATIC void pyb_spi_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in, mp_print_kind_t kind) {
|
STATIC void pyb_spi_print(void (*print)(void *env, const char *fmt, ...), void *env, mp_obj_t self_in, mp_print_kind_t kind) {
|
||||||
pyb_spi_obj_t *self = self_in;
|
pyb_spi_obj_t *self = self_in;
|
||||||
@ -206,7 +206,7 @@ STATIC const mp_arg_parse_t pyb_spi_init_accepted_args[] = {
|
|||||||
{ MP_QSTR_ti, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_BOOL, {.u_bool = false} },
|
{ MP_QSTR_ti, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_BOOL, {.u_bool = false} },
|
||||||
{ MP_QSTR_crc, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_OBJ, {.u_obj = mp_const_none} },
|
{ MP_QSTR_crc, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_OBJ, {.u_obj = mp_const_none} },
|
||||||
};
|
};
|
||||||
#define PYB_SPI_INIT_NUM_ARGS (sizeof(pyb_spi_init_accepted_args) / sizeof(pyb_spi_init_accepted_args[0]))
|
#define PYB_SPI_INIT_NUM_ARGS ARRAY_SIZE(pyb_spi_init_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_spi_init_helper(const pyb_spi_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_spi_init_helper(const pyb_spi_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// parse args
|
// parse args
|
||||||
@ -299,7 +299,7 @@ STATIC const mp_arg_parse_t pyb_spi_send_accepted_args[] = {
|
|||||||
{ MP_QSTR_send, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_send, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_SPI_SEND_NUM_ARGS (sizeof(pyb_spi_send_accepted_args) / sizeof(pyb_spi_send_accepted_args[0]))
|
#define PYB_SPI_SEND_NUM_ARGS ARRAY_SIZE(pyb_spi_send_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_spi_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_spi_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// TODO assumes transmission size is 8-bits wide
|
// TODO assumes transmission size is 8-bits wide
|
||||||
@ -331,7 +331,7 @@ STATIC const mp_arg_parse_t pyb_spi_recv_accepted_args[] = {
|
|||||||
{ MP_QSTR_recv, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_recv, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_SPI_RECV_NUM_ARGS (sizeof(pyb_spi_recv_accepted_args) / sizeof(pyb_spi_recv_accepted_args[0]))
|
#define PYB_SPI_RECV_NUM_ARGS ARRAY_SIZE(pyb_spi_recv_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_spi_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_spi_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// TODO assumes transmission size is 8-bits wide
|
// TODO assumes transmission size is 8-bits wide
|
||||||
@ -368,7 +368,7 @@ STATIC const mp_arg_parse_t pyb_spi_send_recv_accepted_args[] = {
|
|||||||
{ MP_QSTR_recv, MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_recv, MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_SPI_SEND_RECV_NUM_ARGS (sizeof(pyb_spi_send_recv_accepted_args) / sizeof(pyb_spi_send_recv_accepted_args[0]))
|
#define PYB_SPI_SEND_RECV_NUM_ARGS ARRAY_SIZE(pyb_spi_send_recv_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_spi_send_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_spi_send_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// TODO assumes transmission size is 8-bits wide
|
// TODO assumes transmission size is 8-bits wide
|
||||||
|
@ -57,7 +57,7 @@ static uint32_t tim3_counter = 0;
|
|||||||
|
|
||||||
// Used to do callbacks to Python code on interrupt
|
// Used to do callbacks to Python code on interrupt
|
||||||
STATIC pyb_timer_obj_t *pyb_timer_obj_all[14];
|
STATIC pyb_timer_obj_t *pyb_timer_obj_all[14];
|
||||||
#define PYB_TIMER_OBJ_ALL_NUM (sizeof(pyb_timer_obj_all) / sizeof(pyb_timer_obj_all[0]))
|
#define PYB_TIMER_OBJ_ALL_NUM ARRAY_SIZE(pyb_timer_obj_all)
|
||||||
|
|
||||||
void timer_init0(void) {
|
void timer_init0(void) {
|
||||||
tim3_counter = 0;
|
tim3_counter = 0;
|
||||||
@ -180,7 +180,7 @@ STATIC const mp_arg_parse_t pyb_timer_init_accepted_args[] = {
|
|||||||
{ MP_QSTR_mode, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = TIM_COUNTERMODE_UP} },
|
{ MP_QSTR_mode, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = TIM_COUNTERMODE_UP} },
|
||||||
{ MP_QSTR_div, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = TIM_CLOCKDIVISION_DIV1} },
|
{ MP_QSTR_div, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = TIM_CLOCKDIVISION_DIV1} },
|
||||||
};
|
};
|
||||||
#define PYB_TIMER_INIT_NUM_ARGS (sizeof(pyb_timer_init_accepted_args) / sizeof(pyb_timer_init_accepted_args[0]))
|
#define PYB_TIMER_INIT_NUM_ARGS ARRAY_SIZE(pyb_timer_init_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_timer_init_helper(pyb_timer_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_timer_init_helper(pyb_timer_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// parse args
|
// parse args
|
||||||
|
@ -231,7 +231,7 @@ STATIC const mp_arg_parse_t pyb_uart_init_accepted_args[] = {
|
|||||||
{ MP_QSTR_stop, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 1} },
|
{ MP_QSTR_stop, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 1} },
|
||||||
{ MP_QSTR_parity, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_OBJ, {.u_obj = mp_const_none} },
|
{ MP_QSTR_parity, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_OBJ, {.u_obj = mp_const_none} },
|
||||||
};
|
};
|
||||||
#define PYB_UART_INIT_NUM_ARGS (sizeof(pyb_uart_init_accepted_args) / sizeof(pyb_uart_init_accepted_args[0]))
|
#define PYB_UART_INIT_NUM_ARGS ARRAY_SIZE(pyb_uart_init_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_uart_init_helper(pyb_uart_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_uart_init_helper(pyb_uart_obj_t *self, uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// parse args
|
// parse args
|
||||||
@ -331,7 +331,7 @@ STATIC const mp_arg_parse_t pyb_uart_send_accepted_args[] = {
|
|||||||
{ MP_QSTR_send, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_send, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_UART_SEND_NUM_ARGS (sizeof(pyb_uart_send_accepted_args) / sizeof(pyb_uart_send_accepted_args[0]))
|
#define PYB_UART_SEND_NUM_ARGS ARRAY_SIZE(pyb_uart_send_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_uart_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_uart_send(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// TODO assumes transmission size is 8-bits wide
|
// TODO assumes transmission size is 8-bits wide
|
||||||
@ -363,7 +363,7 @@ STATIC const mp_arg_parse_t pyb_uart_recv_accepted_args[] = {
|
|||||||
{ MP_QSTR_recv, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
{ MP_QSTR_recv, MP_ARG_PARSE_REQUIRED | MP_ARG_PARSE_OBJ, {.u_obj = MP_OBJ_NULL} },
|
||||||
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
{ MP_QSTR_timeout, MP_ARG_PARSE_KW_ONLY | MP_ARG_PARSE_INT, {.u_int = 5000} },
|
||||||
};
|
};
|
||||||
#define PYB_UART_RECV_NUM_ARGS (sizeof(pyb_uart_recv_accepted_args) / sizeof(pyb_uart_recv_accepted_args[0]))
|
#define PYB_UART_RECV_NUM_ARGS ARRAY_SIZE(pyb_uart_recv_accepted_args)
|
||||||
|
|
||||||
STATIC mp_obj_t pyb_uart_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
STATIC mp_obj_t pyb_uart_recv(uint n_args, const mp_obj_t *args, mp_map_t *kw_args) {
|
||||||
// TODO assumes transmission size is 8-bits wide
|
// TODO assumes transmission size is 8-bits wide
|
||||||
|
@ -394,8 +394,8 @@ STATIC const mp_obj_dict_t mp_module_ffi_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_ffi_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_ffi_globals_table),
|
||||||
.alloc = sizeof(mp_module_ffi_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_ffi_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_ffi_globals_table,
|
.table = (mp_map_elem_t*)mp_module_ffi_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -378,8 +378,8 @@ STATIC const mp_obj_dict_t mp_module_socket_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_socket_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_socket_globals_table),
|
||||||
.alloc = sizeof(mp_module_socket_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_socket_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_socket_globals_table,
|
.table = (mp_map_elem_t*)mp_module_socket_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -63,8 +63,8 @@ STATIC const mp_obj_dict_t mp_module_time_globals = {
|
|||||||
.map = {
|
.map = {
|
||||||
.all_keys_are_qstrs = 1,
|
.all_keys_are_qstrs = 1,
|
||||||
.table_is_fixed_array = 1,
|
.table_is_fixed_array = 1,
|
||||||
.used = sizeof(mp_module_time_globals_table) / sizeof(mp_map_elem_t),
|
.used = ARRAY_SIZE(mp_module_time_globals_table),
|
||||||
.alloc = sizeof(mp_module_time_globals_table) / sizeof(mp_map_elem_t),
|
.alloc = ARRAY_SIZE(mp_module_time_globals_table),
|
||||||
.table = (mp_map_elem_t*)mp_module_time_globals_table,
|
.table = (mp_map_elem_t*)mp_module_time_globals_table,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user