fs: Remove _files_close and reuse file_close

to save the code space

Signed-off-by: Xiang Xiao <xiaoxiang@xiaomi.com>
Change-Id: I08455010ba121a61b0e29334b580aa83e69a9418
This commit is contained in:
Xiang Xiao 2021-01-02 22:45:24 +08:00 committed by Abdelatif Guettouche
parent cfd7390676
commit 5a7d988a43
2 changed files with 3 additions and 49 deletions

View File

@ -56,8 +56,6 @@
* Close a file that was previously opend with file_open() (or detached * Close a file that was previously opend with file_open() (or detached
* with file_detach()). * with file_detach()).
* *
* REVISIT: This is essentially the same as _files_close()
*
* Input Parameters: * Input Parameters:
* filep - A pointer to a user provided memory location containing the * filep - A pointer to a user provided memory location containing the
* open file data returned by file_detach(). * open file data returned by file_detach().

View File

@ -55,50 +55,6 @@ static int _files_semtake(FAR struct filelist *list)
#define _files_semgive(list) nxsem_post(&list->fl_sem) #define _files_semgive(list) nxsem_post(&list->fl_sem)
/****************************************************************************
* Name: _files_close
*
* Description:
* Close an inode (if open)
*
* Assumptions:
* Caller holds the list semaphore because the file descriptor will be
* freed.
*
****************************************************************************/
static int _files_close(FAR struct file *filep)
{
struct inode *inode = filep->f_inode;
int ret = OK;
/* Check if the struct file is open (i.e., assigned an inode) */
if (inode)
{
/* Close the file, driver, or mountpoint. */
if (inode->u.i_ops && inode->u.i_ops->close)
{
/* Perform the close operation */
ret = inode->u.i_ops->close(filep);
}
/* And release the inode */
inode_release(inode);
/* Release the file descriptor */
filep->f_oflags = 0;
filep->f_pos = 0;
filep->f_inode = NULL;
}
return ret;
}
/**************************************************************************** /****************************************************************************
* Public Functions * Public Functions
****************************************************************************/ ****************************************************************************/
@ -152,7 +108,7 @@ void files_releaselist(FAR struct filelist *list)
for (i = CONFIG_NFILE_DESCRIPTORS; i > 0; i--) for (i = CONFIG_NFILE_DESCRIPTORS; i > 0; i--)
{ {
_files_close(&list->fl_files[i - 1]); file_close(&list->fl_files[i - 1]);
} }
/* Destroy the semaphore */ /* Destroy the semaphore */
@ -217,7 +173,7 @@ int file_dup2(FAR struct file *filep1, FAR struct file *filep2)
* close the file and release the inode. * close the file and release the inode.
*/ */
ret = _files_close(filep2); ret = file_close(filep2);
if (ret < 0) if (ret < 0)
{ {
/* An error occurred while closing the driver */ /* An error occurred while closing the driver */
@ -376,7 +332,7 @@ int files_close(int fd)
ret = _files_semtake(list); ret = _files_semtake(list);
if (ret >= 0) if (ret >= 0)
{ {
ret = _files_close(&list->fl_files[fd]); ret = file_close(&list->fl_files[fd]);
_files_semgive(list); _files_semgive(list);
} }