1
0
Fork 0
forked from nuttx/nuttx-update

fs/mmap: update mapped var before exit

Signed-off-by: Xuxingliang <xuxingliang@xiaomi.com>
This commit is contained in:
Xuxingliang 2023-01-16 18:03:58 +08:00 committed by Xiang Xiao
parent dce315005a
commit 9166eeddf6
2 changed files with 15 additions and 13 deletions

View file

@ -102,7 +102,8 @@ static int file_mmap_(FAR struct file *filep, FAR void *start,
if ((flags & MAP_ANONYMOUS) != 0)
{
return map_anonymous(&entry, kernel);
ret = map_anonymous(&entry, kernel);
goto out;
}
if (filep == NULL)
@ -131,10 +132,6 @@ static int file_mmap_(FAR struct file *filep, FAR void *start,
filep->f_inode->u.i_ops->mmap != NULL)
{
ret = filep->f_inode->u.i_ops->mmap(filep, &entry);
if (ret == OK)
{
*mapped = entry.vaddr;
}
}
else
{
@ -146,11 +143,17 @@ static int file_mmap_(FAR struct file *filep, FAR void *start,
* do much better in the KERNEL build using the MMU.
*/
return rammap(filep, &entry, kernel);
ret = rammap(filep, &entry, kernel);
}
/* Return */
out:
if (ret == OK)
{
*mapped = entry.vaddr;
}
return ret;
}

View file

@ -130,14 +130,13 @@ static int unmap_rammap(FAR struct task_group_s *group,
*
* Input Parameters:
* filep file descriptor of the backing file -- required.
* length The length of the mapping. For exception #1 above, this length
* ignored: The entire underlying media is always accessible.
* offset The offset into the file to map
* entry mmap entry information.
* field offset and length must be initialized correctly.
* kernel kmm_zalloc or kumm_zalloc
* mapped The pointer to the mapped area
*
* Returned Value:
* On success, rammmap returns 0. Otherwise errno is returned appropriately.
* On success, rammap returns 0 and entry->vaddr points to memory mapped.
* Otherwise errno is returned appropriately.
*
* EBADF
* 'fd' is not a valid file descriptor.
@ -251,11 +250,11 @@ int rammap(FAR struct file *filep, FAR struct mm_map_entry_s *entry,
errout_with_region:
if (kernel)
{
kmm_free(rdbuffer);
kmm_free(entry->vaddr);
}
else
{
kumm_free(rdbuffer);
kumm_free(entry->vaddr);
}
return ret;