Modified: tomcat/jk/trunk/native/iis/pcre/pcre_jit_test.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_jit_test.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_jit_test.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_jit_test.c Tue Nov 21 14:37:37 2017
@@ -687,6 +687,7 @@ static struct regression_test_case regre
        { PCRE_FIRSTLINE | PCRE_NEWLINE_LF | PCRE_DOTALL, 0 | F_NOMATCH, "ab.", 
"ab" },
        { MUA | PCRE_FIRSTLINE, 1 | F_NOMATCH, "^[a-d0-9]", "\nxx\nd" },
        { PCRE_NEWLINE_ANY | PCRE_FIRSTLINE | PCRE_DOTALL, 0, "....a", 
"012\n0a" },
+       { MUA | PCRE_FIRSTLINE, 0, "[aC]", "a" },
 
        /* Recurse. */
        { MUA, 0, "(a)(?1)", "aa" },

Modified: tomcat/jk/trunk/native/iis/pcre/pcre_scanner_unittest.cc
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_scanner_unittest.cc?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_scanner_unittest.cc (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_scanner_unittest.cc Tue Nov 21 
14:37:37 2017
@@ -57,6 +57,7 @@
 } while (0)
 
 using std::vector;
+using std::string;
 using pcrecpp::StringPiece;
 using pcrecpp::Scanner;
 

Modified: tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece.h.in
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece.h.in?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece.h.in (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece.h.in Tue Nov 21 14:37:37 
2017
@@ -52,12 +52,12 @@
 
 #include <pcre.h>
 
+namespace pcrecpp {
+
 using std::memcmp;
 using std::strlen;
 using std::string;
 
-namespace pcrecpp {
-
 class PCRECPP_EXP_DEFN StringPiece {
  private:
   const char*   ptr_;

Modified: tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece_unittest.cc
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece_unittest.cc?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece_unittest.cc (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_stringpiece_unittest.cc Tue Nov 21 
14:37:37 2017
@@ -24,6 +24,7 @@
   }                                                     \
 } while (0)
 
+using std::string;
 using pcrecpp::StringPiece;
 
 static void CheckSTLComparator() {

Modified: tomcat/jk/trunk/native/iis/pcre/pcre_tables.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_tables.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_tables.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_tables.c Tue Nov 21 14:37:37 2017
@@ -6,7 +6,7 @@
 and semantics are as close as possible to those of the Perl 5 language.
 
                        Written by Philip Hazel
-           Copyright (c) 1997-2012 University of Cambridge
+           Copyright (c) 1997-2017 University of Cambridge
 
 -----------------------------------------------------------------------------
 Redistribution and use in source and binary forms, with or without
@@ -161,7 +161,7 @@ const pcre_uint32 PRIV(ucp_gbtable[]) =
 
    (1<<ucp_gbExtend)|(1<<ucp_gbSpacingMark),                /*  5 SpacingMark 
*/
    (1<<ucp_gbExtend)|(1<<ucp_gbSpacingMark)|(1<<ucp_gbL)|   /*  6 L */
-     (1<<ucp_gbL)|(1<<ucp_gbV)|(1<<ucp_gbLV)|(1<<ucp_gbLVT),
+     (1<<ucp_gbV)|(1<<ucp_gbLV)|(1<<ucp_gbLVT),
 
    (1<<ucp_gbExtend)|(1<<ucp_gbSpacingMark)|(1<<ucp_gbV)|   /*  7 V */
      (1<<ucp_gbT),

Modified: tomcat/jk/trunk/native/iis/pcre/pcre_ucd.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcre_ucd.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcre_ucd.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcre_ucd.c Tue Nov 21 14:37:37 2017
@@ -38,6 +38,20 @@ const pcre_uint16 PRIV(ucd_stage2)[] = {
 const pcre_uint32 PRIV(ucd_caseless_sets)[] = {0};
 #else
 
+/* If the 32-bit library is run in non-32-bit mode, character values
+greater than 0x10ffff may be encountered. For these we set up a
+special record. */
+
+#ifdef COMPILE_PCRE32
+const ucd_record PRIV(dummy_ucd_record)[] = {{
+  ucp_Common,    /* script */
+  ucp_Cn,        /* type unassigned */
+  ucp_gbOther,   /* grapheme break property */
+  0,             /* case set */
+  0,             /* other case */
+  }};
+#endif
+
 /* When recompiling tables with a new Unicode version, please check the
 types in this structure definition from pcre_internal.h (the actual
 field names will be different):

Modified: tomcat/jk/trunk/native/iis/pcre/pcrecpp_unittest.cc
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcrecpp_unittest.cc?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcrecpp_unittest.cc (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcrecpp_unittest.cc Tue Nov 21 14:37:37 2017
@@ -43,6 +43,7 @@
 #include <vector>
 #include "pcrecpp.h"
 
+using std::string;
 using pcrecpp::StringPiece;
 using pcrecpp::RE;
 using pcrecpp::RE_Options;

Modified: tomcat/jk/trunk/native/iis/pcre/pcregrep.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcregrep.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcregrep.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcregrep.c Tue Nov 21 14:37:37 2017
@@ -1803,6 +1803,7 @@ while (ptr < endptr)
         match = FALSE;
         if (line_buffered) fflush(stdout);
         rc = 0;                      /* Had some success */
+
         startoffset = offsets[1];    /* Restart after the match */
         if (startoffset <= oldstartoffset)
           {
@@ -1812,6 +1813,22 @@ while (ptr < endptr)
           if (utf8)
             while ((matchptr[startoffset] & 0xc0) == 0x80) startoffset++;
           }
+
+        /* If the current match ended past the end of the line (only possible
+        in multiline mode), we must move on to the line in which it did end
+        before searching for more matches. */
+
+        while (startoffset > (int)linelength)
+          {
+          matchptr = ptr += linelength + endlinelength;
+          filepos += (int)(linelength + endlinelength);
+          linenumber++;
+          startoffset -= (int)(linelength + endlinelength);
+          t = end_of_line(ptr, endptr, &endlinelength);
+          linelength = t - ptr - endlinelength;
+          length = (size_t)(endptr - ptr);
+          }
+
         goto ONLY_MATCHING_RESTART;
         }
       }
@@ -3173,9 +3190,11 @@ for (j = 1, cp = patterns; cp != NULL; j
   cp->hint = pcre_study(cp->compiled, study_options, &error);
   if (error != NULL)
     {
-    char s[16];
-    if (patterns->next == NULL) s[0] = 0; else sprintf(s, " number %d", j);
-    fprintf(stderr, "pcregrep: Error while studying regex%s: %s\n", s, error);
+    if (patterns->next == NULL)
+      fprintf(stderr, "pcregrep: Error while studying regex: %s\n", error);
+    else
+      fprintf(stderr, "pcregrep: Error while studying regex number %d: %s\n",
+        j, error);
     goto EXIT2;
     }
 #ifdef SUPPORT_PCREGREP_JIT

Modified: tomcat/jk/trunk/native/iis/pcre/pcreposix.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcreposix.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcreposix.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcreposix.c Tue Nov 21 14:37:37 2017
@@ -6,7 +6,7 @@
 and semantics are as close as possible to those of the Perl 5 language.
 
                        Written by Philip Hazel
-           Copyright (c) 1997-2016 University of Cambridge
+           Copyright (c) 1997-2017 University of Cambridge
 
 -----------------------------------------------------------------------------
 Redistribution and use in source and binary forms, with or without
@@ -389,8 +389,8 @@ if (rc >= 0)
     {
     for (i = 0; i < (size_t)rc; i++)
       {
-      pmatch[i].rm_so = ovector[i*2];
-      pmatch[i].rm_eo = ovector[i*2+1];
+      pmatch[i].rm_so = ovector[i*2] + so;
+      pmatch[i].rm_eo = ovector[i*2+1] + so;
       }
     if (allocated_ovector) free(ovector);
     for (; i < nmatch; i++) pmatch[i].rm_so = pmatch[i].rm_eo = -1;

Modified: tomcat/jk/trunk/native/iis/pcre/pcretest.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/pcretest.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/pcretest.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/pcretest.c Tue Nov 21 14:37:37 2017
@@ -177,7 +177,7 @@ that differ in their output from isprint
 #define PRINTABLE(c) ((c) >= 32 && (c) < 127)
 #endif
 
-#define PRINTOK(c) (locale_set? isprint(c) : PRINTABLE(c))
+#define PRINTOK(c) (locale_set? (((c) < 256) && isprint(c)) : PRINTABLE(c))
 
 /* Posix support is disabled in 16 or 32 bit only mode. */
 #if !defined SUPPORT_PCRE8 && !defined NOPOSIX
@@ -426,11 +426,11 @@ argument, the casting might be incorrect
 #define PCRE_COPY_NAMED_SUBSTRING32(rc, re, bptr, offsets, count, \
     namesptr, cbuffer, size) \
   rc = pcre32_copy_named_substring((pcre32 *)re, (PCRE_SPTR32)bptr, offsets, \
-    count, (PCRE_SPTR32)namesptr, (PCRE_UCHAR32 *)cbuffer, size/2)
+    count, (PCRE_SPTR32)namesptr, (PCRE_UCHAR32 *)cbuffer, size/4)
 
 #define PCRE_COPY_SUBSTRING32(rc, bptr, offsets, count, i, cbuffer, size) \
   rc = pcre32_copy_substring((PCRE_SPTR32)bptr, offsets, count, i, \
-    (PCRE_UCHAR32 *)cbuffer, size/2)
+    (PCRE_UCHAR32 *)cbuffer, size/4)
 
 #define PCRE_DFA_EXEC32(count, re, extra, bptr, len, start_offset, options, \
     offsets, size_offsets, workspace, size_workspace) \
@@ -1982,6 +1982,7 @@ return(result);
 static int pchar(pcre_uint32 c, FILE *f)
 {
 int n = 0;
+char tempbuffer[16];
 if (PRINTOK(c))
   {
   if (f != NULL) fprintf(f, "%c", c);
@@ -2003,6 +2004,8 @@ if (c < 0x100)
   }
 
 if (f != NULL) n = fprintf(f, "\\x{%02x}", c);
+  else n = sprintf(tempbuffer, "\\x{%02x}", c);
+
 return n >= 0 ? n : 0;
 }
 
@@ -4831,7 +4834,16 @@ while (!done)
         continue;
 
         case 'O':
-        while(isdigit(*p)) n = n * 10 + *p++ - '0';
+        while(isdigit(*p))
+          {
+          if (n > (INT_MAX-10)/10)   /* Hack to stop fuzzers */
+            {
+            printf("** \\O argument is too big\n");
+            yield = 1;
+            goto EXIT;
+            }
+          n = n * 10 + *p++ - '0';
+          }
         if (n > size_offsets_max)
           {
           size_offsets_max = n;
@@ -5042,7 +5054,7 @@ while (!done)
 
     if ((all_use_dfa || use_dfa) && find_match_limit)
       {
-      printf("**Match limit not relevant for DFA matching: ignored\n");
+      printf("** Match limit not relevant for DFA matching: ignored\n");
       find_match_limit = 0;
       }
 
@@ -5255,10 +5267,17 @@ while (!done)
 
         if (do_allcaps)
           {
-          if (new_info(re, NULL, PCRE_INFO_CAPTURECOUNT, &count) < 0)
-            goto SKIP_DATA;
-          count++;   /* Allow for full match */
-          if (count * 2 > use_size_offsets) count = use_size_offsets/2;
+          if (all_use_dfa || use_dfa)
+            {
+            fprintf(outfile, "** Show all captures ignored after DFA 
matching\n");
+            }
+          else
+           {
+            if (new_info(re, NULL, PCRE_INFO_CAPTURECOUNT, &count) < 0)
+              goto SKIP_DATA;
+            count++;   /* Allow for full match */
+            if (count * 2 > use_size_offsets) count = use_size_offsets/2;
+            }
           }
 
         /* Output the captured substrings. Note that, for the matched string,

Modified: tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfig.h
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfig.h?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfig.h (original)
+++ tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfig.h Tue Nov 21 14:37:37 2017
@@ -1,7 +1,7 @@
 /*
  *    Stack-less Just-In-Time compiler
  *
- *    Copyright 2009-2012 Zoltan Herczeg (hzmes...@freemail.hu). All rights 
reserved.
+ *    Copyright Zoltan Herczeg (hzmes...@freemail.hu). All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without 
modification, are
  * permitted provided that the following conditions are met:
@@ -82,7 +82,7 @@
 /* --------------------------------------------------------------------- */
 
 /* If SLJIT_STD_MACROS_DEFINED is not defined, the application should
-   define SLJIT_MALLOC, SLJIT_FREE, SLJIT_MEMMOVE, and NULL. */
+   define SLJIT_MALLOC, SLJIT_FREE, SLJIT_MEMCPY, and NULL. */
 #ifndef SLJIT_STD_MACROS_DEFINED
 /* Disabled by default. */
 #define SLJIT_STD_MACROS_DEFINED 0
@@ -90,10 +90,20 @@
 
 /* Executable code allocation:
    If SLJIT_EXECUTABLE_ALLOCATOR is not defined, the application should
-   define both SLJIT_MALLOC_EXEC and SLJIT_FREE_EXEC. */
+   define SLJIT_MALLOC_EXEC, SLJIT_FREE_EXEC, and SLJIT_EXEC_OFFSET. */
 #ifndef SLJIT_EXECUTABLE_ALLOCATOR
 /* Enabled by default. */
 #define SLJIT_EXECUTABLE_ALLOCATOR 1
+
+/* When SLJIT_PROT_EXECUTABLE_ALLOCATOR is enabled SLJIT uses
+   an allocator which does not set writable and executable
+   permission flags at the same time. The trade-of is increased
+   memory consumption and disabled dynamic code modifications. */
+#ifndef SLJIT_PROT_EXECUTABLE_ALLOCATOR
+/* Disabled by default. */
+#define SLJIT_PROT_EXECUTABLE_ALLOCATOR 0
+#endif
+
 #endif
 
 /* Force cdecl calling convention even if a better calling

Modified: tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfigInternal.h
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfigInternal.h?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfigInternal.h (original)
+++ tomcat/jk/trunk/native/iis/pcre/sljit/sljitConfigInternal.h Tue Nov 21 
14:37:37 2017
@@ -1,7 +1,7 @@
 /*
  *    Stack-less Just-In-Time compiler
  *
- *    Copyright 2009-2012 Zoltan Herczeg (hzmes...@freemail.hu). All rights 
reserved.
+ *    Copyright Zoltan Herczeg (hzmes...@freemail.hu). All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without 
modification, are
  * permitted provided that the following conditions are met:
@@ -187,14 +187,6 @@
 /* External function definitions. */
 /**********************************/
 
-#if !(defined SLJIT_STD_MACROS_DEFINED && SLJIT_STD_MACROS_DEFINED)
-
-/* These libraries are needed for the macros below. */
-#include <stdlib.h>
-#include <string.h>
-
-#endif /* SLJIT_STD_MACROS_DEFINED */
-
 /* General macros:
    Note: SLJIT is designed to be independent from them as possible.
 
@@ -210,8 +202,8 @@
 #define SLJIT_FREE(ptr, allocator_data) free(ptr)
 #endif
 
-#ifndef SLJIT_MEMMOVE
-#define SLJIT_MEMMOVE(dest, src, len) memmove(dest, src, len)
+#ifndef SLJIT_MEMCPY
+#define SLJIT_MEMCPY(dest, src, len) memcpy(dest, src, len)
 #endif
 
 #ifndef SLJIT_ZEROMEM
@@ -304,6 +296,13 @@
 #define SLJIT_CACHE_FLUSH(from, to) \
        sys_icache_invalidate((char*)(from), (char*)(to) - (char*)(from))
 
+#elif (defined SLJIT_CONFIG_PPC && SLJIT_CONFIG_PPC)
+
+/* The __clear_cache() implementation of GCC is a dummy function on PowerPC. */
+#define SLJIT_CACHE_FLUSH(from, to) \
+       ppc_cache_flush((from), (to))
+#define SLJIT_CACHE_FLUSH_OWN_IMPL 1
+
 #elif (defined(__GNUC__) && (__GNUC__ >= 5 || (__GNUC__ == 4 && __GNUC_MINOR__ 
>= 3)))
 
 #define SLJIT_CACHE_FLUSH(from, to) \
