summaryrefslogtreecommitdiffstats
path: root/meta/recipes-support/sqlite/files/CVE-2018-20505.patch
diff options
context:
space:
mode:
Diffstat (limited to 'meta/recipes-support/sqlite/files/CVE-2018-20505.patch')
-rw-r--r--meta/recipes-support/sqlite/files/CVE-2018-20505.patch31
1 files changed, 31 insertions, 0 deletions
diff --git a/meta/recipes-support/sqlite/files/CVE-2018-20505.patch b/meta/recipes-support/sqlite/files/CVE-2018-20505.patch
new file mode 100644
index 0000000000..d1119f3b31
--- /dev/null
+++ b/meta/recipes-support/sqlite/files/CVE-2018-20505.patch
@@ -0,0 +1,31 @@
1From: D. Richard Hipp <drh@hwaci.com>
2Date: Sat, 3 Nov 2018 13:11:24 +0000 (+0000)
3Subject: Fix a assert() in the query planner that can arise when doing row-value
4X-Git-Tag: version-3.26.0~59
5X-Git-Url: https://repo.or.cz/sqlite.git/commitdiff_plain/24298027a30cf7941f16a8cc878d0c1f9f14308f
6
7Fix a assert() in the query planner that can arise when doing row-value
8operations on a PRIMARY KEY that contains duplicate columns.
9Ticket [1a84668dcfdebaf12415d].
10
11https://sqlite.org/src/info/1a84668dcfdebaf12415d
12
13upstream-Status: Backport
14CVE: CVE-2018-20505
15affects <= 3.26.0
16
17Signed-off-by: Armin Kuster <akuster@mvista.com>
18
19Index: sqlite-autoconf-3230100/sqlite3.c
20===================================================================
21--- sqlite-autoconf-3230100.orig/sqlite3.c
22+++ sqlite-autoconf-3230100/sqlite3.c
23@@ -131231,7 +131231,7 @@ static Expr *removeUnindexableInClauseTe
24 for(i=iEq; i<pLoop->nLTerm; i++){
25 if( pLoop->aLTerm[i]->pExpr==pX ){
26 int iField = pLoop->aLTerm[i]->iField - 1;
27- assert( pOrigRhs->a[iField].pExpr!=0 );
28+ if( pOrigRhs->a[iField].pExpr==0 ) continue; /* Duplicate PK column */
29 pRhs = sqlite3ExprListAppend(pParse, pRhs, pOrigRhs->a[iField].pExpr);
30 pOrigRhs->a[iField].pExpr = 0;
31 assert( pOrigLhs->a[iField].pExpr!=0 );