Correct a reference counting error in mq_open()

This commit is contained in:
Gregory Nutt 2015-09-23 10:34:08 -06:00
parent c52e3e017b
commit cc7130b836
12 changed files with 42 additions and 15 deletions

View File

@ -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

@ -1 +1 @@
Subproject commit 4dc3ba30bd14059b76c578694842bda0eaaf9763 Subproject commit eaeadc582ae79c5abe1ea8d6515585d2b0f5e34b

View File

@ -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);

View File

@ -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);

View File

@ -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)

View File

@ -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.
*/ */
{ {

View File

@ -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.

View File

@ -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();

View File

@ -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);

View File

@ -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();

View File

@ -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);

View File

@ -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);