CVE-2022-1586 An out-of-bounds read vulnerability was found in the PCRE2 library. This involves a unicode property matching issue in JIT-compiled regular expressions.

The issue is caused by how unicode properties are handled during JIT. Due to the way JIT compiles regular expressions, the library will not check the full unicode value of the characters it uses. Instead, it will just check if the character is within the ASCII range. This is not a security issue, as JIT can be disabled in the regular expression to avoid it altogether. However, it is recommended to do so because it can cause issues with real-world usage of the library. Due to the nature of the issue, it is not possible to use the PCRE2 library with the JIT enabled. This means that users will not be able to checkout a regular expression from PCRE2 and see a JIT-compiled version of it. As a result, out-of-bounds reads can occur when valid user input is validated against the regexp.

How to upgrade to PCRE2 version 2.0.0

JIT and Unicode Property Issues with PCRE2

JIT can be enabled in PCRE2, which allows for a significant performance improvement. However, this comes with a huge trade-off: because PCRE2 does not check the full unicode value of the characters it uses and instead "checks" to see if they are within the ASCII range, out-of-bounds reads can occur when valid user input is matched against a regular expression.
The issue is caused by how unicode properties are handled during JIT compilation. Due to the way JIT compiles regular expressions, the library will not check the full unicode value of the characters it uses. Instead, it will just check if the character is within the ASCII range. This is not a security issue as JIT can be disabled in the regular expression to avoid it altogether. However, it is recommended that users disable JIT because it can cause issues with real-world usage of the library.

Fix code

// if the regular expression is compiled with JIT support
if (preg_jit) {
return len; // this will cause a read of out of bounds
} else {
return 0;

JIT Disabled

JIT is a feature of Regexp::JIT that enables the programmer to compile regular expressions into machine code. This can be done by using the JIT pragma in your regular expression, which will enable the compilation and give you access to optimizations. However, there is a downside to this convenience feature: it might cause security vulnerabilities.
In order to prevent this, you can disable the JIT compiler in your regular expression with the JIT_DISABLED pragma. It has been confirmed that PCRE2 does not support disabling the JIT compiler. This means that users will not be able to checkout a regular expression from PCRE2 and see a JIT-compiled version of it. As a result, out-of-bounds reads can occur when valid user input is validated against the regexp

Timeline

Published on: 05/16/2022 21:15:00 UTC
Last modified on: 06/02/2022 14:15:00 UTC

References