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:
parent
cfd7390676
commit
5a7d988a43
@ -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().
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user