Merge branch 'dhylands-preserve-except'

This commit is contained in:
Damien George 2014-07-01 14:28:40 +01:00
commit 5fc580475f
3 changed files with 13 additions and 0 deletions

View File

@ -172,6 +172,10 @@ void gc_unlock(void) {
gc_lock_depth--; gc_lock_depth--;
} }
bool gc_is_locked(void) {
return gc_lock_depth != 0;
}
#define VERIFY_PTR(ptr) ( \ #define VERIFY_PTR(ptr) ( \
(ptr & (BYTES_PER_BLOCK - 1)) == 0 /* must be aligned on a block */ \ (ptr & (BYTES_PER_BLOCK - 1)) == 0 /* must be aligned on a block */ \
&& ptr >= (machine_uint_t)gc_pool_start /* must be above start of pool */ \ && ptr >= (machine_uint_t)gc_pool_start /* must be above start of pool */ \

View File

@ -30,6 +30,7 @@ void gc_init(void *start, void *end);
// They can be used to prevent the GC from allocating/freeing. // They can be used to prevent the GC from allocating/freeing.
void gc_lock(void); void gc_lock(void);
void gc_unlock(void); void gc_unlock(void);
bool gc_is_locked(void);
// A given port must implement gc_collect by using the other collect functions. // A given port must implement gc_collect by using the other collect functions.
void gc_collect(void); void gc_collect(void);

View File

@ -37,6 +37,7 @@
#include "objtype.h" #include "objtype.h"
#include "runtime.h" #include "runtime.h"
#include "runtime0.h" #include "runtime0.h"
#include "gc.h"
typedef struct _mp_obj_exception_t { typedef struct _mp_obj_exception_t {
mp_obj_base_t base; mp_obj_base_t base;
@ -335,6 +336,13 @@ void mp_obj_exception_clear_traceback(mp_obj_t self_in) {
} }
void mp_obj_exception_add_traceback(mp_obj_t self_in, qstr file, machine_uint_t line, qstr block) { void mp_obj_exception_add_traceback(mp_obj_t self_in, qstr file, machine_uint_t line, qstr block) {
#if MICROPY_ENABLE_GC
if (gc_is_locked()) {
// We can't allocate memory, so don't bother to try
return;
}
#endif
GET_NATIVE_EXCEPTION(self, self_in); GET_NATIVE_EXCEPTION(self, self_in);
// for traceback, we are just using the list object for convenience, it's not really a list of Python objects // for traceback, we are just using the list object for convenience, it's not really a list of Python objects