Merge pull request from s-hadinger/berry_fix

Berry stability fix
This commit is contained in:
s-hadinger 2021-10-14 10:02:07 +02:00 committed by GitHub
commit 14a1805cea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 7 deletions
lib/libesp32/Berry/src
tasmota

View File

@ -786,27 +786,34 @@ newframe: /* a new call frame */
dispatch(); dispatch();
} }
opcase(GETMBR): { opcase(GETMBR): {
bvalue *a = RA(), *b = RKB(), *c = RKC(); bvalue a_temp; /* copy result to a temp variable because the stack may be relocated in virtual member calls */
// bvalue *a = RA(), *b = RKB(), *c = RKC();
bvalue *b = RKB(), *c = RKC();
if (var_isinstance(b) && var_isstr(c)) { if (var_isinstance(b) && var_isstr(c)) {
obj_attribute(vm, b, var_tostr(c), a); obj_attribute(vm, b, var_tostr(c), &a_temp);
reg = vm->reg; reg = vm->reg;
} else if (var_isclass(b) && var_isstr(c)) { } else if (var_isclass(b) && var_isstr(c)) {
class_attribute(vm, b, c, a); class_attribute(vm, b, c, &a_temp);
reg = vm->reg; reg = vm->reg;
} else if (var_ismodule(b) && var_isstr(c)) { } else if (var_ismodule(b) && var_isstr(c)) {
module_attribute(vm, b, c, a); module_attribute(vm, b, c, &a_temp);
reg = vm->reg; reg = vm->reg;
} else { } else {
attribute_error(vm, "attribute", b, c); attribute_error(vm, "attribute", b, c);
} }
bvalue *a = RA();
*a = a_temp; /* assign the resul to the specified register on the updated stack */
dispatch(); dispatch();
} }
opcase(GETMET): { opcase(GETMET): {
bvalue *a = RA(), *b = RKB(), *c = RKC(); bvalue a_temp; /* copy result to a temp variable because the stack may be relocated in virtual member calls */
bvalue *b = RKB(), *c = RKC();
if (var_isinstance(b) && var_isstr(c)) { if (var_isinstance(b) && var_isstr(c)) {
binstance *obj = var_toobj(b); binstance *obj = var_toobj(b);
int type = obj_attribute(vm, b, var_tostr(c), a); int type = obj_attribute(vm, b, var_tostr(c), &a_temp);
reg = vm->reg; reg = vm->reg;
bvalue *a = RA();
*a = a_temp;
if (basetype(type) == BE_FUNCTION) { if (basetype(type) == BE_FUNCTION) {
/* check if the object is a superinstance, if so get the lowest possible subclass */ /* check if the object is a superinstance, if so get the lowest possible subclass */
while (obj->sub) { while (obj->sub) {
@ -819,7 +826,10 @@ newframe: /* a new call frame */
str(be_instance_name(obj)), str(var_tostr(c))); str(be_instance_name(obj)), str(var_tostr(c)));
} }
} else if (var_ismodule(b) && var_isstr(c)) { } else if (var_ismodule(b) && var_isstr(c)) {
module_attribute(vm, b, c, &a[1]); module_attribute(vm, b, c, &a_temp);
reg = vm->reg;
bvalue *a = RA();
a[1] = a_temp;
var_settype(a, NOT_METHOD); var_settype(a, NOT_METHOD);
} else { } else {
attribute_error(vm, "method", b, c); attribute_error(vm, "method", b, c);

View File

@ -120,6 +120,7 @@ void BerryDumpErrorAndClear(bvm *vm, bool berry_console) {
top = be_top(vm); // update top after dump top = be_top(vm); // update top after dump
} else { } else {
AddLog(LOG_LEVEL_ERROR, PSTR(D_LOG_BERRY "Exception> '%s' - %s"), be_tostring(berry.vm, -2), be_tostring(berry.vm, -1)); AddLog(LOG_LEVEL_ERROR, PSTR(D_LOG_BERRY "Exception> '%s' - %s"), be_tostring(berry.vm, -2), be_tostring(berry.vm, -1));
be_tracestack(vm);
} }
} else { } else {
be_dumpstack(vm); be_dumpstack(vm);