diff --git a/core/iwasm/common/SConscript b/core/iwasm/common/SConscript index 0a55f244b9..eb69744e90 100644 --- a/core/iwasm/common/SConscript +++ b/core/iwasm/common/SConscript @@ -13,13 +13,10 @@ cwd = GetCurrentDir() src = Glob('*.c') -if rtconfig.ARCH == 'arm': - if re.match('^cortex-m.*', rtconfig.CPU): - src += ['arch/invokeNative_thumb.s'] - elif re.match('^cortex-a.*', rtconfig.CPU): - src += ['arch/invokeNative_arm.s'] -elif rtconfig.ARCH == 'ia32': - src += ['arch/invokeNative_ia32.s'] +if rtconfig.ARCH == 'arm' and re.match('^cortex-m.*', rtconfig.CPU): + src += ['arch/invokeNative_thumb.s'] +else: + src.append(f"arch/invokeNative_{rtconfig.ARCH}.s") CPPPATH = [cwd, cwd + '/../include'] diff --git a/product-mini/platforms/rt-thread/iwasm.c b/product-mini/platforms/rt-thread/iwasm.c index 7d15a041d0..f8932bdec3 100644 --- a/product-mini/platforms/rt-thread/iwasm.c +++ b/product-mini/platforms/rt-thread/iwasm.c @@ -192,6 +192,21 @@ my_read_file_to_buffer(char *filename, rt_uint32_t *size) { struct stat f_stat; + if (!filename || !size) { + rt_set_errno(-EINVAL); + return RT_NULL; + } + + if (stat(filename, &f_stat) != 0) { + rt_set_errno(errno); + return RT_NULL; + } + + if (f_stat.st_size <= 0) { + rt_set_errno(-EINVAL); + return RT_NULL; + } + rt_uint8_t *buff = rt_malloc(f_stat.st_size); *size = 0; if (!buff) {