felix-dev mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From "Richard S. Hall (JIRA)" <j...@apache.org>
Subject [jira] [Updated] (FELIX-3000) Move sending service registered event out of bundle lock
Date Thu, 16 Jun 2011 16:11:48 GMT

     [ https://issues.apache.org/jira/browse/FELIX-3000?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel

Richard S. Hall updated FELIX-3000:

    Fix Version/s: framework-4.0.0

If this fix is needed before framework 4.0, then we'll need to branch from the 3.2.2 release

> Move sending service registered event out of bundle lock
> --------------------------------------------------------
>                 Key: FELIX-3000
>                 URL: https://issues.apache.org/jira/browse/FELIX-3000
>             Project: Felix
>          Issue Type: Improvement
>          Components: Framework
>    Affects Versions: framework-3.0.7, framework-3.2.2
>            Reporter: Felix Meschberger
>             Fix For: framework-4.0.0
>         Attachments: FELIX-3000-stacktrace.txt, FELIX-3000.patch
> We have a strange situation on a Framework 3.0.7 based system here which is not reproducible
on all platforms.
> We can track down a system freeze/deadlock to three threads all contending for bundle
locks and the global lock. See attached FELIX-3000-stacktrace.txt for the stack trace.
> Looking at the Framework source, particularly acquireBundleLock and acquireGlobalLock
I cannot see where this "deadlock" can occur.
> The only hint I have is a note in the Felix.registerService:
> > // TODO: CONCURRENCY - Reconsider firing event here, outside of the
> > // bundle lock.
> I wonder whether this situation can be fixed with moving the service registration event
> Looking at the code it seems to have not been changed. Thus I report this against 3.0.7
where we saw this and 3.2.2 being the latest release.

This message is automatically generated by JIRA.
For more information on JIRA, see: http://www.atlassian.com/software/jira


View raw message