@@ -316,13 +315,6 @@
 #define SLJIT_CACHE_FLUSH(from, to) \
     cacheflush((long)(from), (long)(to), 0)
 
-#elif (defined SLJIT_CONFIG_PPC && SLJIT_CONFIG_PPC)
-
-/* The __clear_cache() implementation of GCC is a dummy function on PowerPC. */
-#define SLJIT_CACHE_FLUSH(from, to) \
-       ppc_cache_flush((from), (to))
-#define SLJIT_CACHE_FLUSH_OWN_IMPL 1
-
 #elif (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32)
 
 /* The __clear_cache() implementation of GCC is a dummy function on Sparc. */
@@ -401,7 +393,9 @@ typedef double sljit_f64;
 #ifndef SLJIT_W
 
 /* Defining long constants. */
-#if (defined SLJIT_64BIT_ARCHITECTURE && SLJIT_64BIT_ARCHITECTURE)
+#if (defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
+#define SLJIT_W(w)     (w##l)
+#elif (defined SLJIT_64BIT_ARCHITECTURE && SLJIT_64BIT_ARCHITECTURE)
 #define SLJIT_W(w)     (w##ll)
 #else
 #define SLJIT_W(w)     (w)
@@ -545,6 +539,14 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_unused_memory_exec(void);
 #define SLJIT_MALLOC_EXEC(size) sljit_malloc_exec(size)
 #define SLJIT_FREE_EXEC(ptr) sljit_free_exec(ptr)
+
+#if (defined SLJIT_PROT_EXECUTABLE_ALLOCATOR && 
SLJIT_PROT_EXECUTABLE_ALLOCATOR)
+SLJIT_API_FUNC_ATTRIBUTE sljit_sw sljit_exec_offset(void* ptr);
+#define SLJIT_EXEC_OFFSET(ptr) sljit_exec_offset(ptr)
+#else
+#define SLJIT_EXEC_OFFSET(ptr) 0
+#endif
+
 #endif
 
 /**********************************************/
@@ -553,37 +555,37 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 
 #if (defined SLJIT_CONFIG_X86_32 && SLJIT_CONFIG_X86_32)
 
-#define SLJIT_NUMBER_OF_REGISTERS 10
-#define SLJIT_NUMBER_OF_SAVED_REGISTERS 7
+#define SLJIT_NUMBER_OF_REGISTERS 12
+#define SLJIT_NUMBER_OF_SAVED_REGISTERS 9
 #if (defined SLJIT_X86_32_FASTCALL && SLJIT_X86_32_FASTCALL)
-#define SLJIT_LOCALS_OFFSET_BASE ((2 + 4) * sizeof(sljit_sw))
+#define SLJIT_LOCALS_OFFSET_BASE (compiler->locals_offset)
 #else
 /* Maximum 3 arguments are passed on the stack, +1 for double alignment. */
-#define SLJIT_LOCALS_OFFSET_BASE ((3 + 1 + 4) * sizeof(sljit_sw))
+#define SLJIT_LOCALS_OFFSET_BASE (compiler->locals_offset)
 #endif /* SLJIT_X86_32_FASTCALL */
 
 #elif (defined SLJIT_CONFIG_X86_64 && SLJIT_CONFIG_X86_64)
 
 #ifndef _WIN64
