1*8a16b7a1SPedro F. Giffuni /*-
2*8a16b7a1SPedro F. Giffuni * SPDX-License-Identifier: BSD-3-Clause
3*8a16b7a1SPedro F. Giffuni *
478121e79SPeter Wemm * Copyright (c) 1988, 1993
578121e79SPeter Wemm * The Regents of the University of California. All rights reserved.
678121e79SPeter Wemm *
778121e79SPeter Wemm * Redistribution and use in source and binary forms, with or without
878121e79SPeter Wemm * modification, are permitted provided that the following conditions
978121e79SPeter Wemm * are met:
1078121e79SPeter Wemm * 1. Redistributions of source code must retain the above copyright
1178121e79SPeter Wemm * notice, this list of conditions and the following disclaimer.
1278121e79SPeter Wemm * 2. Redistributions in binary form must reproduce the above copyright
1378121e79SPeter Wemm * notice, this list of conditions and the following disclaimer in the
1478121e79SPeter Wemm * documentation and/or other materials provided with the distribution.
153fb3b97cSEd Maste * 3. Neither the name of the University nor the names of its contributors
1678121e79SPeter Wemm * may be used to endorse or promote products derived from this software
1778121e79SPeter Wemm * without specific prior written permission.
1878121e79SPeter Wemm *
1978121e79SPeter Wemm * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
2078121e79SPeter Wemm * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2178121e79SPeter Wemm * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2278121e79SPeter Wemm * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2378121e79SPeter Wemm * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2478121e79SPeter Wemm * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2578121e79SPeter Wemm * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2678121e79SPeter Wemm * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2778121e79SPeter Wemm * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2878121e79SPeter Wemm * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2978121e79SPeter Wemm * SUCH DAMAGE.
3078121e79SPeter Wemm */
3178121e79SPeter Wemm
324f86602cSHajimu UMEMOTO #include "namespace.h"
33fba5c5faSAlexey Zelkin #if defined(NLS)
34fba5c5faSAlexey Zelkin #include <nl_types.h>
35fba5c5faSAlexey Zelkin #endif
36fc7c3528SAlexey Zelkin #include <limits.h>
37fba5c5faSAlexey Zelkin #include <errno.h>
384f86602cSHajimu UMEMOTO #include <stdlib.h>
3978121e79SPeter Wemm #include <string.h>
4078121e79SPeter Wemm #include <signal.h>
414f86602cSHajimu UMEMOTO #include "reentrant.h"
424f86602cSHajimu UMEMOTO #include "un-namespace.h"
4378121e79SPeter Wemm
44fba5c5faSAlexey Zelkin #define UPREFIX "Unknown signal"
45fba5c5faSAlexey Zelkin
464f86602cSHajimu UMEMOTO static char sig_ebuf[NL_TEXTMAX];
474f86602cSHajimu UMEMOTO static char sig_ebuf_err[NL_TEXTMAX];
484f86602cSHajimu UMEMOTO static once_t sig_init_once = ONCE_INITIALIZER;
494f86602cSHajimu UMEMOTO static thread_key_t sig_key;
504f86602cSHajimu UMEMOTO static int sig_keycreated = 0;
514f86602cSHajimu UMEMOTO
524f86602cSHajimu UMEMOTO static void
sig_keycreate(void)534f86602cSHajimu UMEMOTO sig_keycreate(void)
544f86602cSHajimu UMEMOTO {
554f86602cSHajimu UMEMOTO sig_keycreated = (thr_keycreate(&sig_key, free) == 0);
564f86602cSHajimu UMEMOTO }
574f86602cSHajimu UMEMOTO
584f86602cSHajimu UMEMOTO static char *
sig_tlsalloc(void)594f86602cSHajimu UMEMOTO sig_tlsalloc(void)
604f86602cSHajimu UMEMOTO {
614f86602cSHajimu UMEMOTO char *ebuf = NULL;
624f86602cSHajimu UMEMOTO
634f86602cSHajimu UMEMOTO if (thr_main() != 0)
644f86602cSHajimu UMEMOTO ebuf = sig_ebuf;
654f86602cSHajimu UMEMOTO else {
664f86602cSHajimu UMEMOTO if (thr_once(&sig_init_once, sig_keycreate) != 0 ||
674f86602cSHajimu UMEMOTO !sig_keycreated)
684f86602cSHajimu UMEMOTO goto thr_err;
694f86602cSHajimu UMEMOTO if ((ebuf = thr_getspecific(sig_key)) == NULL) {
704f86602cSHajimu UMEMOTO if ((ebuf = malloc(sizeof(sig_ebuf))) == NULL)
714f86602cSHajimu UMEMOTO goto thr_err;
724f86602cSHajimu UMEMOTO if (thr_setspecific(sig_key, ebuf) != 0) {
734f86602cSHajimu UMEMOTO free(ebuf);
744f86602cSHajimu UMEMOTO ebuf = NULL;
754f86602cSHajimu UMEMOTO goto thr_err;
764f86602cSHajimu UMEMOTO }
774f86602cSHajimu UMEMOTO }
784f86602cSHajimu UMEMOTO }
794f86602cSHajimu UMEMOTO thr_err:
804f86602cSHajimu UMEMOTO if (ebuf == NULL)
814f86602cSHajimu UMEMOTO ebuf = sig_ebuf_err;
824f86602cSHajimu UMEMOTO return (ebuf);
834f86602cSHajimu UMEMOTO }
844f86602cSHajimu UMEMOTO
85fba5c5faSAlexey Zelkin /* XXX: negative 'num' ? (REGR) */
8678121e79SPeter Wemm char *
strsignal(int num)87fba5c5faSAlexey Zelkin strsignal(int num)
8878121e79SPeter Wemm {
894f86602cSHajimu UMEMOTO char *ebuf;
90fba5c5faSAlexey Zelkin char tmp[20];
91cea5da04SMaxime Henrion size_t n;
92cea5da04SMaxime Henrion int signum;
93fba5c5faSAlexey Zelkin char *t, *p;
9478121e79SPeter Wemm
95fba5c5faSAlexey Zelkin #if defined(NLS)
96fba5c5faSAlexey Zelkin int saved_errno = errno;
97fba5c5faSAlexey Zelkin nl_catd catd;
98fba5c5faSAlexey Zelkin catd = catopen("libc", NL_CAT_LOCALE);
99fba5c5faSAlexey Zelkin #endif
10078121e79SPeter Wemm
1014f86602cSHajimu UMEMOTO ebuf = sig_tlsalloc();
1024f86602cSHajimu UMEMOTO
103fba5c5faSAlexey Zelkin if (num > 0 && num < sys_nsig) {
104cea5da04SMaxime Henrion n = strlcpy(ebuf,
105fba5c5faSAlexey Zelkin #if defined(NLS)
106fba5c5faSAlexey Zelkin catgets(catd, 2, num, sys_siglist[num]),
107fba5c5faSAlexey Zelkin #else
108fba5c5faSAlexey Zelkin sys_siglist[num],
109fba5c5faSAlexey Zelkin #endif
1104f86602cSHajimu UMEMOTO sizeof(sig_ebuf));
111fba5c5faSAlexey Zelkin } else {
112fba5c5faSAlexey Zelkin n = strlcpy(ebuf,
113fba5c5faSAlexey Zelkin #if defined(NLS)
114fba5c5faSAlexey Zelkin catgets(catd, 2, 0xffff, UPREFIX),
115fba5c5faSAlexey Zelkin #else
116fba5c5faSAlexey Zelkin UPREFIX,
117fba5c5faSAlexey Zelkin #endif
1184f86602cSHajimu UMEMOTO sizeof(sig_ebuf));
119fba5c5faSAlexey Zelkin
120fba5c5faSAlexey Zelkin signum = num;
12178121e79SPeter Wemm if (num < 0)
12278121e79SPeter Wemm signum = -signum;
123fba5c5faSAlexey Zelkin
124fba5c5faSAlexey Zelkin t = tmp;
12578121e79SPeter Wemm do {
12678121e79SPeter Wemm *t++ = "0123456789"[signum % 10];
12778121e79SPeter Wemm } while (signum /= 10);
12878121e79SPeter Wemm if (num < 0)
12978121e79SPeter Wemm *t++ = '-';
130fba5c5faSAlexey Zelkin
131fba5c5faSAlexey Zelkin p = (ebuf + n);
132fba5c5faSAlexey Zelkin *p++ = ':';
133fba5c5faSAlexey Zelkin *p++ = ' ';
134fba5c5faSAlexey Zelkin
135fba5c5faSAlexey Zelkin for (;;) {
13678121e79SPeter Wemm *p++ = *--t;
13778121e79SPeter Wemm if (t <= tmp)
13878121e79SPeter Wemm break;
13978121e79SPeter Wemm }
14078121e79SPeter Wemm *p = '\0';
141b8d472d7SJilles Tjoelker }
142fba5c5faSAlexey Zelkin
143fba5c5faSAlexey Zelkin #if defined(NLS)
144fba5c5faSAlexey Zelkin catclose(catd);
145fba5c5faSAlexey Zelkin errno = saved_errno;
146fba5c5faSAlexey Zelkin #endif
14778121e79SPeter Wemm return (ebuf);
14878121e79SPeter Wemm }
149