Nathan Bronson
2c1db5ea51
always invalidate sequential-insertion cache for concurrent skiplist adds
...
Summary:
InlineSkipList::InsertConcurrently should invalidate the
sequential-insertion cache prev_[] for all inserts of multi-level nodes,
not just those that increase the height of the skip list. The invariant
for prev_ is that prev_[i] (i > 0) is supposed to be the predecessor of
prev_[0] at level i. Before this diff InsertConcurrently could violate
this constraint when inserting a multi-level node after prev_[i] but
before prev_[0].
This diff also reenables kConcurrentSkipList as db_test's
MultiThreaded/MultiThreadedDBTest.MultiThreaded/29.
Test Plan:
1. unit tests
2. temporarily hack kConcurrentSkipList timing so that it is fast but has a 1.5% failure rate on my dev box (1ms stagger on thread launch, 1s test duration, failure rate baseline over 1000 runs)
3. observe 1000 passes post-fix
Reviewers: igor, sdong
Reviewed By: sdong
Subscribers: MarkCallaghan, dhruba
Differential Revision: https://reviews.facebook.net/D53751
2016-02-03 11:08:16 -08:00
..
2016-01-26 10:49:24 -08:00
2016-02-02 10:33:49 +01:00
2016-01-26 10:49:24 -08:00
2015-12-11 12:34:11 -08:00
2015-12-11 12:34:11 -08:00
2015-07-17 18:59:11 +02:00
2016-01-04 09:24:30 -08:00
2016-02-01 12:45:45 -08:00
2016-01-29 16:15:53 -08:00
2016-01-06 18:14:01 -08:00
2016-01-26 11:30:30 -08:00
2015-07-14 11:32:54 -07:00
2015-07-14 11:32:54 -07:00
2015-12-08 16:47:31 -08:00
2015-12-18 16:08:31 -08:00
2015-12-10 11:35:38 -08:00
2015-12-11 16:56:24 -08:00
2015-12-18 16:08:31 -08:00
2016-01-28 18:35:01 -08:00
2015-12-11 01:54:48 +09:00
2016-01-08 13:56:57 -08:00
2016-01-08 13:56:57 -08:00
2015-12-15 15:26:20 -08:00
2015-12-23 22:59:42 -08:00
2015-12-22 11:37:19 -08:00
2015-10-16 14:10:33 -07:00
2015-12-29 13:22:13 -08:00
2015-12-23 22:59:42 -08:00
2015-07-20 10:50:46 -07:00
2016-01-19 18:11:46 -08:00
2015-12-18 16:08:31 -08:00
2016-01-29 16:15:53 -08:00
2015-10-22 15:15:37 -07:00
2015-06-19 16:08:31 -07:00
2015-12-14 11:20:34 -08:00
2015-06-17 12:37:59 -07:00
2015-07-14 11:32:54 -07:00
2015-09-25 21:25:30 -07:00
2016-02-02 19:14:56 -08:00
2016-02-02 19:14:56 -08:00
2016-01-26 10:49:24 -08:00
2016-01-26 10:49:24 -08:00
2015-10-12 13:05:42 -07:00
2015-10-22 15:15:37 -07:00
2016-01-07 07:59:14 -08:00
2015-12-16 12:08:30 -08:00
2015-12-24 04:10:00 +08:00
2016-02-02 19:14:56 -08:00
2015-12-02 14:50:33 -08:00
2015-12-15 15:26:20 -08:00
2016-02-01 20:41:57 -08:00
2016-02-03 11:08:16 -08:00
2016-02-01 15:09:50 -08:00
2016-02-01 14:58:46 -08:00
2015-10-22 15:15:37 -07:00
2015-07-14 00:21:41 -07:00
2015-09-17 11:42:56 -07:00
2015-12-16 12:08:30 -08:00
2015-12-15 15:26:20 -08:00
2015-12-11 16:47:34 -08:00
2015-06-03 19:57:01 -07:00
2015-04-23 12:10:36 -07:00
2016-01-06 11:51:53 -08:00
2015-04-29 10:52:31 -07:00
2015-04-29 10:52:31 -07:00
2015-12-11 01:54:48 +09:00
2015-03-17 14:08:00 -07:00
2015-11-10 22:58:01 -08:00
2015-11-10 22:58:01 -08:00
2015-12-11 12:34:11 -08:00
2016-01-26 10:49:16 -08:00
2015-12-11 12:34:11 -08:00
2015-12-25 11:03:40 -08:00
2015-12-25 11:03:40 -08:00
2015-11-17 11:51:37 -08:00
2015-12-15 15:26:20 -08:00
2015-11-13 15:50:59 -08:00
2015-12-25 11:03:40 -08:00
2016-02-03 11:08:16 -08:00
2016-02-02 19:14:56 -08:00
2016-02-02 19:14:56 -08:00
2015-07-07 12:10:10 -07:00
2015-12-22 11:37:19 -08:00
2015-10-19 17:24:05 -04:00
2015-10-19 17:24:05 -04:00
2015-10-19 17:24:05 -04:00
2015-10-19 17:24:05 -04:00
2015-11-24 16:33:09 +03:00
2015-11-24 16:33:09 +03:00
2016-01-26 10:49:05 -08:00
2015-04-09 21:05:18 -07:00
2015-10-14 11:06:27 -07:00
2015-12-25 11:03:40 -08:00
2015-12-25 11:03:40 -08:00
2015-08-05 07:33:27 -07:00
2015-10-13 15:32:13 -07:00
2015-10-13 15:32:13 -07:00
2016-01-06 13:43:22 -08:00
2015-12-25 11:03:40 -08:00
2015-11-02 12:44:27 -08:00
2015-05-11 14:51:51 -07:00
2015-10-07 09:30:03 -07:00
2015-10-13 15:32:13 -07:00
2015-10-13 15:32:13 -07:00
2015-06-26 11:35:46 -07:00
2015-12-15 15:26:20 -08:00
2015-11-10 23:23:36 -08:00
2016-02-01 13:41:13 -08:00
2016-01-11 16:10:48 -08:00
2015-11-05 13:24:05 -08:00
2015-12-28 15:06:34 -08:00
2015-03-17 14:08:00 -07:00
2015-11-09 19:25:22 -08:00
2015-03-17 19:23:08 -07:00
2015-12-08 16:47:31 -08:00
2015-12-11 12:34:11 -08:00
2015-12-23 10:15:07 -08:00
2015-12-23 10:15:07 -08:00
2015-10-09 14:36:51 -07:00
2015-09-17 11:42:56 -07:00
2015-10-09 14:36:51 -07:00
2015-10-18 21:24:32 -04:00
2015-07-17 16:58:18 -07:00
2015-09-21 17:21:59 -07:00
2015-12-15 15:26:20 -08:00
2015-10-19 17:31:13 -07:00
2015-10-08 15:51:45 -07:00
2015-10-08 15:51:45 -07:00
2015-12-11 16:47:34 -08:00
2015-12-15 15:26:20 -08:00
2016-02-01 14:58:46 -08:00
2016-02-01 14:58:46 -08:00
2015-12-24 04:10:00 +08:00
2015-12-24 04:10:00 +08:00
2014-11-10 17:39:38 -05:00
2015-09-17 11:42:56 -07:00
2015-12-25 11:03:40 -08:00
2016-02-01 16:07:53 -08:00
2015-12-25 11:03:40 -08:00
2015-07-20 10:54:15 -07:00
2015-05-29 14:36:35 -07:00
2015-12-23 11:33:15 -08:00
2016-01-29 16:15:53 -08:00
2016-01-29 16:15:53 -08:00
2015-12-30 14:56:18 -08:00
2015-12-30 14:56:18 -08:00
2015-12-25 11:03:40 -08:00
2016-01-26 10:49:05 -08:00
2016-01-26 10:49:05 -08:00