-#define SLJIT_NUMBER_OF_REGISTERS 12
+#define SLJIT_NUMBER_OF_REGISTERS 13
 #define SLJIT_NUMBER_OF_SAVED_REGISTERS 6
-#define SLJIT_LOCALS_OFFSET_BASE (sizeof(sljit_sw))
+#define SLJIT_LOCALS_OFFSET_BASE 0
 #else
-#define SLJIT_NUMBER_OF_REGISTERS 12
+#define SLJIT_NUMBER_OF_REGISTERS 13
 #define SLJIT_NUMBER_OF_SAVED_REGISTERS 8
-#define SLJIT_LOCALS_OFFSET_BASE ((4 + 2) * sizeof(sljit_sw))
+#define SLJIT_LOCALS_OFFSET_BASE (compiler->locals_offset)
 #endif /* _WIN64 */
 
 #elif (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || (defined 
SLJIT_CONFIG_ARM_V7 && SLJIT_CONFIG_ARM_V7)
 
-#define SLJIT_NUMBER_OF_REGISTERS 11
+#define SLJIT_NUMBER_OF_REGISTERS 12
 #define SLJIT_NUMBER_OF_SAVED_REGISTERS 8
 #define SLJIT_LOCALS_OFFSET_BASE 0
 
 #elif (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2)
 
-#define SLJIT_NUMBER_OF_REGISTERS 11
-#define SLJIT_NUMBER_OF_SAVED_REGISTERS 7
+#define SLJIT_NUMBER_OF_REGISTERS 12
+#define SLJIT_NUMBER_OF_SAVED_REGISTERS 8
 #define SLJIT_LOCALS_OFFSET_BASE 0
 
 #elif (defined SLJIT_CONFIG_ARM_64 && SLJIT_CONFIG_ARM_64)
@@ -607,7 +609,7 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 
 #elif (defined SLJIT_CONFIG_MIPS && SLJIT_CONFIG_MIPS)
 
-#define SLJIT_NUMBER_OF_REGISTERS 17
+#define SLJIT_NUMBER_OF_REGISTERS 21
 #define SLJIT_NUMBER_OF_SAVED_REGISTERS 8
 #if (defined SLJIT_CONFIG_MIPS_32 && SLJIT_CONFIG_MIPS_32)
 #define SLJIT_LOCALS_OFFSET_BASE (4 * sizeof(sljit_sw))
@@ -663,7 +665,7 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 
 #if (defined SLJIT_DEBUG && SLJIT_DEBUG)
 
-#if !defined(SLJIT_ASSERT) || !defined(SLJIT_ASSERT_STOP)
+#if !defined(SLJIT_ASSERT) || !defined(SLJIT_UNREACHABLE)
 
 /* SLJIT_HALT_PROCESS must halt the process. */
 #ifndef SLJIT_HALT_PROCESS
@@ -675,7 +677,7 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 
 #include <stdio.h>
 
-#endif /* !SLJIT_ASSERT || !SLJIT_ASSERT_STOP */
+#endif /* !SLJIT_ASSERT || !SLJIT_UNREACHABLE */
 
 /* Feel free to redefine these two macros. */
 #ifndef SLJIT_ASSERT
@@ -690,34 +692,33 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_free
 
 #endif /* !SLJIT_ASSERT */
 
-#ifndef SLJIT_ASSERT_STOP
+#ifndef SLJIT_UNREACHABLE
 
-#define SLJIT_ASSERT_STOP() \
+#define SLJIT_UNREACHABLE() \
        do { \
                printf("Should never been reached " __FILE__ ":%d\n", 
__LINE__); \
                SLJIT_HALT_PROCESS(); \
        } while (0)
 
-#endif /* !SLJIT_ASSERT_STOP */
+#endif /* !SLJIT_UNREACHABLE */
 
 #else /* (defined SLJIT_DEBUG && SLJIT_DEBUG) */
 
 /* Forcing empty, but valid statements. */
 #undef SLJIT_ASSERT
-#undef SLJIT_ASSERT_STOP
+#undef SLJIT_UNREACHABLE
 
 #define SLJIT_ASSERT(x) \
        do { } while (0)
-#define SLJIT_ASSERT_STOP() \
+#define SLJIT_UNREACHABLE() \
        do { } while (0)
 
 #endif /* (defined SLJIT_DEBUG && SLJIT_DEBUG) */
 
 #ifndef SLJIT_COMPILE_ASSERT
 
-/* Should be improved eventually. */
 #define SLJIT_COMPILE_ASSERT(x, description) \
-       SLJIT_ASSERT(x)
+       switch(0) { case 0: case ((x) ? 1 : 0): break; }
 
 #endif /* !SLJIT_COMPILE_ASSERT */
 

Modified: tomcat/jk/trunk/native/iis/pcre/sljit/sljitExecAllocator.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/sljit/sljitExecAllocator.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/sljit/sljitExecAllocator.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/sljit/sljitExecAllocator.c Tue Nov 21 
14:37:37 2017
@@ -1,7 +1,7 @@
 /*
  *    Stack-less Just-In-Time compiler
  *
- *    Copyright 2009-2012 Zoltan Herczeg (hzmes...@freemail.hu). All rights 
reserved.
+ *    Copyright Zoltan Herczeg (hzmes...@freemail.hu). All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without 
modification, are
  * permitted provided that the following conditions are met:
@@ -86,7 +86,7 @@ static SLJIT_INLINE void* alloc_chunk(sl
        return VirtualAlloc(NULL, size, MEM_COMMIT | MEM_RESERVE, 
PAGE_EXECUTE_READWRITE);
 }
 
-static SLJIT_INLINE void free_chunk(void* chunk, sljit_uw size)
+static SLJIT_INLINE void free_chunk(void *chunk, sljit_uw size)
 {
        SLJIT_UNUSED_ARG(size);
        VirtualFree(chunk, 0, MEM_RELEASE);
@@ -96,7 +96,7 @@ static SLJIT_INLINE void free_chunk(void
 
 static SLJIT_INLINE void* alloc_chunk(sljit_uw size)
 {
-       void* retval;
+       void *retval;
 
 #ifdef MAP_ANON
        retval = mmap(NULL, size, PROT_READ | PROT_WRITE | PROT_EXEC, 
MAP_PRIVATE | MAP_ANON, -1, 0);
@@ -111,7 +111,7 @@ static SLJIT_INLINE void* alloc_chunk(sl
        return (retval != MAP_FAILED) ? retval : NULL;
 }
 
-static SLJIT_INLINE void free_chunk(void* chunk, sljit_uw size)
+static SLJIT_INLINE void free_chunk(void *chunk, sljit_uw size)
 {
        munmap(chunk, size);
 }
@@ -180,8 +180,8 @@ SLJIT_API_FUNC_ATTRIBUTE void* sljit_mal
        sljit_uw chunk_size;
 
        allocator_grab_lock();
-       if (size < sizeof(struct free_block))
-               size = sizeof(struct free_block);
+       if (size < (64 - sizeof(struct block_header)))
+               size = (64 - sizeof(struct block_header));
        size = ALIGN_SIZE(size);
 
        free_block = free_blocks;

Modified: tomcat/jk/trunk/native/iis/pcre/sljit/sljitLir.c
URL: 
http://svn.apache.org/viewvc/tomcat/jk/trunk/native/iis/pcre/sljit/sljitLir.c?rev=1815927&r1=1815926&r2=1815927&view=diff
==============================================================================
--- tomcat/jk/trunk/native/iis/pcre/sljit/sljitLir.c (original)
+++ tomcat/jk/trunk/native/iis/pcre/sljit/sljitLir.c Tue Nov 21 14:37:37 2017
@@ -1,7 +1,7 @@
 /*
  *    Stack-less Just-In-Time compiler
  *
- *    Copyright 2009-2012 Zoltan Herczeg (hzmes...@freemail.hu). All rights 
reserved.
+ *    Copyright Zoltan Herczeg (hzmes...@freemail.hu). All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without 
modification, are
  * permitted provided that the following conditions are met:
@@ -26,6 +26,14 @@
 
 #include "sljitLir.h"
 
+#if !(defined SLJIT_STD_MACROS_DEFINED && SLJIT_STD_MACROS_DEFINED)
+
+/* These libraries are needed for the macros below. */
+#include <stdlib.h>
+#include <string.h>
+
+#endif /* SLJIT_STD_MACROS_DEFINED */
+
 #define CHECK_ERROR() \
        do { \
                if (SLJIT_UNLIKELY(compiler->error)) \
@@ -76,14 +84,18 @@
 
 #if !(defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
 
+#define VARIABLE_FLAG_SHIFT (10)
+#define VARIABLE_FLAG_MASK (0x3f << VARIABLE_FLAG_SHIFT)
+#define GET_FLAG_TYPE(op) ((op) >> VARIABLE_FLAG_SHIFT)
+
 #define GET_OPCODE(op) \
-       ((op) & ~(SLJIT_I32_OP | SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S | 
SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))
+       ((op) & ~(SLJIT_I32_OP | SLJIT_SET_Z | VARIABLE_FLAG_MASK))
 
-#define GET_FLAGS(op) \
-       ((op) & (SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S | SLJIT_SET_O | 
SLJIT_SET_C))
+#define HAS_FLAGS(op) \
+       ((op) & (SLJIT_SET_Z | VARIABLE_FLAG_MASK))
 
 #define GET_ALL_FLAGS(op) \
-       ((op) & (SLJIT_I32_OP | SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S | 
SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))
+       ((op) & (SLJIT_I32_OP | SLJIT_SET_Z | VARIABLE_FLAG_MASK))
 
 #define TYPE_CAST_NEEDED(op) \
        (((op) >= SLJIT_MOV_U8 && (op) <= SLJIT_MOV_S16) || ((op) >= 
SLJIT_MOVU_U8 && (op) <= SLJIT_MOVU_S16))
@@ -242,9 +254,21 @@
 #if !(defined SLJIT_CONFIG_UNSUPPORTED && SLJIT_CONFIG_UNSUPPORTED)
 
 #if (defined SLJIT_EXECUTABLE_ALLOCATOR && SLJIT_EXECUTABLE_ALLOCATOR)
+
+#if (defined SLJIT_PROT_EXECUTABLE_ALLOCATOR && 
SLJIT_PROT_EXECUTABLE_ALLOCATOR)
+#include "sljitProtExecAllocator.c"
+#else
 #include "sljitExecAllocator.c"
 #endif
 
