apps/examples/ostest: Add a test of TLS

This commit is contained in:
Gregory Nutt 2016-03-11 14:02:00 -06:00
parent 18bfa67006
commit 84f453b7a1
6 changed files with 148 additions and 0 deletions

View File

@ -1560,3 +1560,4 @@
(2016-02-23).
* apps/platform/sabre-6quad: Add a platform directory for the
Sabre 6Quad board (2016-03-01).
* apps/examples/ostest: Add a test of TLS (2016-03-11).

View File

@ -51,6 +51,10 @@ ifeq ($(CONFIG_ARCH_FPU),y)
CSRCS += fpu.c
endif
ifeq ($(CONFIG_TLS),y)
CSRCS += tls.c
endif
ifeq ($(CONFIG_EXAMPLES_OSTEST_AIO),y)
CSRCS += aio.c
endif

View File

@ -74,6 +74,7 @@ int dev_null(void)
close(fd);
return -1;
}
printf("dev_null: Read %d bytes from /dev/null\n", nbytes);
nbytes = write(fd, buffer, 1024);
@ -83,6 +84,7 @@ int dev_null(void)
close(fd);
return -1;
}
printf("dev_null: Wrote %d bytes to /dev/null\n", nbytes);
close(fd);

View File

@ -192,6 +192,10 @@ void rr_test(void);
void sporadic_test(void);
/* tls.c ********************************************************************/
void tls_test(void);
/* barrier.c ****************************************************************/
void barrier_test(void);

View File

@ -274,6 +274,7 @@ static int user_main(int argc, char *argv[])
i, g_argv[i-1], argv[i]);
}
}
check_test_memory_usage();
/* If retention of child status is enable, then suppress it for this task.
@ -315,6 +316,13 @@ static int user_main(int argc, char *argv[])
check_test_memory_usage();
#endif
#ifdef CONFIG_TLS
/* Test TLS */
tls_test();
check_test_memory_usage();
#endif
/* Top of test loop */
#if CONFIG_EXAMPLES_OSTEST_LOOPS > 1

129
examples/ostest/tls.c Normal file
View File

@ -0,0 +1,129 @@
/****************************************************************************
* examples/ostest/tls.c
*
* Copyright (C) 2016 Gregory Nutt. All rights reserved.
* Author: Gregory Nutt <gnutt@nuttx.org>
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3. Neither the name NuttX nor the names of its contributors may be
* used to endorse or promote products derived from this software
* without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
* FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
* COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
* BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
* OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*
****************************************************************************/
/****************************************************************************
* Included Files
****************************************************************************/
#include <nuttx/config.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
#include <nuttx/tls.h>
#include "ostest.h"
#ifdef CONFIG_TLS
#include <arch/tls.h>
/****************************************************************************
* Private Data
****************************************************************************/
static struct tls_info_s g_save_info;
/****************************************************************************
* Private Functions
****************************************************************************/
static void get_tls_info(FAR struct tls_info_s *info)
{
memcpy(info, up_tls_info(), sizeof(struct tls_info_s));
}
static void put_tls_info(FAR const struct tls_info_s *info)
{
memcpy(up_tls_info(), info, sizeof(struct tls_info_s));
}
static void set_tls_info(uintptr_t value)
{
FAR struct tls_info_s *info = up_tls_info();
int i;
for (i = 0; i < CONFIG_TLS_NELEM; i++)
{
info->tl_elem[i] = value;
}
}
static bool verify_tls_info(uintptr_t value)
{
FAR struct tls_info_s *info = up_tls_info();
bool fail = false;
int i;
for (i = 0; i < CONFIG_TLS_NELEM; i++)
{
if (info->tl_elem[i] != value)
{
printf("tls: ERROR Element %d: Set %lx / read %lx\n",
i, (unsigned long)value,
(unsigned long)info->tl_elem[i]);
fail = true;
}
}
return fail;
}
static void do_tls_test(uintptr_t value)
{
set_tls_info(value);
if (!verify_tls_info(value))
{
printf("tls: Successfully set %lx\n", (unsigned long)value);
}
}
/****************************************************************************
* Public Functions
****************************************************************************/
void tls_test(void)
{
get_tls_info(&g_save_info);
do_tls_test(0);
do_tls_test(0xffffffff);
do_tls_test(0x55555555);
do_tls_test(0xaaaaaaaa);
put_tls_info(&g_save_info);
}
#endif /* CONFIG_TLS */