Correct a reference counting error in mq_open()
This commit is contained in:
parent
c52e3e017b
commit
cc7130b836
@ -10981,4 +10981,7 @@
|
|||||||
Carvalho de Assis (2015-09-19).
|
Carvalho de Assis (2015-09-19).
|
||||||
* drivers/power/bq2425x.c and .h: Battery Charger: Add BQ24250 driver.
|
* drivers/power/bq2425x.c and .h: Battery Charger: Add BQ24250 driver.
|
||||||
From Alan Carvalho de Assis (2015-09-20).
|
From Alan Carvalho de Assis (2015-09-20).
|
||||||
|
* fs/mqueue/mq_open.c: When message queue is opened, inode_reserve()
|
||||||
|
leaves the reference count at zero. mq_open() logic must assure
|
||||||
|
that the reference count of the newly created inode is one (2015-09-23).
|
||||||
|
|
||||||
|
2
arch
2
arch
@ -1 +1 @@
|
|||||||
Subproject commit 4dc3ba30bd14059b76c578694842bda0eaaf9763
|
Subproject commit eaeadc582ae79c5abe1ea8d6515585d2b0f5e34b
|
@ -108,7 +108,9 @@ int register_blockdriver(FAR const char *path,
|
|||||||
ret = inode_reserve(path, &node);
|
ret = inode_reserve(path, &node);
|
||||||
if (ret >= 0)
|
if (ret >= 0)
|
||||||
{
|
{
|
||||||
/* We have it, now populate it with block driver specific information. */
|
/* We have it, now populate it with block driver specific information.
|
||||||
|
* NOTE that the initial reference count on the new inode is zero.
|
||||||
|
*/
|
||||||
|
|
||||||
INODE_SET_BLOCK(node);
|
INODE_SET_BLOCK(node);
|
||||||
|
|
||||||
|
@ -103,7 +103,9 @@ int register_driver(FAR const char *path, FAR const struct file_operations *fops
|
|||||||
ret = inode_reserve(path, &node);
|
ret = inode_reserve(path, &node);
|
||||||
if (ret >= 0)
|
if (ret >= 0)
|
||||||
{
|
{
|
||||||
/* We have it, now populate it with driver specific information. */
|
/* We have it, now populate it with driver specific information.
|
||||||
|
* NOTE that the initial reference count on the new inode is zero.
|
||||||
|
*/
|
||||||
|
|
||||||
INODE_SET_DRIVER(node);
|
INODE_SET_DRIVER(node);
|
||||||
|
|
||||||
|
@ -145,9 +145,8 @@ static void inode_insert(FAR struct inode *node,
|
|||||||
* Name: inode_reserve
|
* Name: inode_reserve
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Reserve an (initialized) inode the pseudo file system.
|
* Reserve an (initialized) inode the pseudo file system. The initial
|
||||||
*
|
* reference count on the new inode is zero.
|
||||||
* NOTE: Caller must hold the inode semaphore
|
|
||||||
*
|
*
|
||||||
* Input parameters:
|
* Input parameters:
|
||||||
* path - The path to the inode to create
|
* path - The path to the inode to create
|
||||||
@ -161,6 +160,9 @@ static void inode_insert(FAR struct inode *node,
|
|||||||
* EEXIST - An inode already exists at 'path'
|
* EEXIST - An inode already exists at 'path'
|
||||||
* ENOMEM - Failed to allocate in-memory resources for the operation
|
* ENOMEM - Failed to allocate in-memory resources for the operation
|
||||||
*
|
*
|
||||||
|
* Assumptions:
|
||||||
|
* Caller must hold the inode semaphore
|
||||||
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
int inode_reserve(FAR const char *path, FAR struct inode **inode)
|
int inode_reserve(FAR const char *path, FAR struct inode **inode)
|
||||||
|
@ -296,6 +296,8 @@ int mount(FAR const char *source, FAR const char *target,
|
|||||||
|
|
||||||
/* Insert a dummy node -- we need to hold the inode semaphore
|
/* Insert a dummy node -- we need to hold the inode semaphore
|
||||||
* to do this because we will have a momentarily bad structure.
|
* to do this because we will have a momentarily bad structure.
|
||||||
|
* NOTE that the new inode will be created with an initial reference
|
||||||
|
* count of zero.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -136,7 +136,7 @@ int mq_close(mqd_t mqdes)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Name: mq_close
|
* Name: mq_inode_release
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Release a reference count on a message queue inode.
|
* Release a reference count on a message queue inode.
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* fs/mqueue/mq_open.c
|
* fs/mqueue/mq_open.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007-2009, 2011, 2014 Gregory Nutt. All rights reserved.
|
* Copyright (C) 2007-2009, 2011, 2014-2015 Gregory Nutt. All rights reserved.
|
||||||
* Author: Gregory Nutt <gnutt@nuttx.org>
|
* Author: Gregory Nutt <gnutt@nuttx.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
@ -139,7 +139,8 @@ mqd_t mq_open(FAR const char *mq_name, int oflags, ...)
|
|||||||
sched_lock();
|
sched_lock();
|
||||||
|
|
||||||
/* Get the inode for this mqueue. This should succeed if the message
|
/* Get the inode for this mqueue. This should succeed if the message
|
||||||
* queue has already been created.
|
* queue has already been created. In this case, inode_finde() will
|
||||||
|
* have incremented the reference count on the inode.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
inode = inode_find(fullpath, &relpath);
|
inode = inode_find(fullpath, &relpath);
|
||||||
@ -206,7 +207,9 @@ mqd_t mq_open(FAR const char *mq_name, int oflags, ...)
|
|||||||
goto errout_with_lock;
|
goto errout_with_lock;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Allocate memory for the new message queue. */
|
/* Allocate memory for the new message queue. The new inode will
|
||||||
|
* be created with a reference count of zero.
|
||||||
|
*/
|
||||||
|
|
||||||
msgq = (FAR struct mqueue_inode_s*)mq_msgqalloc(mode, attr);
|
msgq = (FAR struct mqueue_inode_s*)mq_msgqalloc(mode, attr);
|
||||||
if (!msgq)
|
if (!msgq)
|
||||||
@ -230,6 +233,9 @@ mqd_t mq_open(FAR const char *mq_name, int oflags, ...)
|
|||||||
inode->u.i_mqueue = msgq;
|
inode->u.i_mqueue = msgq;
|
||||||
msgq->inode = inode;
|
msgq->inode = inode;
|
||||||
|
|
||||||
|
/* Set the initial reference count on this inode to one */
|
||||||
|
|
||||||
|
inode->i_crefs = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
sched_unlock();
|
sched_unlock();
|
||||||
|
@ -148,8 +148,9 @@ FAR sem_t *sem_open (FAR const char *name, int oflags, ...)
|
|||||||
|
|
||||||
snprintf(fullpath, MAX_SEMPATH, CONFIG_FS_NAMED_SEMPATH "/%s", name);
|
snprintf(fullpath, MAX_SEMPATH, CONFIG_FS_NAMED_SEMPATH "/%s", name);
|
||||||
|
|
||||||
/* Get the inode for this semaphore. This should succeed if the semaphore
|
/* Get the inode for this semaphore. This should succeed if the
|
||||||
* has already been created.
|
* semaphore has already been created. In this case, inode_finde()
|
||||||
|
* will have incremented the reference count on the inode.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
inode = inode_find(fullpath, &relpath);
|
inode = inode_find(fullpath, &relpath);
|
||||||
@ -214,7 +215,9 @@ FAR sem_t *sem_open (FAR const char *name, int oflags, ...)
|
|||||||
goto errout_with_lock;
|
goto errout_with_lock;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Create an inode in the pseudo-filesystem at this path */
|
/* Create an inode in the pseudo-filesystem at this path. The new
|
||||||
|
* inode will be created with a reference count of zero.
|
||||||
|
*/
|
||||||
|
|
||||||
inode_semtake();
|
inode_semtake();
|
||||||
ret = inode_reserve(fullpath, &inode);
|
ret = inode_reserve(fullpath, &inode);
|
||||||
|
@ -2568,6 +2568,7 @@ int unionfs_mount(FAR const char *fspath1, FAR const char *prefix1,
|
|||||||
|
|
||||||
/* Insert a dummy node -- we need to hold the inode semaphore
|
/* Insert a dummy node -- we need to hold the inode semaphore
|
||||||
* to do this because we will have a momentarily bad structure.
|
* to do this because we will have a momentarily bad structure.
|
||||||
|
* NOTE that the inode will be created with a refernce count of zero.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
inode_semtake();
|
inode_semtake();
|
||||||
|
@ -154,7 +154,10 @@ int mkdir(const char *pathname, mode_t mode)
|
|||||||
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
/* Create an inode in the pseudo-filesystem at this path */
|
/* Create an inode in the pseudo-filesystem at this path.
|
||||||
|
* NOTE that the new inode will be created with a reference
|
||||||
|
* count of zero.
|
||||||
|
*/
|
||||||
|
|
||||||
inode_semtake();
|
inode_semtake();
|
||||||
ret = inode_reserve(pathname, &inode);
|
ret = inode_reserve(pathname, &inode);
|
||||||
|
@ -175,7 +175,10 @@ int rename(FAR const char *oldpath, FAR const char *newpath)
|
|||||||
#endif
|
#endif
|
||||||
#ifndef CONFIG_DISABLE_PSEUDOFS_OPERATIONS
|
#ifndef CONFIG_DISABLE_PSEUDOFS_OPERATIONS
|
||||||
{
|
{
|
||||||
/* Create a new, empty inode at the destination location */
|
/* Create a new, empty inode at the destination location.
|
||||||
|
* NOTE that the new inode will be created with a reference count
|
||||||
|
* of zero.
|
||||||
|
*/
|
||||||
|
|
||||||
inode_semtake();
|
inode_semtake();
|
||||||
ret = inode_reserve(newpath, &newinode);
|
ret = inode_reserve(newpath, &newinode);
|
||||||
|
Loading…
Reference in New Issue
Block a user