+#endif
+
+#if (defined SLJIT_PROT_EXECUTABLE_ALLOCATOR && 
SLJIT_PROT_EXECUTABLE_ALLOCATOR)
+#define SLJIT_ADD_EXEC_OFFSET(ptr, exec_offset) ((sljit_u8 *)(ptr) + 
(exec_offset))
+#else
+#define SLJIT_ADD_EXEC_OFFSET(ptr, exec_offset) ((sljit_u8 *)(ptr))
+#endif
+
 /* Argument checking features. */
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
@@ -318,7 +342,7 @@
 /*  Public functions                                                     */
 /* --------------------------------------------------------------------- */
 
-#if (defined SLJIT_CONFIG_ARM_V5 && SLJIT_CONFIG_ARM_V5) || (defined 
SLJIT_CONFIG_X86 && SLJIT_CONFIG_X86)
+#if (defined SLJIT_CONFIG_X86 && SLJIT_CONFIG_X86)
 #define SLJIT_NEEDS_COMPILER_INIT 1
 static sljit_s32 compiler_initialized = 0;
 /* A thread safe initialization. */
@@ -345,6 +369,8 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_co
                int_op_and_single_op_must_be_the_same);
        SLJIT_COMPILE_ASSERT(SLJIT_REWRITABLE_JUMP != SLJIT_F32_OP,
                rewritable_jump_and_single_op_must_not_be_the_same);
+       SLJIT_COMPILE_ASSERT(!(SLJIT_EQUAL & 0x1) && !(SLJIT_LESS & 0x1) && 
!(SLJIT_EQUAL_F64 & 0x1) && !(SLJIT_JUMP & 0x1),
+               conditional_flags_must_be_even_numbers);
 
        /* Only the non-zero members must be set. */
        compiler->error = SLJIT_SUCCESS;
@@ -479,6 +505,18 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_set_
        }
 }
 
+SLJIT_API_FUNC_ATTRIBUTE void sljit_set_current_flags(struct sljit_compiler 
*compiler, sljit_s32 current_flags)
+{
+       SLJIT_UNUSED_ARG(compiler);
+       SLJIT_UNUSED_ARG(current_flags);
+
+#if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       if ((current_flags & ~(VARIABLE_FLAG_MASK | SLJIT_I32_OP | 
SLJIT_SET_Z)) == 0) {
+               compiler->last_flags = GET_FLAG_TYPE(current_flags) | 
(current_flags & (SLJIT_I32_OP | SLJIT_SET_Z));
+       }
+#endif
+}
+
 /* --------------------------------------------------------------------- */
 /*  Private functions                                                    */
 /* --------------------------------------------------------------------- */
@@ -624,65 +662,6 @@ static SLJIT_INLINE void set_const(struc
        (((exp) & SLJIT_MEM) && (((exp) & REG_MASK) == reg || OFFS_REG(exp) == 
reg))
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-#define FUNCTION_CHECK_OP() \
-       CHECK_ARGUMENT(!GET_FLAGS(op) || !(op & SLJIT_KEEP_FLAGS)); \
-       switch (GET_OPCODE(op)) { \
-       case SLJIT_NOT: \
-       case SLJIT_CLZ: \
-       case SLJIT_AND: \
-       case SLJIT_OR: \
-       case SLJIT_XOR: \
-       case SLJIT_SHL: \
-       case SLJIT_LSHR: \
-       case SLJIT_ASHR: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_U | SLJIT_SET_S | SLJIT_SET_O 
| SLJIT_SET_C))); \
-               break; \
-       case SLJIT_NEG: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_U | SLJIT_SET_S | 
SLJIT_SET_C))); \
-               break; \
-       case SLJIT_MUL: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S 
| SLJIT_SET_C))); \
-               break; \
-       case SLJIT_ADD: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_U | SLJIT_SET_S))); \
-               break; \
-       case SLJIT_SUB: \
-               break; \
-       case SLJIT_ADDC: \
-       case SLJIT_SUBC: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S 
| SLJIT_SET_O))); \
-               break; \
-       case SLJIT_BREAKPOINT: \
-       case SLJIT_NOP: \
-       case SLJIT_LMUL_UW: \
-       case SLJIT_LMUL_SW: \
-       case SLJIT_MOV: \
-       case SLJIT_MOV_U32: \
-       case SLJIT_MOV_P: \
-       case SLJIT_MOVU: \
-       case SLJIT_MOVU_U32: \
-       case SLJIT_MOVU_P: \
-               /* Nothing allowed */ \
-               CHECK_ARGUMENT(!(op & (SLJIT_I32_OP | SLJIT_SET_E | SLJIT_SET_U 
| SLJIT_SET_S | SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \
-               break; \
-       default: \
-               /* Only SLJIT_I32_OP or SLJIT_F32_OP is allowed. */ \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S 
| SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \
-               break; \
-       }
-
-#define FUNCTION_CHECK_FOP() \
-       CHECK_ARGUMENT(!GET_FLAGS(op) || !(op & SLJIT_KEEP_FLAGS)); \
-       switch (GET_OPCODE(op)) { \
-       case SLJIT_CMP_F64: \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_U | SLJIT_SET_O | SLJIT_SET_C 
| SLJIT_KEEP_FLAGS))); \
-               CHECK_ARGUMENT((op & (SLJIT_SET_E | SLJIT_SET_S))); \
-               break; \
-       default: \
-               /* Only SLJIT_I32_OP or SLJIT_F32_OP is allowed. */ \
-               CHECK_ARGUMENT(!(op & (SLJIT_SET_E | SLJIT_SET_U | SLJIT_SET_S 
| SLJIT_SET_O | SLJIT_SET_C | SLJIT_KEEP_FLAGS))); \
-               break; \
-       }
 
 #define FUNCTION_CHECK_IS_REG(r) \
        (((r) >= SLJIT_R0 && (r) < (SLJIT_R0 + compiler->scratches)) || \
@@ -718,12 +697,12 @@ static SLJIT_INLINE void set_const(struc
                        CHECK_NOT_VIRTUAL_REGISTER(OFFS_REG(p)); \
                        CHECK_ARGUMENT(!((i) & ~0x3)); \
                } \
-               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | SLJIT_IMM | REG_MASK | 
OFFS_REG_MASK))); \
+               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | REG_MASK | 
OFFS_REG_MASK))); \
        }
 
-#define FUNCTION_CHECK_DST(p, i) \
+#define FUNCTION_CHECK_DST(p, i, unused) \
        CHECK_ARGUMENT(compiler->scratches != -1 && compiler->saveds != -1); \
-       if (FUNCTION_CHECK_IS_REG_OR_UNUSED(p)) \
+       if (FUNCTION_CHECK_IS_REG(p) || ((unused) && (p) == SLJIT_UNUSED)) \
                CHECK_ARGUMENT((i) == 0); \
        else if ((p) == (SLJIT_MEM1(SLJIT_SP))) \
                CHECK_ARGUMENT((i) >= 0 && (i) < compiler->logical_local_size); 
\
@@ -737,7 +716,7 @@ static SLJIT_INLINE void set_const(struc
                        CHECK_NOT_VIRTUAL_REGISTER(OFFS_REG(p)); \
                        CHECK_ARGUMENT(!((i) & ~0x3)); \
                } \
-               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | SLJIT_IMM | REG_MASK | 
OFFS_REG_MASK))); \
+               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | REG_MASK | 
OFFS_REG_MASK))); \
        }
 
 #define FUNCTION_FCHECK(p, i) \
@@ -757,15 +736,7 @@ static SLJIT_INLINE void set_const(struc
                        CHECK_NOT_VIRTUAL_REGISTER(OFFS_REG(p)); \
                        CHECK_ARGUMENT(((p) & OFFS_REG_MASK) != 
TO_OFFS_REG(SLJIT_SP) && !(i & ~0x3)); \
                } \
-               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | SLJIT_IMM | REG_MASK | 
OFFS_REG_MASK))); \
-       }
-
-#define FUNCTION_CHECK_OP1() \
-       if (GET_OPCODE(op) >= SLJIT_MOVU && GET_OPCODE(op) <= SLJIT_MOVU_P) { \
-               CHECK_ARGUMENT(!(src & SLJIT_MEM) || (src & REG_MASK) != 
SLJIT_SP); \
-               CHECK_ARGUMENT(!(dst & SLJIT_MEM) || (dst & REG_MASK) != 
SLJIT_SP); \
-               if ((src & SLJIT_MEM) && (src & REG_MASK)) \
-                       CHECK_ARGUMENT((dst & REG_MASK) != (src & REG_MASK) && 
OFFS_REG(dst) != (src & REG_MASK)); \
+               CHECK_ARGUMENT(!((p) & ~(SLJIT_MEM | REG_MASK | 
OFFS_REG_MASK))); \
        }
 
 #endif /* SLJIT_ARGUMENT_CHECKS */
@@ -791,8 +762,10 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_comp
        do { \
                if ((r) < (SLJIT_R0 + compiler->scratches)) \
                        fprintf(compiler->verbose, "r%d", (r) - SLJIT_R0); \
-               else \
+               else if ((r) != SLJIT_SP) \
                        fprintf(compiler->verbose, "s%d", 
SLJIT_NUMBER_OF_REGISTERS - (r)); \
+               else \
+                       fprintf(compiler->verbose, "sp"); \
        } while (0)
 
 #define sljit_verbose_param(compiler, p, i) \
