Commit 3050b404 authored by David Renshaw's avatar David Renshaw

fix bug where PointerBuilder::getPointerType() can corrupt the PointerBuilder::segment field

parent 4759e273
...@@ -264,7 +264,27 @@ TEST(Any, AnyStructListCapInSchema) { ...@@ -264,7 +264,27 @@ TEST(Any, AnyStructListCapInSchema) {
#endif #endif
} }
KJ_TEST("Builder::isStruct() does not corrupt segment pointer") {
MallocMessageBuilder builder(1); // small first segment
auto root = builder.getRoot<AnyPointer>();
// Do a lot of allocations so that there is likely a segment with a decent
// amount of free space.
initTestMessage(root.initAs<test::TestAllTypes>());
// This will probably get allocated in a segment that still has room for the
// Data allocation below.
root.initAs<test::TestAllTypes>();
// At one point, this caused root.builder.segment to point to the segment
// where the struct is allocated, rather than segment where the root pointer
// lives, i.e. segment zero.
EXPECT_TRUE(root.isStruct());
// If root.builder.segment points to the wrong segment and that segment has free
// space, then this triggers a DREQUIRE failure in WirePointer::setKindAndTarget().
root.initAs<Data>(1);
}
TEST(Any, Equals) { TEST(Any, Equals) {
MallocMessageBuilder builderA; MallocMessageBuilder builderA;
......
...@@ -2428,7 +2428,8 @@ PointerType PointerBuilder::getPointerType() { ...@@ -2428,7 +2428,8 @@ PointerType PointerBuilder::getPointerType() {
return PointerType::NULL_; return PointerType::NULL_;
} else { } else {
WirePointer* ptr = pointer; WirePointer* ptr = pointer;
WireHelpers::followFars(ptr, ptr->target(), segment); SegmentBuilder* sgmt = segment;
WireHelpers::followFars(ptr, ptr->target(), sgmt);
switch(ptr->kind()) { switch(ptr->kind()) {
case WirePointer::FAR: case WirePointer::FAR:
KJ_FAIL_ASSERT("far pointer not followed?"); KJ_FAIL_ASSERT("far pointer not followed?");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment