]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Improved selection of the divisor when subdividing nested Bitvec objects.
authordrh <>
Tue, 10 Jun 2025 19:52:21 +0000 (19:52 +0000)
committerdrh <>
Tue, 10 Jun 2025 19:52:21 +0000 (19:52 +0000)
This fixes a potential stack overflow that can occur when the database size
is within 60 pages of the maximum allowed by the file format.

FossilOrigin-Name: f7ab764ed9df6d7a4a96cb0933d291f00174f33fed3d9951785078fe225adcb7

manifest
manifest.uuid
src/bitvec.c

index 8725c66a923b2c0786946392ee0a9b66c71bfeb6..94e2194009c2a634bfc896a74534f2f16aac6243 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Minor\scorrections\sto\sthe\snew\sBitvec\stesting\slogic.
-D 2025-06-10T18:26:09.286
+C Improved\sselection\sof\sthe\sdivisor\swhen\ssubdividing\snested\sBitvec\sobjects.\nThis\sfixes\sa\spotential\sstack\soverflow\sthat\scan\soccur\swhen\sthe\sdatabase\ssize\nis\swithin\s60\spages\sof\sthe\smaximum\sallowed\sby\sthe\sfile\sformat.
+D 2025-06-10T19:52:21.568
 F .fossil-settings/binary-glob 61195414528fb3ea9693577e1980230d78a1f8b0a54c78cf1b9b24d0a409ed6a x
 F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
 F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
@@ -724,7 +724,7 @@ F src/analyze.c 03bcfc083fc0cccaa9ded93604e1d4244ea245c17285d463ef6a60425fcb247d
 F src/attach.c 9af61b63b10ee702b1594ecd24fb8cea0839cfdb6addee52fba26fa879f5db9d
 F src/auth.c 54ab9c6c5803b47c0d45b76ce27eff22a03b4b1f767c5945a3a4eb13aa4c78dc
 F src/backup.c 5c97e8023aab1ce14a42387eb3ae00ba5a0644569e3476f38661fa6f824c3523
-F src/bitvec.c 997e671e5cda1cbed14af3b29c8a6155d78f52386ac5c52e177ded96536325f3
+F src/bitvec.c e242d4496774dfc88fa278177dd23b607dce369ccafb3f61b41638eea2c9b399
 F src/btmutex.c 30dada73a819a1ef5b7583786370dce1842e12e1ad941e4d05ac29695528daea
 F src/btree.c 53a9c7b243e94c992853d90f1dac0959028433b4b0d27e04409cee04e001b508
 F src/btree.h 18e5e7b2124c23426a283523e5f31a4bff029131b795bb82391f9d2f3136fc50
@@ -2208,8 +2208,8 @@ F tool/version-info.c 3b36468a90faf1bbd59c65fd0eb66522d9f941eedd364fabccd7227350
 F tool/warnings-clang.sh bbf6a1e685e534c92ec2bfba5b1745f34fb6f0bc2a362850723a9ee87c1b31a7
 F tool/warnings.sh 1ad0169b022b280bcaaf94a7fa231591be96b514230ab5c98fbf15cd7df842dd
 F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
-P c5680672cae23f65637eebf66f3bb983a2864be03ea70378832034f3c89ef728
-R db1ba5a64ed30c3ee4db5bcae7781ac2
+P 77b79ca1277419b91589aff2c601d4abdd7107d48019a58f7f7c85d96c2a538e
+R bf66b7985c31cceb0c32df308099135b
 U drh
-Z 58131ae6c40b1aa64532119990f28d26
+Z a20e53dfcbadb1b77270bd825fc40efb
 # Remove this line to create a well-formed Fossil manifest.
index 21873285d3e6e7e884f7fbc1a43de7df005e31ec..435403a0504e43d6fd76c6664c18ba34dd0cdfba 100644 (file)
@@ -1 +1 @@
-77b79ca1277419b91589aff2c601d4abdd7107d48019a58f7f7c85d96c2a538e
+f7ab764ed9df6d7a4a96cb0933d291f00174f33fed3d9951785078fe225adcb7
index 70be555bb4e04e9c51a746f0f716b1333d15b1ce..7c5fa71d9bb77a699981480ab50e78165d988e38 100644 (file)
@@ -217,7 +217,9 @@ bitvec_set_rehash:
     }else{
       memcpy(aiValues, p->u.aHash, sizeof(p->u.aHash));
       memset(p->u.apSub, 0, sizeof(p->u.apSub));
-      p->iDivisor = (p->iSize + BITVEC_NPTR - 1)/BITVEC_NPTR;
+      p->iDivisor = p->iSize/BITVEC_NPTR;
+      if( (p->iSize%BITVEC_NPTR)!=0 ) p->iDivisor++;
+      if( p->iDivisor<BITVEC_NBIT ) p->iDivisor = BITVEC_NBIT;
       rc = sqlite3BitvecSet(p, i);
       for(j=0; j<BITVEC_NINT; j++){
         if( aiValues[j] ) rc |= sqlite3BitvecSet(p, aiValues[j]);