RFR (XS) 8143615 compactHashtable.hpp includes oop.inline.hpp file
Stefan Karlsson
stefan.karlsson at oracle.com
Fri Dec 4 09:23:19 UTC 2015
On 2015-12-03 15:44, Ioi Lam wrote:
> On 12/3/15 1:09 AM, Stefan Karlsson wrote:
>> Hi Ioi,
>>
>> Thanks a lot for fixing this!
>>
>> Would you mind swapping these lines around?:
>>
>> #include "classfile/javaClasses.hpp"
>> +#include "classfile/compactHashtable.inline.hpp"
>
> Thanks for noticing. I will fix that.
>> Except for that nit, this looks good.
>>
>> As David says, we should get rid of the allocation.inline.hpp include
>> as well, but I think we could defer that to a separate patch (if you
>> want to).
>
> TL;DR -- this fix probably won't do much in terms of speeding up a
> rebuild, but
> may still be a good clean up ...
My main concern is not about the compile times, but that we're spreading
the include mess.
>
>
> Read the following if you're bored ----v
>
> Actually, I am not quite familiar with the rules of when/if
> *.inline.hpp can
> be inlcluded by a "regular" hpp file.Is that documented somewhere?
https://wiki.openjdk.java.net/display/HotSpot/StyleGuide#Files
>
> My guess is this happened when Stefan reported the bug:
>
> + precompiled header is used
I compile without precompiled headers.
>
> + oop.inline.hpp was (indirectly) included into precompiled.hpp.gch.d
> - this was actually not caused by compactHashtable.hpp(this file is
> not
> included by precompiled.hpp)
> You can verified this from auto-generated files such as
> hotspot/linux_amd64_compiler2/generated/dependencies/precompiled.hpp.gch.d
>
> - the culprit is src/share/vm/compiler/compilerDirectives.hpp,
> which also
> includes oop.inline.hpp,introduced in this changeset:
> changeset: 9323:a176d4737606
> user: neliasso
> 8137167: JEP165: Compiler Control: Implementation task
> Summary: Compiler Control JEP
> - the depedndency is precompiled.hpp -> ciEnv.hpp ->
> compilerDirectives.hpp-> oop.inline.hpp
:(
>
> + oop.inline.hpp itself includes many GC header files, so when Stefan
> touches one of them,
> everything is recompiled.
Yes.
>
> So my interpretation is:
>
> + We should try to minimize the number of other header files included
> in "regular" .hpp files
> - Complex inline functions should be defined in .inline.hpp files.
Yes.
> + Avoid including .inline.hpp files in "regular" .hpp files, since
> that may indirectly
> include a large set of header files.
Yes.
>
> Anyway, I don't think this can be easily adhered to, or easily
> understood, or cared
> about, by the developers.
It's quite simple if you by default _don't_ put definitions in the
header file. Put all implementation in the .cpp files, and if it's
important to inline the functions, put the code in an .inline.hpp files.
It's when code is put into .hpp that things start to become problematic.
Granted, _simple_ getters and setters in header files don't pose a problem.
> Moreover, there are actually a lot of various inline.hpp files
> being included in .hpp files.
>
> hotspot/src/share$ find . -name \*inline.hpp -prune -o -name \*.hpp
> -print | xargs grep inline.hpp | grep -v precompiled.hpp | wc
> 60 189 4387
$ find . -name \*inline.hpp -prune -o -name \*.hpp -print | xargs grep
inline.hpp | grep -v precompiled.hpp | grep "#include" | awk -F: '{
print $2}' | sort | uniq -c
5 #include "asm/macroAssembler.inline.hpp"
1 #include "assembler_zero.inline.hpp"
1 #include "bytes_linux_ppc.inline.hpp"
17 #include "memory/allocation.inline.hpp"
2 #include "memory/universe.inline.hpp"
2 #include "oops/oop.inline.hpp"
1 #include "os_windows.inline.hpp" // needed for sockaddr_in
1 #include "prims/jvmtiThreadState.inline.hpp"
6 #include "runtime/frame.inline.hpp"
6 #include "runtime/handles.inline.hpp"
1 #include "runtime/objectMonitor.inline.hpp"
2 #include "runtime/orderAccess.inline.hpp"
8 #include "runtime/thread.inline.hpp"
2 #include "utilities/bitMap.inline.hpp"
1 #include "utilities/hashtable.inline.hpp"
There used to be loads more includes of oop.inline.hpp, but I removed them.
>
> So I think in an ideal world, we should have a tool that can
> automatically
> flags the "bad" includes. But, I am not sure how much time we want to
> invest in that :-(
>
> In this particular case, after I removed oop.inline.hpp from
> compilerDirectives.hpp
> (it turned out to be an unnecessary include), only 7 include files
> were removed from
> precompiled.hpp.gch.d, so I am not sure it's a big win.
>
> But in terms of clean up, it's still a good idea to move big inline
> function
> definitions out of compactHashtable.hpp.
Not that the size shouldn't be measured in number of lines, but what
they depend on:
120 void add(unsigned int hash, Symbol* symbol) {
121 add(hash, new Entry(hash, symbol));
122 }
123
124 void add(unsigned int hash, oop string) {
125 add(hash, new Entry(hash, string));
126 }
Take these lines, for example, they force the include of
allocation.inline.hpp in compactHashtable.cpp. Simply moving these
definitions to the .cpp removes the need to include allocation.inline.hpp.
>
>
> Also, I can see that allocation.inline.hpp is included by many .hpp
> files, so
> I guess it's OK for compactHashtable.hpp to do the same. If a clean up
> is needed,
> that would need to be done in a separate RFE.
>
> hotspot/src/share$ find . -name \*inline.hpp -prune -o -name \*.hpp
> -print | xargs grep allocation.inline.hpp
> ./vm/precompiled/precompiled.hpp:# include "memory/allocation.inline.hpp"
> ./vm/prims/jvmtiEventController.hpp:#include
> "memory/allocation.inline.hpp"
> ./vm/prims/jvmtiEnvThreadState.hpp:#include
> "memory/allocation.inline.hpp"
> ./vm/prims/jvmtiThreadState.hpp:#include "memory/allocation.inline.hpp"
> ./vm/oops/generateOopMap.hpp:#include "memory/allocation.inline.hpp"
> ./vm/compiler/compileTask.hpp:#include "memory/allocation.inline.hpp"
> ./vm/compiler/methodMatcher.hpp:#include "memory/allocation.inline.hpp"
> ./vm/classfile/compactHashtable.hpp:#include
> "memory/allocation.inline.hpp"
> ./vm/classfile/symbolTable.hpp:#include "memory/allocation.inline.hpp"
> ./vm/classfile/stringTable.hpp:#include "memory/allocation.inline.hpp"
> ./vm/utilities/growableArray.hpp:#include "memory/allocation.inline.hpp"
> ./vm/utilities/stack.hpp:#include "memory/allocation.inline.hpp"
> ./vm/utilities/array.hpp:#include "memory/allocation.inline.hpp"
> ./vm/gc/g1/g1Predictions.hpp:#include "memory/allocation.inline.hpp"
> ./vm/runtime/perfData.hpp:#include "memory/allocation.inline.hpp"
> ./vm/logging/log.hpp:#include "memory/allocation.inline.hpp"
> ./vm/libadt/dict.hpp:#include "memory/allocation.inline.hpp"
It would be good to decrease that list, not add to it. Maybe
allocation.inline.hpp needs to fixed, and parts moved to the .cpp file.
I see that g1Predictions.hpp added allocation.inline.hpp. I recently
went over the entire GC code base and got rid of _all_ includes of
.inline.hpp files from .hpp files.
Stefank
>
>
> Thanks
> - Ioi
>
>
>
>> Thanks,
>> StefanK
>>
>> On 2015-12-03 03:32, Ioi Lam wrote:
>>> Please review a very small fix:
>>>
>>> http://cr.openjdk.java.net/~iklam/8143615-compactHashtable-inline-hpp/
>>>
>>> Bug: compactHashtable.hpp includes oop.inline.hpp file
>>>
>>> https://bugs.openjdk.java.net/browse/JDK-8143615
>>>
>>> Summary of fix:
>>>
>>> + deleted the include of oop.inline.hpp from compactHashtable.hpp
>>> + moved all inlined functions that require oop.inline.hpp into a
>>> new file, compactHashtable.inline.hpp
>>>
>>> Tests:
>>>
>>> JPRT
>>>
>>> Thanks
>>> - Ioi
>>
>
More information about the hotspot-dev
mailing list