From: Imeev Mergen <imeevma@tarantool.org> To: "n.pettik" <korablev@tarantool.org>, tarantool-patches@freelists.org Cc: Vladislav Shpilevoy <v.shpilevoy@tarantool.org> Subject: [tarantool-patches] Re: [PATCH 3/3] sql: too many autogenerated ids leads to SEGFAULT Date: Thu, 22 Nov 2018 21:09:39 +0300 [thread overview] Message-ID: <05a63d11-105a-6dd7-add7-8aeeca48d8ed@tarantool.org> (raw) In-Reply-To: <ADF4F323-ADF3-47A7-BF0B-08FC61898113@tarantool.org> [-- Attachment #1: Type: text/plain, Size: 4172 bytes --] Hi! Thank you for review! New patch below. On 11/19/18 8:27 PM, n.pettik wrote: >> This probleam appeared because region was cleaned twice: once in > Typo: problem > >> sqlite3VdbeHalt() and once in sqlite3VdbeDelete() which was >> executed during sqlite3_finalize(). Autogenerated ids that were >> saved there, were fetched after sqlite3VdbeHalt() and before >> sqlite3_finalize(). In this patch region cleaning in >> sqlite3VdbeHalt() were removed. > Typo: was (or better - has been removed). > > Again, IMHO I would rephrase commit subject: > > sql: remove region_truncate() from sqlite3VdbeHalt() > > And explain in commit message why it was removed. > > Patch itself is OK. Fixed commit-message. *New patch:** * commit dd5b3aaa63b9fe2312a6fb30f3ba87bf8329b222 Author: Mergen Imeev <imeevma@gmail.com> Date: Sat Nov 17 13:05:55 2018 +0300 sql: remove fiber_gc() from sqlite3VdbeHalt() Too many autogenerated ids leads to SEGFAULT. This problem appeared because region was cleaned twice: once in sqlite3VdbeHalt() and once in sqlite3VdbeDelete() which was executed during sqlite3_finalize(). Autogenerated ids that were saved there, were fetched after sqlite3VdbeHalt() and before sqlite3_finalize(). In this patch region cleaning in sqlite3VdbeHalt() has been removed. Follow up #2618 Follow up #3199 diff --git a/src/box/sql/vdbe.c b/src/box/sql/vdbe.c index b6afe91..cc340e9 100644 --- a/src/box/sql/vdbe.c +++ b/src/box/sql/vdbe.c @@ -2911,12 +2911,8 @@ case OP_MakeRecord: { * memory shouldn't be reused until it is written into WAL. * * However, if memory for ephemeral space is allocated - * on region, it will be freed only in vdbeHalt() routine. - * It is the only way to free this region memory, - * since ephemeral spaces don't have nothing in common - * with txn routine and region memory won't be released - * after txn_commit() or txn_rollback() as it happens - * with ordinary spaces. + * on region, it will be freed only in sqlite3_finalize() + * routine. */ if (bIsEphemeral) { rc = sqlite3VdbeMemClearAndResize(pOut, nByte); diff --git a/src/box/sql/vdbeaux.c b/src/box/sql/vdbeaux.c index 615a0f0..f2faad8 100644 --- a/src/box/sql/vdbeaux.c +++ b/src/box/sql/vdbeaux.c @@ -2498,12 +2498,6 @@ sqlite3VdbeHalt(Vdbe * p) p->rc = SQLITE_NOMEM_BKPT; } - /* Release all region memory which was allocated - * to hold tuples to be inserted into ephemeral spaces. - */ - if (!box_txn()) - fiber_gc(); - assert(db->nVdbeActive > 0 || box_txn() || p->anonymous_savepoint == NULL); return (p->rc == SQLITE_BUSY ? SQLITE_BUSY : SQLITE_OK); diff --git a/test/sql/iproto.result b/test/sql/iproto.result index 6c50781..000b359 100644 --- a/test/sql/iproto.result +++ b/test/sql/iproto.result @@ -843,6 +843,22 @@ cn:execute('select * from "test"') s:drop() --- ... +-- Too many autogenerated ids leads to SEGFAULT. +cn = remote.connect(box.cfg.listen) +--- +... +box.sql.execute('CREATE TABLE t1(id INTEGER PRIMARY KEY AUTOINCREMENT)') +--- +... +for i = 0, 1000 do cn:execute("INSERT INTO t1 VALUES (null)") end +--- +... +_ = cn:execute("INSERT INTO t1 SELECT NULL from t1") +--- +... +box.sql.execute('DROP TABLE t1') +--- +... cn:close() --- ... diff --git a/test/sql/iproto.test.lua b/test/sql/iproto.test.lua index e12decd..2501393 100644 --- a/test/sql/iproto.test.lua +++ b/test/sql/iproto.test.lua @@ -272,6 +272,13 @@ s:insert({2, {a = 3}}) cn:execute('select * from "test"') s:drop() +-- Too many autogenerated ids leads to SEGFAULT. +cn = remote.connect(box.cfg.listen) +box.sql.execute('CREATE TABLE t1(id INTEGER PRIMARY KEY AUTOINCREMENT)') +for i = 0, 1000 do cn:execute("INSERT INTO t1 VALUES (null)") end +_ = cn:execute("INSERT INTO t1 SELECT NULL from t1") +box.sql.execute('DROP TABLE t1') + cn:close() box.schema.user.revoke('guest', 'read,write,execute', 'universe') [-- Attachment #2: Type: text/html, Size: 5699 bytes --]
next prev parent reply other threads:[~2018-11-22 18:09 UTC|newest] Thread overview: 18+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-11-19 13:47 [tarantool-patches] [PATCH 0/3] A set of small SQL fixes Vladislav Shpilevoy 2018-11-19 13:47 ` [tarantool-patches] [PATCH 1/3] sql: EXPLAIN through net.box leads to SEGFAULT Vladislav Shpilevoy 2018-11-19 17:27 ` [tarantool-patches] " n.pettik 2018-11-22 18:08 ` Imeev Mergen 2018-11-22 18:31 ` Vladislav Shpilevoy 2018-11-22 20:55 ` [tarantool-patches] Re[2]: " Мерген Имеев 2018-11-23 6:04 ` [tarantool-patches] Re: Re[2]: " Kirill Yukhin 2018-11-28 12:36 ` [tarantool-patches] " n.pettik 2018-11-29 14:58 ` Konstantin Osipov 2018-11-19 13:47 ` [tarantool-patches] [PATCH 2/3] sql: SELECT from system spaces returns unpacked msgpack Vladislav Shpilevoy 2018-11-19 17:27 ` [tarantool-patches] " n.pettik 2018-11-22 18:09 ` Imeev Mergen 2018-11-27 8:51 ` n.pettik 2018-11-19 13:47 ` [tarantool-patches] [PATCH 3/3] sql: too many autogenerated ids leads to SEGFAULT Vladislav Shpilevoy 2018-11-19 17:27 ` [tarantool-patches] " n.pettik 2018-11-22 18:09 ` Imeev Mergen [this message] 2018-11-27 8:50 ` n.pettik 2018-11-27 10:09 ` [tarantool-patches] Re: [PATCH 0/3] A set of small SQL fixes Kirill Yukhin
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=05a63d11-105a-6dd7-add7-8aeeca48d8ed@tarantool.org \ --to=imeevma@tarantool.org \ --cc=korablev@tarantool.org \ --cc=tarantool-patches@freelists.org \ --cc=v.shpilevoy@tarantool.org \ --subject='[tarantool-patches] Re: [PATCH 3/3] sql: too many autogenerated ids leads to SEGFAULT' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox