5f6510825a
This CL fixes all occurences that don't require special OWNER reviews, or can be reviewed by Michi. After this one, we should be able to reenable the readability/check cpplint check. R=mstarzinger@chromium.org Bug: v8:6837, v8:6921 Cq-Include-Trybots: master.tryserver.chromium.linux:linux_chromium_rel_ng;master.tryserver.v8:v8_linux_noi18n_rel_ng Change-Id: Ic81d68d5534eaa795b7197fed5c41ed158361d62 Reviewed-on: https://chromium-review.googlesource.com/721120 Commit-Queue: Clemens Hammacher <clemensh@chromium.org> Reviewed-by: Michael Starzinger <mstarzinger@chromium.org> Cr-Commit-Position: refs/heads/master@{#48670}
46 lines
1.2 KiB
C++
46 lines
1.2 KiB
C++
// Copyright 2016 the V8 project authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef V8_LOOKUP_CACHE_INL_H_
|
|
#define V8_LOOKUP_CACHE_INL_H_
|
|
|
|
#include "src/lookup-cache.h"
|
|
|
|
#include "src/objects-inl.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
|
|
// static
|
|
int DescriptorLookupCache::Hash(Object* source, Name* name) {
|
|
DCHECK(name->IsUniqueName());
|
|
// Uses only lower 32 bits if pointers are larger.
|
|
uint32_t source_hash =
|
|
static_cast<uint32_t>(reinterpret_cast<uintptr_t>(source)) >>
|
|
kPointerSizeLog2;
|
|
uint32_t name_hash = name->hash_field();
|
|
return (source_hash ^ name_hash) % kLength;
|
|
}
|
|
|
|
int DescriptorLookupCache::Lookup(Map* source, Name* name) {
|
|
int index = Hash(source, name);
|
|
Key& key = keys_[index];
|
|
if ((key.source == source) && (key.name == name)) return results_[index];
|
|
return kAbsent;
|
|
}
|
|
|
|
void DescriptorLookupCache::Update(Map* source, Name* name, int result) {
|
|
DCHECK_NE(result, kAbsent);
|
|
int index = Hash(source, name);
|
|
Key& key = keys_[index];
|
|
key.source = source;
|
|
key.name = name;
|
|
results_[index] = result;
|
|
}
|
|
|
|
} // namespace internal
|
|
} // namespace v8
|
|
|
|
#endif // V8_LOOKUP_CACHE_INL_H_
|