Chromium Code Reviews| Index: chromeos/hugepage_text/hugepage_text.cc |
| diff --git a/chromeos/hugepage_text/hugepage_text.cc b/chromeos/hugepage_text/hugepage_text.cc |
| index ccae53f723fdbd9e181f5421fd82c2fdc851062b..dd2dcf4a572c4ee98a2bcf1342abea06512f1634 100644 |
| --- a/chromeos/hugepage_text/hugepage_text.cc |
| +++ b/chromeos/hugepage_text/hugepage_text.cc |
| @@ -172,7 +172,11 @@ static void MremapHugetlbText(void* vaddr, const size_t hsize) { |
| // Effect: physical backing page changed from small page to hugepage. If there |
| // are error condition, the remaping operation is aborted. |
| static void RemapHugetlbText(void* vaddr, const size_t segsize) { |
| - int hsize = segsize; |
| + // remove unaligned head regions |
| + size_t head_gap = (kHpageSize - (size_t)addr % kHpageSize) % kHpageSize; |
|
kenchen
2016/01/22 22:19:42
This should vaddr and the last mod operation is no
yunlian
2016/01/22 22:27:00
Yes, the vaddr is part is done. The last mod is us
|
| + size_t addr = (size_t)vaddr + head_gap; |
| + |
| + int hsize = segsize - head_gap; |
| if (segsize > kHpageSize * kNumHugePages) |
| hsize = kHpageSize * kNumHugePages; |
| hsize = hsize & kHpageMask; |
| @@ -180,7 +184,7 @@ static void RemapHugetlbText(void* vaddr, const size_t segsize) { |
| if (hsize == 0) |
| return; |
| - MremapHugetlbText(vaddr, hsize); |
| + MremapHugetlbText((void *)addr, hsize); |
| } |
| // For a given ELF program header descriptor, iterates over all segments within |