@@ -885,6 +858,7 @@ static char* jump_names[] = {
        (char*)"sig_greater", (char*)"sig_less_equal",
        (char*)"overflow", (char*)"not_overflow",
        (char*)"mul_overflow", (char*)"mul_not_overflow",
+       (char*)"carry", (char*)"",
        (char*)"equal", (char*)"not_equal",
        (char*)"less", (char*)"greater_equal",
        (char*)"greater", (char*)"less_equal",
@@ -929,7 +903,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        SLJIT_UNUSED_ARG(compiler);
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(!(options & ~SLJIT_DOUBLE_ALIGNMENT));
+       CHECK_ARGUMENT(!(options & ~SLJIT_F64_ALIGNMENT));
        CHECK_ARGUMENT(args >= 0 && args <= 3);
        CHECK_ARGUMENT(scratches >= 0 && scratches <= 
SLJIT_NUMBER_OF_REGISTERS);
        CHECK_ARGUMENT(saveds >= 0 && saveds <= SLJIT_NUMBER_OF_REGISTERS);
@@ -939,6 +913,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        CHECK_ARGUMENT(fsaveds >= 0 && fsaveds <= 
SLJIT_NUMBER_OF_FLOAT_REGISTERS);
        CHECK_ARGUMENT(fscratches + fsaveds <= SLJIT_NUMBER_OF_FLOAT_REGISTERS);
        CHECK_ARGUMENT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose))
@@ -952,13 +927,8 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        sljit_s32 options, sljit_s32 args, sljit_s32 scratches, sljit_s32 
saveds,
        sljit_s32 fscratches, sljit_s32 fsaveds, sljit_s32 local_size)
 {
-       if (SLJIT_UNLIKELY(compiler->skip_checks)) {
-               compiler->skip_checks = 0;
-               CHECK_RETURN_OK;
-       }
-
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(!(options & ~SLJIT_DOUBLE_ALIGNMENT));
+       CHECK_ARGUMENT(!(options & ~SLJIT_F64_ALIGNMENT));
        CHECK_ARGUMENT(args >= 0 && args <= 3);
        CHECK_ARGUMENT(scratches >= 0 && scratches <= 
SLJIT_NUMBER_OF_REGISTERS);
        CHECK_ARGUMENT(saveds >= 0 && saveds <= SLJIT_NUMBER_OF_REGISTERS);
@@ -968,6 +938,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        CHECK_ARGUMENT(fsaveds >= 0 && fsaveds <= 
SLJIT_NUMBER_OF_FLOAT_REGISTERS);
        CHECK_ARGUMENT(fscratches + fsaveds <= SLJIT_NUMBER_OF_FLOAT_REGISTERS);
        CHECK_ARGUMENT(local_size >= 0 && local_size <= SLJIT_MAX_LOCAL_SIZE);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose))
@@ -987,6 +958,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        }
        else
                CHECK_ARGUMENT(src == 0 && srcw == 0);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1005,7 +977,8 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 static SLJIT_INLINE CHECK_RETURN_TYPE check_sljit_emit_fast_enter(struct 
sljit_compiler *compiler, sljit_s32 dst, sljit_sw dstw)
 {
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       FUNCTION_CHECK_DST(dst, dstw);
+       FUNCTION_CHECK_DST(dst, dstw, 0);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1021,6 +994,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 {
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        FUNCTION_CHECK_SRC(src, srcw);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1038,6 +1012,8 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        CHECK_ARGUMENT((op >= SLJIT_BREAKPOINT && op <= SLJIT_LMUL_SW)
                || ((op & ~SLJIT_I32_OP) >= SLJIT_DIVMOD_UW && (op & 
~SLJIT_I32_OP) <= SLJIT_DIV_SW));
        CHECK_ARGUMENT(op < SLJIT_LMUL_UW || compiler->scratches >= 2);
+       if (op >= SLJIT_LMUL_UW)
+               compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose))
@@ -1063,10 +1039,49 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_MOV && GET_OPCODE(op) <= 
SLJIT_CLZ);
-       FUNCTION_CHECK_OP();
+
+       switch (GET_OPCODE(op)) {
+       case SLJIT_NOT:
+               /* Only SLJIT_I32_OP and SLJIT_SET_Z are allowed. */
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK));
+               break;
+       case SLJIT_NEG:
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK)
+                       || GET_FLAG_TYPE(op) == SLJIT_OVERFLOW);
+               break;
+       case SLJIT_MOV:
+       case SLJIT_MOV_U32:
+       case SLJIT_MOV_P:
+       case SLJIT_MOVU:
+       case SLJIT_MOVU_U32:
+       case SLJIT_MOVU_P:
+               /* Nothing allowed */
+               CHECK_ARGUMENT(!(op & (SLJIT_I32_OP | SLJIT_SET_Z | 
VARIABLE_FLAG_MASK)));
+               break;
+       default:
+               /* Only SLJIT_I32_OP is allowed. */
+               CHECK_ARGUMENT(!(op & (SLJIT_SET_Z | VARIABLE_FLAG_MASK)));
+               break;
+       }
+
+       FUNCTION_CHECK_DST(dst, dstw, 1);
        FUNCTION_CHECK_SRC(src, srcw);
-       FUNCTION_CHECK_DST(dst, dstw);
-       FUNCTION_CHECK_OP1();
+
+       if (GET_OPCODE(op) >= SLJIT_NOT)
+               compiler->last_flags = GET_FLAG_TYPE(op) | (op & (SLJIT_I32_OP 
| SLJIT_SET_Z));
+       else if (GET_OPCODE(op) >= SLJIT_MOVU) {
+               CHECK_ARGUMENT(!(src & SLJIT_MEM) || (src & REG_MASK) != 
SLJIT_SP);
+               CHECK_ARGUMENT(!(dst & SLJIT_MEM) || (dst & REG_MASK) != 
SLJIT_SP);
+               if ((src & REG_MASK) != SLJIT_UNUSED) {
+                       CHECK_ARGUMENT((src & REG_MASK) != (dst & REG_MASK) && 
(src & REG_MASK) != OFFS_REG(dst));
+                       CHECK_ARGUMENT((src & OFFS_REG_MASK) == SLJIT_UNUSED || 
srcw == 0);
+               }
+               if ((dst & REG_MASK) != SLJIT_UNUSED) {
+                       CHECK_ARGUMENT((dst & REG_MASK) != OFFS_REG(src));
+                       CHECK_ARGUMENT((dst & OFFS_REG_MASK) == SLJIT_UNUSED || 
dstw == 0);
+               }
+               compiler->last_flags = 0;
+       }
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1077,9 +1092,9 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
                }
                else
                {
-                       fprintf(compiler->verbose, "  %s%s%s%s%s%s%s%s ", 
op1_names[GET_OPCODE(op) - SLJIT_OP1_BASE], !(op & SLJIT_I32_OP) ? "" : "32",
-                               !(op & SLJIT_SET_E) ? "" : ".e", !(op & 
SLJIT_SET_U) ? "" : ".u", !(op & SLJIT_SET_S) ? "" : ".s",
-                               !(op & SLJIT_SET_O) ? "" : ".o", !(op & 
SLJIT_SET_C) ? "" : ".c", !(op & SLJIT_KEEP_FLAGS) ? "" : ".k");
+                       fprintf(compiler->verbose, "  %s%s%s%s%s ", 
op1_names[GET_OPCODE(op) - SLJIT_OP1_BASE], !(op & SLJIT_I32_OP) ? "" : "32",
+                               !(op & SLJIT_SET_Z) ? "" : ".z", !(op & 
VARIABLE_FLAG_MASK) ? "" : ".",
+                               !(op & VARIABLE_FLAG_MASK) ? "" : 
jump_names[GET_FLAG_TYPE(op)]);
                }
 
                sljit_verbose_param(compiler, dst, dstw);
@@ -1103,16 +1118,53 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_ADD && GET_OPCODE(op) <= 
SLJIT_ASHR);
-       FUNCTION_CHECK_OP();
+
+       switch (GET_OPCODE(op)) {
+       case SLJIT_AND:
+       case SLJIT_OR:
+       case SLJIT_XOR:
+       case SLJIT_SHL:
+       case SLJIT_LSHR:
+       case SLJIT_ASHR:
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK));
+               break;
+       case SLJIT_MUL:
+               CHECK_ARGUMENT(!(op & SLJIT_SET_Z));
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK)
+                       || GET_FLAG_TYPE(op) == SLJIT_MUL_OVERFLOW);
+               break;
+       case SLJIT_ADD:
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK)
+                       || GET_FLAG_TYPE(op) == GET_FLAG_TYPE(SLJIT_SET_CARRY)
+                       || GET_FLAG_TYPE(op) == SLJIT_OVERFLOW);
+               break;
+       case SLJIT_SUB:
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK)
+                       || (GET_FLAG_TYPE(op) >= SLJIT_LESS && 
GET_FLAG_TYPE(op) <= SLJIT_OVERFLOW)
+                       || GET_FLAG_TYPE(op) == GET_FLAG_TYPE(SLJIT_SET_CARRY));
+               break;
+       case SLJIT_ADDC:
+       case SLJIT_SUBC:
+               CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK)
+                       || GET_FLAG_TYPE(op) == GET_FLAG_TYPE(SLJIT_SET_CARRY));
+               CHECK_ARGUMENT((compiler->last_flags & 0xff) == 
GET_FLAG_TYPE(SLJIT_SET_CARRY));
+               CHECK_ARGUMENT((op & SLJIT_I32_OP) == (compiler->last_flags & 
SLJIT_I32_OP));
+               break;
+       default:
+               SLJIT_UNREACHABLE();
+               break;
+       }
+
+       FUNCTION_CHECK_DST(dst, dstw, 1);
        FUNCTION_CHECK_SRC(src1, src1w);
        FUNCTION_CHECK_SRC(src2, src2w);
