summaryrefslogtreecommitdiff
path: root/unix/modffi.c
diff options
context:
space:
mode:
authorDamien George <damien.p.george@gmail.com>2014-04-17 17:11:58 +0100
committerDamien George <damien.p.george@gmail.com>2014-04-17 17:11:58 +0100
commit5f82b50324d83f963995a6c994eb73435b9660ba (patch)
treedd0914842a2bc14b39c085a219597187d4a672cd /unix/modffi.c
parentdbdfee15a1839858b4d12f352b2e34597e6e76e9 (diff)
parentf200c30d53f7fa0239e4ef48ffcbfcad5cf5406f (diff)
Merge branch 'master' of github.com:micropython/micropython
Diffstat (limited to 'unix/modffi.c')
-rw-r--r--unix/modffi.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/unix/modffi.c b/unix/modffi.c
index cb6a4424f..f2bd6fcec 100644
--- a/unix/modffi.c
+++ b/unix/modffi.c
@@ -61,6 +61,8 @@ STATIC ffi_type *char2ffi_type(char c)
case 'I': return &ffi_type_uint;
case 'l': return &ffi_type_slong;
case 'L': return &ffi_type_ulong;
+ case 'f': return &ffi_type_float;
+ case 'd': return &ffi_type_double;
case 'p':
case 's': return &ffi_type_pointer;
case 'v': return &ffi_type_void;
@@ -92,6 +94,14 @@ STATIC mp_obj_t return_ffi_value(ffi_arg val, char type)
}
case 'v':
return mp_const_none;
+ case 'f': {
+ float *p = (float*)&val;
+ return mp_obj_new_float(*p);
+ }
+ case 'd': {
+ double *p = (double*)&val;
+ return mp_obj_new_float(*p);
+ }
default:
return mp_obj_new_int(val);
}