]> git.ipfire.org Git - thirdparty/sqlite.git/commitdiff
Change a condition in sqlite3VdbeMemShallowCopy() to avoid accessing an unitialized...
authordan <dan@noemail.net>
Fri, 5 Mar 2010 18:46:12 +0000 (18:46 +0000)
committerdan <dan@noemail.net>
Fri, 5 Mar 2010 18:46:12 +0000 (18:46 +0000)
FossilOrigin-Name: 4793c381c6ff4e4d25433298be30028721a9cb67

manifest
manifest.uuid
src/vdbemem.c

index 016332a3eedfef18e766d3948a242d4d4fe9b007..ec068a1a368accc9d83577b48364af79b53afd47 100644 (file)
--- a/manifest
+++ b/manifest
@@ -1,5 +1,5 @@
-C Fix\sa\sone\sbyte\sbuffer\soverread\sin\sfts3.
-D 2010-03-05T17:27:02
+C Change\sa\scondition\sin\ssqlite3VdbeMemShallowCopy()\sto\savoid\saccessing\san\sunitialized\svariable\s(doing\sso\swas\snot\sdangerous,\sbut\scaused\sa\svalgrind\serror).
+D 2010-03-05T18:46:12
 F Makefile.arm-wince-mingw32ce-gcc fcd5e9cd67fe88836360bb4f9ef4cb7f8e2fb5a0
 F Makefile.in 4f2f967b7e58a35bb74fb7ec8ae90e0f4ca7868b
 F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
@@ -217,7 +217,7 @@ F src/vdbeInt.h ae1e6ba0dd3fb4a886898d2829d748be701b01f8
 F src/vdbeapi.c 74c25680046a116b24b95393914d3669c23305dc
 F src/vdbeaux.c 9089e0cdcc7ed3bc4564f2684ce84f5911973ea9
 F src/vdbeblob.c 5327132a42a91e8b7acfb60b9d2c3b1c5c863e0e
-F src/vdbemem.c aeba77b59f3553d3cc5b72c18a8267c6fba546b9
+F src/vdbemem.c 2a82f455f6ca6f78b59fb312f96054c04ae0ead1
 F src/vdbetrace.c 864cef96919323482ebd9986f2132435115e9cc2
 F src/vtab.c 606adf51cd6d4ba51a8c6dccede06a6f7b0dd72d
 F src/walker.c 3112bb3afe1d85dc52317cb1d752055e9a781f8f
@@ -792,7 +792,7 @@ F tool/speedtest2.tcl ee2149167303ba8e95af97873c575c3e0fab58ff
 F tool/speedtest8.c 2902c46588c40b55661e471d7a86e4dd71a18224
 F tool/speedtest8inst1.c 293327bc76823f473684d589a8160bde1f52c14e
 F tool/vdbe-compress.tcl d70ea6d8a19e3571d7ab8c9b75cba86d1173ff0f
-P 8858042fa1449516a2c7dbb991dca3eb6c5794cb
-R 8a9e89b47a06ff6e530c432a233196bb
+P 6e3e014af91601ed1f3a9cbe23f7c4260a4d177f
+R 388898322e7463920b97bb7843b3071a
 U dan
-Z 5bdb78b3531af14f46db30fbad40b790
+Z 52df57cad18b098b73d39ae1b405ce26
index 479e58f5240ee080f54886468609e17b68fbf79d..c8318ade748fe29bdfdc66a593b10de6752bcbb5 100644 (file)
@@ -1 +1 @@
-6e3e014af91601ed1f3a9cbe23f7c4260a4d177f
\ No newline at end of file
+4793c381c6ff4e4d25433298be30028721a9cb67
\ No newline at end of file
index 2b3ea5643dde6a428eed25314d7cbfb4f6638325..8217c4d2998bb335106bbf77bdc03e54a6f4a05a 100644 (file)
@@ -609,7 +609,7 @@ void sqlite3VdbeMemShallowCopy(Mem *pTo, const Mem *pFrom, int srcType){
   sqlite3VdbeMemReleaseExternal(pTo);
   memcpy(pTo, pFrom, MEMCELLSIZE);
   pTo->xDel = 0;
-  if( (pFrom->flags&MEM_Dyn)!=0 || pFrom->z==pFrom->zMalloc ){
+  if( (pFrom->flags&MEM_Static)==0 ){
     pTo->flags &= ~(MEM_Dyn|MEM_Static|MEM_Ephem);
     assert( srcType==MEM_Ephem || srcType==MEM_Static );
     pTo->flags |= srcType;