diff options
author | Damien George <damien.p.george@gmail.com> | 2014-04-17 17:11:58 +0100 |
---|---|---|
committer | Damien George <damien.p.george@gmail.com> | 2014-04-17 17:11:58 +0100 |
commit | 5f82b50324d83f963995a6c994eb73435b9660ba (patch) | |
tree | dd0914842a2bc14b39c085a219597187d4a672cd /unix/modffi.c | |
parent | dbdfee15a1839858b4d12f352b2e34597e6e76e9 (diff) | |
parent | f200c30d53f7fa0239e4ef48ffcbfcad5cf5406f (diff) |
Merge branch 'master' of github.com:micropython/micropython
Diffstat (limited to 'unix/modffi.c')
-rw-r--r-- | unix/modffi.c | 10 |
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); } |