Revert "alloca seems buggy on M4"
This reverts commit 4b1e9d8f92aa948f8ecccf364edcb911a135f2c8.
This commit is contained in:
parent
5de29acbd2
commit
302ad40fb2
@ -144,7 +144,7 @@ STATIC mp_obj_t re_split(size_t n_args, const mp_obj_t *args) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
mp_obj_t retval = mp_obj_new_list(0, NULL);
|
mp_obj_t retval = mp_obj_new_list(0, NULL);
|
||||||
const char* caps[caps_num];
|
const char **caps = alloca(caps_num * sizeof(char*));
|
||||||
while (true) {
|
while (true) {
|
||||||
// cast is a workaround for a bug in msvc: it treats const char** as a const pointer instead of a pointer to pointer to const char
|
// cast is a workaround for a bug in msvc: it treats const char** as a const pointer instead of a pointer to pointer to const char
|
||||||
memset((char**)caps, 0, caps_num * sizeof(char*));
|
memset((char**)caps, 0, caps_num * sizeof(char*));
|
||||||
|
@ -1428,10 +1428,9 @@ import_error:
|
|||||||
mp_load_method_maybe(module, MP_QSTR___name__, dest);
|
mp_load_method_maybe(module, MP_QSTR___name__, dest);
|
||||||
size_t pkg_name_len;
|
size_t pkg_name_len;
|
||||||
const char *pkg_name = mp_obj_str_get_data(dest[0], &pkg_name_len);
|
const char *pkg_name = mp_obj_str_get_data(dest[0], &pkg_name_len);
|
||||||
|
|
||||||
const uint dot_name_len = pkg_name_len + 1 + qstr_len(name);
|
const uint dot_name_len = pkg_name_len + 1 + qstr_len(name);
|
||||||
// Previously dot_name was created using alloca(), but that caused run-time crashes on M4 due to
|
char *dot_name = alloca(dot_name_len);
|
||||||
// stack corruption (compiler bug, it appears), so use an array instead.
|
|
||||||
char dot_name[dot_name_len];
|
|
||||||
memcpy(dot_name, pkg_name, pkg_name_len);
|
memcpy(dot_name, pkg_name, pkg_name_len);
|
||||||
dot_name[pkg_name_len] = '.';
|
dot_name[pkg_name_len] = '.';
|
||||||
memcpy(dot_name + pkg_name_len + 1, qstr_str(name), qstr_len(name));
|
memcpy(dot_name + pkg_name_len + 1, qstr_str(name), qstr_len(name));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user