blob: c3028c4f936edf96712dbe73a07662f0a26b1d0a [file] [log] [blame]
drh643167f2008-01-22 21:30:53 +00001/*
2** 2008 Jan 22
3**
4** The author disclaims copyright to this source code. In place of
5** a legal notice, here is a blessing:
6**
7** May you do good and not evil.
8** May you find forgiveness for yourself and forgive others.
9** May you share freely, never taking more than you give.
10**
11*************************************************************************
drh643167f2008-01-22 21:30:53 +000012**
danielk1977ef05f2d2008-06-20 11:05:37 +000013** This file contains code to support the concept of "benign"
danielk19772d1d86f2008-06-20 14:59:51 +000014** malloc failures (when the xMalloc() or xRealloc() method of the
15** sqlite3_mem_methods structure fails to allocate a block of memory
16** and returns 0).
drh643167f2008-01-22 21:30:53 +000017**
danielk19772d1d86f2008-06-20 14:59:51 +000018** Most malloc failures are non-benign. After they occur, SQLite
19** abandons the current operation and returns an error code (usually
20** SQLITE_NOMEM) to the user. However, sometimes a fault is not necessarily
21** fatal. For example, if a malloc fails while resizing a hash table, this
22** is completely recoverable simply by not carrying out the resize. The
23** hash table will continue to function normally. So a malloc failure
24** during a hash table resize is a benign fault.
drh643167f2008-01-22 21:30:53 +000025*/
danielk1977ef05f2d2008-06-20 11:05:37 +000026
drh643167f2008-01-22 21:30:53 +000027#include "sqliteInt.h"
28
danielk1977ef05f2d2008-06-20 11:05:37 +000029#ifndef SQLITE_OMIT_BUILTIN_TEST
danielk1977d09414c2008-06-19 18:17:49 +000030
31/*
danielk19772d1d86f2008-06-20 14:59:51 +000032** Global variables.
danielk1977d09414c2008-06-19 18:17:49 +000033*/
drh78f82d12008-09-02 00:52:52 +000034typedef struct BenignMallocHooks BenignMallocHooks;
35static SQLITE_WSD struct BenignMallocHooks {
danielk19772d1d86f2008-06-20 14:59:51 +000036 void (*xBenignBegin)(void);
37 void (*xBenignEnd)(void);
drh78f82d12008-09-02 00:52:52 +000038} sqlite3Hooks = { 0, 0 };
39
40/* The "wsdHooks" macro will resolve to the appropriate BenignMallocHooks
41** structure. If writable static data is unsupported on the target,
42** we have to locate the state vector at run-time. In the more common
43** case where writable static data is supported, wsdHooks can refer directly
44** to the "sqlite3Hooks" state vector declared above.
45*/
46#ifdef SQLITE_OMIT_WSD
47# define wsdHooksInit \
48 BenignMallocHooks *x = &GLOBAL(BenignMallocHooks,sqlite3Hooks)
49# define wsdHooks x[0]
50#else
51# define wsdHooksInit
52# define wsdHooks sqlite3Hooks
53#endif
54
danielk1977d09414c2008-06-19 18:17:49 +000055
56/*
danielk19772d1d86f2008-06-20 14:59:51 +000057** Register hooks to call when sqlite3BeginBenignMalloc() and
58** sqlite3EndBenignMalloc() are called, respectively.
danielk1977d09414c2008-06-19 18:17:49 +000059*/
danielk19772d1d86f2008-06-20 14:59:51 +000060void sqlite3BenignMallocHooks(
61 void (*xBenignBegin)(void),
62 void (*xBenignEnd)(void)
63){
drh78f82d12008-09-02 00:52:52 +000064 wsdHooksInit;
65 wsdHooks.xBenignBegin = xBenignBegin;
66 wsdHooks.xBenignEnd = xBenignEnd;
danielk1977d09414c2008-06-19 18:17:49 +000067}
68
danielk19772d1d86f2008-06-20 14:59:51 +000069/*
70** This (sqlite3EndBenignMalloc()) is called by SQLite code to indicate that
71** subsequent malloc failures are benign. A call to sqlite3EndBenignMalloc()
72** indicates that subsequent malloc failures are non-benign.
drh643167f2008-01-22 21:30:53 +000073*/
danielk19772d1d86f2008-06-20 14:59:51 +000074void sqlite3BeginBenignMalloc(void){
drh78f82d12008-09-02 00:52:52 +000075 wsdHooksInit;
76 if( wsdHooks.xBenignBegin ){
77 wsdHooks.xBenignBegin();
danielk19772d1d86f2008-06-20 14:59:51 +000078 }
drh4873d5f2008-05-13 13:27:33 +000079}
danielk19772d1d86f2008-06-20 14:59:51 +000080void sqlite3EndBenignMalloc(void){
drh78f82d12008-09-02 00:52:52 +000081 wsdHooksInit;
82 if( wsdHooks.xBenignEnd ){
83 wsdHooks.xBenignEnd();
danielk19772d1d86f2008-06-20 14:59:51 +000084 }
drh643167f2008-01-22 21:30:53 +000085}
86
danielk1977ef05f2d2008-06-20 11:05:37 +000087#endif /* #ifndef SQLITE_OMIT_BUILTIN_TEST */