[PATCH 2/9] rtems: Add rtems_print_printer_fprintf_putc()

Sebastian Huber sebastian.huber at embedded-brains.de
Thu Oct 26 11:59:06 UTC 2017


Update #3170.
Update #3199.
---
 cpukit/include/rtems/printer.h              | 25 ++++++-----
 cpukit/libcsupport/Makefile.am              |  1 +
 cpukit/libcsupport/src/printerfprintfputc.c | 67 +++++++++++++++++++++++++++++
 3 files changed, 82 insertions(+), 11 deletions(-)
 create mode 100644 cpukit/libcsupport/src/printerfprintfputc.c

diff --git a/cpukit/include/rtems/printer.h b/cpukit/include/rtems/printer.h
index c18600bbe3..fccd9bcf5f 100644
--- a/cpukit/include/rtems/printer.h
+++ b/cpukit/include/rtems/printer.h
@@ -74,7 +74,7 @@ static inline bool rtems_print_printer_valid(const rtems_printer *printer)
 }
 
 /**
- * @brief Initializes the rtems_printer struct to empty.
+ * @brief Initializes the printer to print nothing.
  *
  * An empty printer prints nothing. You can use this to implement an enable and
  * disable type print implementation.
@@ -88,31 +88,34 @@ static inline void rtems_print_printer_empty(rtems_printer *printer)
 }
 
 /**
- * @brief Initializes the rtems_printer struct to printk
- *
- * The printer will output to the kernel printk support.
+ * @brief Initializes the printer to print via printk().
  *
  * @param[in] printer Pointer to the printer structure.
  */
 void rtems_print_printer_printk(rtems_printer *printer);
 
 /**
- * @brief Initializes the rtems_printer struct to printf
- *
- * The printer will output to the libc printf support.
+ * @brief Initializes the printer to print via printf().
  *
  * @param[in] printer Pointer to the printer structure.
  */
-extern void rtems_print_printer_printf(rtems_printer *printer);
+void rtems_print_printer_printf(rtems_printer *printer);
 
 /**
- * @brief Initializes the rtems_printer struct to a fprintf device.
+ * @brief Initializes the printer to print via fprintf() using the specified
+ * file stream.
  *
- * The printer will output to the libc fprintf file provided.
+ * @param[in] printer Pointer to the printer structure.
+ */
+void rtems_print_printer_fprintf(rtems_printer *printer, FILE *file);
+
+/**
+ * @brief Initializes the printer to print via fprintf() using an unbuffered
+ * FILE stream with output through rtems_putc().
  *
  * @param[in] printer Pointer to the printer structure.
  */
-extern void rtems_print_printer_fprintf(rtems_printer *printer, FILE *file);
+void rtems_print_printer_fprintf_putc(rtems_printer *printer);
 
 typedef struct {
   rtems_id                     task;
diff --git a/cpukit/libcsupport/Makefile.am b/cpukit/libcsupport/Makefile.am
index 0b192aa6b0..41985393af 100644
--- a/cpukit/libcsupport/Makefile.am
+++ b/cpukit/libcsupport/Makefile.am
@@ -140,6 +140,7 @@ libcsupport_a_SOURCES = src/gxx_wrappers.c src/getchark.c src/printk.c \
     $(BSD_LIBC_C_FILES) $(BASE_FS_C_FILES) $(MALLOC_C_FILES) \
     $(ERROR_C_FILES) $(ASSOCIATION_C_FILES)
 libcsupport_a_SOURCES += src/printertask.c
+libcsupport_a_SOURCES += src/printerfprintfputc.c
 
 libcsupport_a_SOURCES += $(LIBC_GLUE_C_FILES) $(PASSWORD_GROUP_C_FILES) \
     $(TERMINAL_IDENTIFICATION_C_FILES) $(SYSTEM_CALL_C_FILES) \
diff --git a/cpukit/libcsupport/src/printerfprintfputc.c b/cpukit/libcsupport/src/printerfprintfputc.c
new file mode 100644
index 0000000000..8b502fa489
--- /dev/null
+++ b/cpukit/libcsupport/src/printerfprintfputc.c
@@ -0,0 +1,67 @@
+/*
+ * Copyright (c) 2017 embedded brains GmbH.  All rights reserved.
+ *
+ *  embedded brains GmbH
+ *  Dornierstr. 4
+ *  82178 Puchheim
+ *  Germany
+ *  <rtems at embedded-brains.de>
+ *
+ * The license and distribution terms for this file may be
+ * found in the file LICENSE in this distribution or at
+ * http://www.rtems.org/license/LICENSE.
+ */
+
+#ifdef HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include <rtems/printer.h>
+#include <rtems/bspIo.h>
+
+#include <pthread.h>
+
+static pthread_once_t fprintf_putc_once = PTHREAD_ONCE_INIT;
+
+static FILE fprintf_putc_file;
+
+static _READ_WRITE_RETURN_TYPE fprintf_putc_write(
+  struct _reent            *ptr,
+  void                     *cookie,
+  char const               *buf,
+  _READ_WRITE_BUFSIZE_TYPE  n
+)
+{
+  _READ_WRITE_RETURN_TYPE i;
+  _READ_WRITE_RETURN_TYPE m;
+
+  m = (_READ_WRITE_RETURN_TYPE) n;
+  for (i = 0; i < m; ++i) {
+    rtems_putc(buf[i]);
+  }
+
+  return m;
+}
+
+static void fprintf_putc_init(void)
+{
+  FILE *f;
+
+  f = &fprintf_putc_file;
+  f->_flags = __SWR | __SNBF;
+  f->_cookie = f;
+  f->_write = fprintf_putc_write;
+  __lock_init_recursive(f->_lock);
+}
+
+static int fprintf_putc_printer(void *context, const char *fmt, va_list ap)
+{
+  return vfprintf(context, fmt, ap);
+}
+
+void rtems_print_printer_fprintf_putc(rtems_printer *printer)
+{
+  pthread_once(&fprintf_putc_once, fprintf_putc_init);
+  printer->context = &fprintf_putc_file;
+  printer->printer = fprintf_putc_printer;
+}
-- 
2.12.3




More information about the devel mailing list