-C Increase\sthe\ssize\sof\sthe\scache\sof\sfree\sblocks\sinside\sof\spageFreeArray()\sto\nreduce\sthe\snumber\sof\scalls\sto\sfreeSpace().
-D 2023-04-06T20:14:10.861
+C Try\sto\suse\sa\sheap\sto\smake\scoalescence\sof\sadjacent\sfree\sslots\sfaster\swhen\nfreeing\sspace\son\sa\sbtree\spage.\s\sTurns\sout\sthat\sthe\soverhead\sof\smanaging\nthe\sheap\soverwhelms\sany\sperformance\sgain\sand\sthe\sresult\sis\sslower.
+D 2023-04-07T11:55:58.282
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
F src/backup.c a2891172438e385fdbe97c11c9745676bec54f518d4447090af97189fd8e52d7
F src/bitvec.c 7c849aac407230278445cb069bebc5f89bf2ddd87c5ed9459b070a9175707b3d
F src/btmutex.c 6ffb0a22c19e2f9110be0964d0731d2ef1c67b5f7fabfbaeb7b9dabc4b7740ca
-F src/btree.c 1a5f31d548a68d2bd537919d8afa176540c3ea70787fe10d5873beb00f9db615
+F src/btree.c 8bd2f2b5e41d9ebb6e9f828f597e824af41c3a48315543027d741fbbc1fa89b0
F src/btree.h aa354b9bad4120af71e214666b35132712b8f2ec11869cb2315c52c81fad45cc
F src/btreeInt.h a3268a60cbc91f578001f44ba40aae9c1b8aecbb0d2c095dd7fc54b0872ea4b8
F src/build.c 8357d6ca9a8c9afc297c431df28bc2af407b47f3ef2311875276c944b30c4d54
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
-P 56ea2c2fe6108d39833ac40957afab59ade01a216639d5bafdeeca53bbf4cd67
-R f4ea0d3a1a9bcf702848933fabd592b4
-T *branch * btree-freespace-opt
-T *sym-btree-freespace-opt *
-T -sym-trunk *
+P 27c59f1ea789f3ff245f23e79ded5cd71c48e3a51ffbb8c220b51101a4e69fd7
+R c1ff538937e36abd2cf16de04be70f7b
+T *branch * deadend
+T *sym-deadend *
+T -sym-btree-freespace-opt *
U drh
-Z a279ebfc98f243d3f64ca427ad2184cf
+Z 10cff07ea83d09e599ad019612e5aecd
# Remove this line to create a well-formed Fossil manifest.
return SQLITE_OK;
}
+
/*
** Remove the i-th cell from pPage. This routine effects pPage only.
** The cell content is not freed or deallocated. It is assumed that
return 0;
}
+static void btreeHeapInsert(u32 *aHeap, u32 x);
+static int btreeHeapPull(u32 *aHeap, u32 *pOut);
+
+/*
+** Add all of the cells on aHep to the freelist for a page.
+*/
+static void btreeFreeCellsOnHeap(MemPage *pPg, u32 *aHeap){
+ u32 x;
+ int iOfst;
+ int iSize;
+
+ assert( aHeap[0] );
+ btreeHeapPull(aHeap, &x);
+ iSize = x & 0xffff;
+ iOfst = x>>16;
+ while( aHeap[0] ){
+ int iNxOfst;
+ int iNxSize;
+ btreeHeapPull(aHeap, &x);
+ iNxSize = x & 0xffff;
+ iNxOfst = x>>16;
+ if( iSize+iOfst==iNxOfst ){
+ iSize += iNxSize;
+ }else{
+ freeSpace(pPg, iOfst, iSize);
+ iOfst = iNxOfst;
+ iSize = iNxSize;
+ }
+ }
+ freeSpace(pPg, iOfst, iSize);
+}
+
/*
** The pCArray object contains pointers to b-tree cells and their sizes.
**
u8 * const pEnd = &aData[pPg->pBt->usableSize];
u8 * const pStart = &aData[pPg->hdrOffset + 8 + pPg->childPtrSize];
int nRet = 0;
- int i, j;
+ int i;
int iEnd = iFirst + nCell;
- int nFree = 0;
- int aOfst[10];
- int aAfter[10];
+ u32 aHeap[100];
+ aHeap[0] = 0;
for(i=iFirst; i<iEnd; i++){
u8 *pCell = pCArray->apCell[i];
if( SQLITE_WITHIN(pCell, pStart, pEnd) ){
- int sz;
- int iAfter;
- int iOfst;
+ u16 sz;
+ u16 iOfst;
+
/* No need to use cachedCellSize() here. The sizes of all cells that
** are to be freed have already been computing while deciding which
** cells need freeing */
sz = pCArray->szCell[i]; assert( sz>0 );
iOfst = (u16)(pCell - aData);
- iAfter = iOfst+sz;
- for(j=0; j<nFree; j++){
- if( aOfst[j]==iAfter ){
- aOfst[j] = iOfst;
- break;
- }else if( aAfter[j]==iOfst ){
- aAfter[j] = iAfter;
- break;
- }
- }
- if( j>=nFree ){
- if( nFree>=sizeof(aOfst)/sizeof(aOfst[0]) ){
- for(j=0; j<nFree; j++){
- freeSpace(pPg, aOfst[j], aAfter[j]-aOfst[j]);
- }
- nFree = 0;
- }
- aOfst[nFree] = iOfst;
- aAfter[nFree] = iAfter;
- nFree++;
- }
+ btreeHeapInsert(aHeap, (iOfst<<16)|sz);
+ if( aHeap[0]>=90 ) btreeFreeCellsOnHeap(pPg, aHeap);
nRet++;
}
}
- for(j=0; j<nFree; j++){
- freeSpace(pPg, aOfst[j], aAfter[j]-aOfst[j]);
- }
+ if( aHeap[0] ) btreeFreeCellsOnHeap(pPg, aHeap);
return nRet;
}