修改region相关:优化OsVmRegionSplit红黑树节点操作,修改OsVmRegionAdjust起始地址不在region时的行为,修复OsIsRegionCanExpand计算错误,更正几处typos
This commit is contained in:
parent
0b2ac37c07
commit
c2b31e9628
|
@ -624,8 +624,7 @@ STATUS_T LOS_ArchMmuChangeProt(LosArchMmu *archMmu, VADDR_T vaddr, size_t count,
|
||||||
|
|
||||||
status = LOS_ArchMmuUnmap(archMmu, vaddr, 1);
|
status = LOS_ArchMmuUnmap(archMmu, vaddr, 1);
|
||||||
if (status < 0) {
|
if (status < 0) {
|
||||||
VM_ERR("invalid args:aspace %p, vaddr %p, count %d",
|
VM_ERR("invalid args:aspace %p, vaddr %p, count %d", archMmu, vaddr, count);
|
||||||
__FUNCTION__, __LINE__, archMmu, vaddr, count);
|
|
||||||
return LOS_NOK;
|
return LOS_NOK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -832,7 +831,7 @@ STATIC VOID OsSetKSectionAttr(VOID)
|
||||||
kmallocLength >> MMU_DESCRIPTOR_L2_SMALL_SHIFT,
|
kmallocLength >> MMU_DESCRIPTOR_L2_SMALL_SHIFT,
|
||||||
VM_MAP_REGION_FLAG_PERM_READ | VM_MAP_REGION_FLAG_PERM_WRITE);
|
VM_MAP_REGION_FLAG_PERM_READ | VM_MAP_REGION_FLAG_PERM_WRITE);
|
||||||
if (status != (kmallocLength >> MMU_DESCRIPTOR_L2_SMALL_SHIFT)) {
|
if (status != (kmallocLength >> MMU_DESCRIPTOR_L2_SMALL_SHIFT)) {
|
||||||
VM_ERR("unmap failed, status: %d", status);
|
VM_ERR("mmap failed, status: %d", status);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
LOS_VmSpaceReserve(kSpace, kmallocLength, bssEndBoundary);
|
LOS_VmSpaceReserve(kSpace, kmallocLength, bssEndBoundary);
|
||||||
|
|
|
@ -561,7 +561,7 @@ STATIC VOID OsDevPagesRemove(LosArchMmu *archMmu, VADDR_T vaddr, UINT32 count)
|
||||||
status_t status;
|
status_t status;
|
||||||
|
|
||||||
if ((archMmu == NULL) || (vaddr == 0) || (count == 0)) {
|
if ((archMmu == NULL) || (vaddr == 0) || (count == 0)) {
|
||||||
VM_ERR("OsAnonPagesRemove invalid args, archMmu %p, vaddr %p, count %d", archMmu, vaddr, count);
|
VM_ERR("OsDevPagesRemove invalid args, archMmu %p, vaddr %p, count %d", archMmu, vaddr, count);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -658,10 +658,9 @@ STATIC LosVmMapRegion *OsVmRegionSplit(LosVmMapRegion *oldRegion, VADDR_T newReg
|
||||||
LosVmSpace *space = oldRegion->space;
|
LosVmSpace *space = oldRegion->space;
|
||||||
size_t size = LOS_RegionSize(newRegionStart, LOS_RegionEndAddr(oldRegion));
|
size_t size = LOS_RegionSize(newRegionStart, LOS_RegionEndAddr(oldRegion));
|
||||||
|
|
||||||
LOS_RbDelNode(&space->regionRbTree, &oldRegion->rbNode);
|
|
||||||
oldRegion->range.size = LOS_RegionSize(oldRegion->range.base, newRegionStart - 1);
|
oldRegion->range.size = LOS_RegionSize(oldRegion->range.base, newRegionStart - 1);
|
||||||
if (oldRegion->range.size != 0) {
|
if (oldRegion->range.size == 0) {
|
||||||
LOS_RbAddNode(&space->regionRbTree, &oldRegion->rbNode);
|
LOS_RbDelNode(&space->regionRbTree, &oldRegion->rbNode);
|
||||||
}
|
}
|
||||||
|
|
||||||
newRegion = OsVmRegionDup(oldRegion->space, oldRegion, newRegionStart, size);
|
newRegion = OsVmRegionDup(oldRegion->space, oldRegion, newRegionStart, size);
|
||||||
|
@ -682,15 +681,7 @@ STATUS_T OsVmRegionAdjust(LosVmSpace *space, VADDR_T newRegionStart, size_t size
|
||||||
LosVmMapRegion *newRegion = NULL;
|
LosVmMapRegion *newRegion = NULL;
|
||||||
|
|
||||||
region = LOS_RegionFind(space, newRegionStart);
|
region = LOS_RegionFind(space, newRegionStart);
|
||||||
if ((region == NULL) || (region->range.base >= nextRegionBase)) {
|
if ((region != NULL) && (newRegionStart > region->range.base)) {
|
||||||
return LOS_ERRNO_VM_NOT_FOUND;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((region->range.base == newRegionStart) && (region->range.size == size)) {
|
|
||||||
return LOS_OK;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (newRegionStart > region->range.base) {
|
|
||||||
newRegion = OsVmRegionSplit(region, newRegionStart);
|
newRegion = OsVmRegionSplit(region, newRegionStart);
|
||||||
if (newRegion == NULL) {
|
if (newRegion == NULL) {
|
||||||
VM_ERR("region split fail");
|
VM_ERR("region split fail");
|
||||||
|
@ -796,7 +787,7 @@ STATUS_T OsIsRegionCanExpand(LosVmSpace *space, LosVmMapRegion *region, size_t s
|
||||||
|
|
||||||
nextRegion = (LosVmMapRegion *)LOS_RbSuccessorNode(&space->regionRbTree, ®ion->rbNode);
|
nextRegion = (LosVmMapRegion *)LOS_RbSuccessorNode(&space->regionRbTree, ®ion->rbNode);
|
||||||
/* if the gap is larger than size, then we can expand */
|
/* if the gap is larger than size, then we can expand */
|
||||||
if ((nextRegion != NULL) && ((nextRegion->range.base - region->range.base - region->range.size) > size)) {
|
if ((nextRegion != NULL) && ((nextRegion->range.base - region->range.base ) >= size)) {
|
||||||
return LOS_OK;
|
return LOS_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue