|
Packit |
c71e3f |
#include "gcc-common.h"
|
|
Packit |
c71e3f |
#include <error.h>
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
#define PLUGIN_NAME "ppc64le-plugin"
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
int plugin_is_GPL_compatible;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
struct plugin_info plugin_info = {
|
|
Packit |
c71e3f |
.version = "1",
|
|
Packit |
c71e3f |
.help = PLUGIN_NAME ": insert nops after local calls\n",
|
|
Packit |
c71e3f |
};
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
static unsigned int ppc64le_plugin_execute(void)
|
|
Packit |
c71e3f |
{
|
|
Packit |
c71e3f |
rtx_insn *insn;
|
|
Packit |
c71e3f |
int code;
|
|
Packit |
c71e3f |
const char *name;
|
|
Packit |
c71e3f |
static int nonlocal_code = -1, local_code = -1,
|
|
Packit |
c71e3f |
value_nonlocal_code = -1, value_local_code = -1;
|
|
Packit |
c71e3f |
static bool initialized = false;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
if (initialized)
|
|
Packit |
c71e3f |
goto found;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
/* Find the rs6000.md code numbers for local and non-local calls */
|
|
Packit |
c71e3f |
initialized = true;
|
|
Packit |
c71e3f |
for (code = 0; code < 1000; code++) {
|
|
Packit |
c71e3f |
name = get_insn_name(code);
|
|
Packit |
c71e3f |
if (!name)
|
|
Packit |
c71e3f |
continue;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
if (!strcmp(name , "*call_local_aixdi"))
|
|
Packit |
c71e3f |
local_code = code;
|
|
Packit |
c71e3f |
else if (!strcmp(name , "*call_nonlocal_aixdi"))
|
|
Packit |
c71e3f |
nonlocal_code = code;
|
|
Packit |
c71e3f |
else if (!strcmp(name, "*call_value_local_aixdi"))
|
|
Packit |
c71e3f |
value_local_code = code;
|
|
Packit |
c71e3f |
else if (!strcmp(name, "*call_value_nonlocal_aixdi"))
|
|
Packit |
c71e3f |
value_nonlocal_code = code;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
if (nonlocal_code != -1 && local_code != -1 &&
|
|
Packit |
c71e3f |
value_nonlocal_code != -1 && value_local_code != -1)
|
|
Packit |
c71e3f |
goto found;
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
found:
|
|
Packit |
c71e3f |
if (nonlocal_code == -1 || local_code == -1 ||
|
|
Packit |
c71e3f |
value_nonlocal_code == -1 || value_local_code == -1) {
|
|
Packit |
c71e3f |
fprintf(stderr, PLUGIN_NAME ": can't find call instruction codes");
|
|
Packit |
c71e3f |
return 1;
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
/* Convert local calls to non-local */
|
|
Packit |
c71e3f |
for (insn = get_insns(); insn; insn = NEXT_INSN(insn)) {
|
|
Packit |
c71e3f |
if (GET_CODE(insn) == CALL_INSN) {
|
|
Packit |
c71e3f |
if (INSN_CODE(insn) == local_code)
|
|
Packit |
c71e3f |
INSN_CODE(insn) = nonlocal_code;
|
|
Packit |
c71e3f |
else if (INSN_CODE(insn) == value_local_code)
|
|
Packit |
c71e3f |
INSN_CODE(insn) = value_nonlocal_code;
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
return 0;
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
#define PASS_NAME ppc64le_plugin
|
|
Packit |
c71e3f |
#define NO_GATE
|
|
Packit |
c71e3f |
#include "gcc-generate-rtl-pass.h"
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
int plugin_init(struct plugin_name_args *plugin_info,
|
|
Packit |
c71e3f |
struct plugin_gcc_version *version)
|
|
Packit |
c71e3f |
{
|
|
Packit |
c71e3f |
const char * const plugin_name = plugin_info->base_name;
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
PASS_INFO(ppc64le_plugin, "vregs", 1, PASS_POS_INSERT_AFTER);
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
if (!plugin_default_version_check(version, &gcc_version))
|
|
Packit |
c71e3f |
error(1, 0, PLUGIN_NAME ": incompatible gcc/plugin versions");
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
register_callback(plugin_name, PLUGIN_INFO, NULL, &plugin_info);
|
|
Packit |
c71e3f |
register_callback(plugin_name, PLUGIN_PASS_MANAGER_SETUP, NULL,
|
|
Packit |
c71e3f |
&ppc64le_plugin_pass_info);
|
|
Packit |
c71e3f |
|
|
Packit |
c71e3f |
return 0;
|
|
Packit |
c71e3f |
}
|
|
Packit |
c71e3f |
|