diff options
Diffstat (limited to 'miasm/jitter/arch/JitCore_arm.c')
| -rw-r--r-- | miasm/jitter/arch/JitCore_arm.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/miasm/jitter/arch/JitCore_arm.c b/miasm/jitter/arch/JitCore_arm.c index 1ce1cf47..90c95352 100644 --- a/miasm/jitter/arch/JitCore_arm.c +++ b/miasm/jitter/arch/JitCore_arm.c @@ -188,7 +188,7 @@ PyObject* cpu_get_exception(JitCpu* self, PyObject* args) -void check_automod(JitCpu* jitcpu, uint64_t addr, uint64_t size) +void check_automod(JitCpu* jitcpu, uint64_t addr, size_t size) { PyObject *result; @@ -230,7 +230,7 @@ PyObject* vm_set_mem(JitCpu *self, PyObject* args) Py_ssize_t py_length; char * buffer; - uint64_t size; + Py_ssize_t pysize; uint64_t addr; int ret; @@ -242,13 +242,16 @@ PyObject* vm_set_mem(JitCpu *self, PyObject* args) if(!PyBytes_Check(py_buffer)) RAISE(PyExc_TypeError,"arg must be bytes"); - size = PyBytes_Size(py_buffer); + pysize = PyBytes_Size(py_buffer); + if (pysize < 0) { + RAISE(PyExc_TypeError,"Python error"); + } PyBytes_AsStringAndSize(py_buffer, &buffer, &py_length); - ret = vm_write_mem(&(((VmMngr*)self->pyvm)->vm_mngr), addr, buffer, size); + ret = vm_write_mem(&(((VmMngr*)self->pyvm)->vm_mngr), addr, buffer, pysize); if (ret < 0) RAISE(PyExc_TypeError,"arg must be str"); - check_automod(self, addr, size*8); + check_automod(self, addr, (size_t)pysize); Py_INCREF(Py_None); return Py_None; |