]> git.saurik.com Git - apple/xnu.git/blobdiff - osfmk/i386/hibernate_restore.c
xnu-2422.100.13.tar.gz
[apple/xnu.git] / osfmk / i386 / hibernate_restore.c
index f04a56c4afa57e940763b867014ff75465160c69..278ff4e78003cc0c3b7b396209ee70d6f6b98cd7 100644 (file)
@@ -43,7 +43,6 @@ hibernate_restore_phys_page(uint64_t src, uint64_t dst, uint32_t len, uint32_t p
        (void)procFlags;
        uint64_t * d;
        uint64_t * s;
        (void)procFlags;
        uint64_t * d;
        uint64_t * s;
-       uint32_t idx;
 
        if (src == 0)
                return (uintptr_t)dst;
 
        if (src == 0)
                return (uintptr_t)dst;
@@ -51,8 +50,7 @@ hibernate_restore_phys_page(uint64_t src, uint64_t dst, uint32_t len, uint32_t p
        d = (uint64_t *)pal_hib_map(DEST_COPY_AREA, dst);
        s = (uint64_t *) (uintptr_t)src;
 
        d = (uint64_t *)pal_hib_map(DEST_COPY_AREA, dst);
        s = (uint64_t *) (uintptr_t)src;
 
-       for (idx = 0; idx < (len / (uint32_t)sizeof(uint64_t)); idx++) 
-               d[idx] = s[idx];
+       memcpy(d, s, len);
 
        return (uintptr_t)d;
 }
 
        return (uintptr_t)d;
 }
@@ -74,14 +72,21 @@ pal_hib_map(uintptr_t virt, uint64_t phys)
        case IMAGE_AREA:
        case IMAGE2_AREA:
            break;
        case IMAGE_AREA:
        case IMAGE2_AREA:
            break;
+
        default:
            asm("cli;hlt;");
            break;
     }
        default:
            asm("cli;hlt;");
            break;
     }
-
+    if (phys < IMAGE2_AREA)
+    {
+       // first 4Gb is all mapped,
+       // and do not expect source areas to cross 4Gb
+        return (phys);
+    }
     index = (virt >> I386_LPGSHIFT);
     virt += (uintptr_t)(phys & I386_LPGMASK);
     phys  = ((phys & ~((uint64_t)I386_LPGMASK)) | INTEL_PTE_PS  | INTEL_PTE_VALID | INTEL_PTE_WRITE);
     index = (virt >> I386_LPGSHIFT);
     virt += (uintptr_t)(phys & I386_LPGMASK);
     phys  = ((phys & ~((uint64_t)I386_LPGMASK)) | INTEL_PTE_PS  | INTEL_PTE_VALID | INTEL_PTE_WRITE);
+    if (phys == BootPTD[index]) return (virt);
     BootPTD[index] = phys;
     invlpg(virt);
     BootPTD[index + 1] = (phys + I386_LPGBYTES);
     BootPTD[index] = phys;
     invlpg(virt);
     BootPTD[index + 1] = (phys + I386_LPGBYTES);