<p>In <a href="https://github.com/ipxe/ipxe/pull/36#discussion_r34925905">src/arch/i386/image/freebsd.c</a>:</p>
<pre style='color:#555'>> +
> +  // Copy image
> +  for_each_image ( module_image ) {
> +          if (image == module_image) continue;
> +          memcpy_user(phys_to_user(buffer), 0, module_image->data, 0, module_image->len);
> +          buffer += ALIGN_PAGE(module_image->len);
> +  }
> +
> +  kern_end = buffer;
> +
> +  entry_lo = ehdr.e_entry & 0xffffffff;
> +  entry_hi = (ehdr.e_entry >> 32) & 0xffffffff;
> +
> +  for (i = 0; i < 512; i++) {
> +          /* Each slot of the level 4 pages points to the same level 3 page */
> +          PT4[i] = (p4_entry_t)VTOP((void *)&PT3[0]);
</pre>
<p>Don't worry too much about the specifics of vtop and friends, that is a btx-ism that won't apply the same way in this environment. btx runs with a non-zero segmentation offset.  You'll be looking for whatever the equivalent is here if there's even a difference between virtual and physical addresses.</p>

<p style="font-size:small;-webkit-text-size-adjust:none;color:#666;">—<br>Reply to this email directly or <a href="https://github.com/ipxe/ipxe/pull/36/files#r34925905">view it on GitHub</a>.<img alt="" height="1" src="https://github.com/notifications/beacon/AArTVO7OD1HagwPeQ0rFSIm18nf-p3Xmks5oeVcMgaJpZM4FLzyb.gif" width="1" /></p>
<div itemscope itemtype="http://schema.org/EmailMessage">
  <div itemprop="action" itemscope itemtype="http://schema.org/ViewAction">
    <link itemprop="url" href="https://github.com/ipxe/ipxe/pull/36/files#r34925905"></link>
    <meta itemprop="name" content="View Pull Request"></meta>
  </div>
  <meta itemprop="description" content="View this Pull Request on GitHub"></meta>
</div>