public inbox for java@gcc.gnu.org
 help / color / mirror / Atom feed
From: Dave Korn <dave.korn.cygwin@googlemail.com>
To: "Boehm, Hans" <hans.boehm@hp.com>
Cc: Dave Korn <dave.korn.cygwin@googlemail.com>,
	  GCC Java <java@gcc.gnu.org>
Subject: Re: Two quick GC questions [was Re: [REVIVED: PATCH PR42811,4.5 regression]   java.lang.ExceptionInInitializerError in ecj1]
Date: Fri, 19 Feb 2010 07:04:00 -0000	[thread overview]
Message-ID: <4B7E3C07.6030806@gmail.com> (raw)
In-Reply-To: <238A96A773B3934685A7269CC8A8D0425784FAA73B@GVW0436EXB.americas.hpqcorp.net>

On 18/02/2010 22:05, Boehm, Hans wrote:
>> From: Dave Korn

>> Well, it turns out to be fairly straightforward: there is no code to
>> register the .data and .bss sections of the main executable as static
>> data regions with the GC, so it has no idea there's a live pointer to an
>> object(*) in there, and happily frees it up.

>> 1- There's no call to GC_INIT anywhere under libjava/, and I can't find
>> anything in boehm.cc that even looks suitable for the purpose.  Does
>> anyone know how the main exe's data/bss sections are supposed to get
>> registered on a posixy system?

> The GC normally does that internally, whether or not GC_INIT is called.
> GC_init_inner() does not need to get called, but the collector tries to do
> that automatically when it can, though IIRC gcj should call
> GC_init()directly, possibly not through the GC_INIT() macro.
> 
> In the simplest case, GC_init_inner calls GC_register_data_segments.  In
> other cases, GC_register_dynamic_libraries does it, and
> GC_register_main_static_data() returns false, avoiding the call the
> GC_register_data_segments.

  Thanks Hans, I think I've got it now.  The cygwin target ends up using the
generic GC_register_data_segments() implementation, which registers the minmax
range of the data and bss segments.  That did the job when cygwin was only
able to use libjava statically linked and everything was ending up in one
monolithic executable, but now we can build a shared libjava it only registers
the static data areas in the libgcj DLL, naturally.

  There's no definition for GC_register_dynamic_libraries at all, either, it
uses the empty definition that defines GC_no_dynamic_loading.  I could either
adapt the "parse /proc/self/maps file" strategy, or try making the win32 stuff
work; either way, it'll have to take care of registering the main exe's data
sections - which I guess is how things probably end up working on *nix hosts
too, when they parse the maps file.

>> 2- Libgcj statically links its own personal private copy of boehm-gc,
>> rather than using a shared library; does anyone know why it was designed
>> this way?
> Way back when, it needed a custon GC configuration.  But those options have
> generally become runtime configurable, so I suspect that's no longer true,
> though it may need to make some initialization calls to get the right
> configuration.

  Ah.  Well, when I'm building libjava as two separate sublibraries, I now
have the problem that each gets its own separate copy of the GC; that's
obviously liable to be disastrous.

  One solution would be to build a single shared GC library for them both to
reference, but I don't know what I'd have to do to get the runtime config correct.

  Another alternative would be to export the GC functions from the main libgcj
dll, for the benefit of the libgcj-noncore dll.  That's a little ugly because
we don't really want to expose those APIs to the user, but they shouldn't be
linking anything against them anyway, so we could just call it a private
interface between the two dlls and not worry about breaking binary
compatibility (or even removing altogether it in favour of an external shared
lib gc) in future.  This would probably be a safer change this close to the
release of 4.5.0, so unless any of the java maintainers have a fundamental
objection or can see a serious flaw in the suggestion, I'll go ahead and
prepare a patch that resolves the clash that way.

    cheers,
      DaveK

  reply	other threads:[~2010-02-19  7:04 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
     [not found] <4B6C9B26.3010106@gmail.com>
     [not found] ` <4B6D0C67.5030500@gmail.com>
2010-02-14 22:23   ` JVMTI events system and _jvmtiEnvironments uninitialised memory problem? [was Re: [PATCH " Dave Korn
     [not found]   ` <4B78BA6D.5000603@gmail.com>
     [not found]     ` <7230133d1002150504r23738e28if92303426c349661@mail.gmail.com>
     [not found]       ` <4B7CC61E.1050709@gmail.com>
     [not found]         ` <4B7D631B.8030401@gmail.com>
2010-02-18 20:41           ` Two quick GC questions [was Re: [REVIVED: PATCH " Dave Korn
2010-02-18 22:06             ` Boehm, Hans
2010-02-19  7:04               ` Dave Korn [this message]
2010-02-18 22:13             ` Bryce McKinlay
2010-02-19  3:22               ` Boehm, Hans
2010-02-20 18:22             ` Dave Korn

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=4B7E3C07.6030806@gmail.com \
    --to=dave.korn.cygwin@googlemail.com \
    --cc=hans.boehm@hp.com \
    --cc=java@gcc.gnu.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).