8306304: Fix xlc17 clang warnings in ppc and aix code

Reviewed-by: erikj, tsteele, mbaesken
This commit is contained in:
JoKern65 2023-05-17 11:48:56 +00:00 committed by Matthias Baesken
parent 285c833ffa
commit c7951cf674
9 changed files with 37 additions and 29 deletions

View File

@ -168,10 +168,14 @@ $(eval $(call SetupJdkLibrary, BUILD_LIBJVM, \
DISABLED_WARNINGS_clang_management.cpp := missing-field-initializers, \ DISABLED_WARNINGS_clang_management.cpp := missing-field-initializers, \
DISABLED_WARNINGS_clang_notificationThread.cpp := bitwise-instead-of-logical, \ DISABLED_WARNINGS_clang_notificationThread.cpp := bitwise-instead-of-logical, \
DISABLED_WARNINGS_clang_os_posix.cpp := mismatched-tags missing-field-initializers, \ DISABLED_WARNINGS_clang_os_posix.cpp := mismatched-tags missing-field-initializers, \
DISABLED_WARNINGS_clang_aix_os_posix.cpp := format-nonliteral, \
DISABLED_WARNINGS_clang_postaloc.cpp := tautological-undefined-compare, \ DISABLED_WARNINGS_clang_postaloc.cpp := tautological-undefined-compare, \
DISABLED_WARNINGS_clang_serviceThread.cpp := bitwise-instead-of-logical, \ DISABLED_WARNINGS_clang_serviceThread.cpp := bitwise-instead-of-logical, \
DISABLED_WARNINGS_clang_vm_version_x86.cpp := missing-field-initializers, \ DISABLED_WARNINGS_clang_vm_version_x86.cpp := missing-field-initializers, \
DISABLED_WARNINGS_clang_zTracer.cpp := undefined-var-template, \ DISABLED_WARNINGS_clang_zTracer.cpp := undefined-var-template, \
DISABLED_WARNINGS_clang_aix_debug.cpp := format-nonliteral, \
DISABLED_WARNINGS_clang_aix_jvm.cpp := format-nonliteral, \
DISABLED_WARNINGS_clang_aix_osThread_aix.cpp := tautological-undefined-compare, \
DISABLED_WARNINGS_xlc := $(DISABLED_WARNINGS_xlc), \ DISABLED_WARNINGS_xlc := $(DISABLED_WARNINGS_xlc), \
DISABLED_WARNINGS_microsoft := $(DISABLED_WARNINGS_microsoft), \ DISABLED_WARNINGS_microsoft := $(DISABLED_WARNINGS_microsoft), \
ASFLAGS := $(JVM_ASFLAGS), \ ASFLAGS := $(JVM_ASFLAGS), \

View File

@ -1,6 +1,6 @@
/* /*
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2015 SAP SE. All rights reserved. * Copyright (c) 2012, 2023 SAP SE. 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
@ -61,7 +61,7 @@ int Assembler::patched_branch(int dest_pos, int inst, int inst_pos) {
case bc_op: m = bd(-1); v = bd(disp(dest_pos, inst_pos)); break; case bc_op: m = bd(-1); v = bd(disp(dest_pos, inst_pos)); break;
default: ShouldNotReachHere(); default: ShouldNotReachHere();
} }
return inst & ~m | v; return (inst & ~m) | v;
} }
// Return the offset, relative to _code_begin, of the destination of // Return the offset, relative to _code_begin, of the destination of

View File

@ -1,6 +1,6 @@
/* /*
* Copyright (c) 2002, 2023, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2002, 2023, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2022 SAP SE. All rights reserved. * Copyright (c) 2012, 2023 SAP SE. 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
@ -1013,15 +1013,15 @@ class Assembler : public AbstractAssembler {
// Test if x is within signed immediate range for nbits. // Test if x is within signed immediate range for nbits.
static bool is_simm(int x, unsigned int nbits) { static bool is_simm(int x, unsigned int nbits) {
assert(0 < nbits && nbits < 32, "out of bounds"); assert(0 < nbits && nbits < 32, "out of bounds");
const int min = -(((int)1) << nbits-1); const int min = -(((int)1) << (nbits-1));
const int maxplus1 = (((int)1) << nbits-1); const int maxplus1 = (((int)1) << (nbits-1));
return min <= x && x < maxplus1; return min <= x && x < maxplus1;
} }
static bool is_simm(jlong x, unsigned int nbits) { static bool is_simm(jlong x, unsigned int nbits) {
assert(0 < nbits && nbits < 64, "out of bounds"); assert(0 < nbits && nbits < 64, "out of bounds");
const jlong min = -(((jlong)1) << nbits-1); const jlong min = -(((jlong)1) << (nbits-1));
const jlong maxplus1 = (((jlong)1) << nbits-1); const jlong maxplus1 = (((jlong)1) << (nbits-1));
return min <= x && x < maxplus1; return min <= x && x < maxplus1;
} }
@ -1044,7 +1044,7 @@ class Assembler : public AbstractAssembler {
// X is supposed to fit in a field "nbits" wide // X is supposed to fit in a field "nbits" wide
// and be sign-extended. Check the range. // and be sign-extended. Check the range.
static void assert_signed_range(intptr_t x, int nbits) { static void assert_signed_range(intptr_t x, int nbits) {
assert(nbits == 32 || (-(1 << nbits-1) <= x && x < (1 << nbits-1)), assert(nbits == 32 || (-(1 << (nbits-1)) <= x && x < (1 << (nbits-1))),
"value out of range"); "value out of range");
} }
@ -1086,7 +1086,7 @@ class Assembler : public AbstractAssembler {
// Same as u_field for signed values // Same as u_field for signed values
static int s_field(int x, int hi_bit, int lo_bit) { static int s_field(int x, int hi_bit, int lo_bit) {
int nbits = hi_bit - lo_bit + 1; int nbits = hi_bit - lo_bit + 1;
assert(nbits == 32 || (-(1 << nbits-1) <= x && x < (1 << nbits-1)), assert(nbits == 32 || (-(1 << (nbits-1)) <= x && x < (1 << (nbits-1))),
"value out of range"); "value out of range");
x &= fmask(hi_bit, lo_bit); x &= fmask(hi_bit, lo_bit);
int r = x << lo_bit; int r = x << lo_bit;

View File

@ -1,6 +1,6 @@
/* /*
* Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2019 SAP SE. All rights reserved. * Copyright (c) 2012, 2023 SAP SE. 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
@ -40,6 +40,7 @@
#include "runtime/vm_version.hpp" #include "runtime/vm_version.hpp"
#include "utilities/powerOfTwo.hpp" #include "utilities/powerOfTwo.hpp"
#include "vmreg_ppc.inline.hpp" #include "vmreg_ppc.inline.hpp"
#include <stdint.h>
#ifdef ASSERT #ifdef ASSERT
#define __ gen()->lir(__FILE__, __LINE__)-> #define __ gen()->lir(__FILE__, __LINE__)->
@ -423,7 +424,7 @@ void LIRGenerator::do_ArithmeticOp_Long(ArithmeticOp* x) {
LIRItem right(x->y(), this); LIRItem right(x->y(), this);
// Missing test if instr is commutative and if we should swap. // Missing test if instr is commutative and if we should swap.
if (right.value()->type()->as_LongConstant() && if (right.value()->type()->as_LongConstant() &&
(x->op() == Bytecodes::_lsub && right.value()->type()->as_LongConstant()->value() == ((-1)<<15)) ) { (x->op() == Bytecodes::_lsub && right.value()->type()->as_LongConstant()->value() == INT16_MIN) ) {
// Sub is implemented by addi and can't support min_simm16 as constant.. // Sub is implemented by addi and can't support min_simm16 as constant..
right.load_item(); right.load_item();
} else { } else {
@ -477,7 +478,7 @@ void LIRGenerator::do_ArithmeticOp_Int(ArithmeticOp* x) {
LIRItem right(x->y(), this); LIRItem right(x->y(), this);
// Missing test if instr is commutative and if we should swap. // Missing test if instr is commutative and if we should swap.
if (right.value()->type()->as_IntConstant() && if (right.value()->type()->as_IntConstant() &&
(x->op() == Bytecodes::_isub && right.value()->type()->as_IntConstant()->value() == ((-1)<<15)) ) { (x->op() == Bytecodes::_isub && right.value()->type()->as_IntConstant()->value() == INT16_MIN) ) {
// Sub is implemented by addi and can't support min_simm16 as constant. // Sub is implemented by addi and can't support min_simm16 as constant.
right.load_item(); right.load_item();
} else { } else {

View File

@ -3039,7 +3039,7 @@ void MacroAssembler::decode_klass_not_null(Register dst, Register src) {
if (src == noreg) src = dst; if (src == noreg) src = dst;
Register shifted_src = src; Register shifted_src = src;
if (CompressedKlassPointers::shift() != 0 || if (CompressedKlassPointers::shift() != 0 ||
CompressedKlassPointers::base() == 0 && src != dst) { // Move required. (CompressedKlassPointers::base() == 0 && src != dst)) { // Move required.
shifted_src = dst; shifted_src = dst;
sldi(shifted_src, src, CompressedKlassPointers::shift()); sldi(shifted_src, src, CompressedKlassPointers::shift());
} }

View File

@ -11441,7 +11441,7 @@ instruct cmpL3_reg_reg(iRegIdst dst, iRegLsrc src1, iRegLsrc src2, flagsRegCR0 c
match(Set dst (CmpL3 src1 src2)); match(Set dst (CmpL3 src1 src2));
effect(KILL cr0); effect(KILL cr0);
ins_cost(DEFAULT_COST * 5); ins_cost(DEFAULT_COST * 5);
size(VM_Version::has_brw() ? 16 : 20); size((VM_Version::has_brw() ? 16 : 20));
format %{ "cmpL3_reg_reg $dst, $src1, $src2" %} format %{ "cmpL3_reg_reg $dst, $src1, $src2" %}
@ -11776,7 +11776,7 @@ instruct cmpF3_reg_reg(iRegIdst dst, regF src1, regF src2, flagsRegCR0 cr0) %{
match(Set dst (CmpF3 src1 src2)); match(Set dst (CmpF3 src1 src2));
effect(KILL cr0); effect(KILL cr0);
ins_cost(DEFAULT_COST * 6); ins_cost(DEFAULT_COST * 6);
size(VM_Version::has_brw() ? 20 : 24); size((VM_Version::has_brw() ? 20 : 24));
format %{ "cmpF3_reg_reg $dst, $src1, $src2" %} format %{ "cmpF3_reg_reg $dst, $src1, $src2" %}
@ -11860,7 +11860,7 @@ instruct cmpD3_reg_reg(iRegIdst dst, regD src1, regD src2, flagsRegCR0 cr0) %{
match(Set dst (CmpD3 src1 src2)); match(Set dst (CmpD3 src1 src2));
effect(KILL cr0); effect(KILL cr0);
ins_cost(DEFAULT_COST * 6); ins_cost(DEFAULT_COST * 6);
size(VM_Version::has_brw() ? 20 : 24); size((VM_Version::has_brw() ? 20 : 24));
format %{ "cmpD3_reg_reg $dst, $src1, $src2" %} format %{ "cmpD3_reg_reg $dst, $src1, $src2" %}
@ -14403,7 +14403,7 @@ instruct CallStaticJavaDirect(method meth) %{
ins_num_consts(3 /* up to 3 patchable constants: inline cache, 2 call targets. */); ins_num_consts(3 /* up to 3 patchable constants: inline cache, 2 call targets. */);
format %{ "CALL,static $meth \t// ==> " %} format %{ "CALL,static $meth \t// ==> " %}
size(Continuations::enabled() ? 8 : 4); size((Continuations::enabled() ? 8 : 4));
ins_encode( enc_java_static_call(meth) ); ins_encode( enc_java_static_call(meth) );
ins_pipe(pipe_class_call); ins_pipe(pipe_class_call);
%} %}
@ -14424,7 +14424,7 @@ instruct CallDynamicJavaDirectSched(method meth) %{
ins_num_consts(1 /* 1 patchable constant: call destination */); ins_num_consts(1 /* 1 patchable constant: call destination */);
format %{ "BL \t// dynamic $meth ==> " %} format %{ "BL \t// dynamic $meth ==> " %}
size(Continuations::enabled() ? 8 : 4); size((Continuations::enabled() ? 8 : 4));
ins_encode( enc_java_dynamic_call_sched(meth) ); ins_encode( enc_java_dynamic_call_sched(meth) );
ins_pipe(pipe_class_call); ins_pipe(pipe_class_call);
%} %}
@ -14502,7 +14502,7 @@ instruct CallLeafDirect(method meth) %{
predicate(false); // but never match. predicate(false); // but never match.
format %{ "BCTRL \t// leaf call $meth ==> " %} format %{ "BCTRL \t// leaf call $meth ==> " %}
size(Continuations::enabled() ? 8 : 4); size((Continuations::enabled() ? 8 : 4));
ins_encode %{ ins_encode %{
__ bctrl(); __ bctrl();
__ post_call_nop(); __ post_call_nop();

View File

@ -81,6 +81,9 @@
#include "utilities/vmError.hpp" #include "utilities/vmError.hpp"
// put OS-includes here (sorted alphabetically) // put OS-includes here (sorted alphabetically)
#ifdef AIX_XLC_GE_17
#include <alloca.h>
#endif
#include <errno.h> #include <errno.h>
#include <fcntl.h> #include <fcntl.h>
#include <inttypes.h> #include <inttypes.h>
@ -286,7 +289,7 @@ static bool my_disclaim64(char* addr, size_t size) {
char* p = addr; char* p = addr;
for (int i = 0; i < numFullDisclaimsNeeded; i ++) { for (unsigned int i = 0; i < numFullDisclaimsNeeded; i ++) {
if (::disclaim(p, maxDisclaimSize, DISCLAIM_ZEROMEM) != 0) { if (::disclaim(p, maxDisclaimSize, DISCLAIM_ZEROMEM) != 0) {
trcVerbose("Cannot disclaim %p - %p (errno %d)\n", p, p + maxDisclaimSize, errno); trcVerbose("Cannot disclaim %p - %p (errno %d)\n", p, p + maxDisclaimSize, errno);
return false; return false;
@ -371,7 +374,7 @@ static const char* describe_pagesize(size_t pagesize) {
// Must be called before calling os::large_page_init(). // Must be called before calling os::large_page_init().
static void query_multipage_support() { static void query_multipage_support() {
guarantee(g_multipage_support.pagesize == -1, guarantee(g_multipage_support.pagesize == (size_t)-1,
"do not call twice"); "do not call twice");
g_multipage_support.pagesize = ::sysconf(_SC_PAGESIZE); g_multipage_support.pagesize = ::sysconf(_SC_PAGESIZE);
@ -461,7 +464,7 @@ static void query_multipage_support() {
IPC_CREAT | S_IRUSR | S_IWUSR); IPC_CREAT | S_IRUSR | S_IWUSR);
guarantee0(shmid != -1); // Should always work. guarantee0(shmid != -1); // Should always work.
// Try to set pagesize. // Try to set pagesize.
struct shmid_ds shm_buf = { 0 }; struct shmid_ds shm_buf = { };
shm_buf.shm_pagesize = pagesize; shm_buf.shm_pagesize = pagesize;
if (::shmctl(shmid, SHM_PAGESIZE, &shm_buf) != 0) { if (::shmctl(shmid, SHM_PAGESIZE, &shm_buf) != 0) {
const int en = errno; const int en = errno;
@ -1578,7 +1581,7 @@ static char* reserve_shmated_memory (size_t bytes, char* requested_addr) {
// Just for info: query the real page size. In case setting the page size did not // Just for info: query the real page size. In case setting the page size did not
// work (see above), the system may have given us something other then 4K (LDR_CNTRL). // work (see above), the system may have given us something other then 4K (LDR_CNTRL).
const size_t real_pagesize = os::Aix::query_pagesize(addr); const size_t real_pagesize = os::Aix::query_pagesize(addr);
if (real_pagesize != shmbuf.shm_pagesize) { if (real_pagesize != (size_t)shmbuf.shm_pagesize) {
trcVerbose("pagesize is, surprisingly, " SIZE_FORMAT, real_pagesize); trcVerbose("pagesize is, surprisingly, " SIZE_FORMAT, real_pagesize);
} }

View File

@ -1,6 +1,6 @@
/* /*
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
* Copyright (c) 2012, 2021 SAP SE. All rights reserved. * Copyright (c) 2012, 2023 SAP SE. 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
@ -233,7 +233,7 @@ bool PosixSignals::pd_hotspot_signal_handler(int sig, siginfo_t* info,
goto run_stub; goto run_stub;
} }
else if ((sig == USE_POLL_BIT_ONLY ? SIGTRAP : SIGSEGV) && else if ((sig == (USE_POLL_BIT_ONLY ? SIGTRAP : SIGSEGV)) &&
((NativeInstruction*)pc)->is_safepoint_poll() && ((NativeInstruction*)pc)->is_safepoint_poll() &&
CodeCache::contains((void*) pc) && CodeCache::contains((void*) pc) &&
((cb = CodeCache::find_blob(pc)) != nullptr) && ((cb = CodeCache::find_blob(pc)) != nullptr) &&
@ -331,7 +331,7 @@ bool PosixSignals::pd_hotspot_signal_handler(int sig, siginfo_t* info,
// End life with a fatal error, message and detail message and the context. // End life with a fatal error, message and detail message and the context.
// Note: no need to do any post-processing here (e.g. signal chaining) // Note: no need to do any post-processing here (e.g. signal chaining)
va_list va_dummy; va_list va_dummy = nullptr;
VMError::report_and_die(thread, uc, nullptr, 0, msg, detail_msg, va_dummy); VMError::report_and_die(thread, uc, nullptr, 0, msg, detail_msg, va_dummy);
va_end(va_dummy); va_end(va_dummy);

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2012, 2019 SAP SE. All rights reserved. * Copyright (c) 2012, 2023 SAP SE. 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
@ -46,7 +46,7 @@ static int dladdr_dont_reload(void* addr, Dl_info* info) {
memset((void *)info, 0, sizeof(Dl_info)); memset((void *)info, 0, sizeof(Dl_info));
for (;;) { for (;;) {
if (addr >= p->ldinfo_textorg && if (addr >= p->ldinfo_textorg &&
addr < p->ldinfo_textorg + p->ldinfo_textsize) { (char*)addr < (char*)(p->ldinfo_textorg) + p->ldinfo_textsize) {
info->dli_fname = p->ldinfo_filename; info->dli_fname = p->ldinfo_filename;
info->dli_fbase = p->ldinfo_textorg; info->dli_fbase = p->ldinfo_textorg;
return 1; /* [sic] */ return 1; /* [sic] */