Actions
Bug #5062
closeddouble free in OpenSSL::Engine
    Bug #5062:
    double free in OpenSSL::Engine
  
Description
以下のコードを実行すると終了時にglibcがdouble freeを検出して停止します。
require 'openssl'
OpenSSL::Engine.load
OpenSSL::Engine.engines
OpenSSL::Engine.engines
停止時の出力を添付します。
ENGINE_get_nextが前に返したengineのref countを下げるのが原因のようで、添付したパッチでとりあえず直ります。
Files
        
           Updated by MartinBosslet (Martin Bosslet) over 14 years ago
          Updated by MartinBosslet (Martin Bosslet) over 14 years ago
          
          
        
        
      
      - Status changed from Open to Assigned
- Assignee set to MartinBosslet (Martin Bosslet)
- Target version set to 1.9.3
Thanks Ippei,
I'll take a look at it!
        
           Updated by kosaki (Motohiro KOSAKI) over 14 years ago
          Updated by kosaki (Motohiro KOSAKI) over 14 years ago
          
          
        
        
      
      - Priority changed from Normal to 5
        
           Updated by Anonymous over 14 years ago
          Updated by Anonymous over 14 years ago
          
          
        
        
      
      - Status changed from Assigned to Closed
- % Done changed from 0 to 100
This issue was solved with changeset r32604.
Ippei, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.
- ext/openssl/ossl_engine.c: Avoid double free of ENGINE reference.
- test/openssl/test_engine.rb: Add a test for it.
 Thanks to Ippei Obayashi for providing the patch.
 [ Ruby 1.9 - Bug #5062 ] [ruby-dev:44173]
Actions