<html>
    <head>
      <base href="https://bugs.webkit.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - We should consider allocating a CodeBlock's Instruction stream away from other things"
   href="https://bugs.webkit.org/show_bug.cgi?id=163375#c3">Comment # 3</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW - We should consider allocating a CodeBlock's Instruction stream away from other things"
   href="https://bugs.webkit.org/show_bug.cgi?id=163375">bug 163375</a>
              from <span class="vcard"><a class="email" href="mailto:ggaren&#64;apple.com" title="Geoffrey Garen &lt;ggaren&#64;apple.com&gt;"> <span class="fn">Geoffrey Garen</span></a>
</span></b>
        <pre>I don't think it's practical to do this in a general-purpose way because each unicorn object class, which refuses to share memory with other object classes, linearly increases fragmentation, memory footprint, cache non-locality, TLB misses, and paging.

In my experiments with MallocBench and bmalloc, too much separation between object types introduces significant performance cost, and I invested a lot of effort to avoid that cost.

It might be practical to do this in a special-purpose way, as long as it's only for a small number of object types, and we only request a best-effort separation and not a permanent guaranteed separation.

Phil's fastMallocSeparate API, with best-effort service, is trivial to achieve using bmalloc's &quot;Cache&quot; class as the type for &quot;mySpace&quot;, and we could probably service the CodeBlock instruction stream, the render tree, and the DOM tree that way without penalty.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>