-       FUNCTION_CHECK_DST(dst, dstw);
+       compiler->last_flags = GET_FLAG_TYPE(op) | (op & (SLJIT_I32_OP | 
SLJIT_SET_Z));
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
-               fprintf(compiler->verbose, "  %s%s%s%s%s%s%s%s ", 
op2_names[GET_OPCODE(op) - SLJIT_OP2_BASE], !(op & SLJIT_I32_OP) ? "" : "32",
-                       !(op & SLJIT_SET_E) ? "" : ".e", !(op & SLJIT_SET_U) ? 
"" : ".u", !(op & SLJIT_SET_S) ? "" : ".s",
-                       !(op & SLJIT_SET_O) ? "" : ".o", !(op & SLJIT_SET_C) ? 
"" : ".c", !(op & SLJIT_KEEP_FLAGS) ? "" : ".k");
+               fprintf(compiler->verbose, "  %s%s%s%s%s ", 
op2_names[GET_OPCODE(op) - SLJIT_OP2_BASE], !(op & SLJIT_I32_OP) ? "" : "32",
+                       !(op & SLJIT_SET_Z) ? "" : ".z", !(op & 
VARIABLE_FLAG_MASK) ? "" : ".",
+                       !(op & VARIABLE_FLAG_MASK) ? "" : 
jump_names[GET_FLAG_TYPE(op)]);
                sljit_verbose_param(compiler, dst, dstw);
                fprintf(compiler->verbose, ", ");
                sljit_verbose_param(compiler, src1, src1w);
@@ -1153,6 +1205,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        CHECK_ARGUMENT(instruction);
+
 #if (defined SLJIT_CONFIG_X86 && SLJIT_CONFIG_X86)
        CHECK_ARGUMENT(size > 0 && size < 16);
 #elif (defined SLJIT_CONFIG_ARM_THUMB2 && SLJIT_CONFIG_ARM_THUMB2)
@@ -1162,6 +1215,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        CHECK_ARGUMENT(size == 4 && (((sljit_sw)instruction) & 0x3) == 0);
 #endif
 
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1184,9 +1238,9 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        }
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_MOV_F64 && GET_OPCODE(op) <= 
SLJIT_ABS_F64);
-       FUNCTION_CHECK_FOP();
+       CHECK_ARGUMENT(!(op & (SLJIT_SET_Z | VARIABLE_FLAG_MASK)));
        FUNCTION_FCHECK(src, srcw);
        FUNCTION_FCHECK(dst, dstw);
 #endif
@@ -1212,22 +1266,31 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        sljit_s32 src1, sljit_sw src1w,
        sljit_s32 src2, sljit_sw src2w)
 {
+#if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->last_flags = GET_FLAG_TYPE(op) | (op & (SLJIT_I32_OP | 
SLJIT_SET_Z));
+#endif
+
        if (SLJIT_UNLIKELY(compiler->skip_checks)) {
                compiler->skip_checks = 0;
                CHECK_RETURN_OK;
        }
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(GET_OPCODE(op) == SLJIT_CMP_F64);
-       FUNCTION_CHECK_FOP();
+       CHECK_ARGUMENT(!(op & SLJIT_SET_Z));
+       CHECK_ARGUMENT((op & VARIABLE_FLAG_MASK)
+               || (GET_FLAG_TYPE(op) >= SLJIT_EQUAL_F64 && GET_FLAG_TYPE(op) 
<= SLJIT_ORDERED_F64));
        FUNCTION_FCHECK(src1, src1w);
        FUNCTION_FCHECK(src2, src2w);
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
-               fprintf(compiler->verbose, "  %s%s%s%s ", 
fop1_names[SLJIT_CMP_F64 - SLJIT_FOP1_BASE], (op & SLJIT_F32_OP) ? ".f32" : 
".f64",
-                       (op & SLJIT_SET_E) ? ".e" : "", (op & SLJIT_SET_S) ? 
".s" : "");
+               fprintf(compiler->verbose, "  %s%s", fop1_names[SLJIT_CMP_F64 - 
SLJIT_FOP1_BASE], (op & SLJIT_F32_OP) ? ".f32" : ".f64");
+               if (op & VARIABLE_FLAG_MASK) {
+                       fprintf(compiler->verbose, ".%s_f", 
jump_names[GET_FLAG_TYPE(op)]);
+               }
+               fprintf(compiler->verbose, " ");
                sljit_verbose_fparam(compiler, src1, src1w);
                fprintf(compiler->verbose, ", ");
                sljit_verbose_fparam(compiler, src2, src2w);
@@ -1247,11 +1310,11 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        }
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_CONV_SW_FROM_F64 && 
GET_OPCODE(op) <= SLJIT_CONV_S32_FROM_F64);
-       FUNCTION_CHECK_FOP();
+       CHECK_ARGUMENT(!(op & (SLJIT_SET_Z | VARIABLE_FLAG_MASK)));
        FUNCTION_FCHECK(src, srcw);
-       FUNCTION_CHECK_DST(dst, dstw);
+       FUNCTION_CHECK_DST(dst, dstw, 0);
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1277,9 +1340,9 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        }
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_CONV_F64_FROM_SW && 
GET_OPCODE(op) <= SLJIT_CONV_F64_FROM_S32);
-       FUNCTION_CHECK_FOP();
+       CHECK_ARGUMENT(!(op & (SLJIT_SET_Z | VARIABLE_FLAG_MASK)));
        FUNCTION_CHECK_SRC(src, srcw);
        FUNCTION_FCHECK(dst, dstw);
 #endif
@@ -1303,9 +1366,9 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        sljit_s32 src2, sljit_sw src2w)
 {
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(GET_OPCODE(op) >= SLJIT_ADD_F64 && GET_OPCODE(op) <= 
SLJIT_DIV_F64);
-       FUNCTION_CHECK_FOP();
+       CHECK_ARGUMENT(!(op & (SLJIT_SET_Z | VARIABLE_FLAG_MASK)));
        FUNCTION_FCHECK(src1, src1w);
        FUNCTION_FCHECK(src2, src2w);
        FUNCTION_FCHECK(dst, dstw);
@@ -1328,6 +1391,15 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 {
        SLJIT_UNUSED_ARG(compiler);
 
+       if (SLJIT_UNLIKELY(compiler->skip_checks)) {
+               compiler->skip_checks = 0;
+               CHECK_RETURN_OK;
+       }
+
+#if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->last_flags = 0;
+#endif
+
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose))
                fprintf(compiler->verbose, "label:\n");
