[oe] [meta-java][PATCH 1/2] icedtea7-native: Fix segmentation fault

Ricardo Ribalda Delgado ricardo.ribalda at gmail.com
Wed Nov 16 00:11:33 UTC 2016


ping?

On Mon, Oct 31, 2016 at 11:34 AM, Ricardo Ribalda Delgado
<ricardo.ribalda at gmail.com> wrote:
> Without this patch the generated icedtea produces segmentation faults.
> This is probably due to a race condition during cleanout.
>
> Signed-off-by: Ricardo Ribalda Delgado <ricardo.ribalda at gmail.com>
> ---
>  recipes-core/icedtea/icedtea7-native.inc           |  2 ++
>  .../icedtea/openjdk-7-03b147/sigsegv.patch         | 42 ++++++++++++++++++++++
>  2 files changed, 44 insertions(+)
>  create mode 100644 recipes-core/icedtea/openjdk-7-03b147/sigsegv.patch
>
> diff --git a/recipes-core/icedtea/icedtea7-native.inc b/recipes-core/icedtea/icedtea7-native.inc
> index 00756888b62c..0ecf620cd279 100644
> --- a/recipes-core/icedtea/icedtea7-native.inc
> +++ b/recipes-core/icedtea/icedtea7-native.inc
> @@ -42,6 +42,7 @@ SRC_URI = " \
>    file://allow-headless-build.patch;striplevel=0 \
>    file://jaxws_fix_NullPointerException.patch;apply=no \
>    file://timezoneszip.patch \
> +  file://sigsegv.patch;apply=no \
>    "
>
>  S = "${WORKDIR}/${ICEDTEA}"
> @@ -153,6 +154,7 @@ do_configure_append() {
>         oe_runmake patch-boot
>
>         patch -p1 < ${WORKDIR}/jaxws_fix_NullPointerException.patch
> +       patch -p1 < ${WORKDIR}/sigsegv.patch
>  }
>
>  EXTRA_OEMAKE = ' \
> diff --git a/recipes-core/icedtea/openjdk-7-03b147/sigsegv.patch b/recipes-core/icedtea/openjdk-7-03b147/sigsegv.patch
> new file mode 100644
> index 000000000000..0c3e44eff826
> --- /dev/null
> +++ b/recipes-core/icedtea/openjdk-7-03b147/sigsegv.patch
> @@ -0,0 +1,42 @@
> +diff --git a/openjdk-boot/hotspot/src/share/vm/runtime/thread.cpp b/openjdk-boot/hotspot/src/share/vm/runtime/thread.cpp
> +index 8b7059c8389f..67e9e7bd4bce 100644
> +--- a/openjdk-boot/hotspot/src/share/vm/runtime/thread.cpp
> ++++ b/openjdk-boot/hotspot/src/share/vm/runtime/thread.cpp
> +@@ -764,10 +764,13 @@ bool Thread::claim_oops_do_par_case(int strong_roots_parity) {
> + }
> +
> + void Thread::oops_do(OopClosure* f, CodeBlobClosure* cf) {
> +-  active_handles()->oops_do(f);
> ++  if (f && active_handles())
> ++        active_handles()->oops_do(f);
> +   // Do oop for ThreadShadow
> +-  f->do_oop((oop*)&_pending_exception);
> +-  handle_area()->oops_do(f);
> ++  if (f)
> ++        f->do_oop((oop*)&_pending_exception);
> ++  if (f && handle_area())
> ++        handle_area()->oops_do(f);
> + }
> +
> + void Thread::nmethods_do(CodeBlobClosure* cf) {
> +diff --git a/openjdk/hotspot/src/share/vm/runtime/thread.cpp b/openjdk/hotspot/src/share/vm/runtime/thread.cpp
> +index 8b7059c8389f..67e9e7bd4bce 100644
> +--- a/openjdk/hotspot/src/share/vm/runtime/thread.cpp
> ++++ b/openjdk/hotspot/src/share/vm/runtime/thread.cpp
> +@@ -764,10 +764,13 @@ bool Thread::claim_oops_do_par_case(int strong_roots_parity) {
> + }
> +
> + void Thread::oops_do(OopClosure* f, CodeBlobClosure* cf) {
> +-  active_handles()->oops_do(f);
> ++  if (f && active_handles())
> ++        active_handles()->oops_do(f);
> +   // Do oop for ThreadShadow
> +-  f->do_oop((oop*)&_pending_exception);
> +-  handle_area()->oops_do(f);
> ++  if (f)
> ++        f->do_oop((oop*)&_pending_exception);
> ++  if (f && handle_area())
> ++        handle_area()->oops_do(f);
> + }
> +
> + void Thread::nmethods_do(CodeBlobClosure* cf) {
> --
> 2.10.1
>



-- 
Ricardo Ribalda



More information about the Openembedded-devel mailing list