source: rtems-libbsd/rtemsbsd/rtems/syslog.c @ 028bf82

55-freebsd-126-freebsd-12
Last change on this file since 028bf82 was 4a2b844, checked in by Chris Johns <chrisj@…>, on 06/29/16 at 23:14:55

Default syslog priority to INFO. Add rtems_setlogpriority to configure the priority.

The rc.conf has 'syslog_priority' where the priority is the name, eg

syslog_priority="debug"

sets the priority to "debug".

  • Property mode set to 100644
File size: 2.4 KB
Line 
1/**
2 * @file
3 *
4 * @ingroup rtems_bsd_rtems
5 *
6 * @brief TODO.
7 */
8
9/*
10 * Copyright (c) 2014, 2016 embedded brains GmbH.  All rights reserved.
11 *
12 *  embedded brains GmbH
13 *  Dornierstr. 4
14 *  82178 Puchheim
15 *  Germany
16 *  <rtems@embedded-brains.de>
17 *
18 * Redistribution and use in source and binary forms, with or without
19 * modification, are permitted provided that the following conditions
20 * are met:
21 * 1. Redistributions of source code must retain the above copyright
22 *    notice, this list of conditions and the following disclaimer.
23 * 2. Redistributions in binary form must reproduce the above copyright
24 *    notice, this list of conditions and the following disclaimer in the
25 *    documentation and/or other materials provided with the distribution.
26 *
27 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
28 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
29 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
30 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
31 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
32 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
33 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
34 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
35 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
36 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
37 * SUCH DAMAGE.
38 */
39
40#include <errno.h>
41#include <stddef.h>
42#include <strings.h>
43
44#define SYSLOG_NAMES
45#include <syslog.h>
46
47#include <rtems/bsd/bsd.h>
48
49static int syslog_priority = LOG_NOTICE;
50
51void
52syslog(int priority, const char *format, ...)
53{
54        if (priority <= syslog_priority) {
55                va_list ap;
56
57                va_start(ap, format);
58                vsyslog(priority, format, ap);
59                va_end(ap);
60        }
61}
62
63void
64vsyslog(int priority, const char *format, va_list ap)
65{
66        if (priority <= syslog_priority) {
67                rtems_bsd_vprintf(priority, format, ap);
68        }
69}
70
71void
72openlog(const char *ident, int option, int facility)
73{
74        /* TODO */
75}
76
77void
78closelog(void)
79{
80        /* TODO */
81}
82
83int
84setlogmask(int mask)
85{
86        /* TODO */
87}
88
89int
90rtems_bsd_setlogpriority(const char* priority)
91{
92        CODE* c = &prioritynames[0];
93        while (c->c_name != NULL) {
94                if (strcasecmp(c->c_name, priority) == 0) {
95                        syslog_priority = c->c_val;
96                        return 0;
97                }
98                ++c;
99        }
100        errno = ENOENT;
101        return -1;
102}
Note: See TracBrowser for help on using the repository browser.