代码拉取完成,页面将自动刷新
同步操作将从 TenonOS-Mirror/lib-pthread-embedded 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
/* SPDX-License-Identifier: LGPL-2.0-or-later */
/*
* Unikraft port of POSIX Threads Library for embedded systems
* Copyright(C) 2019 Costin Lupu, University Politehnica of Bucharest
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library in the file COPYING.LIB;
* if not, write to the Free Software Foundation, Inc.,
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
*/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include <errno.h>
#ifdef _GNU_SOURCE
#include <uk/arch/limits.h>
#endif
#include <pthread.h>
#include <implement.h>
/* TODO We currently do not support guards */
int pthread_attr_setguardsize(pthread_attr_t *attr, size_t guardsize)
{
if (guardsize != 0)
return EINVAL;
return 0;
}
int pthread_attr_getguardsize(const pthread_attr_t *attr, size_t *guardsize)
{
if (!guardsize)
return EINVAL;
*guardsize = 0;
return 0;
}
int pthread_attr_setstack(pthread_attr_t *attr,
void *stackaddr, size_t stacksize)
{
int rc;
rc = pthread_attr_setstacksize(attr, stacksize);
if (rc)
goto out;
rc = pthread_attr_setstackaddr(attr, stackaddr);
out:
return rc;
}
int pthread_attr_getstack(const pthread_attr_t *attr,
void **stackaddr, size_t *stacksize)
{
int rc;
rc = pthread_attr_getstacksize(attr, stacksize);
if (rc)
goto out;
rc = pthread_attr_getstackaddr(attr, stackaddr);
out:
return rc;
}
int pthread_getattr_np(pthread_t thread, pthread_attr_t *attr)
{
pte_thread_t *tp = (pte_thread_t *) thread.p;
struct uk_thread *_uk_thread;
pthread_attr_t _attr;
int prio = 0;
int rc;
if (tp == NULL || tp->threadId == NULL)
return ENOENT;
if (attr == NULL || *attr == NULL)
return EINVAL;
_uk_thread = tp->threadId;
_attr = *attr;
_attr->stackaddr = _uk_thread->_mem.stack;
_attr->stacksize = __STACK_SIZE;
/**
* The new Unikraft scheduling API does not implement
* detachable states.
*/
_attr->detachstate = PTHREAD_CREATE_JOINABLE;
/* No priorities implemented. */
_attr->param.sched_priority = prio;
/* TODO inheritsched and contentionscope */
return 0;
}
int pthread_setname_np(pthread_t thread, const char *name)
{
pte_thread_t *tp = (pte_thread_t *) thread.p;
struct uk_thread *_uk_thread;
size_t len;
if (tp == NULL || tp->threadId == NULL)
return ENOENT;
_uk_thread = tp->threadId;
len = strnlen(name, 16);
if (len > 15)
return ERANGE;
_uk_thread->name = name;
return 0;
}
int pthread_getname_np(pthread_t thread, char *name, size_t len)
{
pte_thread_t *tp = (pte_thread_t *) thread.p;
struct uk_thread *_uk_thread;
size_t _len;
if (tp == NULL || tp->threadId == NULL)
return ENOENT;
_uk_thread = tp->threadId;
_len = strlen(_uk_thread->name);
if (len < _len + 1)
return ERANGE;
sprintf(name,"%s", _uk_thread->name);
return 0;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。