/*
* Copyright (c) 2022, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
#ifndef CPU_X86_VMSTORAGE_X86_INLINE_HPP
#define CPU_X86_VMSTORAGE_X86_INLINE_HPP
#include <cstdint>
#include "asm/register.hpp"
#include "code/vmreg.inline.hpp"
// keep in sync with jdk/internal/foreign/abi/x64/X86_64Architecture
enum class StorageType : int8_t {
INTEGER = 0,
VECTOR = 1,
X87 = 2,
STACK = 3,
PLACEHOLDER = 4,
// special locations used only by native code
FRAME_DATA = PLACEHOLDER + 1,
INVALID = -1
};
// need to define this before constructing VMStorage (below)
constexpr inline bool VMStorage::is_reg(StorageType type) {
return type == StorageType::INTEGER || type == StorageType::VECTOR || type == StorageType::X87;
}
constexpr inline StorageType VMStorage::stack_type() { return StorageType::STACK; }
constexpr inline StorageType VMStorage::placeholder_type() { return StorageType::PLACEHOLDER; }
constexpr inline StorageType VMStorage::frame_data_type() { return StorageType::FRAME_DATA; }
constexpr uint16_t REG64_MASK = 0b0000000000001111;
constexpr uint16_t XMM_MASK = 0b0000000000000001;
inline Register as_Register(VMStorage vms) {
assert(vms.type() == StorageType::INTEGER, "not the right type");
return ::as_Register(vms.index());
}
inline XMMRegister as_XMMRegister(VMStorage vms) {
assert(vms.type() == StorageType::VECTOR, "not the right type");
return ::as_XMMRegister(vms.index());
}
inline VMReg as_VMReg(VMStorage vms) {
switch (vms.type()) {
case StorageType::INTEGER: return as_Register(vms)->as_VMReg();
case StorageType::VECTOR: return as_XMMRegister(vms)->as_VMReg();
case StorageType::STACK: {
assert((vms.index() % VMRegImpl::stack_slot_size) == 0, "can not represent as VMReg");
return VMRegImpl::stack2reg(vms.index() / VMRegImpl::stack_slot_size);
}
default: ShouldNotReachHere(); return VMRegImpl::Bad();
}
}
constexpr inline VMStorage as_VMStorage(Register reg) {
return VMStorage::reg_storage(StorageType::INTEGER, REG64_MASK, reg->encoding());
}
constexpr inline VMStorage as_VMStorage(XMMRegister reg) {
return VMStorage::reg_storage(StorageType::VECTOR, XMM_MASK, reg->encoding());
}
inline VMStorage as_VMStorage(VMReg reg) {
if (reg->is_Register()) {
return as_VMStorage(reg->as_Register());
} else if (reg->is_XMMRegister()) {
return as_VMStorage(reg->as_XMMRegister());
} else if (reg->is_stack()) {
return VMStorage::stack_storage(reg);
} else if (!reg->is_valid()) {
return VMStorage::invalid();
}
ShouldNotReachHere();
return VMStorage::invalid();
}
#endif // CPU_X86_VMSTORAGE_X86_INLINE_HPP
¤ Dauer der Verarbeitung: 0.36 Sekunden
(vorverarbeitet)
¤
|
Haftungshinweis
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung ist noch experimentell.
|