mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-20 11:04:34 +02:00
8058880: Introduce identifier TEMP_DEF for effects in adl
Modified adlc sources. Reviewed-by: kvn, drchase
This commit is contained in:
parent
854f91fd5b
commit
1d9e66c743
4 changed files with 46 additions and 38 deletions
|
@ -1,5 +1,5 @@
|
||||||
//
|
//
|
||||||
// Copyright (c) 1997, 2013, Oracle and/or its affiliates. All rights reserved.
|
// Copyright (c) 1997, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
//
|
//
|
||||||
// This code is free software; you can redistribute it and/or modify it
|
// This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -981,8 +981,7 @@ void ArchDesc::initBaseOpTypes() {
|
||||||
!strcmp(ident, "ConL") || !strcmp(ident, "Con" ) ||
|
!strcmp(ident, "ConL") || !strcmp(ident, "Con" ) ||
|
||||||
!strcmp(ident, "Bool")) {
|
!strcmp(ident, "Bool")) {
|
||||||
constructOperand(ident, true);
|
constructOperand(ident, true);
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
InstructForm *insForm = new InstructForm(ident, true);
|
InstructForm *insForm = new InstructForm(ident, true);
|
||||||
// insForm->_opcode = nextUserOpType(ident);
|
// insForm->_opcode = nextUserOpType(ident);
|
||||||
_globalNames.Insert(ident, insForm);
|
_globalNames.Insert(ident, insForm);
|
||||||
|
@ -1038,6 +1037,9 @@ void ArchDesc::initBaseOpTypes() {
|
||||||
ident = "TEMP";
|
ident = "TEMP";
|
||||||
eForm = new Effect(ident);
|
eForm = new Effect(ident);
|
||||||
_globalNames.Insert(ident, eForm);
|
_globalNames.Insert(ident, eForm);
|
||||||
|
ident = "TEMP_DEF";
|
||||||
|
eForm = new Effect(ident);
|
||||||
|
_globalNames.Insert(ident, eForm);
|
||||||
ident = "CALL";
|
ident = "CALL";
|
||||||
eForm = new Effect(ident);
|
eForm = new Effect(ident);
|
||||||
_globalNames.Insert(ident, eForm);
|
_globalNames.Insert(ident, eForm);
|
||||||
|
|
|
@ -1822,6 +1822,7 @@ static int effect_lookup(const char *name) {
|
||||||
if (!strcmp(name, "KILL")) return Component::KILL;
|
if (!strcmp(name, "KILL")) return Component::KILL;
|
||||||
if (!strcmp(name, "USE_KILL")) return Component::USE_KILL;
|
if (!strcmp(name, "USE_KILL")) return Component::USE_KILL;
|
||||||
if (!strcmp(name, "TEMP")) return Component::TEMP;
|
if (!strcmp(name, "TEMP")) return Component::TEMP;
|
||||||
|
if (!strcmp(name, "TEMP_DEF")) return Component::TEMP_DEF;
|
||||||
if (!strcmp(name, "INVALID")) return Component::INVALID;
|
if (!strcmp(name, "INVALID")) return Component::INVALID;
|
||||||
if (!strcmp(name, "CALL")) return Component::CALL;
|
if (!strcmp(name, "CALL")) return Component::CALL;
|
||||||
assert(false,"Invalid effect name specified\n");
|
assert(false,"Invalid effect name specified\n");
|
||||||
|
@ -1836,6 +1837,7 @@ const char *Component::getUsedefName() {
|
||||||
case Component::USE_KILL: return "USE_KILL"; break;
|
case Component::USE_KILL: return "USE_KILL"; break;
|
||||||
case Component::KILL: return "KILL"; break;
|
case Component::KILL: return "KILL"; break;
|
||||||
case Component::TEMP: return "TEMP"; break;
|
case Component::TEMP: return "TEMP"; break;
|
||||||
|
case Component::TEMP_DEF: return "TEMP_DEF"; break;
|
||||||
case Component::DEF: return "DEF"; break;
|
case Component::DEF: return "DEF"; break;
|
||||||
case Component::CALL: return "CALL"; break;
|
case Component::CALL: return "CALL"; break;
|
||||||
default: assert(false, "unknown effect");
|
default: assert(false, "unknown effect");
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2013, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -912,10 +912,13 @@ public:
|
||||||
enum use_def_enum {
|
enum use_def_enum {
|
||||||
INVALID = 0x0,
|
INVALID = 0x0,
|
||||||
USE = 0x1,
|
USE = 0x1,
|
||||||
DEF = 0x2, USE_DEF = 0x3,
|
DEF = 0x2,
|
||||||
KILL = 0x4, USE_KILL = 0x5,
|
USE_DEF = USE | DEF,
|
||||||
|
KILL = 0x4,
|
||||||
|
USE_KILL = USE | KILL,
|
||||||
SYNTHETIC = 0x8,
|
SYNTHETIC = 0x8,
|
||||||
TEMP = USE | SYNTHETIC,
|
TEMP = USE | SYNTHETIC,
|
||||||
|
TEMP_DEF = TEMP | DEF,
|
||||||
CALL = 0x10
|
CALL = 0x10
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
|
@ -1721,7 +1721,8 @@ void ArchDesc::defineExpand(FILE *fp, InstructForm *node) {
|
||||||
assert(form, "component type must be a defined form");
|
assert(form, "component type must be a defined form");
|
||||||
OperandForm *op = form->is_operand();
|
OperandForm *op = form->is_operand();
|
||||||
|
|
||||||
if (comp->is(Component::TEMP)) {
|
if (comp->is(Component::TEMP) ||
|
||||||
|
comp->is(Component::TEMP_DEF)) {
|
||||||
fprintf(fp, " // TEMP %s\n", comp->_name);
|
fprintf(fp, " // TEMP %s\n", comp->_name);
|
||||||
if (!declared_def) {
|
if (!declared_def) {
|
||||||
// Define the variable "def" to hold new MachProjNodes
|
// Define the variable "def" to hold new MachProjNodes
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue