/* * Copyright (C) 2008, 2014, 2015 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include "config.h" #include "StructureStubInfo.h" #include "JSObject.h" #include "PolymorphicGetByIdList.h" #include "PolymorphicPutByIdList.h" namespace JSC { #if ENABLE(JIT) void StructureStubInfo::deref() { switch (accessType) { case access_get_by_id_list: { delete u.getByIdList.list; return; } case access_put_by_id_list: delete u.putByIdList.list; return; case access_in_list: { PolymorphicAccessStructureList* polymorphicStructures = u.inList.structureList; delete polymorphicStructures; return; } case access_put_by_id_transition_normal: case access_put_by_id_transition_direct: ObjectPropertyConditionSet::adoptRawPointer(u.putByIdTransition.rawConditionSet); u.putByIdTransition.rawConditionSet = nullptr; return; case access_get_by_id_self: case access_put_by_id_replace: case access_unset: // These instructions don't have to release any allocated memory return; default: RELEASE_ASSERT_NOT_REACHED(); } } bool StructureStubInfo::visitWeakReferences(RepatchBuffer& repatchBuffer) { switch (accessType) { case access_get_by_id_self: if (!Heap::isMarked(u.getByIdSelf.baseObjectStructure.get())) return false; break; case access_get_by_id_list: { if (!u.getByIdList.list->visitWeak(repatchBuffer)) return false; break; } case access_put_by_id_transition_normal: case access_put_by_id_transition_direct: if (!Heap::isMarked(u.putByIdTransition.previousStructure.get()) || !Heap::isMarked(u.putByIdTransition.structure.get())) return false; if (!ObjectPropertyConditionSet::fromRawPointer(u.putByIdTransition.rawConditionSet).areStillLive()) return false; break; case access_put_by_id_replace: if (!Heap::isMarked(u.putByIdReplace.baseObjectStructure.get())) return false; break; case access_put_by_id_list: if (!u.putByIdList.list->visitWeak(repatchBuffer)) return false; break; case access_in_list: { PolymorphicAccessStructureList* polymorphicStructures = u.inList.structureList; if (!polymorphicStructures->visitWeak(u.inList.listSize)) return false; break; } default: // The rest of the instructions don't require references, so there is no need to // do anything. break; } return true; } #endif } // namespace JSC