Add SQLITE_LIMIT_WORKER_THREADS for controlling the maximum number of
worker threads. FossilOrigin-Name: 1b598c68f32db635d1cea1373bedc434aa60cf08
This commit is contained in:
parent
503ae86508
commit
111544cbb4
20
manifest
20
manifest
@ -1,5 +1,5 @@
|
|||||||
C Merge\srecent\sperformance\senhancements\sfrom\strunk\sonto\sthe\sthreads\sbranch.
|
C Add\sSQLITE_LIMIT_WORKER_THREADS\sfor\scontrolling\sthe\smaximum\snumber\sof\nworker\sthreads.
|
||||||
D 2014-08-29T14:40:07.113
|
D 2014-08-29T16:20:47.382
|
||||||
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
F Makefile.arm-wince-mingw32ce-gcc d6df77f1f48d690bd73162294bbba7f59507c72f
|
||||||
F Makefile.in cf57f673d77606ab0f2d9627ca52a9ba1464146a
|
F Makefile.in cf57f673d77606ab0f2d9627ca52a9ba1464146a
|
||||||
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
F Makefile.linux-gcc 91d710bdc4998cb015f39edf3cb314ec4f4d7e23
|
||||||
@ -190,7 +190,7 @@ F src/journal.c b4124532212b6952f42eb2c12fa3c25701d8ba8d
|
|||||||
F src/legacy.c 87c92f4a08e2f70220e3b22a9c3b2482d36a134a
|
F src/legacy.c 87c92f4a08e2f70220e3b22a9c3b2482d36a134a
|
||||||
F src/lempar.c cdf0a000315332fc9b50b62f3b5e22e080a0952b
|
F src/lempar.c cdf0a000315332fc9b50b62f3b5e22e080a0952b
|
||||||
F src/loadext.c 31c2122b7dd05a179049bbf163fd4839f181cbab
|
F src/loadext.c 31c2122b7dd05a179049bbf163fd4839f181cbab
|
||||||
F src/main.c f1726e704941d365ce2846161e93ba689a245845
|
F src/main.c e71d7c8b415e3b54d729aabb876f39f7aa35b000
|
||||||
F src/malloc.c 954de5f998c23237e04474a3f2159bf483bba65a
|
F src/malloc.c 954de5f998c23237e04474a3f2159bf483bba65a
|
||||||
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
F src/mem0.c 6a55ebe57c46ca1a7d98da93aaa07f99f1059645
|
||||||
F src/mem1.c c0c990fcaddff810ea277b4fb5d9138603dd5d4b
|
F src/mem1.c c0c990fcaddff810ea277b4fb5d9138603dd5d4b
|
||||||
@ -217,7 +217,7 @@ F src/parse.y 22d6a074e5f5a7258947a1dc55a9bf946b765dd0
|
|||||||
F src/pcache.c 3b3791297e8977002e56b4a9b8916f2039abad9b
|
F src/pcache.c 3b3791297e8977002e56b4a9b8916f2039abad9b
|
||||||
F src/pcache.h 9b559127b83f84ff76d735c8262f04853be0c59a
|
F src/pcache.h 9b559127b83f84ff76d735c8262f04853be0c59a
|
||||||
F src/pcache1.c c5af6403a55178c9d1c09e4f77b0f9c88822762c
|
F src/pcache1.c c5af6403a55178c9d1c09e4f77b0f9c88822762c
|
||||||
F src/pragma.c 33971fcaa7c13b84b1a0f2e813f4a3ab4d745ede
|
F src/pragma.c 14bcdb504128a476cce5bbc086d5226c5e46c225
|
||||||
F src/prepare.c 3842c1dfc0b053458e3adcf9f6efc48e03e3fe3d
|
F src/prepare.c 3842c1dfc0b053458e3adcf9f6efc48e03e3fe3d
|
||||||
F src/printf.c 00986c86ddfffefc2fd3c73667ff51b3b9709c74
|
F src/printf.c 00986c86ddfffefc2fd3c73667ff51b3b9709c74
|
||||||
F src/random.c d10c1f85b6709ca97278428fd5db5bbb9c74eece
|
F src/random.c d10c1f85b6709ca97278428fd5db5bbb9c74eece
|
||||||
@ -225,10 +225,10 @@ F src/resolve.c 0ea356d32a5e884add23d1b9b4e8736681dd5697
|
|||||||
F src/rowset.c a9c9aae3234b44a6d7c6f5a3cadf90dce1e627be
|
F src/rowset.c a9c9aae3234b44a6d7c6f5a3cadf90dce1e627be
|
||||||
F src/select.c 89e569b263535662f54b537eb9118b2c554ae7aa
|
F src/select.c 89e569b263535662f54b537eb9118b2c554ae7aa
|
||||||
F src/shell.c 88378cef39aba4b4a1df82793dcb1daf9276bb81
|
F src/shell.c 88378cef39aba4b4a1df82793dcb1daf9276bb81
|
||||||
F src/sqlite.h.in aa2cc1405cb999c9d73484e0686f7b869b430ba3
|
F src/sqlite.h.in 74b42237f0d2b010779cc1b1a00190452b31a2ec
|
||||||
F src/sqlite3.rc 992c9f5fb8285ae285d6be28240a7e8d3a7f2bad
|
F src/sqlite3.rc 992c9f5fb8285ae285d6be28240a7e8d3a7f2bad
|
||||||
F src/sqlite3ext.h 886f5a34de171002ad46fae8c36a7d8051c190fc
|
F src/sqlite3ext.h 886f5a34de171002ad46fae8c36a7d8051c190fc
|
||||||
F src/sqliteInt.h 43419afaed8cd3bf99df06d38952a52f827217b9
|
F src/sqliteInt.h e539938b3504520da5cefe225712452abea6795a
|
||||||
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
F src/sqliteLimit.h 164b0e6749d31e0daa1a4589a169d31c0dec7b3d
|
||||||
F src/status.c 7ac05a5c7017d0b9f0b4bcd701228b784f987158
|
F src/status.c 7ac05a5c7017d0b9f0b4bcd701228b784f987158
|
||||||
F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e
|
F src/table.c 2cd62736f845d82200acfa1287e33feb3c15d62e
|
||||||
@ -292,7 +292,7 @@ F src/vdbeapi.c 09677a53dd8c71bcd670b0bd073bb9aefa02b441
|
|||||||
F src/vdbeaux.c cef5d34a64ae3a65b56d96d3fd663246ec8e1c36
|
F src/vdbeaux.c cef5d34a64ae3a65b56d96d3fd663246ec8e1c36
|
||||||
F src/vdbeblob.c 848238dc73e93e48432991bb5651bf87d865eca4
|
F src/vdbeblob.c 848238dc73e93e48432991bb5651bf87d865eca4
|
||||||
F src/vdbemem.c 921d5468a68ac06f369810992e84ca22cc730a62
|
F src/vdbemem.c 921d5468a68ac06f369810992e84ca22cc730a62
|
||||||
F src/vdbesort.c 50fe3442f41dbfe0b37d2e8b55e7460244015533
|
F src/vdbesort.c f92628f3d5d4432f751b15a5f39bacc3c6a64a03
|
||||||
F src/vdbetrace.c 6f52bc0c51e144b7efdcfb2a8f771167a8816767
|
F src/vdbetrace.c 6f52bc0c51e144b7efdcfb2a8f771167a8816767
|
||||||
F src/vtab.c 019dbfd0406a7447c990e1f7bd1dfcdb8895697f
|
F src/vtab.c 019dbfd0406a7447c990e1f7bd1dfcdb8895697f
|
||||||
F src/wal.c 264df50a1b33124130b23180ded2e2c5663c652a
|
F src/wal.c 264df50a1b33124130b23180ded2e2c5663c652a
|
||||||
@ -1193,7 +1193,7 @@ F tool/vdbe_profile.tcl 67746953071a9f8f2f668b73fe899074e2c6d8c1
|
|||||||
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
F tool/warnings-clang.sh f6aa929dc20ef1f856af04a730772f59283631d4
|
||||||
F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32
|
F tool/warnings.sh 0abfd78ceb09b7f7c27c688c8e3fe93268a13b32
|
||||||
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
|
F tool/win/sqlite.vsix deb315d026cc8400325c5863eef847784a219a2f
|
||||||
P e3305d4b4efcbe06945ce7f6ec0f2e864244aaf9 2a74129a21f9745f1363f844807e2d10201a3f40
|
P 35c44a3c73e2e8b14ff194c41986f4bdb9dfe737
|
||||||
R a4f057fd137875212defd2b87d648d95
|
R 2f78b359e3468cdedd78b18f8317c2eb
|
||||||
U drh
|
U drh
|
||||||
Z c730a4dfee48578be19b0ff5cd3b7719
|
Z bfedd71a211c8cc0f7a49234bc820538
|
||||||
|
@ -1 +1 @@
|
|||||||
35c44a3c73e2e8b14ff194c41986f4bdb9dfe737
|
1b598c68f32db635d1cea1373bedc434aa60cf08
|
@ -2078,6 +2078,7 @@ static const int aHardLimit[] = {
|
|||||||
SQLITE_MAX_LIKE_PATTERN_LENGTH,
|
SQLITE_MAX_LIKE_PATTERN_LENGTH,
|
||||||
SQLITE_MAX_VARIABLE_NUMBER, /* IMP: R-38091-32352 */
|
SQLITE_MAX_VARIABLE_NUMBER, /* IMP: R-38091-32352 */
|
||||||
SQLITE_MAX_TRIGGER_DEPTH,
|
SQLITE_MAX_TRIGGER_DEPTH,
|
||||||
|
SQLITE_MAX_WORKER_THREADS,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2113,6 +2114,9 @@ static const int aHardLimit[] = {
|
|||||||
#if SQLITE_MAX_TRIGGER_DEPTH<1
|
#if SQLITE_MAX_TRIGGER_DEPTH<1
|
||||||
# error SQLITE_MAX_TRIGGER_DEPTH must be at least 1
|
# error SQLITE_MAX_TRIGGER_DEPTH must be at least 1
|
||||||
#endif
|
#endif
|
||||||
|
#if SQLITE_MAX_WORKER_THREADS<0 || SQLITE_MAX_WORKER_THREADS>50
|
||||||
|
# error SQLITE_MAX_WORKER_THREADS must be between 0 and 50
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2146,7 +2150,8 @@ int sqlite3_limit(sqlite3 *db, int limitId, int newLimit){
|
|||||||
SQLITE_MAX_LIKE_PATTERN_LENGTH );
|
SQLITE_MAX_LIKE_PATTERN_LENGTH );
|
||||||
assert( aHardLimit[SQLITE_LIMIT_VARIABLE_NUMBER]==SQLITE_MAX_VARIABLE_NUMBER);
|
assert( aHardLimit[SQLITE_LIMIT_VARIABLE_NUMBER]==SQLITE_MAX_VARIABLE_NUMBER);
|
||||||
assert( aHardLimit[SQLITE_LIMIT_TRIGGER_DEPTH]==SQLITE_MAX_TRIGGER_DEPTH );
|
assert( aHardLimit[SQLITE_LIMIT_TRIGGER_DEPTH]==SQLITE_MAX_TRIGGER_DEPTH );
|
||||||
assert( SQLITE_LIMIT_TRIGGER_DEPTH==(SQLITE_N_LIMIT-1) );
|
assert( aHardLimit[SQLITE_LIMIT_WORKER_THREADS]==SQLITE_MAX_WORKER_THREADS );
|
||||||
|
assert( SQLITE_LIMIT_WORKER_THREADS==(SQLITE_N_LIMIT-1) );
|
||||||
|
|
||||||
|
|
||||||
if( limitId<0 || limitId>=SQLITE_N_LIMIT ){
|
if( limitId<0 || limitId>=SQLITE_N_LIMIT ){
|
||||||
@ -2493,6 +2498,7 @@ static int openDatabase(
|
|||||||
|
|
||||||
assert( sizeof(db->aLimit)==sizeof(aHardLimit) );
|
assert( sizeof(db->aLimit)==sizeof(aHardLimit) );
|
||||||
memcpy(db->aLimit, aHardLimit, sizeof(db->aLimit));
|
memcpy(db->aLimit, aHardLimit, sizeof(db->aLimit));
|
||||||
|
db->aLimit[SQLITE_LIMIT_WORKER_THREADS] = 0;
|
||||||
db->autoCommit = 1;
|
db->autoCommit = 1;
|
||||||
db->nextAutovac = -1;
|
db->nextAutovac = -1;
|
||||||
db->szMmap = sqlite3GlobalConfig.szMmap;
|
db->szMmap = sqlite3GlobalConfig.szMmap;
|
||||||
|
@ -2287,15 +2287,14 @@ void sqlite3Pragma(
|
|||||||
*/
|
*/
|
||||||
case PragTyp_THREADS: {
|
case PragTyp_THREADS: {
|
||||||
sqlite3_int64 N;
|
sqlite3_int64 N;
|
||||||
if( sqlite3GlobalConfig.bCoreMutex
|
if( zRight
|
||||||
&& zRight
|
|
||||||
&& sqlite3DecOrHexToI64(zRight, &N)==SQLITE_OK
|
&& sqlite3DecOrHexToI64(zRight, &N)==SQLITE_OK
|
||||||
&& N>=0
|
&& N>=0
|
||||||
){
|
){
|
||||||
if( N>SQLITE_MAX_WORKER_THREADS ) N = SQLITE_MAX_WORKER_THREADS;
|
sqlite3_limit(db, SQLITE_LIMIT_WORKER_THREADS, (int)(N&0x7fffffff));
|
||||||
db->mxWorker = N&0xff;
|
|
||||||
}
|
}
|
||||||
returnSingleInt(pParse, "soft_heap_limit", db->mxWorker);
|
returnSingleInt(pParse, "threads",
|
||||||
|
sqlite3_limit(db, SQLITE_LIMIT_WORKER_THREADS, -1));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3073,6 +3073,10 @@ int sqlite3_limit(sqlite3*, int id, int newVal);
|
|||||||
**
|
**
|
||||||
** [[SQLITE_LIMIT_TRIGGER_DEPTH]] ^(<dt>SQLITE_LIMIT_TRIGGER_DEPTH</dt>
|
** [[SQLITE_LIMIT_TRIGGER_DEPTH]] ^(<dt>SQLITE_LIMIT_TRIGGER_DEPTH</dt>
|
||||||
** <dd>The maximum depth of recursion for triggers.</dd>)^
|
** <dd>The maximum depth of recursion for triggers.</dd>)^
|
||||||
|
**
|
||||||
|
** [[SQLITE_LIMIT_WORKER_THREADS]] ^(<dt>SQLITE_LIMIT_WORKER_THREADS</dt>
|
||||||
|
** <dd>The maximum number of separate worker threads that a single
|
||||||
|
** [database connection] may start to help it with a computation.</dd>)^
|
||||||
** </dl>
|
** </dl>
|
||||||
*/
|
*/
|
||||||
#define SQLITE_LIMIT_LENGTH 0
|
#define SQLITE_LIMIT_LENGTH 0
|
||||||
@ -3086,6 +3090,7 @@ int sqlite3_limit(sqlite3*, int id, int newVal);
|
|||||||
#define SQLITE_LIMIT_LIKE_PATTERN_LENGTH 8
|
#define SQLITE_LIMIT_LIKE_PATTERN_LENGTH 8
|
||||||
#define SQLITE_LIMIT_VARIABLE_NUMBER 9
|
#define SQLITE_LIMIT_VARIABLE_NUMBER 9
|
||||||
#define SQLITE_LIMIT_TRIGGER_DEPTH 10
|
#define SQLITE_LIMIT_TRIGGER_DEPTH 10
|
||||||
|
#define SQLITE_LIMIT_WORKER_THREADS 11
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** CAPI3REF: Compiling An SQL Statement
|
** CAPI3REF: Compiling An SQL Statement
|
||||||
|
@ -941,7 +941,7 @@ struct Schema {
|
|||||||
** The number of different kinds of things that can be limited
|
** The number of different kinds of things that can be limited
|
||||||
** using the sqlite3_limit() interface.
|
** using the sqlite3_limit() interface.
|
||||||
*/
|
*/
|
||||||
#define SQLITE_N_LIMIT (SQLITE_LIMIT_TRIGGER_DEPTH+1)
|
#define SQLITE_N_LIMIT (SQLITE_LIMIT_WORKER_THREADS+1)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
** Lookaside malloc is a set of fixed-size buffers that can be used
|
** Lookaside malloc is a set of fixed-size buffers that can be used
|
||||||
@ -1013,7 +1013,6 @@ struct sqlite3 {
|
|||||||
u8 suppressErr; /* Do not issue error messages if true */
|
u8 suppressErr; /* Do not issue error messages if true */
|
||||||
u8 vtabOnConflict; /* Value to return for s3_vtab_on_conflict() */
|
u8 vtabOnConflict; /* Value to return for s3_vtab_on_conflict() */
|
||||||
u8 isTransactionSavepoint; /* True if the outermost savepoint is a TS */
|
u8 isTransactionSavepoint; /* True if the outermost savepoint is a TS */
|
||||||
u8 mxWorker; /* Maximum number of worker threads */
|
|
||||||
int nextPagesize; /* Pagesize after VACUUM if >0 */
|
int nextPagesize; /* Pagesize after VACUUM if >0 */
|
||||||
u32 magic; /* Magic number for detect library misuse */
|
u32 magic; /* Magic number for detect library misuse */
|
||||||
int nChange; /* Value returned by sqlite3_changes() */
|
int nChange; /* Value returned by sqlite3_changes() */
|
||||||
|
@ -796,7 +796,16 @@ int sqlite3VdbeSorterInit(
|
|||||||
#if SQLITE_MAX_WORKER_THREADS==0
|
#if SQLITE_MAX_WORKER_THREADS==0
|
||||||
# define nWorker 0
|
# define nWorker 0
|
||||||
#else
|
#else
|
||||||
int nWorker = sqlite3TempInMemory(db) ? 0 : db->mxWorker ;
|
int nWorker;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Initialize the upper limit on the number of worker threads */
|
||||||
|
#if SQLITE_MAX_WORKER_THREADS>0
|
||||||
|
if( sqlite3TempInMemory(db) || sqlite3GlobalConfig.bCoreMutex==0 ){
|
||||||
|
nWorker = 0;
|
||||||
|
}else{
|
||||||
|
nWorker = db->aLimit[SQLITE_LIMIT_WORKER_THREADS];
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* Do not allow the total number of threads (main thread + all workers)
|
/* Do not allow the total number of threads (main thread + all workers)
|
||||||
|
Loading…
Reference in New Issue
Block a user