Closed
      
        Bug 614423
      
      
        Opened 14 years ago
          Closed 7 years ago
      
        
    
  
Meta: Reduce plugin-enumeration IO
Categories
(Core Graveyard :: Plug-ins, defect)
Tracking
(Not tracked)
        RESOLVED
        FIXED
        
    
  
People
(Reporter: taras.mozilla, Unassigned)
References
(Blocks 1 open bug)
Details
(Keywords: meta, perf)
Attachments
(1 file, 1 obsolete file)
| 4.33 KB,
          text/plain         | Details | 
nsPluginHost::ScanPluginsDirectory takes ~4 seconds on startup enumerating directories containing disabled plugins. From xperf logs, those dlls are being loaded, so I'm guessing that ScanPluginsDirectory is unintentially LoadLibrary()ing those dlls(and their dependencies).
|   | Reporter | |
| Comment 1•14 years ago
           | ||
Note, this user only has the flash plugin enabled
|   | Reporter | |
| Comment 2•14 years ago
           | ||
bug 613679 fixed this too.
Status: NEW → RESOLVED
Closed: 14 years ago
Resolution: --- → DUPLICATE
|   | Reporter | |
| Comment 3•14 years ago
           | ||
Nevermind, bug 613679 made this go away on my system, Kurt's machine is still suffering.
Status: RESOLVED → REOPENED
Resolution: DUPLICATE → ---
|   | Reporter | |
| Comment 4•14 years ago
           | ||
The problem is that nsPluginsDir::IsPluginFile check calls CanLoadPlugin() which opens files to check if they are actually plugins. I think we can all agree that memory mapping + reading a few bits of every damn dll in every a plugin directory on every startup is stupid.
This is resulting in extra 30s of startup for some users :(
blocking2.0: --- → ?
OS: Linux → Windows 7
|   | Reporter | |
| Comment 5•14 years ago
           | ||
The files that do not get opened get stat()ed. In a sample log i got 21pointless open()s and >200 pointless stat() calls of this variety.
| Comment 6•14 years ago
           | ||
I assume that we do this so that we don't report that a plugin is usable if we're running as a different architecture (like our 64-bit Windows builds running on a system with 32-bit plugins installed).
|   | Reporter | |
| Comment 7•14 years ago
           | ||
(In reply to comment #6)
> I assume that we do this so that we don't report that a plugin is usable if
> we're running as a different architecture (like our 64-bit Windows builds
> running on a system with 32-bit plugins installed).
Can we not do that when we actually try to load the plugin for the first time, instead of every time :)
|   | Reporter | |
| Comment 8•14 years ago
           | ||
|   | Reporter | |
| Comment 9•14 years ago
           | ||
(In reply to comment #8)
> Created attachment 494099 [details] [diff] [review]
> this cuts down the number of firefox stat() calls by 4x
This patch + removing .dll-reading code speeds up the enumeration process by ~4x
|   | Reporter | |
| Updated•14 years ago
           | 
        Attachment #494099 -
        Attachment is obsolete: true
|   | Reporter | |
| Comment 12•14 years ago
           | ||
(In reply to comment #11)
> Taras, is this done?
There are a few minor issues remaining: I need to track down why the java plugin is being poked on every startup and make sure that linux/mac codepaths are also fixed.
| Comment 13•14 years ago
           | ||
Windows and Mac seem to be dealt with now. Is there anything more for Linux that is needed still?
|   | Reporter | |
| Comment 14•14 years ago
           | ||
(In reply to comment #13)
> Windows and Mac seem to be dealt with now. Is there anything more for Linux
> that is needed still?
Linux is ok =D
|   | Reporter | |
| Updated•14 years ago
           | 
Summary: Plugin enumeration takes up large portion of startup → Meta: Reduce plugin-enumeration IO
|   | ||
| Comment 15•14 years ago
           | ||
Then time to land this?
|   | Reporter | |
| Comment 16•14 years ago
           | ||
(In reply to comment #15)
> Then time to land this?
Everything is landed, this is just a tracking bug
| Updated•14 years ago
           | 
| Updated•14 years ago
           | 
blocking2.0: final+ → ---
|   | Reporter | |
| Updated•13 years ago
           | 
Assignee: tglek → nobody
| Comment 17•7 years ago
           | ||
Resolving this old meta bug as fixed, as all its dependencies are resolved.
fwiw, there's still main thread IO related to plugin enumeration, but it's mostly due to checking the blocklist, and we are tracking fixing this up in bug 1425602.
Status: REOPENED → RESOLVED
Closed: 14 years ago → 7 years ago
Resolution: --- → FIXED
| Updated•3 years ago
           | 
Product: Core → Core Graveyard
          You need to log in
          before you can comment on or make changes to this bug.
        
Description
•