summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPaul Sokolovsky <pfalcon@users.sourceforge.net>2018-08-29 19:37:03 +0300
committerDamien George <damien.p.george@gmail.com>2018-12-10 14:25:05 +1100
commit9d864bde044faf02fe6c0e95dac14b7b6bc66e8c (patch)
treecda5ca73d9ba2942f72b3a0df8a8b113b90d742b
parentd690c2e148796cd1019b9e4c41bc9e196c7b36b7 (diff)
extmod/moductypes: Implement __int__ for PTR.
Allows to get address a pointer contains, as an integer.
-rw-r--r--extmod/moductypes.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/extmod/moductypes.c b/extmod/moductypes.c
index 4baf36e4e..9c7c23bea 100644
--- a/extmod/moductypes.c
+++ b/extmod/moductypes.c
@@ -614,6 +614,25 @@ STATIC mp_obj_t uctypes_struct_subscr(mp_obj_t self_in, mp_obj_t index_in, mp_ob
}
}
+STATIC mp_obj_t uctypes_struct_unary_op(mp_unary_op_t op, mp_obj_t self_in) {
+ mp_obj_uctypes_struct_t *self = MP_OBJ_TO_PTR(self_in);
+ switch (op) {
+ case MP_UNARY_OP_INT:
+ if (MP_OBJ_IS_TYPE(self->desc, &mp_type_tuple)) {
+ mp_obj_tuple_t *t = MP_OBJ_TO_PTR(self->desc);
+ mp_int_t offset = MP_OBJ_SMALL_INT_VALUE(t->items[0]);
+ uint agg_type = GET_TYPE(offset, AGG_TYPE_BITS);
+ if (agg_type == PTR) {
+ byte *p = *(void**)self->addr;
+ return mp_obj_new_int((mp_int_t)(uintptr_t)p);
+ }
+ }
+ /* fallthru */
+
+ default: return MP_OBJ_NULL; // op not supported
+ }
+}
+
STATIC mp_int_t uctypes_get_buffer(mp_obj_t self_in, mp_buffer_info_t *bufinfo, mp_uint_t flags) {
(void)flags;
mp_obj_uctypes_struct_t *self = MP_OBJ_TO_PTR(self_in);
@@ -662,6 +681,7 @@ STATIC const mp_obj_type_t uctypes_struct_type = {
.make_new = uctypes_struct_make_new,
.attr = uctypes_struct_attr,
.subscr = uctypes_struct_subscr,
+ .unary_op = uctypes_struct_unary_op,
.buffer_p = { .get_buffer = uctypes_get_buffer },
};