1
0
mirror of https://github.com/azure-rtos/threadx synced 2025-02-06 08:08:27 +08:00
Bo Chen (from Dev Box) 8276bcf711 Update copyright.
2024-01-29 13:51:15 +08:00

92 lines
5.1 KiB
C

/***************************************************************************
* Copyright (c) 2024 Microsoft Corporation
*
* This program and the accompanying materials are made available under the
* terms of the MIT License which is available at
* https://opensource.org/licenses/MIT.
*
* SPDX-License-Identifier: MIT
**************************************************************************/
/**************************************************************************/
/**************************************************************************/
/** */
/** 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 */
/* */
/* pthread_testcancel PORTABLE C */
/* 6.1.7 */
/* AUTHOR */
/* */
/* William E. Lamie, Microsoft Corporation */
/* */
/* DESCRIPTION */
/* */
/* The pthread_testcancel function shall request that thread be */
/* canceled if the cancel state is enabled and cancel type is */
/* deferred, and a cancellation request has happened in the past. */
/* The target thread's cancelability state and type determines when */
/* the cancellation takes effect. When the cancellation is acted on, */
/* the cancelation cleanup handlers for thread shall be called. When */
/* the last cancelation cleanup handler returns, the thread-specific */
/* data destructor functions shall be called for thread. When the last */
/* destructor function returns, thread shall be terminated. */
/* */
/* INPUT */
/* */
/* thread pthread handle to thread to be canceled */
/* */
/* OUTPUT */
/* */
/* */
/* */
/* CALLS */
/* posix_destroy_thread */
/* */
/* CALLED BY */
/* */
/* Application Code */
/* */
/* RELEASE HISTORY */
/* */
/* DATE NAME DESCRIPTION */
/* */
/* 06-02-2021 William E. Lamie Initial Version 6.1.7 */
/* */
/**************************************************************************/
VOID pthread_testcancel(VOID)
{
POSIX_TCB *pthread_ptr;
/* Get the thread identifier of the calling pthread */
pthread_ptr = posix_tid2tcb(pthread_self());
/* Check if thread was created with cancel enable */
if ( (pthread_ptr->cancel_state == PTHREAD_CANCEL_ENABLE) &&
(pthread_ptr->cancel_type==PTHREAD_CANCEL_DEFERRED) &&
(pthread_ptr->cancel_request==TRUE) )
{
/* Signal the housekeeping ThreadX thread to cancel (delete) this pthread */
posix_destroy_pthread(pthread_ptr,(VOID *)0);
}
}