Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libpthread Use the pta_magic field in pthread attribute
details: https://anonhg.NetBSD.org/src/rev/100cff1f2786
branches: trunk
changeset: 744311:100cff1f2786
user: kamil <kamil%NetBSD.org@localhost>
date: Wed Jan 29 13:47:31 2020 +0000
description:
Use the pta_magic field in pthread attribute
Set PT_ATTR_DEAD on pthread_attr_destroy().
Check pta_magic before using pthread_attr_t in a bunch of other functions.
diffstat:
lib/libpthread/pthread_attr.c | 76 +++++++++++++++++++++++++++++++++++++++++-
1 files changed, 74 insertions(+), 2 deletions(-)
diffs (261 lines):
diff -r 69bbb9cfeda5 -r 100cff1f2786 lib/libpthread/pthread_attr.c
--- a/lib/libpthread/pthread_attr.c Wed Jan 29 13:40:23 2020 +0000
+++ b/lib/libpthread/pthread_attr.c Wed Jan 29 13:47:31 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pthread_attr.c,v 1.18 2017/08/01 12:31:45 martin Exp $ */
+/* $NetBSD: pthread_attr.c,v 1.19 2020/01/29 13:47:31 kamil Exp $ */
/*-
* Copyright (c) 2001, 2002, 2003, 2008 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__RCSID("$NetBSD: pthread_attr.c,v 1.18 2017/08/01 12:31:45 martin Exp $");
+__RCSID("$NetBSD: pthread_attr.c,v 1.19 2020/01/29 13:47:31 kamil Exp $");
#include <errno.h>
#include <stdio.h>
@@ -86,9 +86,14 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) != NULL)
free(p);
+ attr->pta_magic = PT_ATTR_DEAD;
+
return 0;
}
@@ -98,6 +103,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = pthread__attr_init_private(attr);
if (p == NULL)
return ENOMEM;
@@ -117,6 +125,9 @@
pthread_attr_getdetachstate(const pthread_attr_t *attr, int *detachstate)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (attr->pta_flags & PT_FLAG_DETACHED)
*detachstate = PTHREAD_CREATE_DETACHED;
else
@@ -130,6 +141,9 @@
pthread_attr_setdetachstate(pthread_attr_t *attr, int detachstate)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
switch (detachstate) {
case PTHREAD_CREATE_JOINABLE:
attr->pta_flags &= ~PT_FLAG_DETACHED;
@@ -150,6 +164,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) == NULL)
*guard = pthread__guardsize;
else
@@ -164,6 +181,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = pthread__attr_init_private(attr);
if (p == NULL)
return ENOMEM;
@@ -178,6 +198,9 @@
pthread_attr_getinheritsched(const pthread_attr_t *attr, int *inherit)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (attr->pta_flags & PT_FLAG_EXPLICIT_SCHED)
*inherit = PTHREAD_EXPLICIT_SCHED;
else
@@ -191,6 +214,9 @@
pthread_attr_setinheritsched(pthread_attr_t *attr, int inherit)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
switch (inherit) {
case PTHREAD_INHERIT_SCHED:
attr->pta_flags &= ~PT_FLAG_EXPLICIT_SCHED;
@@ -210,6 +236,9 @@
pthread_attr_getscope(const pthread_attr_t *attr, int *scope)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (attr->pta_flags & PT_FLAG_SCOPE_SYSTEM)
*scope = PTHREAD_SCOPE_SYSTEM;
else
@@ -223,6 +252,9 @@
pthread_attr_setscope(pthread_attr_t *attr, int scope)
{
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
switch (scope) {
case PTHREAD_SCOPE_PROCESS:
attr->pta_flags &= ~PT_FLAG_SCOPE_SYSTEM;
@@ -245,6 +277,9 @@
struct pthread_attr_private *p;
int error;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (param == NULL)
return EINVAL;
p = pthread__attr_init_private(attr);
@@ -263,6 +298,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (param == NULL)
return EINVAL;
p = attr->pta_private;
@@ -279,6 +317,8 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
switch (policy) {
case SCHED_OTHER:
@@ -300,6 +340,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = attr->pta_private;
if (p == NULL) {
*policy = SCHED_OTHER;
@@ -315,6 +358,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) == NULL) {
*addr = NULL;
*size = pthread__stacksize;
@@ -332,6 +378,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = pthread__attr_init_private(attr);
if (p == NULL)
return ENOMEM;
@@ -348,6 +397,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) == NULL)
*size = pthread__stacksize;
else
@@ -362,6 +414,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if (size < (size_t)sysconf(_SC_THREAD_STACK_MIN))
return EINVAL;
@@ -380,6 +435,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) == NULL)
*addr = NULL;
else
@@ -394,6 +452,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = pthread__attr_init_private(attr);
if (p == NULL)
return ENOMEM;
@@ -410,6 +471,9 @@
{
struct pthread_attr_private *p;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
if ((p = attr->pta_private) == NULL) {
name[0] = '\0';
if (argp != NULL)
@@ -430,6 +494,9 @@
struct pthread_attr_private *p;
int namelen;
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
p = pthread__attr_init_private(attr);
if (p == NULL)
return ENOMEM;
@@ -447,6 +514,10 @@
int
pthread_attr_setcreatesuspend_np(pthread_attr_t *attr)
{
+
+ pthread__error(EINVAL, "Invalid attribute",
+ attr->pta_magic == PT_ATTR_MAGIC);
+
attr->pta_flags |= PT_FLAG_SUSPENDED;
return 0;
}
@@ -455,6 +526,7 @@
pthread_getattr_np(pthread_t thread, pthread_attr_t *attr)
{
int error;
+
if ((error = pthread_attr_init(attr)) != 0)
return error;
if ((error = pthread_attr_get_np(thread, attr)) != 0) {
Home |
Main Index |
Thread Index |
Old Index