Merge remote-tracking branch 'origin/master' into syslog

This commit is contained in:
Gregory Nutt 2016-06-19 11:20:31 -06:00
commit d82942cf3b
6 changed files with 80 additions and 50 deletions

View File

@ -160,7 +160,7 @@ config ARMV7M_STACKCHECK
config ARMV7M_ITMSYSLOG
bool "ITM SYSLOG support"
default n
select ARCH_HAVE_SYSLOG
select ARCH_SYSLOG
select SYSLOG
---help---
Enable hooks to support ITM syslog output. This requires additional

View File

@ -7,7 +7,7 @@ comment "System Logging"
# Selected if the architecture has its own, built-in SYSLOGging enabled
config ARCH_HAVE_SYSLOG
config ARCH_SYSLOG
bool
default n
@ -29,7 +29,7 @@ if RAMLOG
config RAMLOG_SYSLOG
bool "Use RAMLOG for SYSLOG"
default n
depends on SYSLOG && !ARCH_HAVE_SYSLOG
depends on SYSLOG && !ARCH_SYSLOG
---help---
Use the RAM logging device for the syslogging interface. If this feature
is enabled (along with SYSLOG), then all debug output (only) will be re-directed
@ -122,7 +122,7 @@ if SYSLOG
config SYSLOG_CHAR
bool "System log character device support"
default y
depends on !ARCH_HAVE_SYSLOG
depends on !ARCH_SYSLOG
---help---
Enable the generic character device for the SYSLOG. The full path to the
SYSLOG device is provided by SYSLOG_DEVPATH. A valid character device (or

View File

@ -44,6 +44,10 @@ ifeq ($(CONFIG_SYSLOG_INTBUFFER),y)
CSRCS += syslog_intbuffer.c
endif
ifneq ($(CONFIG_ARCH_SYSLOG),y)
CSRCS += syslog_initialize.c
endif
# The note driver is hosted in this directory, but is not associated with
# SYSLOGging

View File

@ -76,7 +76,7 @@
/* This enumeration represents the state of the SYSLOG device interface */
enum syslog_state_e
enum syslog_dev_state
{
SYSLOG_UNINITIALIZED = 0, /* SYSLOG has not been initialized */
SYSLOG_INITIALIZING, /* SYSLOG is being initialized */
@ -89,7 +89,7 @@ enum syslog_state_e
struct syslog_dev_s
{
uint8_t sl_state; /* See enum syslog_state_e */
uint8_t sl_state; /* See enum syslog_dev_state */
sem_t sl_sem; /* Enforces mutually exclusive access */
pid_t sl_holder; /* PID of the thread that holds the semaphore */
struct file sl_file; /* The syslog file structure */
@ -101,7 +101,7 @@ struct syslog_dev_s
/* This is the device structure for the console or syslogging function. */
static struct syslog_dev_s g_sysdev;
static struct syslog_dev_s g_syslog_dev;
static const uint8_t g_syscrlf[2] =
{
'\r', '\n'
@ -112,25 +112,25 @@ static const uint8_t g_syscrlf[2] =
****************************************************************************/
/****************************************************************************
* Name: syslog_takesem
* Name: syslog_dev_takesem
*
* Description:
* Write to the syslog device
*
****************************************************************************/
static inline int syslog_takesem(void)
static inline int syslog_dev_takesem(void)
{
pid_t me = getpid();
int ret;
/* Does this thread already hold the semaphore? That could happen if
* we wer called recursively, i.e., if the logic kicked off by
* syslog_write() where to generate more debug output. Return an error
* syslog_dev_write() where to generate more debug output. Return an error
* in that case.
*/
if (g_sysdev.sl_holder == me)
if (g_syslog_dev.sl_holder == me)
{
/* Return an error (instead of deadlocking) */
@ -141,7 +141,7 @@ static inline int syslog_takesem(void)
* thread. Wait for it to become available.
*/
ret = sem_wait(&g_sysdev.sl_sem);
ret = sem_wait(&g_syslog_dev.sl_sem);
if (ret < 0)
{
return -get_errno();
@ -151,53 +151,53 @@ static inline int syslog_takesem(void)
* of the semaphore.
*/
g_sysdev.sl_holder = me;
g_syslog_dev.sl_holder = me;
return OK;
}
/****************************************************************************
* Name: syslog_givesem
* Name: syslog_dev_givesem
*
* Description:
* Write to the syslog device
*
****************************************************************************/
static inline void syslog_givesem(void)
static inline void syslog_dev_givesem(void)
{
#ifdef CONFIG_DEBUG_ASSERTIONS
pid_t me = getpid();
DEBUGASSERT(g_sysdev.sl_holder == me);
DEBUGASSERT(g_syslog_dev.sl_holder == me);
#endif
/* Relinquish the semaphore */
g_sysdev.sl_holder = NO_HOLDER;
sem_post(&g_sysdev.sl_sem);
g_syslog_dev.sl_holder = NO_HOLDER;
sem_post(&g_syslog_dev.sl_sem);
}
/****************************************************************************
* Name: syslog_write
* Name: syslog_dev_write
*
* Description:
* Write to the syslog device
*
****************************************************************************/
static inline ssize_t syslog_write(FAR const void *buf, size_t nbytes)
static inline ssize_t syslog_dev_write(FAR const void *buf, size_t nbytes)
{
FAR struct inode *inode;
/* Let the driver perform the write */
inode = g_sysdev.sl_file.f_inode;
inode = g_syslog_dev.sl_file.f_inode;
DEBUGASSERT(inode != NULL);
return inode->u.i_ops->write(&g_sysdev.sl_file, buf, nbytes);
return inode->u.i_ops->write(&g_syslog_dev.sl_file, buf, nbytes);
}
/****************************************************************************
* Name: syslog_flush
* Name: syslog_dev_flush
*
* Description:
* Flush any buffer data in the file system to media.
@ -205,9 +205,9 @@ static inline ssize_t syslog_write(FAR const void *buf, size_t nbytes)
****************************************************************************/
#ifndef CONFIG_DISABLE_MOUNTPOINT
static inline void syslog_flush(void)
static inline void syslog_dev_flush(void)
{
FAR struct inode *inode = g_sysdev.sl_file.f_inode;
FAR struct inode *inode = g_syslog_dev.sl_file.f_inode;
/* Is this a mountpoint? Does it support the sync method? */
@ -216,7 +216,7 @@ static inline void syslog_flush(void)
{
/* Yes... synchronize to the stream */
(void)inode->u.i_mops->sync(&g_sysdev.sl_file);
(void)inode->u.i_mops->sync(&g_syslog_dev.sl_file);
}
}
#endif
@ -259,10 +259,10 @@ int syslog_dev_initialize(void)
* SYSLOG_REOPEN.. Not SYSLOG_INITIALIZING, SYSLOG_FAILURE, SYSLOG_OPENED.
*/
DEBUGASSERT(g_sysdev.sl_state == SYSLOG_UNINITIALIZED ||
g_sysdev.sl_state == SYSLOG_REOPEN);
DEBUGASSERT(g_syslog_dev.sl_state == SYSLOG_UNINITIALIZED ||
g_syslog_dev.sl_state == SYSLOG_REOPEN);
g_sysdev.sl_state = SYSLOG_INITIALIZING;
g_syslog_dev.sl_state = SYSLOG_INITIALIZING;
/* Open the device driver. */
@ -282,7 +282,7 @@ int syslog_dev_initialize(void)
* not yet been installed.
*/
g_sysdev.sl_state = SYSLOG_REOPEN;
g_syslog_dev.sl_state = SYSLOG_REOPEN;
return -errcode;
}
@ -291,23 +291,23 @@ int syslog_dev_initialize(void)
* descriptor allows us to use the device on all threads in all tasks.
*/
ret = file_detach(fd, &g_sysdev.sl_file);
ret = file_detach(fd, &g_syslog_dev.sl_file);
if (ret < 0)
{
/* This should not happen and means that something very bad has
* occurred.
*/
g_sysdev.sl_state = SYSLOG_FAILURE;
g_syslog_dev.sl_state = SYSLOG_FAILURE;
close(fd);
return ret;
}
/* The SYSLOG device is open and ready for writing. */
sem_init(&g_sysdev.sl_sem, 0, 1);
g_sysdev.sl_holder = NO_HOLDER;
g_sysdev.sl_state = SYSLOG_OPENED;
sem_init(&g_syslog_dev.sl_sem, 0, 1);
g_syslog_dev.sl_holder = NO_HOLDER;
g_syslog_dev.sl_state = SYSLOG_OPENED;
return OK;
}
@ -368,12 +368,12 @@ int syslog_putc(int ch)
* has been successfully opened.
*/
if (g_sysdev.sl_state != SYSLOG_OPENED)
if (g_syslog_dev.sl_state != SYSLOG_OPENED)
{
/* Case (1) and (2) */
if (g_sysdev.sl_state == SYSLOG_UNINITIALIZED ||
g_sysdev.sl_state == SYSLOG_INITIALIZING)
if (g_syslog_dev.sl_state == SYSLOG_UNINITIALIZED ||
g_syslog_dev.sl_state == SYSLOG_INITIALIZING)
{
errcode = EAGAIN; /* Can't access the SYSLOG now... maybe next time? */
goto errout_with_errcode;
@ -381,7 +381,7 @@ int syslog_putc(int ch)
/* Case (6) */
if (g_sysdev.sl_state == SYSLOG_FAILURE)
if (g_syslog_dev.sl_state == SYSLOG_FAILURE)
{
errcode = ENXIO; /* There is no SYSLOG device */
goto errout_with_errcode;
@ -399,7 +399,7 @@ int syslog_putc(int ch)
*/
sched_lock();
if (g_sysdev.sl_state == SYSLOG_REOPEN)
if (g_syslog_dev.sl_state == SYSLOG_REOPEN)
{
/* Try again to initialize the device. We may do this repeatedly
* because the log device might be something that was not ready
@ -418,7 +418,7 @@ int syslog_putc(int ch)
}
sched_unlock();
DEBUGASSERT(g_sysdev.sl_state == SYSLOG_OPENED);
DEBUGASSERT(g_syslog_dev.sl_state == SYSLOG_OPENED);
}
/* Ignore carriage returns */
@ -432,11 +432,11 @@ int syslog_putc(int ch)
* value to write.
*/
ret = syslog_takesem();
ret = syslog_dev_takesem();
if (ret < 0)
{
/* We probably already hold the semaphore and were probably
* re-entered by the logic kicked off by syslog_write().
* re-entered by the logic kicked off by syslog_dev_write().
* We might also have been interrupted by a signal. Either
* way, we are outta here.
*/
@ -451,7 +451,7 @@ int syslog_putc(int ch)
{
/* Write the CR-LF sequence */
nbytes = syslog_write(g_syscrlf, 2);
nbytes = syslog_dev_write(g_syscrlf, 2);
/* Synchronize the file when each CR-LF is encountered (i.e.,
* implements line buffering always).
@ -460,7 +460,7 @@ int syslog_putc(int ch)
#ifndef CONFIG_DISABLE_MOUNTPOINT
if (nbytes > 0)
{
syslog_flush();
syslog_dev_flush();
}
#endif
}
@ -469,10 +469,10 @@ int syslog_putc(int ch)
/* Write the non-newline character (and don't flush) */
uch = (uint8_t)ch;
nbytes = syslog_write(&uch, 1);
nbytes = syslog_dev_write(&uch, 1);
}
syslog_givesem();
syslog_dev_givesem();
/* Check if the write was successful. If not, nbytes will be
* a negated errno value.

View File

@ -45,6 +45,8 @@
#include "syslog.h"
#ifndef CONFIG_ARCH_SYSLOG
/****************************************************************************
* Public Functions
****************************************************************************/
@ -54,10 +56,19 @@
*
* Description:
* One power up, the SYSLOG facility is non-existent or limited to very
* low-level output. This function is called later in the intialization
* low-level output. This function is called later in the initialization
* sequence after full driver support has been initialized. It installs
* the configured SYSLOG drivers and enables full SYSLOGing capability.
*
* This function performs these basic operations:
*
* - Initialize the SYSLOG device
* - Call syslog_channel() to begin using that device.
*
* If CONFIG_ARCH_SYSLOG is selected, then the architecture-specifica
* logic will provide its own SYSLOG device initialize which must include
* as a minimum a call to syslog_channel() to use the device.
*
* Input Parameters:
* None
*
@ -92,3 +103,5 @@ int syslog_initialize(void)
return ret;
}
#endif /* CONFIG_ARCH_SYSLOG */

View File

@ -156,10 +156,19 @@ int syslog_channel(FAR const struct syslog_channel_s *channel);
*
* Description:
* One power up, the SYSLOG facility is non-existent or limited to very
* low-level output. This function is called later in the intialization
* low-level output. This function is called later in the initialization
* sequence after full driver support has been initialized. It installs
* the configured SYSLOG drivers and enables full SYSLOGing capability.
*
* This function performs these basic operations:
*
* - Initialize the SYSLOG device
* - Call syslog_channel() to begin using that device.
*
* If CONFIG_ARCH_SYSLOG is selected, then the architecture-specifica
* logic will provide its own SYSLOG device initialize which must include
* as a minimum a call to syslog_channel() to use the device.
*
* Input Parameters:
* None
*
@ -176,7 +185,11 @@ int syslog_channel(FAR const struct syslog_channel_s *channel);
*
****************************************************************************/
#ifndef CONFIG_ARCH_SYSLOG
int syslog_initialize(void);
#else
# define syslog_initialize()
#endif
/****************************************************************************
* Name: syslog_putc
@ -206,7 +219,7 @@ int syslog_putc(int ch);
* perform the flush using low-level, non-interrupt driven logic.
*
* Input Parameters:
* ch - The character to add to the SYSLOG (must be positive).
* None
*
* Returned Value:
* Zero (OK)is returned on success. A negated errno value is returned