Skip to content

Commit

Permalink
Merge pull request #1933 from Expensify/flo_logsv8
Browse files Browse the repository at this point in the history
Update SQLite with more logs, v8
  • Loading branch information
flodnv authored Nov 1, 2024
2 parents 8bcab67 + 94cecc3 commit bcaa8d9
Show file tree
Hide file tree
Showing 2 changed files with 54 additions and 16 deletions.
68 changes: 53 additions & 15 deletions libstuff/sqlite3.c
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
** separate file. This file contains only code for the core SQLite library.
**
** The content in this amalgamation comes from Fossil check-in
** 7dbb43bd307b5e297e6b2deac4e1d73d8cd6.
** 492a0a85438586a8ccd9629239304f4df3f2.
*/
#define SQLITE_CORE 1
#define SQLITE_AMALGAMATION 1
Expand Down Expand Up @@ -465,7 +465,7 @@ extern "C" {
*/
#define SQLITE_VERSION "3.47.0"
#define SQLITE_VERSION_NUMBER 3047000
#define SQLITE_SOURCE_ID "2024-10-30 18:24:33 7dbb43bd307b5e297e6b2deac4e1d73d8cd68e37d880a5ecf5a3918a53e99d9d"
#define SQLITE_SOURCE_ID "2024-11-01 15:25:34 492a0a85438586a8ccd9629239304f4df3f2c6391ec05dd9837b7a553313d632"

/*
** CAPI3REF: Run-Time Library Version Numbers
Expand Down Expand Up @@ -17451,20 +17451,34 @@ SQLITE_PRIVATE int sqlite3CursorRangeHintExprCheck(Walker *pWalker, Expr *pExpr)

#define COMMIT_TIME_AFTER_FIXUNLOCKED 10

#define COMMIT_TIME_OSWRITE 11
#define COMMIT_TIME_AFTER_WALFRAMES 12
#define COMMIT_TIME_BEFORE_WALFRAMES 11
#define COMMIT_TIME_AFTER_CHANGECOUNTER 13
#define COMMIT_TIME_AFTER_RESTARTLOG 14
#define COMMIT_TIME_AFTER_WRITEHDR 15

#define COMMIT_TIME_BEFORE_PHASETWO 13
#define COMMIT_TIME_AFTER_PHASETWO 14
#define COMMIT_TIME_OSWRITE 16

#define COMMIT_TIME_AFTER_VDBECOMMIT 15
#define COMMIT_TIME_AFTER_HALT 16
#define COMMIT_TIME_FINISH 17
#define COMMIT_TIME_AFTER_WRITEFRAMES 17

#define COMMIT_TIME_N 18
#define COMMIT_TIME_BEFORE_WALINDEX 18
#define COMMIT_TIME_AFTER_WALINDEX 19
#define COMMIT_TIME_AFTER_WALINDEXHDR 20

#define COMMIT_TIME_WALFRAMESFLAGS 21

#define COMMIT_TIME_AFTER_WALFRAMES 22

#define COMMIT_TIME_BEFORE_PHASETWO 23
#define COMMIT_TIME_AFTER_PHASETWO 24

#define COMMIT_TIME_AFTER_VDBECOMMIT 25
#define COMMIT_TIME_AFTER_HALT 26
#define COMMIT_TIME_FINISH 27

#define COMMIT_TIME_N 28

/* #define COMMIT_TIME_TIMEOUT (2*1000*1000) */
#define COMMIT_TIME_TIMEOUT (0*1000) /* 10ms threshold */
#define COMMIT_TIME_TIMEOUT (10*1000) /* 10ms threshold */

SQLITE_PRIVATE void sqlite3CommitTimeLog(u64*);
SQLITE_PRIVATE u64 sqlite3STimeNow();
Expand Down Expand Up @@ -61156,6 +61170,7 @@ static int pagerWalFrames(
pPager->aStat[PAGER_STAT_WRITE] += nList;

if( pList->pgno==1 ) pager_write_changecounter(pList);
sqlite3CommitTimeSet(pPager->aCommitTime, COMMIT_TIME_AFTER_CHANGECOUNTER);
rc = sqlite3WalFrames(pPager->pWal,
pPager->pageSize, pList, nTruncate, isCommit, pPager->walSyncFlags
);
Expand Down Expand Up @@ -64546,6 +64561,7 @@ SQLITE_PRIVATE int sqlite3PagerCommitPhaseOne(
}
assert( rc==SQLITE_OK );
if( ALWAYS(pList) ){
sqlite3CommitTimeSet(pPager->aCommitTime, COMMIT_TIME_BEFORE_WALFRAMES);
rc = pagerWalFrames(pPager, pList, pPager->dbSize, 1);
sqlite3CommitTimeSet(pPager->aCommitTime, COMMIT_TIME_AFTER_WALFRAMES);
}
Expand Down Expand Up @@ -71067,6 +71083,8 @@ static int walFrames(
int iApp;
int bWal2 = isWalMode2(pWal);

int logFlags = 0;

assert( pList );
assert( pWal->writeLock );

Expand All @@ -71087,6 +71105,8 @@ static int walFrames(
return rc;
}

sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_AFTER_RESTARTLOG);

/* If this is the first frame written into the log, write the WAL
** header to the start of the WAL file. See comments at the top of
** this source file for a description of the WAL header format.
Expand All @@ -71102,6 +71122,7 @@ static int walFrames(
}
#endif

logFlags |= (iFrame==0 ? 0x01 : 0x00);
if( iFrame==0 ){
u32 iCkpt = 0;
u8 aWalHdr[WAL_HDRSIZE]; /* Buffer to assemble wal-header in */
Expand Down Expand Up @@ -71155,6 +71176,7 @@ static int walFrames(
if( (int)pWal->szPage!=szPage ){
return SQLITE_CORRUPT_BKPT; /* TH3 test case: cov1/corrupt155.test */
}
sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_AFTER_WRITEHDR);

/* Setup information needed to write frames into the WAL */
w.pWal = pWal;
Expand All @@ -71166,6 +71188,7 @@ static int walFrames(
szFrame = szPage + WAL_FRAME_HDRSIZE;

/* Write all frames into the log file exactly once */
logFlags |= (iFirst==0 ? 0x00 : 0x02);
for(p=pList; p; p=p->pDirty){
int nDbSize; /* 0 normally. Positive == commit flag */

Expand Down Expand Up @@ -71204,8 +71227,10 @@ static int walFrames(
p->flags |= PGHDR_WAL_APPEND;
}

sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_AFTER_WRITEFRAMES);

/* Recalculate checksums within the wal file if required. */
logFlags |= (pWal->iReCksum==0 ? 0x00 : 0x04);
if( isCommit && pWal->iReCksum ){
rc = walRewriteChecksums(pWal, iFrame);
if( rc ) return rc;
Expand All @@ -71225,6 +71250,7 @@ static int walFrames(
** sector boundary is synced; the part of the last frame that extends
** past the sector boundary is written after the sync.
*/
logFlags |= (WAL_SYNC_FLAGS(sync_flags)==0 ? 0x00 : 0x08);
if( isCommit && WAL_SYNC_FLAGS(sync_flags)!=0 ){
int bSync = 1;
if( pWal->padToSectorBoundary ){
Expand Down Expand Up @@ -71259,6 +71285,8 @@ static int walFrames(
pWal->truncateOnCommit = 0;
}

sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_BEFORE_WALINDEX);

/* Append data to the wal-index. It is not necessary to lock the
** wal-index to do this as the SQLITE_SHM_WRITE lock held on the wal-index
** guarantees that there are no other writers, and no data that may
Expand All @@ -71277,6 +71305,8 @@ static int walFrames(
rc = walIndexAppend(pWal, iApp, iFrame, pLast->pgno);
}

sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_AFTER_WALINDEX);

if( rc==SQLITE_OK ){
/* Update the private copy of the header. */
pWal->hdr.szPage = (u16)((szPage&0xff00) | (szPage>>16));
Expand Down Expand Up @@ -71304,6 +71334,11 @@ static int walFrames(
}
}

sqlite3CommitTimeSet(pWal->aCommitTime, COMMIT_TIME_AFTER_WALINDEXHDR);
if( pWal->aCommitTime ){
pWal->aCommitTime[COMMIT_TIME_WALFRAMESFLAGS] = logFlags;
}

WALTRACE(("WAL%p: frame write %s\n", pWal, rc ? "failed" : "ok"));
return rc;
}
Expand Down Expand Up @@ -93240,12 +93275,15 @@ SQLITE_PRIVATE void sqlite3CommitTimeLog(u64 *aCommit){
}else if( ii==COMMIT_TIME_OSWRITE ){
iVal = (int)aCommit[ii];
zU = "us";
}else if( ii==COMMIT_TIME_WALFRAMESFLAGS ){
iVal = (int)aCommit[ii];
zHash = "flags=";
}else{
iVal = (aCommit[ii]==0 ? 0 : (int)(aCommit[ii] - i1));
}
zStr = sqlite3_mprintf("%z%s%s%d%s", zStr, (zStr?", ":""),zHash,iVal,zU);
}
sqlite3_log(SQLITE_WARNING, "slow commit (v=7): (%s)", zStr);
sqlite3_log(SQLITE_WARNING, "slow commit (v=8): (%s)", zStr);
sqlite3_free(zStr);
}
}
Expand Down Expand Up @@ -93273,7 +93311,7 @@ SQLITE_PRIVATE void sqlite3PrepareTimeLog(const char *zSql, int nSql, u64 *aPrep
}
if( nByte<0 ){ nByte = sqlite3Strlen30(zSql); }
sqlite3_log(SQLITE_WARNING,
"slow prepare (v=7): (%s) [%.*s]", zStr, nByte, zSql
"slow prepare (v=8): (%s) [%.*s]", zStr, nByte, zSql
);
sqlite3_free(zStr);
}
Expand All @@ -93289,7 +93327,7 @@ SQLITE_PRIVATE void sqlite3SchemaTimeLog(u64 *aSchema){
(aSchema[ii]==0 ? 0 : (int)(aSchema[ii] - i1))
);
}
sqlite3_log(SQLITE_WARNING, "slow schema (v=7): (%s)", zStr);
sqlite3_log(SQLITE_WARNING, "slow schema (v=8): (%s)", zStr);
sqlite3_free(zStr);
}
}
Expand Down Expand Up @@ -257667,7 +257705,7 @@ static void fts5SourceIdFunc(
){
assert( nArg==0 );
UNUSED_PARAM2(nArg, apUnused);
sqlite3_result_text(pCtx, "fts5: 2024-10-30 18:24:33 7dbb43bd307b5e297e6b2deac4e1d73d8cd68e37d880a5ecf5a3918a53e99d9d", -1, SQLITE_TRANSIENT);
sqlite3_result_text(pCtx, "fts5: 2024-11-01 15:25:34 492a0a85438586a8ccd9629239304f4df3f2c6391ec05dd9837b7a553313d632", -1, SQLITE_TRANSIENT);
}

/*
Expand Down
2 changes: 1 addition & 1 deletion libstuff/sqlite3.h
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,7 @@ extern "C" {
*/
#define SQLITE_VERSION "3.47.0"
#define SQLITE_VERSION_NUMBER 3047000
#define SQLITE_SOURCE_ID "2024-10-30 18:24:33 7dbb43bd307b5e297e6b2deac4e1d73d8cd68e37d880a5ecf5a3918a53e99d9d"
#define SQLITE_SOURCE_ID "2024-11-01 15:25:34 492a0a85438586a8ccd9629239304f4df3f2c6391ec05dd9837b7a553313d632"

/*
** CAPI3REF: Run-Time Library Version Numbers
Expand Down

0 comments on commit bcaa8d9

Please sign in to comment.