@@ -1344,9 +1416,20 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        CHECK_ARGUMENT(!(type & ~(0xff | SLJIT_REWRITABLE_JUMP | 
SLJIT_I32_OP)));
+       CHECK_ARGUMENT((type & 0xff) != GET_FLAG_TYPE(SLJIT_SET_CARRY) && (type 
& 0xff) != (GET_FLAG_TYPE(SLJIT_SET_CARRY) + 1));
        CHECK_ARGUMENT((type & 0xff) >= SLJIT_EQUAL && (type & 0xff) <= 
SLJIT_CALL3);
        CHECK_ARGUMENT((type & 0xff) < SLJIT_JUMP || !(type & SLJIT_I32_OP));
        CHECK_ARGUMENT((type & 0xff) <= SLJIT_CALL0 || ((type & 0xff) - 
SLJIT_CALL0) <= compiler->scratches);
+
+       if ((type & 0xff) < SLJIT_JUMP) {
+               if ((type & 0xff) <= SLJIT_NOT_ZERO)
+                       CHECK_ARGUMENT(compiler->last_flags & SLJIT_SET_Z);
+               else
+                       CHECK_ARGUMENT((type & 0xff) == (compiler->last_flags & 
0xff)
+                               || ((type & 0xff) == SLJIT_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_OVERFLOW)
+                               || ((type & 0xff) == SLJIT_MUL_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_MUL_OVERFLOW));
+               CHECK_ARGUMENT((type & SLJIT_I32_OP) == (compiler->last_flags & 
SLJIT_I32_OP));
+       }
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose))
@@ -1365,6 +1448,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        CHECK_ARGUMENT((type & 0xff) >= SLJIT_EQUAL && (type & 0xff) <= 
SLJIT_SIG_LESS_EQUAL);
        FUNCTION_CHECK_SRC(src1, src1w);
        FUNCTION_CHECK_SRC(src2, src2w);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1384,11 +1468,12 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        sljit_s32 src2, sljit_sw src2w)
 {
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       CHECK_ARGUMENT(sljit_is_fpu_available());
+       CHECK_ARGUMENT(sljit_has_cpu_feature(SLJIT_HAS_FPU));
        CHECK_ARGUMENT(!(type & ~(0xff | SLJIT_REWRITABLE_JUMP | 
SLJIT_F32_OP)));
        CHECK_ARGUMENT((type & 0xff) >= SLJIT_EQUAL_F64 && (type & 0xff) <= 
SLJIT_ORDERED_F64);
        FUNCTION_FCHECK(src1, src1w);
        FUNCTION_FCHECK(src2, src2w);
+       compiler->last_flags = 0;
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1405,6 +1490,10 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 static SLJIT_INLINE CHECK_RETURN_TYPE check_sljit_emit_ijump(struct 
sljit_compiler *compiler, sljit_s32 type, sljit_s32 src, sljit_sw srcw)
 {
+#if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->last_flags = 0;
+#endif
+
        if (SLJIT_UNLIKELY(compiler->skip_checks)) {
                compiler->skip_checks = 0;
                CHECK_RETURN_OK;
@@ -1427,46 +1516,80 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
 
 static SLJIT_INLINE CHECK_RETURN_TYPE check_sljit_emit_op_flags(struct 
sljit_compiler *compiler, sljit_s32 op,
        sljit_s32 dst, sljit_sw dstw,
-       sljit_s32 src, sljit_sw srcw,
        sljit_s32 type)
 {
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        CHECK_ARGUMENT(!(type & ~(0xff | SLJIT_I32_OP)));
        CHECK_ARGUMENT((type & 0xff) >= SLJIT_EQUAL && (type & 0xff) <= 
SLJIT_ORDERED_F64);
-       CHECK_ARGUMENT(op == SLJIT_MOV || GET_OPCODE(op) == SLJIT_MOV_U32 || 
GET_OPCODE(op) == SLJIT_MOV_S32
+       CHECK_ARGUMENT((type & 0xff) != GET_FLAG_TYPE(SLJIT_SET_CARRY) && (type 
& 0xff) != (GET_FLAG_TYPE(SLJIT_SET_CARRY) + 1));
+       CHECK_ARGUMENT(op == SLJIT_MOV || op == SLJIT_MOV32
                || (GET_OPCODE(op) >= SLJIT_AND && GET_OPCODE(op) <= 
SLJIT_XOR));
-       CHECK_ARGUMENT((op & (SLJIT_SET_U | SLJIT_SET_S | SLJIT_SET_O | 
SLJIT_SET_C)) == 0);
-       CHECK_ARGUMENT((op & (SLJIT_SET_E | SLJIT_KEEP_FLAGS)) != (SLJIT_SET_E 
| SLJIT_KEEP_FLAGS));
-       if (GET_OPCODE(op) < SLJIT_ADD) {
-               CHECK_ARGUMENT(src == SLJIT_UNUSED && srcw == 0);
-       } else {
-               CHECK_ARGUMENT(src == dst && srcw == dstw);
-       }
-       FUNCTION_CHECK_DST(dst, dstw);
+       CHECK_ARGUMENT(!(op & VARIABLE_FLAG_MASK));
+
+       if ((type & 0xff) <= SLJIT_NOT_ZERO)
+               CHECK_ARGUMENT(compiler->last_flags & SLJIT_SET_Z);
+       else
+               CHECK_ARGUMENT((type & 0xff) == (compiler->last_flags & 0xff)
+                       || ((type & 0xff) == SLJIT_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_OVERFLOW)
+                       || ((type & 0xff) == SLJIT_MUL_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_MUL_OVERFLOW));
+
+       FUNCTION_CHECK_DST(dst, dstw, 0);
+
+       if (GET_OPCODE(op) >= SLJIT_ADD)
+               compiler->last_flags = GET_FLAG_TYPE(op) | (op & (SLJIT_I32_OP 
| SLJIT_SET_Z));
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
-               fprintf(compiler->verbose, "  flags %s%s%s%s, ",
-                       !(op & SLJIT_SET_E) ? "" : ".e", !(op & 
SLJIT_KEEP_FLAGS) ? "" : ".k",
+               fprintf(compiler->verbose, "  flags%s %s%s, ",
+                       !(op & SLJIT_SET_Z) ? "" : ".z",
                        GET_OPCODE(op) < SLJIT_OP2_BASE ? "mov" : 
op2_names[GET_OPCODE(op) - SLJIT_OP2_BASE],
                        GET_OPCODE(op) < SLJIT_OP2_BASE ? 
op1_names[GET_OPCODE(op) - SLJIT_OP1_BASE] : ((op & SLJIT_I32_OP) ? "32" : ""));
                sljit_verbose_param(compiler, dst, dstw);
-               if (src != SLJIT_UNUSED) {
-                       fprintf(compiler->verbose, ", ");
-                       sljit_verbose_param(compiler, src, srcw);
-               }
                fprintf(compiler->verbose, ", %s%s\n", jump_names[type & 0xff], 
JUMP_POSTFIX(type));
        }
 #endif
        CHECK_RETURN_OK;
 }
 
+static SLJIT_INLINE CHECK_RETURN_TYPE check_sljit_emit_cmov(struct 
sljit_compiler *compiler, sljit_s32 type,
+       sljit_s32 dst_reg,
+       sljit_s32 src, sljit_sw srcw)
+{
+#if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       CHECK_ARGUMENT(!(type & ~(0xff | SLJIT_I32_OP)));
+       CHECK_ARGUMENT((type & 0xff) >= SLJIT_EQUAL && (type & 0xff) <= 
SLJIT_ORDERED_F64);
+       CHECK_ARGUMENT(FUNCTION_CHECK_IS_REG(dst_reg & ~SLJIT_I32_OP));
+       if (src != SLJIT_IMM) {
+               CHECK_ARGUMENT(FUNCTION_CHECK_IS_REG(src));
+       }
+
+       if ((type & 0xff) <= SLJIT_NOT_ZERO)
+               CHECK_ARGUMENT(compiler->last_flags & SLJIT_SET_Z);
+       else
+               CHECK_ARGUMENT((type & 0xff) == (compiler->last_flags & 0xff)
+                       || ((type & 0xff) == SLJIT_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_OVERFLOW)
+                       || ((type & 0xff) == SLJIT_MUL_NOT_OVERFLOW && 
(compiler->last_flags & 0xff) == SLJIT_MUL_OVERFLOW));
+#endif
+#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
+       if (SLJIT_UNLIKELY(!!compiler->verbose)) {
+               fprintf(compiler->verbose, "  cmov%s %s%s, ",
+                       !(dst_reg & SLJIT_I32_OP) ? "" : ".i",
+                       jump_names[type & 0xff], JUMP_POSTFIX(type));
+               sljit_verbose_reg(compiler, dst_reg & ~SLJIT_I32_OP);
+               fprintf(compiler->verbose, ", ");
+               sljit_verbose_param(compiler, src, srcw);
+               fprintf(compiler->verbose, "\n");
+       }
+#endif
+       CHECK_RETURN_OK;
+}
+
 static SLJIT_INLINE CHECK_RETURN_TYPE check_sljit_get_local_base(struct 
sljit_compiler *compiler, sljit_s32 dst, sljit_sw dstw, sljit_sw offset)
 {
        SLJIT_UNUSED_ARG(offset);
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       FUNCTION_CHECK_DST(dst, dstw);
+       FUNCTION_CHECK_DST(dst, dstw, 0);
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1483,7 +1606,7 @@ static SLJIT_INLINE CHECK_RETURN_TYPE ch
        SLJIT_UNUSED_ARG(init_value);
 
 #if (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
-       FUNCTION_CHECK_DST(dst, dstw);
+       FUNCTION_CHECK_DST(dst, dstw, 0);
 #endif
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE)
        if (SLJIT_UNLIKELY(!!compiler->verbose)) {
@@ -1544,6 +1667,44 @@ static SLJIT_INLINE sljit_s32 emit_mov_b
        return sljit_emit_op1(compiler, op, SLJIT_RETURN_REG, 0, src, srcw);
 }
 
+#if (defined SLJIT_CONFIG_X86 && SLJIT_CONFIG_X86) \
+               || (defined SLJIT_CONFIG_PPC && SLJIT_CONFIG_PPC) \
+               || (defined SLJIT_CONFIG_SPARC_32 && SLJIT_CONFIG_SPARC_32) \
+               || ((defined SLJIT_CONFIG_MIPS && SLJIT_CONFIG_MIPS) && 
!(defined SLJIT_MIPS_R1 && SLJIT_MIPS_R1))
+
+static SLJIT_INLINE sljit_s32 sljit_emit_cmov_generic(struct sljit_compiler 
*compiler, sljit_s32 type,
+       sljit_s32 dst_reg,
+       sljit_s32 src, sljit_sw srcw)
+{
+       struct sljit_label *label;
+       struct sljit_jump *jump;
+       sljit_s32 op = (dst_reg & SLJIT_I32_OP) ? SLJIT_MOV32 : SLJIT_MOV;
+
+#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
+               || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->skip_checks = 1;
+#endif
+       jump = sljit_emit_jump(compiler, type ^ 0x1);
+       FAIL_IF(!jump);
+
+#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
+               || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->skip_checks = 1;
+#endif
+       FAIL_IF(sljit_emit_op1(compiler, op, dst_reg & ~SLJIT_I32_OP, 0, src, 
srcw));
+
+#if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
+               || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
+       compiler->skip_checks = 1;
+#endif
+       label = sljit_emit_label(compiler);
+       FAIL_IF(!label);
+       sljit_set_label(jump, label);
+       return SLJIT_SUCCESS;
+}
+
+#endif
+
 /* CPU description section */
 
 #if (defined SLJIT_32BIT_ARCHITECTURE && SLJIT_32BIT_ARCHITECTURE)
@@ -1645,6 +1806,7 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
                        condition = SLJIT_SIG_GREATER_EQUAL;
                        break;
                }
+
                type = condition | (type & (SLJIT_I32_OP | 
SLJIT_REWRITABLE_JUMP));
                tmp_src = src1;
                src1 = src2;
@@ -1655,11 +1817,9 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
        }
 
        if (condition <= SLJIT_NOT_ZERO)
-               flags = SLJIT_SET_E;
-       else if (condition <= SLJIT_LESS_EQUAL)
-               flags = SLJIT_SET_U;
+               flags = SLJIT_SET_Z;
        else
-               flags = SLJIT_SET_S;
+               flags = condition << VARIABLE_FLAG_SHIFT;
 
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
                || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
@@ -1671,38 +1831,31 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
                || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        compiler->skip_checks = 1;
 #endif
-       return sljit_emit_jump(compiler, condition | (type & 
SLJIT_REWRITABLE_JUMP));
+       return sljit_emit_jump(compiler, condition | (type & 
(SLJIT_REWRITABLE_JUMP | SLJIT_I32_OP)));
 }
 
+#endif
+
 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump* sljit_emit_fcmp(struct 
sljit_compiler *compiler, sljit_s32 type,
        sljit_s32 src1, sljit_sw src1w,
        sljit_s32 src2, sljit_sw src2w)
 {
-       sljit_s32 flags, condition;
-
        CHECK_ERROR_PTR();
        CHECK_PTR(check_sljit_emit_fcmp(compiler, type, src1, src1w, src2, 
src2w));
 
-       condition = type & 0xff;
-       flags = (condition <= SLJIT_NOT_EQUAL_F64) ? SLJIT_SET_E : SLJIT_SET_S;
-       if (type & SLJIT_F32_OP)
-               flags |= SLJIT_F32_OP;
-
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
                || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        compiler->skip_checks = 1;
 #endif
-       sljit_emit_fop1(compiler, SLJIT_CMP_F64 | flags, src1, src1w, src2, 
src2w);
+       sljit_emit_fop1(compiler, SLJIT_CMP_F64 | ((type & 0xff) << 
VARIABLE_FLAG_SHIFT) | (type & SLJIT_I32_OP), src1, src1w, src2, src2w);
 
 #if (defined SLJIT_VERBOSE && SLJIT_VERBOSE) \
                || (defined SLJIT_ARGUMENT_CHECKS && SLJIT_ARGUMENT_CHECKS)
        compiler->skip_checks = 1;
 #endif
-       return sljit_emit_jump(compiler, condition | (type & 
SLJIT_REWRITABLE_JUMP));
+       return sljit_emit_jump(compiler, type);
 }
 
-#endif
-
 #if !(defined SLJIT_CONFIG_X86 && SLJIT_CONFIG_X86)
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_get_local_base(struct sljit_compiler 
*compiler, sljit_s32 dst, sljit_sw dstw, sljit_sw offset)
@@ -1716,7 +1869,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        compiler->skip_checks = 1;
 #endif
        if (offset != 0)
-               return sljit_emit_op2(compiler, SLJIT_ADD | SLJIT_KEEP_FLAGS, 
dst, dstw, SLJIT_SP, 0, SLJIT_IMM, offset);
+               return sljit_emit_op2(compiler, SLJIT_ADD, dst, dstw, SLJIT_SP, 
0, SLJIT_IMM, offset);
        return sljit_emit_op1(compiler, SLJIT_MOV, dst, dstw, SLJIT_SP, 0);
 }
 
