1c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// Copyright 2011 the V8 project authors. All rights reserved.
2c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// Redistribution and use in source and binary forms, with or without
3c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// modification, are permitted provided that the following conditions are
4c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// met:
5c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//
6c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//     * Redistributions of source code must retain the above copyright
7c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       notice, this list of conditions and the following disclaimer.
8c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//     * Redistributions in binary form must reproduce the above
9c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       copyright notice, this list of conditions and the following
10c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       disclaimer in the documentation and/or other materials provided
11c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       with the distribution.
12c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//     * Neither the name of Google Inc. nor the names of its
13c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       contributors may be used to endorse or promote products derived
14c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//       from this software without specific prior written permission.
15c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com//
16c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
28c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// Regression test of a very rare corner case where left-trimming an
29c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com// array caused invalid marking bit patterns on lazily swept pages.
30865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org//
31865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org// Lazy sweeping was deprecated. We are keeping the test case to make
32865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org// sure that concurrent sweeping, which relies on similar assumptions
33865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org// as lazy sweeping works correctly.
34c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
353c3c8d733702cb2b41471efa5eead1faf5b5711bmachenbach@chromium.org// Flags: --expose-gc --noincremental-marking --max-semi-space-size=1
36c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
37c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com(function() {
38c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  var head = new Array(1);
39c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  var tail = head;
40c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
41865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org  // Fill heap to increase old-space size and trigger concurrent sweeping on
42c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // some of the old-space pages.
43c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  for (var i = 0; i < 200; i++) {
44c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com    tail[1] = new Array(1000);
45c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com    tail = tail[1];
46c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  }
47c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  array = new Array(100);
48c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  gc(); gc();
49c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
50c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // At this point "array" should have been promoted to old-space and be
51865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org  // located in a concurrently swept page with intact marking bits. Now shift
52c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // the array to trigger left-trimming operations.
53c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  assertEquals(100, array.length);
54c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  for (var i = 0; i < 50; i++) {
55c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com    array.shift();
56c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  }
57c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  assertEquals(50, array.length);
58c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com
59c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // At this point "array" should have been trimmed from the left with
60c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // marking bits being correctly transfered to the new object start.
61865f51ff8c94f86f4c97636d70addc0f29e79674machenbach@chromium.org  // Scavenging operations cause concurrent sweeping to advance and verify
62c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  // that marking bit patterns are still sane.
63c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  for (var i = 0; i < 200; i++) {
64c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com    tail[1] = new Array(1000);
65c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com    tail = tail[1];
66c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com  }
67c3b670ff19220959730d7886892bc4beb95d2ebaerik.corry@gmail.com})();
68