Files
threadx/utility/rtos_compatibility_layers/posix/px_in_thread_context.c
2021-07-28 07:24:02 +00:00

108 lines
5.7 KiB
C

/**************************************************************************/
/* */
/* Copyright (c) Microsoft Corporation. All rights reserved. */
/* */
/* This software is licensed under the Microsoft Software License */
/* Terms for Microsoft Azure RTOS. Full text of the license can be */
/* found in the LICENSE file at https://aka.ms/AzureRTOS_EULA */
/* and in the root directory of this software. */
/* */
/**************************************************************************/
/**************************************************************************/
/**************************************************************************/
/** */
/** POSIX wrapper for THREADX */
/** */
/** */
/** */
/**************************************************************************/
/**************************************************************************/
/* Include necessary system files. */
#include "tx_api.h" /* Threadx API */
#include "pthread.h" /* Posix API */
#include "px_int.h" /* Posix helper functions */
/**************************************************************************/
/* */
/* FUNCTION RELEASE */
/* */
/* posix_in_thread_context PORTABLE C */
/* 6.1.7 */
/* AUTHOR */
/* */
/* William E. Lamie, Microsoft Corporation */
/* */
/* DESCRIPTION */
/* */
/* This function determines if the system is currently in "thread" */
/* context, i.e. not timer routine, not ISR, not idling. */
/* */
/* INPUT */
/* */
/* None */
/* */
/* OUTPUT */
/* */
/* TX_TRUE | TX_FALSE */
/* */
/* CALLS */
/* */
/* None */
/* */
/* CALLED BY */
/* */
/* posix internal code */
/* */
/* RELEASE HISTORY */
/* */
/* DATE NAME DESCRIPTION */
/* */
/* 06-02-2021 William E. Lamie Initial Version 6.1.7 */
/* */
/**************************************************************************/
ULONG posix_in_thread_context(VOID)
{
/* External variables, defined within ThreadX, needed here. */
extern TX_THREAD * _tx_thread_current_ptr;
extern ULONG _tx_thread_system_state;
#ifndef TX_TIMER_PROCESS_IN_ISR
extern TX_THREAD _tx_timer_thread;
#endif
/* Return TX_FALSE if any of the following are true:
- we are in the scheduling loop (not in a thread);
- we are in an ISR
- we are in a timer routine
Return TX_TRUE otherwise (we are in a thread.)
*/
if (_tx_thread_system_state == TX_INITIALIZE_IN_PROGRESS)
{
/* We are calling from initialization, return TRUE. */
return(TX_TRUE);
}
else if ((!_tx_thread_current_ptr) /* Not in a thread */
|| (_tx_thread_system_state) /* In an ISR */
#ifndef TX_TIMER_PROCESS_IN_ISR
/* Timer routine */
|| (_tx_thread_current_ptr == &_tx_timer_thread)
#endif
)
{
/* We are NOT in thread (thread) context. */
return (TX_FALSE);
}
else
{
/* We ARE in thread (thread) context. */
return (TX_TRUE);
}
}