#ifdef HAVE_LUAJIT
}
else if (sm->type == DETECT_LUAJIT) {
+ SCLogDebug("luajit starting");
/* for flowvar gets and sets we need to know the flow's lock status */
int need_flow_lock = 0;
if (inspection_mode <= DETECT_ENGINE_CONTENT_INSPECTION_MODE_STREAM)
if (DetectLuajitMatchBuffer(det_ctx, s, sm, buffer, buffer_len,
det_ctx->buffer_offset, f, need_flow_lock) != 1)
{
+ SCLogDebug("luajit no_match");
goto no_match;
}
+ SCLogDebug("luajit match");
goto match;
#endif
} else {
* invalid read errors in valgrind otherwise. Adding in a nul to be sure.
*
* Buffer size = len + 1 (for nul) + whatever makes it a multiple of 4 */
+ size_t reallen = fv->data.fv_str.value_len;
size_t buflen = fv->data.fv_str.value_len + 1 + ((fv->data.fv_str.value_len + 1) % 4);
uint8_t buf[buflen];
memset(buf, 0x00, buflen);
FLOWLOCK_UNLOCK(f);
/* return value through luastate, as a luastring */
- lua_pushlstring(luastate, (char *)buf, buflen);
+ lua_pushlstring(luastate, (char *)buf, reallen);
return 1;
lua_settable(tluajit->luastate, -3);
lua_pushstring (tluajit->luastate, luajit->buffername); /* stack at -2 */
- lua_pushlstring (tluajit->luastate, (const char *)buffer, (size_t)buffer_len);
+ if (buffer_len % 4) {
+ size_t tmpbuflen = buffer_len + (buffer_len % 4);
+ uint8_t tmpbuf[tmpbuflen];
+ memset(tmpbuf, 0x00, tmpbuflen);
+ memcpy(tmpbuf, buffer, buffer_len);
+ tmpbuf[buffer_len] = '\0';
+ lua_pushlstring (tluajit->luastate, (const char *)tmpbuf, (size_t)buffer_len);
+ } else {
+ lua_pushlstring (tluajit->luastate, (const char *)buffer, (size_t)buffer_len);
+ }
lua_settable(tluajit->luastate, -3);
int retval = lua_pcall(tluajit->luastate, 1, 1, 0);