RFR(M): 8207049: Minor improvements of compiler code.
Doerr, Martin
martin.doerr at sap.com
Thu Jul 12 14:21:00 UTC 2018
Hi Götz,
I have looked at all your changes. There are quite some good findings. And the other ones look at least ok to me. I couldn't see any mistakes. Reviewed.
Best regards,
Martin
-----Original Message-----
From: hotspot-compiler-dev [mailto:hotspot-compiler-dev-bounces at openjdk.java.net] On Behalf Of Lindenmaier, Goetz
Sent: Mittwoch, 11. Juli 2018 16:23
To: hotspot compiler <hotspot-compiler-dev at openjdk.java.net>
Subject: RFR(M): 8207049: Minor improvements of compiler code.
Hi,
I ran coverity on the jdk11 hotspot sources and want to propose the following fixes. I scanned the linux x86_64 build. Some issues are similar to previous parfait fixes (check for NULL, add guarantees etc.) I also identified some issues I consider real problems. If you consider some tooo conservative, I'm happy to remove them.
http://cr.openjdk.java.net/~goetz/wr18/8207049-covCompiler/01/
Real issues
-----------
x86.ad
For Op_CMoveVF the code always returned 'false'.
compileLog.cpp
read returns -1 on unsuccesful completion. Use a
singned variable and check for error before
subtracting -1 from to_read etc.
disassembler.cpp
check for _library.
jvmciCompilerToVM.cpp, getResolvedJavaType
base_object is checked for null above, so
check before printing the name, too.
simpleThresholdPolicy.cpp
If I understand correctly, if the compile queue is empty,
no max_task will be found. This is quite unlikely, though.
Useful code improvements:
-------------------------
codeBuffer.cpp
Above, next_cs is checked for NULL. I would assume this
check is boguous, but checking below, too, is on the
safe side.
The codebuffer should be aligned properly, so the
first section does not need alignment.
Make this more clear in the code. Else it looks
as if prev_dest_cs is dereferenced when NULL.
c1_IR.cpp
It's not obvious that n->subst() != n if false
on the first iteration.
c1_LinearScan.cpp
spill_candidate is used as index to an array in
_mapping_from.at() and thus should not be negative.
prev_cmp is dereferenced further down. change to guarantee.
codeCache.cpp
Use format specifyer to print strings.
methodLiveness.cpp
Turn assert into guarantee().
oopMap.cpp
Change loop so that last is always initilaized.
last gets dereferenced below.
jvmciCodeInstaller.cpp
DebugInformationRecorder::describe_scope might pass NULL.
arraycopy.cpp
If c == NULL the condition of the next if will crash.
Change to guarantee.
bytecodeInfo.cpp
If callee_method ever had been NULL, we would have
seen a crach or assertion in post_inlining_event.
callnode.cpp
Would fail if IR is broken.
compile.cpp
Don't access arrays at negative indexes.
gcm.cpp
There must be an LCA, as there should be at least one
ancestor.
ifnode.cpp
It's unclear that a proj is found in if (vop == Op_Phi)
indexSet.cpp
Wrong data type used.
lcm.cpp
Turn assertion into guarantee, don't access worklist at -1.
loopPredicate.cpp
limit is dereferenced by _igvn.type(limit)
loopTransform.cpp
if limit_n == NULL, we will skip the following if and do _igvn.type(limit_n)
either return false, a guarantee or assert would do, too, I think.
macro.cpp
igvn.replace_node(fallthroughproj, ctrl) would fail if ctrl == NULL.
memnode.cpp
igvn is checked for NULL above, too. Protect all uses similarly.
In the default case load == NULL would be dereferenced below.
node.hpp
arr is checked for NULL above. Maybe remove (arr == NULL) check above?
output.cpp
turn assertion into guarantee
parse1.cpp
turn assertion into guarantee
reg_split.cpp
turn assertion into guarantee
runtime.cpp
print "no method" if m == NULL (assigned NULL above).
type.cpp
One of the if blocks should be reached in any case.
Change else if into a guarantee.
It's obviously pointless to scan adlc, but fixing the
issues does not hurt either I think.
archDesc.cpp
Above, node is checked for NULL.
arena.cpp
memset writes bytes.
dfa.cpp, valid_loc():
breaks are missing.
dfa.cpp, compute_external():
Use strncat (should also use snprintf, but we still have
VS 2013 which does not support that)
filebuff.cpp
breaks are missing.
formssel.cpp
name_left was just checked for NULL.
form2 is checked for NULL above, so check needed here, too.
main.cpp
Wrong delete operator used.
output_c.cpp
We cannot continue after this error, as below
inst_rep_var is dereferenced.
opc is assigned NULL if local == NULL. (in both cases).
More information about the hotspot-compiler-dev
mailing list