@@ -1731,23 +1884,30 @@ SLJIT_API_FUNC_ATTRIBUTE const char* slj
        return "unsupported";
 }
 
-SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_create_compiler(void)
+SLJIT_API_FUNC_ATTRIBUTE struct sljit_compiler* sljit_create_compiler(void 
*allocator_data)
 {
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNUSED_ARG(allocator_data);
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_compiler(struct sljit_compiler 
*compiler)
 {
        SLJIT_UNUSED_ARG(compiler);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
+}
+
+SLJIT_API_FUNC_ATTRIBUTE void sljit_set_compiler_memory_error(struct 
sljit_compiler *compiler)
+{
+       SLJIT_UNUSED_ARG(compiler);
+       SLJIT_UNREACHABLE();
 }
 
 SLJIT_API_FUNC_ATTRIBUTE void* sljit_alloc_memory(struct sljit_compiler 
*compiler, sljit_s32 size)
 {
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(size);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
@@ -1756,21 +1916,28 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_comp
 {
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(verbose);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
 }
 #endif
 
 SLJIT_API_FUNC_ATTRIBUTE void* sljit_generate_code(struct sljit_compiler 
*compiler)
 {
        SLJIT_UNUSED_ARG(compiler);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
+SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_has_cpu_feature(sljit_s32 
feature_type)
+{
+       SLJIT_UNUSED_ARG(feature_type);
+       SLJIT_UNREACHABLE();
+       return 0;
+}
+
 SLJIT_API_FUNC_ATTRIBUTE void sljit_free_code(void* code)
 {
        SLJIT_UNUSED_ARG(code);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
 }
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_emit_enter(struct sljit_compiler 
*compiler,
@@ -1785,7 +1952,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(fscratches);
        SLJIT_UNUSED_ARG(fsaveds);
        SLJIT_UNUSED_ARG(local_size);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1801,7 +1968,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(fscratches);
        SLJIT_UNUSED_ARG(fsaveds);
        SLJIT_UNUSED_ARG(local_size);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1811,7 +1978,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(op);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1820,7 +1987,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(dst);
        SLJIT_UNUSED_ARG(dstw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1829,7 +1996,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1837,7 +2004,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
 {
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(op);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1851,7 +2018,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(dstw);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1868,13 +2035,13 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(src1w);
        SLJIT_UNUSED_ARG(src2);
        SLJIT_UNUSED_ARG(src2w);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_get_register_index(sljit_s32 reg)
 {
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return reg;
 }
 
@@ -1884,14 +2051,14 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(instruction);
        SLJIT_UNUSED_ARG(size);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
-SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_is_fpu_available(void)
+SLJIT_API_FUNC_ATTRIBUTE void sljit_set_current_flags(struct sljit_compiler 
*compiler, sljit_s32 current_flags)
 {
-       SLJIT_ASSERT_STOP();
-       return 0;
+       SLJIT_UNUSED_ARG(compiler);
+       SLJIT_UNUSED_ARG(current_flags);
 }
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_emit_fop1(struct sljit_compiler 
*compiler, sljit_s32 op,
@@ -1904,7 +2071,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(dstw);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -1921,14 +2088,14 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(src1w);
        SLJIT_UNUSED_ARG(src2);
        SLJIT_UNUSED_ARG(src2w);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
 SLJIT_API_FUNC_ATTRIBUTE struct sljit_label* sljit_emit_label(struct 
sljit_compiler *compiler)
 {
        SLJIT_UNUSED_ARG(compiler);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
@@ -1936,7 +2103,7 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
 {
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(type);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
@@ -1950,7 +2117,7 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
        SLJIT_UNUSED_ARG(src1w);
        SLJIT_UNUSED_ARG(src2);
        SLJIT_UNUSED_ARG(src2w);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
@@ -1964,7 +2131,7 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_ju
        SLJIT_UNUSED_ARG(src1w);
        SLJIT_UNUSED_ARG(src2);
        SLJIT_UNUSED_ARG(src2w);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
@@ -1972,14 +2139,14 @@ SLJIT_API_FUNC_ATTRIBUTE void sljit_set_
 {
        SLJIT_UNUSED_ARG(jump);
        SLJIT_UNUSED_ARG(label);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
 }
 
 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_target(struct sljit_jump *jump, 
sljit_uw target)
 {
        SLJIT_UNUSED_ARG(jump);
        SLJIT_UNUSED_ARG(target);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
 }
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_emit_ijump(struct sljit_compiler 
*compiler, sljit_s32 type, sljit_s32 src, sljit_sw srcw)
@@ -1988,23 +2155,33 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(type);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
 SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_emit_op_flags(struct sljit_compiler 
*compiler, sljit_s32 op,
        sljit_s32 dst, sljit_sw dstw,
-       sljit_s32 src, sljit_sw srcw,
        sljit_s32 type)
 {
        SLJIT_UNUSED_ARG(compiler);
        SLJIT_UNUSED_ARG(op);
        SLJIT_UNUSED_ARG(dst);
        SLJIT_UNUSED_ARG(dstw);
+       SLJIT_UNUSED_ARG(type);
+       SLJIT_UNREACHABLE();
+       return SLJIT_ERR_UNSUPPORTED;
+}
+
+SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit_emit_cmov(struct sljit_compiler 
*compiler, sljit_s32 type,
+       sljit_s32 dst_reg,
+       sljit_s32 src, sljit_sw srcw)
+{
+       SLJIT_UNUSED_ARG(compiler);
+       SLJIT_UNUSED_ARG(type);
+       SLJIT_UNUSED_ARG(dst_reg);
        SLJIT_UNUSED_ARG(src);
        SLJIT_UNUSED_ARG(srcw);
-       SLJIT_UNUSED_ARG(type);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -2014,7 +2191,7 @@ SLJIT_API_FUNC_ATTRIBUTE sljit_s32 sljit
        SLJIT_UNUSED_ARG(dst);
        SLJIT_UNUSED_ARG(dstw);
        SLJIT_UNUSED_ARG(offset);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return SLJIT_ERR_UNSUPPORTED;
 }
 
@@ -2024,22 +2201,24 @@ SLJIT_API_FUNC_ATTRIBUTE struct sljit_co
        SLJIT_UNUSED_ARG(dst);
        SLJIT_UNUSED_ARG(dstw);
        SLJIT_UNUSED_ARG(initval);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNREACHABLE();
        return NULL;
 }
 
-SLJIT_API_FUNC_ATTRIBUTE void sljit_set_jump_addr(sljit_uw addr, sljit_uw 
new_addr)
+SLJIT_API_FUNC_ATTRIBUTE void sljit_set_jump_addr(sljit_uw addr, sljit_uw 
new_target, sljit_sw executable_offset)
 {
        SLJIT_UNUSED_ARG(addr);
-       SLJIT_UNUSED_ARG(new_addr);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNUSED_ARG(new_target);
+       SLJIT_UNUSED_ARG(executable_offset);
+       SLJIT_UNREACHABLE();
 }
 
-SLJIT_API_FUNC_ATTRIBUTE void sljit_set_const(sljit_uw addr, sljit_sw 
new_constant)
+SLJIT_API_FUNC_ATTRIBUTE void sljit_set_const(sljit_uw addr, sljit_sw 
new_constant, sljit_sw executable_offset)
 {
        SLJIT_UNUSED_ARG(addr);
        SLJIT_UNUSED_ARG(new_constant);
-       SLJIT_ASSERT_STOP();
+       SLJIT_UNUSED_ARG(executable_offset);
+       SLJIT_UNREACHABLE();
 }
 
 #endif



---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscr...@tomcat.apache.org
For additional commands, e-mail: dev-h...@tomcat.apache.org

Reply via email to