[rtems commit] testsuite/newlib: Check newlib does not touch an assigned std FILE pointer
Chris Johns
chrisj at rtems.org
Thu Feb 20 04:00:29 UTC 2020
Module: rtems
Branch: master
Commit: 3f7ebddfa40a6cce1b9fe9ac0a8c71fd9695df14
Changeset: http://git.rtems.org/rtems/commit/?id=3f7ebddfa40a6cce1b9fe9ac0a8c71fd9695df14
Author: Chris Johns <chrisj at rtems.org>
Date: Fri Feb 14 14:16:17 2020 +1100
testsuite/newlib: Check newlib does not touch an assigned std FILE pointer
Update #3870
---
testsuites/libtests/newlib01/init.c | 16 +++++++++++++++-
1 file changed, 15 insertions(+), 1 deletion(-)
diff --git a/testsuites/libtests/newlib01/init.c b/testsuites/libtests/newlib01/init.c
index 74e6487..529531e 100644
--- a/testsuites/libtests/newlib01/init.c
+++ b/testsuites/libtests/newlib01/init.c
@@ -18,6 +18,8 @@
#include <stdio.h>
+#include <sys/reent.h>
+
#include <rtems.h>
#include <rtems/console.h>
#include <rtems/imfs.h>
@@ -63,12 +65,24 @@ static void wait(void)
static void worker_task(rtems_task_argument arg)
{
test_context *ctx = &test_instance;
+ struct _reent *reent = _REENT;
+ FILE *output;
char buf[1] = { 'x' };
size_t n;
- stdout = fopen(&file_path[0], "r+");
+ rtems_test_assert(reent->__sdidinit == 0);
+
+ output = stdout = fopen(&file_path[0], "r+");
rtems_test_assert(stdout != NULL);
+ /*
+ * Check newlib's __sinit does not touch our assigned file pointer.
+ */
+ rtems_test_assert(reent->__sdidinit == 0);
+ rtems_test_assert(fflush(stdout) == 0);
+ rtems_test_assert(reent->__sdidinit != 0);
+ rtems_test_assert(stdout == output);
+
n = fwrite(&buf[0], sizeof(buf), 1, stdout);
rtems_test_assert(n == 1);
More information about the vc
mailing list