Ticket UUID: | 95ab8f02c3b8eb314cae8962d8b8ed8a45abde42 | ||
Title: | Bus error in SQLite under Solaris 9 (sparc) | ||
Status: | Fixed | Type: | Code_Defect |
Severity: | Critical | Priority: | |
Subsystem: | Resolution: | Fixed | |
Last Modified: | 2009-06-08 03:32:35 | ||
Version Found In: | 915bfd99fe | ||
Description & Comments: | |||
To develop another project under Solaris 9 (sparc), I decided first to build Fossil to use it as VCS for my project. Unfortunately it was not possible to build it streight ahead. Following was necessary:
After these, the binary could be built. But using it to e.g. clone or rebuild an existing repository, will result in a bus error with core dump. A debugger excerpt shows: bash-2.05$ ./fossil clone ~/repos/t3x.fsl t3x.fsl Repository cloned into t3x.fsl Rebuilding repository meta-data... Bus Error (core dumped) bash-2.05$ gdb fossil core GNU gdb 5.0 Copyright 2000 Free Software Foundation, Inc. GDB is free software, covered by the GNU General Public License, and you are welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions. There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "sparc-sun-solaris2.9"... Core was generated by `./fossil clone /export/home/cle/repos/t3x.fsl t3x.fsl'. Program terminated with signal 10, Bus Error. Reading symbols from /usr/lib/libz.so.1...done. Loaded symbols for /usr/lib/libz.so.1 Reading symbols from /usr/lib/libsocket.so.1...done. Loaded symbols for /usr/lib/libsocket.so.1 Reading symbols from /usr/lib/libnsl.so.1...done. Loaded symbols for /usr/lib/libnsl.so.1 Reading symbols from /usr/lib/libc.so.1...done. Loaded symbols for /usr/lib/libc.so.1 Reading symbols from /usr/lib/libdl.so.1...done. Loaded symbols for /usr/lib/libdl.so.1 Reading symbols from /usr/lib/libmp.so.2...done. Loaded symbols for /usr/lib/libmp.so.2 Reading symbols from /usr/platform/SUNW,Ultra-5_10/lib/libc_psr.so.1...done. Loaded symbols for /usr/platform/SUNW,Ultra-5_10/lib/libc_psr.so.1 #0 sqlite3RowSetInsert (p=0x10e7a0, rowid=16) at src/sqlite3.c:30020 30020 pEntry->v = rowid; (gdb) bt #0 sqlite3RowSetInsert (p=0x10e7a0, rowid=16) at src/sqlite3.c:30020 #1 0x71410 in sqlite3VdbeExec (p=0xff568) at src/sqlite3.c:54628 #2 0x6c4dc in sqlite3Step (p=0xff568) at src/sqlite3.c:49092 #3 0x6c624 in sqlite3_step (pStmt=0xff568) at src/sqlite3.c:49168 #4 0x85f5c in sqlite3_exec (db=0xf54f8, zSql=0xff668 "DROP TABLE 'filename'", xCallback=0, pArg=0x0, pzErrMsg=0xffbffa3c) at src/sqlite3.c:5421 #5 0x29af4 in db_multi_exec (zSql=0xc2ae0 "DROP TABLE %Q") at db_.c:390 #6 0x3cdc4 in rebuild_db (randomize=0, doOut=1039808) at rebuild_.c:221 #7 0x27288 in clone_cmd () at clone_.c:94 #8 0x3579c in main (argc=0, argv=0xffbffc5c) at main_.c:248 (gdb) p pEntry No symbol "pEntry" in current context. (gdb) list 30015 p->pFresh = pNew->aEntry; 30016 p->nFresh = ROWSET_ENTRY_PER_CHUNK; 30017 } 30018 pEntry = p->pFresh++; 30019 p->nFresh--; 30020 pEntry->v = rowid; 30021 pEntry->pRight = 0; 30022 pLast = p->pLast; 30023 if( pLast ){ 30024 if( p->isSorted && rowid<=pLast->v ){ (gdb) info loc pLast = (struct RowSetEntry *) 0x0 (gdb) quit However, if I took the file sqlite3.c of revision 767ae79c3d replacing the actual file of revision 915bfd99fe, then all will run correctly without any fault! So I assume, the error was introduced in revision 3b76c0474e (SQLite 3.6.14.1), as replacing the faulty file with that revision's one, also caused a bus error. If further information is necessary, please let me know ... Ciao, chi :-) drh added on 2009-06-07 17:07:10: See http://www.sqlite.org/cvstrac/tktview?tn=3869 for additional information. chi added on 2009-06-08 03:32:35: Thank you very much! Ciao, chi. |