summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorWilliam Wilgus <me.theuser@yahoo.com>2019-08-28 00:56:08 -0500
committerWilliam Wilgus <me.theuser@yahoo.com>2019-08-28 00:56:08 -0500
commitc251d1879fd5f3b2705547182622ec19175ff1a7 (patch)
treead8f2b3b7b25c7e7682fa74d80aea9b6d4c61992
parentb99d4d7fa900a4f6cebd5b87420e2831fdb5a4f3 (diff)
downloadrockbox-c251d18.tar.gz
rockbox-c251d18.zip
lua fix mem_read_write, strtol
back when I wrote this I was running the sim on a 32 bit machine I didn't catch the hardcoded LONG_MAX reference or the fact that lua_tointeger maxes ot at 32 bits on 64 bit machines strtol caused all kinds of issues especially since it returned the real LONG_MIN/MAX values Change-Id: I3571ebbd9df333f7cbf4077562412c27429bfadc
-rw-r--r--apps/plugins/lua/rocklib.c5
-rw-r--r--apps/plugins/lua/strtol.c2
2 files changed, 4 insertions, 3 deletions
diff --git a/apps/plugins/lua/rocklib.c b/apps/plugins/lua/rocklib.c
index 8c662b7359..3c38440850 100644
--- a/apps/plugins/lua/rocklib.c
+++ b/apps/plugins/lua/rocklib.c
@@ -642,8 +642,8 @@ RB_WRAP(strncasecmp)
static int mem_read_write(lua_State *L, uintptr_t address, size_t maxsize)
{
- intptr_t offset = (intptr_t) luaL_optint(L, 1, 0);
- size_t size = (size_t) luaL_optint(L, 2, maxsize);
+ intptr_t offset = (intptr_t) luaL_optnumber(L, 1, 0);
+ size_t size = (size_t) luaL_optnumber(L, 2, maxsize);
size_t written;
int type = lua_type(L, 3);
@@ -651,6 +651,7 @@ static int mem_read_write(lua_State *L, uintptr_t address, size_t maxsize)
{
/* allows pointer within structure to be calculated offset */
offset = -(address + offset);
+ luaL_argcheck(L, ((size_t) offset) <= maxsize, 1, ERR_IDX_RANGE);
size = (size_t) maxsize - offset;
}
diff --git a/apps/plugins/lua/strtol.c b/apps/plugins/lua/strtol.c
index 184951b844..3dd29b6b57 100644
--- a/apps/plugins/lua/strtol.c
+++ b/apps/plugins/lua/strtol.c
@@ -2,7 +2,7 @@
extern unsigned long int strtoul(const char *ptr, char **endptr, int base);
-#define ABS_LONG_MIN 2147483648UL
+#define ABS_LONG_MIN LONG_MAX
long int strtol(const char *nptr, char **endptr, int base)
{
int neg=0;