构建JVM(HotSpot)源码调试环境(OpenJDK8)
原本想在 Windows 下编译调试,但过程中遇到了诸多错误(老是报路径错误。。。),最后只好放弃。
此次记录调试的方法为 CentOS7 上编译,Windows 上使用 Clion 远程调试(也可直接在 CentOS7 桌面环境直接调试,速度快)。
一、下载源码(OpenJDK8)
yum 源使用的是阿里的 https://opsx.alibaba.com/mirror?lang=zh-CN
这里使用 mercurial(类似 Git 的版本控制系统) 下载源码,方便更新。
下面网址可以下载 mercurial 较新的版本。
https://mercurial.selenic.com/wiki/ChineseDownload
https://www.mercurial-scm.org/wiki/Download
# 或者 yum install hg -yyum install mercurial -y
# 下载源码,目标目录需要为空
hg clone http://hg.openjdk.java.net/jdk8u/jdk8u /opt/jdk8u
# 更新代码,操作和 Git 类似
hg pull
# 获取完整源码(需要在源码目录下执行,下载时间较长,一次可能下载不成功,多试几次)
cd /opt/jdk8u/
sh get_source.sh
# 完全下载成功的打印信息。若输出中出现回滚字样,即代表下载过程中出错了,需重新执行下载脚本
No repositories to process.
# Repositories: . corba jaxp jaxws langtools jdk hotspot nashorn
.: cd . && hg pull -u
corba: cd corba && hg pull -u
jaxp: cd jaxp && hg pull -u
jaxws: cd jaxws && hg pull -u
langtools: cd langtools && hg pull -u
jdk: cd jdk && hg pull -u
hotspot: cd hotspot && hg pull -u
nashorn: cd nashorn && hg pull -u
.: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/
corba: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/corba
jaxp: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/jaxp
jaxws: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/jaxws
jdk: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/jdk
langtools: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/langtools
hotspot: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/hotspot
nashorn: 正在拉自 http://hg.openjdk.java.net/jdk8u/jdk8u/nashorn
corba: 正在搜索修改
corba: 没有发现修改
jdk: 正在搜索修改
jdk: 没有发现修改
jaxws: 正在搜索修改
jaxws: 没有发现修改
.: 正在搜索修改
.: 没有发现修改
langtools: 正在搜索修改
langtools: 没有发现修改
hotspot: 正在搜索修改
hotspot: 没有发现修改
jaxp: 正在搜索修改
jaxp: 没有发现修改
nashorn: 正在搜索修改
nashorn: 没有发现修改
这里手动执行多次比较麻烦,自己写了个小脚本,循环执行。
#!/bin/bashfor i in {1..28}
do
cd /opt/jdk8u/;
sh ./get_source.sh;
done
二、编译源码
Linux 下编译比 Windows 下简单太多。
https://hg.openjdk.java.net/jdk8u/jdk8u/raw-file/945f4ae40e43/README-builds.html
构建 JDK 8 需要使用 Update 7 或更高版本的 JDK 7 版本。JDK 8 开发人员不应使用 JDK 8 作为引导 JDK,以确保 JDK 8 依赖关系不会引入使用 JDK 7 构建的系统部分。
# 查询yum list installed | grep jdk
rpm -qa | grep jdk
# 卸载
yum remove -y xxxxxxx
# 验证
java -version
# -bash: java: 未找到命令
# 安装 JDK7
# https://www.oracle.com/technetwork/java/javase/downloads/java-archive-downloads-javase7-521261.html
tar -zxf jdk-7u80-linux-x64.tar.gz -C /opt/
配置
cd /opt/jdk8u/chmod +x configure
# 直接执行配置,看看缺少什么工具或参数,按照错误提示安装和添加参数即可
./configure
# 安装编译所需工具包
yum install -y unzip zip libXtst-devel libXt-devel libXrender-devel cups-devel freetype-devel alsa-lib-devel fontconfig-devel
yum groupinstall -y "Development Tools"
# 配置编译环境
./configure --with-boot-jdk=/opt/jdk1.7.0_80/
##################################### 配置生产成功打印信息 #################################
A new configuration has been successfully created in
/opt/jdk8u/build/linux-x86_64-normal-server-release
using configure arguments "--with-boot-jdk=/opt/jdk1.7.0_80/".
Configuration summary:
* Debug level: release
* JDK variant: normal
* JVM variants: server
* OpenJDK target: OS: linux, CPU architecture: x86, address length: 64
Tools summary:
* Boot JDK: java version "1.7.0_80" Java(TM) SE Runtime Environment (build 1.7.0_80-b15) Java HotSpot(TM) 64-Bit Server VM (build 2 4.80-b11, mixed mode) (at /opt/jdk1.7.0_80)
* Toolchain: gcc (GNU Compiler Collection)
* C Compiler: Version 4.8.5 (at /usr/bin/gcc)
* C++ Compiler: Version 4.8.5 (at /usr/bin/g++)
Build performance summary:
* Cores to use: 7
* Memory limit: 15884 MB
WARNING: The result of this configuration has overridden an older
configuration. You *should* run "make clean" to make sure you get a
proper build. Failure to do so might result in strange build problems.
configure 帮助文档
Running generated-configure.sh`configure" configures OpenJDK jdk8 to adapt to many kinds of systems.
Usage: /opt/jdk8u/configure [OPTION]... [VAR=VALUE]...
To assign environment variables (e.g., CC, CFLAGS...), specify them as
VAR=VALUE. See below for descriptions of some of the useful variables.
Defaults for the options are specified in brackets.
Configuration:
-h, --help display this help and exit
--help=short display options specific to this package
--help=recursive display the short help of all the included packages
-V, --version display version information and exit
-q, --quiet, --silent do not print `checking ..." messages
--cache-file=FILE cache test results in FILE [disabled]
-C, --config-cache alias for `--cache-file=config.cache"
-n, --no-create do not create output files
--srcdir=DIR find the sources in DIR [configure dir or `.."]
Installation directories:
--prefix=PREFIX install architecture-independent files in PREFIX [/usr/local]
--exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX]
By default, `make install" will install all the files in `/usr/local/bin", `/usr/local/lib" etc. You can specify an installation prefix other than `/usr/local" using `--prefix", for instance `--prefix=$HOME".
For better control, use the options below.
Fine tuning of the installation directories:
--bindir=DIR user executables [EPREFIX/bin]
--sbindir=DIR system admin executables [EPREFIX/sbin]
--libexecdir=DIR program executables [EPREFIX/libexec]
--sysconfdir=DIR read-only single-machine data [PREFIX/etc]
--sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com]
--localstatedir=DIR modifiable single-machine data [PREFIX/var]
--libdir=DIR object code libraries [EPREFIX/lib]
--includedir=DIR C header files [PREFIX/include]
--oldincludedir=DIR C header files for non-gcc [/usr/include]
--datarootdir=DIR read-only arch.-independent data root [PREFIX/share]
--datadir=DIR read-only architecture-independent data [DATAROOTDIR]
--infodir=DIR info documentation [DATAROOTDIR/info]
--localedir=DIR locale-dependent data [DATAROOTDIR/locale]
--mandir=DIR man documentation [DATAROOTDIR/man]
--docdir=DIR documentation root [DATAROOTDIR/doc/openjdk]
--htmldir=DIR html documentation [DOCDIR]
--dvidir=DIR dvi documentation [DOCDIR]
--pdfdir=DIR pdf documentation [DOCDIR]
--psdir=DIR ps documentation [DOCDIR]
X features:
--x-includes=DIR X include files are in DIR
--x-libraries=DIR X library files are in DIR
System types:
--build=BUILD configure for building on BUILD [guessed]
--host=HOST cross-compile to build programs to run on HOST [BUILD]
--target=TARGET configure for building compilers for TARGET [HOST]
Optional Features:
--disable-option-checking ignore unrecognized --enable/--with options
--disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no)
--enable-FEATURE[=ARG] include FEATURE [ARG=yes]
--enable-openjdk-only suppress building custom source even if present [disabled]
--enable-debug set the debug level to fastdebug (shorthand for --with-debug-level=fastdebug) [disabled]
--disable-headful disable building headful support (graphical UI support) [enabled]
--enable-hotspot-test-in-build
run the Queens test after Hotspot build [disabled]
--enable-unlimited-crypto
Enable unlimited crypto policy [disabled]
--disable-debug-symbols disable generation of debug symbols [enabled]
--disable-zip-debug-info
disable zipping of debug-info files [enabled]
--enable-macosx-runtime-support
Deprecated. Option is kept for backwards compatibility and is ignored
--disable-freetype-bundling
disable bundling of the freetype library with the build result [enabled on Windows or when using --with-freetype, disabled otherwise]
--enable-sjavac use sjavac to do fast incremental compiles [disabled]
--disable-precompiled-headers
disable using precompiled headers when compiling C++ [enabled]
--enable-ccache enable using ccache to speed up recompilations [disabled]
Optional Packages:
--with-PACKAGE[=ARG] use PACKAGE [ARG=yes]
--without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no)
--with-custom-make-dir use this directory for custom build/make files
--with-target-bits build 32-bit or 64-bit binaries (for platforms that support it), e.g. --with-target-bits=32 [guessed]
--with-jdk-variant JDK variant to build (normal) [normal]
--with-jvm-interpreter JVM interpreter to build (template, cpp) [template]
--with-jvm-variants JVM variants (separated by commas) to build (server, client, minimal1, kernel, zero, zeroshark, core) [server]
--with-debug-level set the debug level (release, fastdebug, slowdebug) [release]
--with-devkit use this devkit for compilers, tools and resources
--with-sys-root alias for --with-sysroot for backwards compatability
--with-sysroot use this directory as sysroot)
--with-tools-dir alias for --with-toolchain-path for backwards compatibility
--with-toolchain-path prepend these directories when searching for toolchain binaries (compilers etc)
--with-extra-path prepend these directories to the default path
--with-xcode-path explicit path to Xcode 4 (generally for building on 10.9 and later)
--with-conf-name use this as the name of the configuration [generated from important configuration options]
--with-builddeps-conf use this configuration file for the builddeps
--with-builddeps-server download and use build dependencies from this server url
--with-builddeps-dir store downloaded build dependencies here [/localhome/builddeps]
--with-builddeps-group chgrp the downloaded build dependencies to this group
--with-cacerts-file specify alternative cacerts file
--with-milestone Set milestone value for build [internal]
--with-update-version Set update version value for build [b00]
--with-user-release-suffix
Add a custom string to the version string if build number isn"t set.[username_builddateb00]
--with-build-number Set build number value for build [b00]
--with-vendor-name Set vendor name. Among others, used to set the "java.vendor" and "java.vm.vendor" system properties. [not specified]
--with-vendor-url Set the "java.vendor.url" system property [not specified]
--with-vendor-bug-url Set the "java.vendor.url.bug" system property [not specified]
--with-vendor-vm-bug-url
Sets the bug URL which will be displayed when the VM crashes [not specified]
--with-copyright-year Set copyright year value for build [current year]
--with-boot-jdk path to Boot JDK (used to bootstrap build) [probed]
--with-boot-jdk-jvmargs specify JVM arguments to be passed to all invocations of the Boot JDK, overriding the default values, e.g --with-boot-jdk-jvmargs="-Xmx8G -enableassertions"
--with-add-source-root for each and every source directory, look in this additional source root for the same directory; if it exists and have files in it, include it in the build
--with-override-source-root
for each and every source directory, look in this override source root for the same directory; if it exists, use that directory instead and ignore the directory in the original source root
--with-adds-and-overrides
use the subdirs "adds" and "overrides" in the specified directory as add-source-root and override-source-root
--with-override-langtools
use this langtools dir for the build
--with-override-corba use this corba dir for the build
--with-override-jaxp use this jaxp dir for the build
--with-override-jaxws use this jaxws dir for the build
--with-override-hotspot use this hotspot dir for the build
--with-override-nashorn use this nashorn dir for the build
--with-override-jdk use this jdk dir for the build
--with-import-hotspot import hotspot binaries from this jdk image or hotspot build dist dir instead of building from source
--with-toolchain-type the toolchain type (or family) to use, use "--help" to show possible values [platform dependent]
--with-toolchain-version
the version of the toolchain to look for, use "--help" to show possible values [platform dependent]
--with-jtreg Regression Test Harness [probed]
--with-extra-cflags extra flags to be used when compiling jdk c-files
--with-extra-cxxflags extra flags to be used when compiling jdk c++-files
--with-extra-ldflags extra flags to be used when linking jdk
--with-native-debug-symbols
set the native debug symbol configuration (none, internal, external, zipped) [varying]
--with-x use the X Window System
--with-cups specify prefix directory for the cups package (expecting the headers under PATH/include)
--with-cups-include specify directory for the cups include files
--with-freetype specify prefix directory for the freetype package (expecting the libraries under PATH/lib and the headers under PATH/include)
--with-freetype-include specify directory for the freetype include files
--with-freetype-lib specify directory for the freetype library
--with-freetype-src specify directory with freetype sources to automatically build the library (experimental, Windows-only)
--with-alsa specify prefix directory for the alsa package (expecting the libraries under PATH/lib and the headers under PATH/include)
--with-alsa-include specify directory for the alsa include files
--with-alsa-lib specify directory for the alsa library
--with-fontconfig specify prefix directory for the fontconfig package (expecting the headers under PATH/include)
--with-fontconfig-include
specify directory for the fontconfig include files
--with-giflib use giflib from build system or OpenJDK source (system, bundled) [bundled]
--with-zlib use zlib from build system or OpenJDK source (system, bundled) [bundled]
--with-stdc++lib=<static>,<dynamic>,<default>
force linking of the C++ runtime on Linux to either static or dynamic, default is static with dynamic as fallback
--with-msvcr-dll path to microsoft C runtime dll (msvcr*.dll) (Windows only) [probed]
--with-msvcp-dll path to microsoft C++ runtime dll (msvcp*.dll) (Windows only) [probed]
--with-ucrt-dll-dir path to Microsoft Windows Kit UCRT DLL dir (Windows only) [probed]
--with-dxsdk Deprecated. Option is kept for backwards compatibility and is ignored
--with-dxsdk-lib Deprecated. Option is kept for backwards compatibility and is ignored
--with-dxsdk-include Deprecated. Option is kept for backwards compatibility and is ignored
--with-num-cores number of cores in the build system, e.g. --with-num-cores=8 [probed]
--with-memory-size memory (in MB) available in the build system, e.g. --with-memory-size=1024 [probed]
--with-jobs number of parallel jobs to let make run [calculated based on cores and memory]
--with-sjavac-server-java
use this java binary for running the sjavac background server [Boot JDK java]
--with-ccache-dir where to store ccache files [~/.ccache]
Some influential environment variables:
BASENAME Override default value for BASENAME
BASH Override default value for BASH
CAT Override default value for CAT
CHMOD Override default value for CHMOD
CMP Override default value for CMP
COMM Override default value for COMM
CP Override default value for CP
CUT Override default value for CUT
DATE Override default value for DATE
DIFF Override default value for DIFF
DIRNAME Override default value for DIRNAME
ECHO Override default value for ECHO
EXPR Override default value for EXPR
FILE Override default value for FILE
FIND Override default value for FIND
HEAD Override default value for HEAD
LN Override default value for LN
LS Override default value for LS
MKDIR Override default value for MKDIR
MKTEMP Override default value for MKTEMP
MV Override default value for MV
NAWK Override default value for NAWK
PRINTF Override default value for PRINTF
RM Override default value for RM
SH Override default value for SH
SORT Override default value for SORT
TAIL Override default value for TAIL
TAR Override default value for TAR
TEE Override default value for TEE
TOUCH Override default value for TOUCH
TR Override default value for TR
UNAME Override default value for UNAME
UNIQ Override default value for UNIQ
WC Override default value for WC
WHICH Override default value for WHICH
XARGS Override default value for XARGS
AWK Override default value for AWK
GREP Override default value for GREP
EGREP Override default value for EGREP
FGREP Override default value for FGREP
SED Override default value for SED
CYGPATH Override default value for CYGPATH
READLINK Override default value for READLINK
DF Override default value for DF
SETFILE Override default value for SETFILE
CPIO Override default value for CPIO
UNZIP Override default value for UNZIP
ZIP Override default value for ZIP
LDD Override default value for LDD
READELF Override default value for READELF
HG Override default value for HG
STAT Override default value for STAT
TIME Override default value for TIME
DSYMUTIL Override default value for DSYMUTIL
XATTR Override default value for XATTR
CODESIGN Override default value for CODESIGN
PKG_CONFIG path to pkg-config utility
CC C compiler command
CFLAGS C compiler flags
LDFLAGS linker flags, e.g. -L<lib dir> if you have libraries in a
nonstandard directory <lib dir>
LIBS libraries to pass to the linker, e.g. -l<library>
CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I<include dir> if
you have headers in a nonstandard directory <include dir>
CXX C++ compiler command
CXXFLAGS C++ compiler flags
CPP C preprocessor
CXXCPP C++ preprocessor
AS Override default value for AS
AR Override default value for AR
OBJC Objective C compiler command
OBJCFLAGS Objective C compiler flags
LIPO Override default value for LIPO
STRIP Override default value for STRIP
NM Override default value for NM
GNM Override default value for GNM
MCS Override default value for MCS
OBJCOPY Override default value for OBJCOPY
OBJDUMP Override default value for OBJDUMP
BUILD_CC Override default value for BUILD_CC
BUILD_CXX Override default value for BUILD_CXX
BUILD_LD Override default value for BUILD_LD
JTREGEXE Override default value for JTREGEXE
XMKMF Path to xmkmf, Makefile generator for X Window System
FREETYPE_CFLAGS
C compiler flags for FREETYPE, overriding pkg-config
FREETYPE_LIBS
linker flags for FREETYPE, overriding pkg-config
ALSA_CFLAGS C compiler flags for ALSA, overriding pkg-config
ALSA_LIBS linker flags for ALSA, overriding pkg-config
LIBFFI_CFLAGS
C compiler flags for LIBFFI, overriding pkg-config
LIBFFI_LIBS linker flags for LIBFFI, overriding pkg-config
CCACHE Override default value for CCACHE
Use these variables to override the choices made by `configure" or to help
it to find libraries and programs with nonstandard names/locations.
Report bugs to <build-dev@openjdk.java.net>.
OpenJDK home page: <http://openjdk.java.net>.
Additional (non-autoconf) OpenJDK Options:
--openjdk-target=TARGET cross-compile with TARGET as target platform (i.e. the one you will run the resulting binary on).
Equivalent to --host=TARGET --target=TARGET --build=<current platform>
--debug-configure Run the configure script with additional debug logging enabled.
The following toolchains are available as arguments to --with-toolchain-type.
Which are valid to use depends on the build platform.
gcc GNU Compiler Collection
clang clang/LLVM
solstudio Oracle Solaris Studio
xlc IBM XL C/C++
microsoft Microsoft Visual Studio
Please be aware that, when cross-compiling, the OpenJDK configure script will
generally use "target" where autoconf traditionally uses "host".
Also note that variables must be passed on the command line. Variables in the
environment will generally be ignored, unlike traditional autoconf scripts.
编译
# ZIP_DEBUGINFO_FILES=0 生成调试信息文件 libjvm.debuginfo,否则会被压缩成 libjvm.diz,debug 时只能看到汇编代码,不能跟进源码# ENABLE_FULL_DEBUG_SYMBOLS=1 生成调试符号,可不加,不影响调试
# 编译
make all ZIP_DEBUGINFO_FILES=0 ENABLE_FULL_DEBUG_SYMBOLS=1
# 编译成功打印信息
----- Build times -------
Start 2019-06-27 01:22:28
End 2019-06-27 01:31:44
00:00:20 corba
00:00:09 demos
00:01:53 docs
00:03:01 hotspot
00:00:17 images
00:00:18 jaxp
00:00:23 jaxws
00:02:06 jdk
00:00:34 langtools
00:00:15 nashorn
00:09:16 TOTAL
-------------------------
Finished building OpenJDK for target "all"
# 测试
./build/linux-x86_64-normal-server-release/jdk/bin/java -version
# openjdk version "1.8.0-internal"
# OpenJDK Runtime Environment (build 1.8.0-internal-root_2019_06_27_00_56-b00)
# OpenJDK 64-Bit Server VM (build 25.71-b00, mixed mode)
# 查看 libjvm.debuginfo
ls ./build/linux-x86_64-normal-server-release/jdk/lib/amd64/server/
# 若编译时没有设置生成,可进入该目录(libjvm.so 所在目录)手动解压
unzip libjvm.diz
make 帮助文档
View Code
三、Windows 远程调试
CentOS7 端
yum remove -y cmake gdbyum install -y gcc gcc-c++ make wget
# 安装 cmake,yum 源安装的版本较低
cd /opt/
wget https://cmake.org/files/v3.14/cmake-3.14.5.tar.gz
tar -zxf cmake-3.14.5.tar.gz
cd cmake-3.14.5
# 默认安装在 /usr/local/share/,可执行文件在 /usr/local/bin/
./bootstrap && make && make install
ln -s /usr/local/bin/cmake /usr/bin/cmake
cmake -version
# 安装 gdb
# 这里可以找到 gdb 镜像站点 https://www.gnu.org/software/gdb/download/
# 这里下载 texinfo 新版本 http://ftp.gnu.org/gnu/texinfo/
yum install -y texinfo
cd /opt/
wget https://mirrors.ustc.edu.cn/gnu/gdb/gdb-8.2.1.tar.gz
tar -zxf gdb-8.2.1.tar.gz
cd gdb-8.2.1
# 之前若出现过编译错误需要删掉(有缓存),重新解压编译
# 默认安装在 /usr/local/share/,可执行文件在 /usr/local/bin/
./configure && make && make install
ln -s /usr/local/bin/gdb /usr/bin/gdb
gdb -ver
Windows 端
首先用 Clion 新建一个空项目
远程调试
同步代码(windows 上的代码需要和 CentOS 上的代码一样)
连接信息
对应目录,本地目录为新建的 Hello World 项目路径
同步时要排除的本地目录
下载远程代码
关闭项目,用载入的方式重新打开项目
设置远程调试,地址为 CentOS 地址,端口随意
在 CentOS 上启动 GDB,端口与上面对应
yum install gdb-gdbserver -ygdbserver :1234 /opt/jdk8u/build/linux-x86_64-normal-server-release/jdk/bin/java -version
打上断点,启动的 DeBug(比较慢,载入 libjvm.debuginfo 的时候)
四、CentOS 桌面本地调试
只调试 JVM 可以直接导入 hotspot 项目,速度快点
配置调试
https://blog.csdn.net/tjiyu/article/details/53725247
https://my.oschina.net/u/3982963/blog/3045233
https://www.jianshu.com/p/ee7e9176632c
https://yddmax.github.io/2017/06/11/openjdk7%E4%B9%8B%E7%BC%96%E8%AF%91%E5%92%8Cdebug/
https://blog.csdn.net/lihao21/article/details/87425187
https://jiges.github.io/2017/11/10/win10%E5%88%A9%E7%94%A8Netbeans%E8%BF%9C%E7%A8%8B%E6%9E%84%E5%BB%BA%E8%B0%83%E8%AF%95OpenJDK/
https://coding3min.com/CLion_cplusplus/
以上是 构建JVM(HotSpot)源码调试环境(OpenJDK8) 的全部内容, 来源链接: utcz.com/z/512767.html