1 /* SPDX-License-Identifier: GPL-2.0 */ 2 3 #define _GNU_SOURCE 4 #define _LARGEFILE64_SOURCE 5 #define _FILE_OFFSET_BITS 64 6 7 /* libc-specific include files 8 * The program may be built in 3 ways: 9 * $(CC) -nostdlib -include /path/to/nolibc.h => NOLIBC already defined 10 * $(CC) -nostdlib -I/path/to/nolibc/sysroot => _NOLIBC_* guards are present 11 * $(CC) with default libc => NOLIBC* never defined 12 */ 13 #include <stdio.h> 14 #include <stdlib.h> 15 #include <string.h> 16 #include <sys/auxv.h> 17 #include <sys/ioctl.h> 18 #include <sys/mman.h> 19 #include <sys/mount.h> 20 #include <sys/prctl.h> 21 #include <sys/ptrace.h> 22 #include <sys/random.h> 23 #include <sys/reboot.h> 24 #include <sys/resource.h> 25 #include <sys/stat.h> 26 #include <sys/syscall.h> 27 #include <sys/sysmacros.h> 28 #include <sys/time.h> 29 #include <sys/timerfd.h> 30 #include <sys/uio.h> 31 #include <sys/utsname.h> 32 #include <sys/wait.h> 33 #include <dirent.h> 34 #include <errno.h> 35 #include <fcntl.h> 36 #include <poll.h> 37 #include <sched.h> 38 #include <signal.h> 39 #include <stdarg.h> 40 #include <stddef.h> 41 #include <stdint.h> 42 #include <time.h> 43 #include <unistd.h> 44 #include <limits.h> 45 #include <ctype.h> 46 #include <stdbool.h> 47 #include <byteswap.h> 48 #include <endian.h> 49 #include <alloca.h> 50 51 #pragma GCC diagnostic ignored "-Wmissing-prototypes" 52 53 #include "nolibc-test-linkage.h" 54 55 /* for the type of int_fast16_t and int_fast32_t, musl differs from glibc and nolibc */ 56 #define SINT_MAX_OF_TYPE(type) (((type)1 << (sizeof(type) * 8 - 2)) - (type)1 + ((type)1 << (sizeof(type) * 8 - 2))) 57 #define SINT_MIN_OF_TYPE(type) (-SINT_MAX_OF_TYPE(type) - 1) 58 59 /* will be used to test initialization of environ */ 60 static char **test_envp; 61 62 /* will be used to test initialization of argv */ 63 static char **test_argv; 64 65 /* will be used to test initialization of argc */ 66 static int test_argc; 67 68 /* will be used by some test cases as readable file, please don't write it */ 69 static const char *argv0; 70 71 /* will be used by constructor tests */ 72 static int constructor_test_value; 73 74 static const int is_le = __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__; 75 76 static const int is_nolibc = 77 #ifdef NOLIBC 78 1 79 #else 80 0 81 #endif 82 ; 83 84 static const int is_glibc = 85 #ifdef __GLIBC__ 86 1 87 #else 88 0 89 #endif 90 ; 91 92 #if !defined(NOLIBC) 93 /* Some disabled tests may not compile. */ 94 95 /* strlcat() and strlcpy() may not be in the system headers. */ 96 #undef strlcat 97 #undef strlcpy 98 #define strlcat(d, s, l) 0 99 #define strlcpy(d, s, l) 0 100 101 /* readdir_r() is likely to be marked deprecated */ 102 #undef readdir_r 103 #define readdir_r(dir, dirent, result) ((errno = EINVAL), -1) 104 105 #define _syscall(...) 0 106 #endif 107 108 /* definition of a series of tests */ 109 struct test { 110 const char *name; /* test name */ 111 int (*func)(int min, int max); /* handler */ 112 }; 113 114 #ifndef _NOLIBC_STDLIB_H 115 char *itoa(int i) 116 { 117 static char buf[12]; 118 int ret; 119 120 ret = snprintf(buf, sizeof(buf), "%d", i); 121 return (ret >= 0 && ret < sizeof(buf)) ? buf : "#err"; 122 } 123 #endif 124 125 #define CASE_ERR(err) \ 126 case err: return #err 127 128 /* returns the error name (e.g. "ENOENT") for common errors, "SUCCESS" for 0, 129 * or the decimal value for less common ones. 130 */ 131 static const char *errorname(int err) 132 { 133 switch (err) { 134 case 0: return "SUCCESS"; 135 CASE_ERR(EPERM); 136 CASE_ERR(ENOENT); 137 CASE_ERR(ESRCH); 138 CASE_ERR(EINTR); 139 CASE_ERR(EIO); 140 CASE_ERR(ENXIO); 141 CASE_ERR(E2BIG); 142 CASE_ERR(ENOEXEC); 143 CASE_ERR(EBADF); 144 CASE_ERR(ECHILD); 145 CASE_ERR(EAGAIN); 146 CASE_ERR(ENOMEM); 147 CASE_ERR(EACCES); 148 CASE_ERR(EFAULT); 149 CASE_ERR(ENOTBLK); 150 CASE_ERR(EBUSY); 151 CASE_ERR(EEXIST); 152 CASE_ERR(EXDEV); 153 CASE_ERR(ENODEV); 154 CASE_ERR(ENOTDIR); 155 CASE_ERR(EISDIR); 156 CASE_ERR(EINVAL); 157 CASE_ERR(ENFILE); 158 CASE_ERR(EMFILE); 159 CASE_ERR(ENOTTY); 160 CASE_ERR(ETXTBSY); 161 CASE_ERR(EFBIG); 162 CASE_ERR(ENOSPC); 163 CASE_ERR(ESPIPE); 164 CASE_ERR(EROFS); 165 CASE_ERR(EMLINK); 166 CASE_ERR(EPIPE); 167 CASE_ERR(EDOM); 168 CASE_ERR(ERANGE); 169 CASE_ERR(ENOSYS); 170 CASE_ERR(EOVERFLOW); 171 default: 172 return itoa(err); 173 } 174 } 175 176 enum RESULT { 177 OK, 178 FAIL, 179 SKIPPED, 180 }; 181 182 static void result(int llen, enum RESULT r) 183 { 184 const char *msg; 185 186 if (r == OK) 187 msg = " [OK]"; 188 else if (r == SKIPPED) 189 msg = "[SKIPPED]"; 190 else 191 msg = " [FAIL]"; 192 193 llen = 64 - llen; 194 if (llen < 0) 195 llen = 0; 196 printf("%*s%s\n", llen, "", msg); 197 } 198 199 /* The tests below are intended to be used by the macroes, which evaluate 200 * expression <expr>, print the status to stdout, and update the "ret" 201 * variable to count failures. The functions themselves return the number 202 * of failures, thus either 0 or 1. 203 */ 204 205 #define EXPECT_ZR(cond, expr) \ 206 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_zr(expr, llen); } while (0) 207 208 static __attribute__((unused)) 209 int expect_zr(int expr, int llen) 210 { 211 int ret = !(expr == 0); 212 213 llen += printf(" = %d ", expr); 214 result(llen, ret ? FAIL : OK); 215 return ret; 216 } 217 218 219 #define EXPECT_NZ(cond, expr) \ 220 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_nz(expr, llen); } while (0) 221 222 static __attribute__((unused)) 223 int expect_nz(int expr, int llen) 224 { 225 int ret = !(expr != 0); 226 227 llen += printf(" = %d ", expr); 228 result(llen, ret ? FAIL : OK); 229 return ret; 230 } 231 232 233 #define EXPECT_EQ(cond, expr, val) \ 234 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_eq(expr, llen, val); } while (0) 235 236 static __attribute__((unused)) 237 int expect_eq(uint64_t expr, int llen, uint64_t val) 238 { 239 int ret = !(expr == val); 240 241 llen += printf(" = %lld ", (long long)expr); 242 result(llen, ret ? FAIL : OK); 243 return ret; 244 } 245 246 247 #define EXPECT_NE(cond, expr, val) \ 248 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ne(expr, llen, val); } while (0) 249 250 static __attribute__((unused)) 251 int expect_ne(int expr, int llen, int val) 252 { 253 int ret = !(expr != val); 254 255 llen += printf(" = %d ", expr); 256 result(llen, ret ? FAIL : OK); 257 return ret; 258 } 259 260 261 #define EXPECT_GE(cond, expr, val) \ 262 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ge(expr, llen, val); } while (0) 263 264 static __attribute__((unused)) 265 int expect_ge(int expr, int llen, int val) 266 { 267 int ret = !(expr >= val); 268 269 llen += printf(" = %d ", expr); 270 result(llen, ret ? FAIL : OK); 271 return ret; 272 } 273 274 275 #define EXPECT_GT(cond, expr, val) \ 276 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_gt(expr, llen, val); } while (0) 277 278 static __attribute__((unused)) 279 int expect_gt(int expr, int llen, int val) 280 { 281 int ret = !(expr > val); 282 283 llen += printf(" = %d ", expr); 284 result(llen, ret ? FAIL : OK); 285 return ret; 286 } 287 288 289 #define EXPECT_LE(cond, expr, val) \ 290 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_le(expr, llen, val); } while (0) 291 292 static __attribute__((unused)) 293 int expect_le(int expr, int llen, int val) 294 { 295 int ret = !(expr <= val); 296 297 llen += printf(" = %d ", expr); 298 result(llen, ret ? FAIL : OK); 299 return ret; 300 } 301 302 303 #define EXPECT_LT(cond, expr, val) \ 304 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_lt(expr, llen, val); } while (0) 305 306 static __attribute__((unused)) 307 int expect_lt(int expr, int llen, int val) 308 { 309 int ret = !(expr < val); 310 311 llen += printf(" = %d ", expr); 312 result(llen, ret ? FAIL : OK); 313 return ret; 314 } 315 316 317 #define EXPECT_SYSZR(cond, expr) \ 318 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_syszr(expr, llen); } while (0) 319 320 static __attribute__((unused)) 321 int expect_syszr(int expr, int llen) 322 { 323 int ret = 0; 324 325 if (expr) { 326 ret = 1; 327 llen += printf(" = %d %s ", expr, errorname(errno)); 328 result(llen, FAIL); 329 } else { 330 llen += printf(" = %d ", expr); 331 result(llen, OK); 332 } 333 return ret; 334 } 335 336 337 #define EXPECT_SYSEQ(cond, expr, val) \ 338 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_syseq(expr, llen, val); } while (0) 339 340 static __attribute__((unused)) 341 int expect_syseq(int expr, int llen, int val) 342 { 343 int ret = 0; 344 345 if (expr != val) { 346 ret = 1; 347 llen += printf(" = %d %s ", expr, errorname(errno)); 348 result(llen, FAIL); 349 } else { 350 llen += printf(" = %d ", expr); 351 result(llen, OK); 352 } 353 return ret; 354 } 355 356 357 #define EXPECT_SYSNE(cond, expr, val) \ 358 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_sysne(expr, llen, val); } while (0) 359 360 static __attribute__((unused)) 361 int expect_sysne(int expr, int llen, int val) 362 { 363 int ret = 0; 364 365 if (expr == val) { 366 ret = 1; 367 llen += printf(" = %d %s ", expr, errorname(errno)); 368 result(llen, FAIL); 369 } else { 370 llen += printf(" = %d ", expr); 371 result(llen, OK); 372 } 373 return ret; 374 } 375 376 377 #define EXPECT_SYSER2(cond, expr, expret, experr1, experr2) \ 378 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_syserr2(expr, expret, experr1, experr2, llen); } while (0) 379 380 #define EXPECT_SYSER(cond, expr, expret, experr) \ 381 EXPECT_SYSER2(cond, expr, expret, experr, 0) 382 383 static __attribute__((unused)) 384 int expect_syserr2(int expr, int expret, int experr1, int experr2, int llen) 385 { 386 int ret = 0; 387 int _errno = errno; 388 389 llen += printf(" = %d %s ", expr, errorname(_errno)); 390 if (expr != expret || (_errno != experr1 && _errno != experr2)) { 391 ret = 1; 392 if (experr2 == 0) 393 llen += printf(" != (%d %s) ", expret, errorname(experr1)); 394 else 395 llen += printf(" != (%d %s %s) ", expret, errorname(experr1), errorname(experr2)); 396 result(llen, FAIL); 397 } else { 398 result(llen, OK); 399 } 400 return ret; 401 } 402 403 404 #define EXPECT_PTRZR(cond, expr) \ 405 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrzr(expr, llen); } while (0) 406 407 static __attribute__((unused)) 408 int expect_ptrzr(const void *expr, int llen) 409 { 410 int ret = 0; 411 412 llen += printf(" = <%p> ", expr); 413 if (expr) { 414 ret = 1; 415 result(llen, FAIL); 416 } else { 417 result(llen, OK); 418 } 419 return ret; 420 } 421 422 423 #define EXPECT_PTRNZ(cond, expr) \ 424 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrnz(expr, llen); } while (0) 425 426 static __attribute__((unused)) 427 int expect_ptrnz(const void *expr, int llen) 428 { 429 int ret = 0; 430 431 llen += printf(" = <%p> ", expr); 432 if (!expr) { 433 ret = 1; 434 result(llen, FAIL); 435 } else { 436 result(llen, OK); 437 } 438 return ret; 439 } 440 441 #define EXPECT_PTREQ(cond, expr, cmp) \ 442 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptreq(expr, llen, cmp); } while (0) 443 444 static __attribute__((unused)) 445 int expect_ptreq(const void *expr, int llen, const void *cmp) 446 { 447 int ret = 0; 448 449 llen += printf(" = <%p> ", expr); 450 if (expr != cmp) { 451 ret = 1; 452 result(llen, FAIL); 453 } else { 454 result(llen, OK); 455 } 456 return ret; 457 } 458 459 #define EXPECT_PTRNE(cond, expr, cmp) \ 460 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrne(expr, llen, cmp); } while (0) 461 462 static __attribute__((unused)) 463 int expect_ptrne(const void *expr, int llen, const void *cmp) 464 { 465 int ret = 0; 466 467 llen += printf(" = <%p> ", expr); 468 if (expr == cmp) { 469 ret = 1; 470 result(llen, FAIL); 471 } else { 472 result(llen, OK); 473 } 474 return ret; 475 } 476 477 #define EXPECT_PTRGE(cond, expr, cmp) \ 478 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrge(expr, llen, cmp); } while (0) 479 480 static __attribute__((unused)) 481 int expect_ptrge(const void *expr, int llen, const void *cmp) 482 { 483 int ret = !(expr >= cmp); 484 485 llen += printf(" = <%p> ", expr); 486 result(llen, ret ? FAIL : OK); 487 return ret; 488 } 489 490 #define EXPECT_PTRGT(cond, expr, cmp) \ 491 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrgt(expr, llen, cmp); } while (0) 492 493 static __attribute__((unused)) 494 int expect_ptrgt(const void *expr, int llen, const void *cmp) 495 { 496 int ret = !(expr > cmp); 497 498 llen += printf(" = <%p> ", expr); 499 result(llen, ret ? FAIL : OK); 500 return ret; 501 } 502 503 504 #define EXPECT_PTRLE(cond, expr, cmp) \ 505 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrle(expr, llen, cmp); } while (0) 506 507 static __attribute__((unused)) 508 int expect_ptrle(const void *expr, int llen, const void *cmp) 509 { 510 int ret = !(expr <= cmp); 511 512 llen += printf(" = <%p> ", expr); 513 result(llen, ret ? FAIL : OK); 514 return ret; 515 } 516 517 518 #define EXPECT_PTRLT(cond, expr, cmp) \ 519 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrlt(expr, llen, cmp); } while (0) 520 521 static __attribute__((unused)) 522 int expect_ptrlt(const void *expr, int llen, const void *cmp) 523 { 524 int ret = !(expr < cmp); 525 526 llen += printf(" = <%p> ", expr); 527 result(llen, ret ? FAIL : OK); 528 return ret; 529 } 530 531 #define EXPECT_PTRER2(cond, expr, expret, experr1, experr2) \ 532 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_ptrerr2(expr, expret, experr1, experr2, llen); } while (0) 533 534 #define EXPECT_PTRER(cond, expr, expret, experr) \ 535 EXPECT_PTRER2(cond, expr, expret, experr, 0) 536 537 static __attribute__((unused)) 538 int expect_ptrerr2(const void *expr, const void *expret, int experr1, int experr2, int llen) 539 { 540 int ret = 0; 541 int _errno = errno; 542 543 llen += printf(" = <%p> %s ", expr, errorname(_errno)); 544 if (expr != expret || (_errno != experr1 && _errno != experr2)) { 545 ret = 1; 546 if (experr2 == 0) 547 llen += printf(" != (<%p> %s) ", expret, errorname(experr1)); 548 else 549 llen += printf(" != (<%p> %s %s) ", expret, errorname(experr1), errorname(experr2)); 550 result(llen, FAIL); 551 } else { 552 result(llen, OK); 553 } 554 return ret; 555 } 556 557 #define EXPECT_STRZR(cond, expr) \ 558 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_strzr(expr, llen); } while (0) 559 560 static __attribute__((unused)) 561 int expect_strzr(const char *expr, int llen) 562 { 563 int ret = 0; 564 565 llen += printf(" = <%s> ", expr ? expr : "(null)"); 566 if (expr) { 567 ret = 1; 568 result(llen, FAIL); 569 } else { 570 result(llen, OK); 571 } 572 return ret; 573 } 574 575 576 #define EXPECT_STRNZ(cond, expr) \ 577 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_strnz(expr, llen); } while (0) 578 579 static __attribute__((unused)) 580 int expect_strnz(const char *expr, int llen) 581 { 582 int ret = 0; 583 584 llen += printf(" = <%s> ", expr ? expr : "(null)"); 585 if (!expr) { 586 ret = 1; 587 result(llen, FAIL); 588 } else { 589 result(llen, OK); 590 } 591 return ret; 592 } 593 594 595 #define EXPECT_STREQ(cond, expr, cmp) \ 596 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_streq(expr, llen, cmp); } while (0) 597 598 static __attribute__((unused)) 599 int expect_streq(const char *expr, int llen, const char *cmp) 600 { 601 int ret = 0; 602 603 llen += printf(" = <%s> ", expr); 604 if (strcmp(expr, cmp) != 0) { 605 ret = 1; 606 result(llen, FAIL); 607 } else { 608 result(llen, OK); 609 } 610 return ret; 611 } 612 613 614 #define EXPECT_STRNE(cond, expr, cmp) \ 615 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_strne(expr, llen, cmp); } while (0) 616 617 static __attribute__((unused)) 618 int expect_strne(const char *expr, int llen, const char *cmp) 619 { 620 int ret = 0; 621 622 llen += printf(" = <%s> ", expr); 623 if (strcmp(expr, cmp) == 0) { 624 ret = 1; 625 result(llen, FAIL); 626 } else { 627 result(llen, OK); 628 } 629 return ret; 630 } 631 632 #define EXPECT_STRBUFEQ(cond, expr, buf, val, cmp) \ 633 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_str_buf_eq(expr, buf, val, llen, cmp); } while (0) 634 635 static __attribute__((unused)) 636 int expect_str_buf_eq(size_t expr, const char *buf, size_t val, int llen, const char *cmp) 637 { 638 llen += printf(" = %lu <%s> ", (unsigned long)expr, buf); 639 if (strcmp(buf, cmp) != 0) { 640 result(llen, FAIL); 641 return 1; 642 } 643 if (expr != val) { 644 result(llen, FAIL); 645 return 1; 646 } 647 648 result(llen, OK); 649 return 0; 650 } 651 652 enum strtox_func { 653 strtox_func_strtol, 654 strtox_func_strtoul, 655 }; 656 657 #define EXPECT_STRTOX(cond, func, input, base, expected, chars, expected_errno) \ 658 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_strtox(llen, strtox_func_ ## func, input, base, expected, chars, expected_errno); } while (0) 659 660 static __attribute__((unused)) 661 int expect_strtox(int llen, enum strtox_func func, const char *input, int base, intmax_t expected, int expected_chars, int expected_errno) 662 { 663 char *endptr; 664 int actual_errno, actual_chars; 665 intmax_t r; 666 667 errno = 0; 668 if (func == strtox_func_strtol) { 669 r = strtol(input, &endptr, base); 670 } else if (func == strtox_func_strtoul) { 671 r = strtoul(input, &endptr, base); 672 } else { 673 result(llen, FAIL); 674 return 1; 675 } 676 actual_errno = errno; 677 actual_chars = endptr - input; 678 679 llen += printf(" %lld = %lld", (long long)expected, (long long)r); 680 if (r != expected) { 681 result(llen, FAIL); 682 return 1; 683 } 684 if (expected_chars == -1) { 685 if (*endptr != '\0') { 686 result(llen, FAIL); 687 return 1; 688 } 689 } else if (expected_chars != actual_chars) { 690 result(llen, FAIL); 691 return 1; 692 } 693 if (actual_errno != expected_errno) { 694 result(llen, FAIL); 695 return 1; 696 } 697 698 result(llen, OK); 699 return 0; 700 } 701 702 /* declare tests based on line numbers. There must be exactly one test per line. */ 703 #define CASE_TEST(name) \ 704 case __LINE__: llen += printf("%d %s", test, #name); 705 706 __attribute__((constructor)) 707 static void constructor1(void) 708 { 709 constructor_test_value |= 1 << 0; 710 } 711 712 __attribute__((constructor)) 713 static void constructor2(int argc, char **argv, char **envp) 714 { 715 if (argc && argv && envp) 716 constructor_test_value |= 1 << 1; 717 } 718 719 int test_program_invocation_name(void) 720 { 721 char buf[100]; 722 char *dirsep; 723 ssize_t r; 724 int fd; 725 726 fd = open("/proc/self/cmdline", O_RDONLY); 727 if (fd == -1) 728 return 1; 729 730 r = read(fd, buf, sizeof(buf)); 731 close(fd); 732 if (r < 1 || r == sizeof(buf)) 733 return 1; 734 735 buf[r - 1] = '\0'; 736 737 if (strcmp(program_invocation_name, buf) != 0) 738 return 1; 739 740 dirsep = strrchr(buf, '/'); 741 if (!dirsep || dirsep[1] == '\0') 742 return 1; 743 744 if (strcmp(program_invocation_short_name, dirsep + 1) != 0) 745 return 1; 746 747 return 0; 748 } 749 750 int run_startup(int min, int max) 751 { 752 int test; 753 int ret = 0; 754 /* kernel at least passes HOME and TERM, shell passes more */ 755 int env_total = 2; 756 /* checking NULL for argv/argv0, environ and _auxv is not enough, let's compare with sbrk(0) or &end */ 757 extern char end; 758 char *brk = sbrk(0) != (void *)-1 ? sbrk(0) : &end; 759 /* differ from nolibc, both glibc and musl have no global _auxv */ 760 const unsigned long *test_auxv = (void *)-1; 761 #ifdef NOLIBC 762 test_auxv = _auxv; 763 #endif 764 bool proc = access("/proc", R_OK) == 0; 765 766 for (test = min; test >= 0 && test <= max; test++) { 767 int llen = 0; /* line length */ 768 769 /* avoid leaving empty lines below, this will insert holes into 770 * test numbers. 771 */ 772 switch (test + __LINE__ + 1) { 773 CASE_TEST(argc); EXPECT_GE(1, test_argc, 1); break; 774 CASE_TEST(argv_addr); EXPECT_PTRGT(1, test_argv, brk); break; 775 CASE_TEST(argv_environ); EXPECT_PTRLT(1, test_argv, environ); break; 776 CASE_TEST(argv_total); EXPECT_EQ(1, environ - test_argv - 1, test_argc ?: 1); break; 777 CASE_TEST(argv0_addr); EXPECT_PTRGT(1, argv0, brk); break; 778 CASE_TEST(argv0_str); EXPECT_STRNZ(1, argv0 > brk ? argv0 : NULL); break; 779 CASE_TEST(argv0_len); EXPECT_GE(1, argv0 > brk ? strlen(argv0) : 0, 1); break; 780 CASE_TEST(environ_addr); EXPECT_PTRGT(1, environ, brk); break; 781 CASE_TEST(environ_envp); EXPECT_PTREQ(1, environ, test_envp); break; 782 CASE_TEST(environ_auxv); EXPECT_PTRLT(test_auxv != (void *)-1, environ, test_auxv); break; 783 CASE_TEST(environ_total); EXPECT_GE(test_auxv != (void *)-1, (void *)test_auxv - (void *)environ - 1, env_total); break; 784 CASE_TEST(environ_HOME); EXPECT_PTRNZ(1, getenv("HOME")); break; 785 CASE_TEST(auxv_addr); EXPECT_PTRGT(test_auxv != (void *)-1, test_auxv, brk); break; 786 CASE_TEST(auxv_AT_UID); EXPECT_EQ(1, getauxval(AT_UID), getuid()); break; 787 CASE_TEST(constructor); EXPECT_EQ(is_nolibc, constructor_test_value, 0x3); break; 788 CASE_TEST(linkage_errno); EXPECT_PTREQ(1, linkage_test_errno_addr(), &errno); break; 789 CASE_TEST(linkage_constr); EXPECT_EQ(1, linkage_test_constructor_test_value, 0x3); break; 790 CASE_TEST(prog_name); EXPECT_ZR(proc, test_program_invocation_name()); break; 791 case __LINE__: 792 return ret; /* must be last */ 793 /* note: do not set any defaults so as to permit holes above */ 794 } 795 } 796 return ret; 797 } 798 799 800 /* used by some syscall tests below */ 801 int test_getdents64(const char *dir) 802 { 803 char buffer[4096]; 804 int fd, ret; 805 int err; 806 807 ret = fd = open(dir, O_RDONLY | O_DIRECTORY); 808 if (ret < 0) 809 return ret; 810 811 ret = getdents64(fd, (void *)buffer, sizeof(buffer)); 812 err = errno; 813 close(fd); 814 815 errno = err; 816 return ret; 817 } 818 819 static int test_dirent(void) 820 { 821 int comm = 0, cmdline = 0; 822 struct dirent dirent, *result; 823 DIR *dir; 824 int ret; 825 826 dir = opendir("/proc/self"); 827 if (!dir) 828 return 1; 829 830 while (1) { 831 errno = 0; 832 ret = readdir_r(dir, &dirent, &result); 833 if (ret != 0) 834 return 1; 835 if (!result) 836 break; 837 838 if (strcmp(dirent.d_name, "comm") == 0) 839 comm++; 840 else if (strcmp(dirent.d_name, "cmdline") == 0) 841 cmdline++; 842 } 843 844 if (errno) 845 return 1; 846 847 ret = closedir(dir); 848 if (ret) 849 return 1; 850 851 if (comm != 1 || cmdline != 1) 852 return 1; 853 854 return 0; 855 } 856 857 int test_getrandom(void) 858 { 859 uint64_t rng = 0; 860 ssize_t ret; 861 862 ret = getrandom(&rng, sizeof(rng), GRND_NONBLOCK); 863 if (ret == -1 && errno == EAGAIN) 864 return 0; /* No entropy available yet */ 865 866 if (ret != sizeof(rng)) 867 return ret; 868 869 if (!rng) { 870 errno = EINVAL; 871 return -1; 872 } 873 874 return 0; 875 } 876 877 int test_getpagesize(void) 878 { 879 int x = getpagesize(); 880 int c; 881 882 if (x < 0) 883 return x; 884 885 #if defined(__x86_64__) || defined(__i386__) || defined(__i486__) || defined(__i586__) || defined(__i686__) 886 /* 887 * x86 family is always 4K page. 888 */ 889 c = (x == 4096); 890 #elif defined(__aarch64__) 891 /* 892 * Linux aarch64 supports three values of page size: 4K, 16K, and 64K 893 * which are selected at kernel compilation time. 894 */ 895 c = (x == 4096 || x == (16 * 1024) || x == (64 * 1024)); 896 #else 897 /* 898 * Assuming other architectures must have at least 4K page. 899 */ 900 c = (x >= 4096); 901 #endif 902 903 return !c; 904 } 905 906 int test_file_stream(void) 907 { 908 FILE *f; 909 int r; 910 911 f = fopen("/dev/null", "r"); 912 if (!f) 913 return -1; 914 915 errno = 0; 916 r = fwrite("foo", 1, 3, f); 917 if (r != 0 || ((is_nolibc || is_glibc) && errno != EBADF)) { 918 fclose(f); 919 return -1; 920 } 921 922 r = fclose(f); 923 if (r == EOF) 924 return -1; 925 926 return 0; 927 } 928 929 int test_file_stream_wsr(void) 930 { 931 const char dataout[] = "foo"; 932 const size_t datasz = sizeof(dataout); 933 char datain[datasz]; 934 int fd, r; 935 FILE *f; 936 937 fd = open("/tmp", O_TMPFILE | O_RDWR, 0644); 938 if (fd == -1) 939 return -1; 940 941 f = fdopen(fd, "w+"); 942 if (!f) 943 return -1; 944 945 errno = 0; 946 r = fwrite(dataout, 1, datasz, f); 947 if (r != datasz) 948 return -1; 949 950 /* Attempt to read from the file without rewinding, 951 * we should read 0 items. 952 */ 953 r = fread(datain, 1, datasz, f); 954 if (r) 955 return -1; 956 957 /* Rewind the file to the start */ 958 r = fseek(f, 0, SEEK_SET); 959 if (r) 960 return -1; 961 962 /* Attempt to read back more than was written to 963 * make sure we handle short reads properly. 964 * fread() should return the number of complete items. 965 */ 966 r = fread(datain, 1, datasz + 1, f); 967 if (r != datasz) 968 return -1; 969 970 /* Data we read should match the data we just wrote */ 971 if (memcmp(datain, dataout, datasz) != 0) 972 return -1; 973 974 r = fclose(f); 975 if (r) 976 return -1; 977 978 return 0; 979 } 980 981 enum fork_type { 982 FORK_STANDARD, 983 FORK_VFORK, 984 }; 985 986 int test_fork(enum fork_type type) 987 { 988 int status; 989 pid_t pid; 990 991 /* flush the printf buffer to avoid child flush it */ 992 fflush(stdout); 993 fflush(stderr); 994 995 switch (type) { 996 case FORK_STANDARD: 997 pid = fork(); 998 break; 999 case FORK_VFORK: 1000 pid = vfork(); 1001 break; 1002 default: 1003 return 1; 1004 } 1005 1006 switch (pid) { 1007 case -1: 1008 return 1; 1009 1010 case 0: 1011 _exit(123); 1012 1013 default: 1014 pid = waitpid(pid, &status, 0); 1015 1016 return pid == -1 || !WIFEXITED(status) || WEXITSTATUS(status) != 123; 1017 } 1018 } 1019 1020 int test_ftruncate(void) 1021 { 1022 struct stat stat_buf; 1023 int ret, fd; 1024 1025 ret = ftruncate(-1, 0); 1026 if (ret != -1 || errno != EBADF) { 1027 errno = EINVAL; 1028 return __LINE__; 1029 } 1030 1031 fd = memfd_create(__func__, 0); 1032 if (fd == -1) 1033 return __LINE__; 1034 1035 /* 1036 * This also tests that the high 32-bit half is passed through correctly. 1037 * If it gets lost, the kernel will see a positive number and not fail. 1038 */ 1039 ret = ftruncate(fd, -1); 1040 if (!(ret == -1 && errno == EINVAL)) { 1041 if (ret == 0) 1042 errno = EINVAL; 1043 ret = __LINE__; 1044 goto end; 1045 } 1046 1047 ret = ftruncate(fd, 42); 1048 if (ret != 0) { 1049 ret = __LINE__; 1050 goto end; 1051 } 1052 1053 ret = fstat(fd, &stat_buf); 1054 if (ret != 0) { 1055 ret = __LINE__; 1056 goto end; 1057 } 1058 1059 if (stat_buf.st_size != 42) { 1060 errno = EINVAL; 1061 ret = __LINE__; 1062 goto end; 1063 } 1064 1065 end: 1066 close(fd); 1067 1068 return ret; 1069 } 1070 1071 int test_stat_timestamps(void) 1072 { 1073 struct stat st; 1074 1075 if (sizeof(st.st_atim.tv_sec) != sizeof(st.st_atime)) 1076 return 1; 1077 1078 if (stat("/proc/self/", &st) && stat(argv0, &st) && stat("/", &st)) 1079 return 1; 1080 1081 if (st.st_atim.tv_sec != st.st_atime || st.st_atim.tv_nsec > 1000000000) 1082 return 1; 1083 1084 if (st.st_mtim.tv_sec != st.st_mtime || st.st_mtim.tv_nsec > 1000000000) 1085 return 1; 1086 1087 if (st.st_ctim.tv_sec != st.st_ctime || st.st_ctim.tv_nsec > 1000000000) 1088 return 1; 1089 1090 return 0; 1091 } 1092 1093 int test_timer(void) 1094 { 1095 struct itimerspec timerspec; 1096 struct sigevent evp; 1097 timer_t timer; 1098 int ret; 1099 1100 evp.sigev_notify = SIGEV_NONE; 1101 1102 ret = timer_create(CLOCK_MONOTONIC, &evp, &timer); 1103 if (ret) 1104 return ret; 1105 1106 timerspec = (struct itimerspec) { 1107 .it_value.tv_sec = 1000000, 1108 }; 1109 ret = timer_settime(timer, 0, &timerspec, NULL); 1110 if (ret) 1111 goto err; 1112 1113 timerspec = (struct itimerspec) { 1114 .it_value.tv_sec = -1, 1115 .it_value.tv_nsec = -1, 1116 .it_interval.tv_sec = -1, 1117 .it_interval.tv_nsec = -1, 1118 }; 1119 ret = timer_gettime(timer, &timerspec); 1120 if (ret) 1121 goto err; 1122 1123 errno = EINVAL; 1124 ret = -1; 1125 1126 if (timerspec.it_interval.tv_sec || timerspec.it_interval.tv_nsec) 1127 goto err; 1128 1129 if (timerspec.it_value.tv_sec > 1000000) 1130 goto err; 1131 1132 ret = timer_delete(timer); 1133 if (ret) 1134 return ret; 1135 1136 return 0; 1137 1138 err: 1139 timer_delete(timer); 1140 return ret; 1141 } 1142 1143 int test_timerfd(void) 1144 { 1145 struct itimerspec timerspec; 1146 int timer, ret; 1147 1148 timer = timerfd_create(CLOCK_MONOTONIC, 0); 1149 if (timer == -1) 1150 return -1; 1151 1152 timerspec = (struct itimerspec) { 1153 .it_value.tv_sec = 1000000, 1154 }; 1155 ret = timerfd_settime(timer, 0, &timerspec, NULL); 1156 if (ret) 1157 goto err; 1158 1159 timerspec = (struct itimerspec) { 1160 .it_value.tv_sec = -1, 1161 .it_value.tv_nsec = -1, 1162 .it_interval.tv_sec = -1, 1163 .it_interval.tv_nsec = -1, 1164 }; 1165 ret = timerfd_gettime(timer, &timerspec); 1166 if (ret) 1167 goto err; 1168 1169 errno = EINVAL; 1170 ret = -1; 1171 1172 if (timerspec.it_interval.tv_sec || timerspec.it_interval.tv_nsec) 1173 goto err; 1174 1175 if (timerspec.it_value.tv_sec > 1000000) 1176 goto err; 1177 1178 ret = close(timer); 1179 if (ret) 1180 return ret; 1181 1182 return 0; 1183 1184 err: 1185 close(timer); 1186 return ret; 1187 } 1188 1189 int test_uname(void) 1190 { 1191 struct utsname buf; 1192 char osrelease[sizeof(buf.release)]; 1193 ssize_t r; 1194 int fd; 1195 1196 memset(&buf.domainname, 'P', sizeof(buf.domainname)); 1197 1198 if (uname(&buf)) 1199 return 1; 1200 1201 if (strncmp("Linux", buf.sysname, sizeof(buf.sysname))) 1202 return 1; 1203 1204 fd = open("/proc/sys/kernel/osrelease", O_RDONLY); 1205 if (fd == -1) 1206 return 1; 1207 1208 r = read(fd, osrelease, sizeof(osrelease)); 1209 if (r == -1) 1210 return 1; 1211 1212 close(fd); 1213 1214 if (osrelease[r - 1] == '\n') 1215 r--; 1216 1217 /* Validate one of the later fields to ensure field sizes are correct */ 1218 if (strncmp(osrelease, buf.release, r)) 1219 return 1; 1220 1221 /* Ensure the field domainname is set, it is missing from struct old_utsname */ 1222 if (strnlen(buf.domainname, sizeof(buf.domainname)) == sizeof(buf.domainname)) 1223 return 1; 1224 1225 return 0; 1226 } 1227 1228 int test_mmap_munmap(void) 1229 { 1230 int ret, fd, i, page_size; 1231 void *mem; 1232 size_t file_size, length, mem_length; 1233 off_t offset, pa_offset; 1234 struct stat stat_buf; 1235 const char * const files[] = { 1236 "/dev/zero", 1237 "/proc/1/exe", "/proc/self/exe", 1238 argv0, 1239 NULL 1240 }; 1241 1242 page_size = getpagesize(); 1243 if (page_size < 0) 1244 return 1; 1245 1246 /* find a right file to mmap, existed and accessible */ 1247 for (i = 0; files[i] != NULL; i++) { 1248 ret = fd = open(files[i], O_RDONLY); 1249 if (ret == -1) 1250 continue; 1251 else 1252 break; 1253 } 1254 if (ret == -1) 1255 return 1; 1256 1257 ret = stat(files[i], &stat_buf); 1258 if (ret == -1) 1259 goto end; 1260 1261 /* file size of the special /dev/zero is 0, let's assign one manually */ 1262 if (i == 0) 1263 file_size = 3*page_size; 1264 else 1265 file_size = stat_buf.st_size; 1266 1267 offset = file_size - 1; 1268 if (offset < 0) 1269 offset = 0; 1270 length = file_size - offset; 1271 pa_offset = offset & ~(page_size - 1); 1272 mem_length = length + offset - pa_offset; 1273 1274 mem = mmap(NULL, mem_length, PROT_READ, MAP_SHARED, fd, pa_offset); 1275 if (mem == MAP_FAILED) { 1276 ret = 1; 1277 goto end; 1278 } 1279 1280 mem = mremap(mem, mem_length, mem_length * 2, MREMAP_MAYMOVE, 0); 1281 if (mem == MAP_FAILED) { 1282 munmap(mem, mem_length); 1283 ret = 1; 1284 goto end; 1285 } 1286 1287 ret = munmap(mem, mem_length * 2); 1288 1289 end: 1290 close(fd); 1291 return !!ret; 1292 } 1293 1294 int test_pipe(void) 1295 { 1296 const char *const msg = "hello, nolibc"; 1297 int pipefd[2]; 1298 char buf[32]; 1299 size_t len; 1300 1301 if (pipe(pipefd) == -1) 1302 return 1; 1303 1304 write(pipefd[1], msg, strlen(msg)); 1305 close(pipefd[1]); 1306 len = read(pipefd[0], buf, sizeof(buf)); 1307 close(pipefd[0]); 1308 1309 if (len != strlen(msg)) 1310 return 1; 1311 1312 return !!memcmp(buf, msg, len); 1313 } 1314 1315 int test_rlimit(void) 1316 { 1317 struct rlimit rlim = { 1318 .rlim_cur = 1 << 20, 1319 .rlim_max = 1 << 21, 1320 }; 1321 int ret; 1322 1323 ret = setrlimit(RLIMIT_CORE, &rlim); 1324 if (ret) 1325 return -1; 1326 1327 rlim.rlim_cur = 0; 1328 rlim.rlim_max = 0; 1329 1330 ret = getrlimit(RLIMIT_CORE, &rlim); 1331 if (ret) 1332 return -1; 1333 1334 if (rlim.rlim_cur != 1 << 20) 1335 return -1; 1336 if (rlim.rlim_max != 1 << 21) 1337 return -1; 1338 1339 return 0; 1340 } 1341 1342 int test_openat(void) 1343 { 1344 int dev, null; 1345 1346 dev = openat(AT_FDCWD, "/dev", O_DIRECTORY); 1347 if (dev < 0) 1348 return -1; 1349 1350 null = openat(dev, "null", O_RDONLY); 1351 close(dev); 1352 if (null < 0) 1353 return -1; 1354 1355 close(null); 1356 return 0; 1357 } 1358 1359 int test_open_mode(void) 1360 { 1361 const mode_t mode = 0444; 1362 struct stat stat_buf; 1363 int fd, ret; 1364 1365 fd = open("/tmp", O_TMPFILE | O_RDWR, mode); 1366 if (fd == -1) 1367 return -1; 1368 1369 ret = fstat(fd, &stat_buf); 1370 close(fd); 1371 1372 if (ret == -1) 1373 return -1; 1374 1375 if ((stat_buf.st_mode & 0777) != mode) 1376 return -1; 1377 1378 return 0; 1379 } 1380 1381 int test_nolibc_enosys(void) 1382 { 1383 if (true) 1384 return 0; 1385 1386 #if defined(NOLIBC) 1387 /* 1388 * __nolibc_enosys() will fail the compilation. 1389 * Make sure it can be optimized away if not actually called. 1390 */ 1391 if (__nolibc_enosys("something") != -ENOSYS) 1392 return 1; 1393 #endif 1394 1395 return 0; 1396 } 1397 1398 int test_namespace(void) 1399 { 1400 int original_ns, new_ns, ret; 1401 ino_t original_ns_ino; 1402 struct stat stat_buf; 1403 1404 original_ns = open("/proc/self/ns/uts", O_RDONLY); 1405 if (original_ns == -1) 1406 return -1; 1407 1408 ret = fstat(original_ns, &stat_buf); 1409 if (ret) 1410 goto out; 1411 1412 original_ns_ino = stat_buf.st_ino; 1413 1414 ret = unshare(CLONE_NEWUTS); 1415 if (ret) 1416 goto out; 1417 1418 new_ns = open("/proc/self/ns/uts", O_RDONLY); 1419 if (new_ns == -1) { 1420 ret = new_ns; 1421 goto out; 1422 } 1423 1424 ret = fstat(new_ns, &stat_buf); 1425 close(new_ns); 1426 if (ret) 1427 goto out; 1428 1429 if (stat_buf.st_ino == original_ns_ino) { 1430 errno = EINVAL; 1431 ret = -1; 1432 goto out; 1433 } 1434 1435 ret = setns(original_ns, CLONE_NEWUTS); 1436 if (ret) 1437 goto out; 1438 1439 new_ns = open("/proc/self/ns/uts", O_RDONLY); 1440 if (new_ns == -1) { 1441 ret = new_ns; 1442 goto out; 1443 } 1444 1445 ret = fstat(new_ns, &stat_buf); 1446 if (ret) 1447 goto out; 1448 1449 close(new_ns); 1450 1451 if (stat_buf.st_ino != original_ns_ino) { 1452 errno = EINVAL; 1453 ret = -1; 1454 goto out; 1455 } 1456 1457 ret = 0; 1458 1459 out: 1460 close(original_ns); 1461 return ret; 1462 } 1463 1464 int test_large_file(void) 1465 { 1466 off_t large_seek = ((off_t)UINT32_MAX) + 100; 1467 int fd, ret, saved_errno; 1468 ssize_t written; 1469 off_t off; 1470 1471 #if defined(__mips__) && defined(_ABIN32) 1472 /* https://lore.kernel.org/qemu-devel/fed03914-a95a-4522-a432-f129264cb2ac@t-8ch.de/ */ 1473 if (getpid() != 1) 1474 return 0; 1475 #endif 1476 1477 if (large_seek < UINT32_MAX) { 1478 errno = EOVERFLOW; 1479 return -1; 1480 } 1481 1482 fd = open("/tmp", O_TMPFILE | O_RDWR, 0644); 1483 if (fd == -1) 1484 return -1; 1485 1486 off = lseek(fd, large_seek, SEEK_CUR); 1487 if (off == -1) { 1488 ret = off; 1489 goto out; 1490 } else if (off != large_seek) { 1491 errno = ERANGE; 1492 ret = -1; 1493 goto out; 1494 } 1495 1496 written = write(fd, "1", 1); 1497 if (written == -1) { 1498 ret = written; 1499 goto out; 1500 } 1501 1502 ret = 0; 1503 out: 1504 saved_errno = errno; 1505 close(fd); 1506 errno = saved_errno; 1507 return ret; 1508 } 1509 1510 /* Run syscall tests between IDs <min> and <max>. 1511 * Return 0 on success, non-zero on failure. 1512 */ 1513 int run_syscall(int min, int max) 1514 { 1515 struct timeval tv; 1516 struct timezone tz; 1517 struct timespec ts; 1518 struct stat stat_buf; 1519 int euid0; 1520 int proc; 1521 int test; 1522 int tmp; 1523 struct iovec iov_one = { 1524 .iov_base = &tmp, 1525 .iov_len = 1, 1526 }; 1527 int ret = 0; 1528 void *p1, *p2; 1529 int has_gettid = 1; 1530 int has_brk; 1531 1532 /* <proc> indicates whether or not /proc is mounted */ 1533 proc = stat("/proc", &stat_buf) == 0; 1534 1535 /* this will be used to skip certain tests that can't be run unprivileged */ 1536 euid0 = geteuid() == 0; 1537 1538 /* from 2.30, glibc provides gettid() */ 1539 #if defined(__GLIBC_MINOR__) && defined(__GLIBC__) 1540 has_gettid = __GLIBC__ > 2 || (__GLIBC__ == 2 && __GLIBC_MINOR__ >= 30); 1541 #endif 1542 1543 /* on musl setting brk()/sbrk() always fails */ 1544 has_brk = brk(0) == 0; 1545 1546 for (test = min; test >= 0 && test <= max; test++) { 1547 int llen = 0; /* line length */ 1548 1549 /* avoid leaving empty lines below, this will insert holes into 1550 * test numbers. 1551 */ 1552 switch (test + __LINE__ + 1) { 1553 CASE_TEST(access); EXPECT_SYSZR(proc, access("/proc/self", R_OK)); break; 1554 CASE_TEST(access_bad); EXPECT_SYSER(proc, access("/proc/self", W_OK), -1, EPERM); break; 1555 CASE_TEST(clock_getres); EXPECT_SYSZR(1, clock_getres(CLOCK_MONOTONIC, &ts)); break; 1556 CASE_TEST(clock_gettime); EXPECT_SYSZR(1, clock_gettime(CLOCK_MONOTONIC, &ts)); break; 1557 CASE_TEST(clock_settime); EXPECT_SYSER(1, clock_settime(CLOCK_MONOTONIC, &ts), -1, EINVAL); break; 1558 CASE_TEST(getpid); EXPECT_SYSNE(1, getpid(), -1); break; 1559 CASE_TEST(getppid); EXPECT_SYSNE(1, getppid(), -1); break; 1560 CASE_TEST(gettid); EXPECT_SYSNE(has_gettid, gettid(), -1); break; 1561 CASE_TEST(getpgid_self); EXPECT_SYSNE(1, getpgid(0), -1); break; 1562 CASE_TEST(getpgid_bad); EXPECT_SYSER(1, getpgid(-1), -1, ESRCH); break; 1563 CASE_TEST(kill_0); EXPECT_SYSZR(1, kill(getpid(), 0)); break; 1564 CASE_TEST(kill_CONT); EXPECT_SYSZR(1, kill(getpid(), 0)); break; 1565 CASE_TEST(kill_BADPID); EXPECT_SYSER(1, kill(INT_MAX, 0), -1, ESRCH); break; 1566 CASE_TEST(sbrk_0); EXPECT_PTRNE(has_brk, sbrk(0), (void *)-1); break; 1567 CASE_TEST(sbrk); if ((p1 = p2 = sbrk(4096)) != (void *)-1) p2 = sbrk(-4096); EXPECT_SYSZR(has_brk, (p2 == (void *)-1) || p2 == p1); break; 1568 CASE_TEST(brk); EXPECT_SYSZR(has_brk, brk(sbrk(0))); break; 1569 CASE_TEST(chdir_root); EXPECT_SYSZR(1, chdir("/")); chdir(getenv("PWD")); break; 1570 CASE_TEST(chdir_dot); EXPECT_SYSZR(1, chdir(".")); break; 1571 CASE_TEST(chdir_blah); EXPECT_SYSER(1, chdir("/blah"), -1, ENOENT); break; 1572 CASE_TEST(chmod_argv0); EXPECT_SYSZR(1, chmod(argv0, 0555)); break; 1573 CASE_TEST(chmod_self); EXPECT_SYSER(proc, chmod("/proc/self", 0555), -1, EPERM); break; 1574 CASE_TEST(chown_self); EXPECT_SYSER(proc, chown("/proc/self", 0, 0), -1, EPERM); break; 1575 CASE_TEST(chroot_root); EXPECT_SYSZR(euid0, chroot("/")); break; 1576 CASE_TEST(chroot_blah); EXPECT_SYSER(1, chroot("/proc/self/blah"), -1, ENOENT); break; 1577 CASE_TEST(chroot_exe); EXPECT_SYSER(1, chroot(argv0), -1, ENOTDIR); break; 1578 CASE_TEST(clock_nanosleep); ts.tv_nsec = -1; EXPECT_EQ(1, EINVAL, clock_nanosleep(CLOCK_REALTIME, 0, &ts, NULL)); break; 1579 CASE_TEST(close_m1); EXPECT_SYSER(1, close(-1), -1, EBADF); break; 1580 CASE_TEST(close_dup); EXPECT_SYSZR(1, close(dup(0))); break; 1581 CASE_TEST(dup_0); tmp = dup(0); EXPECT_SYSNE(1, tmp, -1); close(tmp); break; 1582 CASE_TEST(dup_m1); tmp = dup(-1); EXPECT_SYSER(1, tmp, -1, EBADF); if (tmp != -1) close(tmp); break; 1583 CASE_TEST(dup2_0); tmp = dup2(0, 100); EXPECT_SYSNE(1, tmp, -1); close(tmp); break; 1584 CASE_TEST(dup2_m1); tmp = dup2(-1, 100); EXPECT_SYSER(1, tmp, -1, EBADF); if (tmp != -1) close(tmp); break; 1585 CASE_TEST(dup3_0); tmp = dup3(0, 100, 0); EXPECT_SYSNE(1, tmp, -1); close(tmp); break; 1586 CASE_TEST(dup3_m1); tmp = dup3(-1, 100, 0); EXPECT_SYSER(1, tmp, -1, EBADF); if (tmp != -1) close(tmp); break; 1587 CASE_TEST(execve_root); EXPECT_SYSER(1, execve("/", (char*[]){ [0] = (char []){"/"}, [1] = NULL }, NULL), -1, EACCES); break; 1588 CASE_TEST(fchdir_stdin); EXPECT_SYSER(1, fchdir(STDIN_FILENO), -1, ENOTDIR); break; 1589 CASE_TEST(fchdir_badfd); EXPECT_SYSER(1, fchdir(-1), -1, EBADF); break; 1590 CASE_TEST(file_stream); EXPECT_SYSZR(1, test_file_stream()); break; 1591 CASE_TEST(file_stream_wsr); EXPECT_SYSZR(1, test_file_stream_wsr()); break; 1592 CASE_TEST(fork); EXPECT_SYSZR(1, test_fork(FORK_STANDARD)); break; 1593 CASE_TEST(ftruncate); EXPECT_SYSZR(1, test_ftruncate()); break; 1594 CASE_TEST(getdents64_root); EXPECT_SYSNE(1, test_getdents64("/"), -1); break; 1595 CASE_TEST(getdents64_null); EXPECT_SYSER(1, test_getdents64("/dev/null"), -1, ENOTDIR); break; 1596 CASE_TEST(directories); EXPECT_SYSZR(is_nolibc && proc, test_dirent()); break; 1597 CASE_TEST(getrandom); EXPECT_SYSZR(1, test_getrandom()); break; 1598 CASE_TEST(gettimeofday_tv); EXPECT_SYSZR(1, gettimeofday(&tv, NULL)); break; 1599 CASE_TEST(gettimeofday_tv_tz);EXPECT_SYSZR(1, gettimeofday(&tv, &tz)); break; 1600 CASE_TEST(getpagesize); EXPECT_SYSZR(1, test_getpagesize()); break; 1601 CASE_TEST(ioctl_tiocinq); EXPECT_SYSZR(1, ioctl(0, TIOCINQ, &tmp)); break; 1602 CASE_TEST(link_root1); EXPECT_SYSER(1, link("/", "/"), -1, EEXIST); break; 1603 CASE_TEST(link_blah); EXPECT_SYSER(1, link("/proc/self/blah", "/blah"), -1, ENOENT); break; 1604 CASE_TEST(link_dir); EXPECT_SYSER(euid0, link("/", "/blah"), -1, EPERM); break; 1605 CASE_TEST(link_cross); EXPECT_SYSER(proc, link("/proc/self/cmdline", "/blah"), -1, EXDEV); break; 1606 CASE_TEST(lseek_m1); EXPECT_SYSER(1, lseek(-1, 0, SEEK_SET), -1, EBADF); break; 1607 CASE_TEST(lseek_0); EXPECT_SYSER(1, lseek(0, 0, SEEK_SET), -1, ESPIPE); break; 1608 CASE_TEST(mkdir_root); EXPECT_SYSER(1, mkdir("/", 0755), -1, EEXIST); break; 1609 CASE_TEST(mmap_bad); EXPECT_PTRER(1, mmap(NULL, 0, PROT_READ, MAP_PRIVATE, 0, 0), MAP_FAILED, EINVAL); break; 1610 CASE_TEST(munmap_bad); EXPECT_SYSER(1, munmap(NULL, 0), -1, EINVAL); break; 1611 CASE_TEST(mmap_munmap_good); EXPECT_SYSZR(1, test_mmap_munmap()); break; 1612 CASE_TEST(nanosleep); ts.tv_nsec = -1; EXPECT_SYSER(1, nanosleep(&ts, NULL), -1, EINVAL); break; 1613 CASE_TEST(nolibc_enosys); EXPECT_ZR(is_nolibc, test_nolibc_enosys()); break; 1614 CASE_TEST(open_tty); EXPECT_SYSNE(1, tmp = open("/dev/null", O_RDONLY), -1); if (tmp != -1) close(tmp); break; 1615 CASE_TEST(open_blah); EXPECT_SYSER(1, tmp = open("/proc/self/blah", O_RDONLY), -1, ENOENT); if (tmp != -1) close(tmp); break; 1616 CASE_TEST(openat_dir); EXPECT_SYSZR(1, test_openat()); break; 1617 CASE_TEST(open_mode); EXPECT_SYSZR(1, test_open_mode()); break; 1618 CASE_TEST(pipe); EXPECT_SYSZR(1, test_pipe()); break; 1619 CASE_TEST(poll_null); EXPECT_SYSZR(1, poll(NULL, 0, 0)); break; 1620 CASE_TEST(poll_stdout); EXPECT_SYSNE(1, ({ struct pollfd fds = { 1, POLLOUT, 0}; poll(&fds, 1, 0); }), -1); break; 1621 CASE_TEST(poll_fault); EXPECT_SYSER(1, poll(NULL, 1, 0), -1, EFAULT); break; 1622 CASE_TEST(prctl); EXPECT_SYSER(1, prctl(PR_SET_NAME, (unsigned long)NULL, 0, 0, 0), -1, EFAULT); break; 1623 CASE_TEST(read_badf); EXPECT_SYSER(1, read(-1, &tmp, 1), -1, EBADF); break; 1624 CASE_TEST(rlimit); EXPECT_SYSZR(1, test_rlimit()); break; 1625 CASE_TEST(rmdir_blah); EXPECT_SYSER(1, rmdir("/blah"), -1, ENOENT); break; 1626 CASE_TEST(sched_yield); EXPECT_SYSZR(1, sched_yield()); break; 1627 CASE_TEST(select_null); EXPECT_SYSZR(1, ({ struct timeval tv = { 0 }; select(0, NULL, NULL, NULL, &tv); })); break; 1628 CASE_TEST(select_stdout); EXPECT_SYSNE(1, ({ fd_set fds; FD_ZERO(&fds); FD_SET(1, &fds); select(2, NULL, &fds, NULL, NULL); }), -1); break; 1629 CASE_TEST(select_fault); EXPECT_SYSER(1, select(1, (void *)1, NULL, NULL, 0), -1, EFAULT); break; 1630 CASE_TEST(stat_blah); EXPECT_SYSER(1, stat("/proc/self/blah", &stat_buf), -1, ENOENT); break; 1631 CASE_TEST(stat_fault); EXPECT_SYSER(1, stat(NULL, &stat_buf), -1, EFAULT); break; 1632 CASE_TEST(stat_rdev); EXPECT_SYSZR(1, ({ int ret = stat("/dev/null", &stat_buf); ret ?: stat_buf.st_rdev != makedev(1, 3); })); break; 1633 CASE_TEST(stat_timestamps); EXPECT_SYSZR(1, test_stat_timestamps()); break; 1634 CASE_TEST(symlink_root); EXPECT_SYSER(1, symlink("/", "/"), -1, EEXIST); break; 1635 CASE_TEST(timer); EXPECT_SYSZR(1, test_timer()); break; 1636 CASE_TEST(timerfd); EXPECT_SYSZR(1, test_timerfd()); break; 1637 CASE_TEST(uname); EXPECT_SYSZR(proc, test_uname()); break; 1638 CASE_TEST(uname_fault); EXPECT_SYSER(1, uname(NULL), -1, EFAULT); break; 1639 CASE_TEST(unlink_root); EXPECT_SYSER(1, unlink("/"), -1, EISDIR); break; 1640 CASE_TEST(unlink_blah); EXPECT_SYSER(1, unlink("/proc/self/blah"), -1, ENOENT); break; 1641 CASE_TEST(vfork); EXPECT_SYSZR(1, test_fork(FORK_VFORK)); break; 1642 CASE_TEST(wait_child); EXPECT_SYSER(1, wait(&tmp), -1, ECHILD); break; 1643 CASE_TEST(waitpid_min); EXPECT_SYSER(1, waitpid(INT_MIN, &tmp, WNOHANG), -1, ESRCH); break; 1644 CASE_TEST(waitpid_child); EXPECT_SYSER(1, waitpid(getpid(), &tmp, WNOHANG), -1, ECHILD); break; 1645 CASE_TEST(write_badf); EXPECT_SYSER(1, write(-1, &tmp, 1), -1, EBADF); break; 1646 CASE_TEST(write_zero); EXPECT_SYSZR(1, write(1, &tmp, 0)); break; 1647 CASE_TEST(readv_badf); EXPECT_SYSER(1, readv(-1, &iov_one, 1), -1, EBADF); break; 1648 CASE_TEST(readv_zero); EXPECT_SYSZR(1, readv(0, NULL, 0)); break; 1649 CASE_TEST(writev_badf); EXPECT_SYSER(1, writev(-1, &iov_one, 1), -1, EBADF); break; 1650 CASE_TEST(writev_zero); EXPECT_SYSZR(1, writev(1, NULL, 0)); break; 1651 CASE_TEST(ptrace); tmp = ptrace(PTRACE_CONT, getpid(), NULL, NULL); EXPECT_SYSER(tmp != -1 && errno != ENOSYS, tmp, -1, EFAULT); break; 1652 CASE_TEST(syscall_noargs); EXPECT_SYSEQ(1, syscall(__NR_getpid), getpid()); break; 1653 CASE_TEST(syscall_args); EXPECT_SYSER(1, syscall(__NR_statx, 0, NULL, 0, 0, NULL), -1, EFAULT); break; 1654 CASE_TEST(_syscall_noargs); EXPECT_SYSEQ(is_nolibc, _syscall(__NR_getpid), getpid()); break; 1655 CASE_TEST(_syscall_args); EXPECT_SYSEQ(is_nolibc, _syscall(__NR_statx, 0, NULL, 0, 0, NULL), -EFAULT); break; 1656 CASE_TEST(namespace); EXPECT_SYSZR(euid0 && proc, test_namespace()); break; 1657 CASE_TEST(largefile); EXPECT_SYSZR(1, test_large_file()); break; 1658 case __LINE__: 1659 return ret; /* must be last */ 1660 /* note: do not set any defaults so as to permit holes above */ 1661 } 1662 } 1663 return ret; 1664 } 1665 1666 int test_alloca(void) 1667 { 1668 uint64_t *x; 1669 1670 x = alloca(sizeof(*x)); 1671 1672 *x = 0x1234; 1673 __asm__ ("" : "+r" (x)); 1674 1675 return *x - 0x1234; 1676 } 1677 1678 int test_difftime(void) 1679 { 1680 if (difftime(200., 100.) != 100.) 1681 return 1; 1682 1683 if (difftime(100., 200.) != -100.) 1684 return 1; 1685 1686 return 0; 1687 } 1688 1689 int test_time_types(void) 1690 { 1691 #ifdef NOLIBC 1692 struct __kernel_timespec kts; 1693 struct timespec ts; 1694 1695 if (!__builtin_types_compatible_p(time_t, __kernel_time64_t)) 1696 return 1; 1697 1698 if (sizeof(ts) != sizeof(kts)) 1699 return 1; 1700 1701 if (!__builtin_types_compatible_p(__typeof__(ts.tv_sec), __typeof__(kts.tv_sec))) 1702 return 1; 1703 1704 if (!__builtin_types_compatible_p(__typeof__(ts.tv_nsec), __typeof__(kts.tv_nsec))) 1705 return 1; 1706 1707 if (offsetof(__typeof__(ts), tv_sec) != offsetof(__typeof__(kts), tv_sec)) 1708 return 1; 1709 1710 if (offsetof(__typeof__(ts), tv_nsec) != offsetof(__typeof__(kts), tv_nsec)) 1711 return 1; 1712 #endif /* NOLIBC */ 1713 1714 return 0; 1715 } 1716 1717 int test_malloc(void) 1718 { 1719 size_t sz_array1, sz_array2, sz_array3; 1720 int *array1, *array2, *array3; 1721 int pagesize = getpagesize(); 1722 size_t idx; 1723 1724 if (pagesize < 0) 1725 return 1; 1726 1727 /* Dependent on the page size, as that is the granularity of our allocator. */ 1728 sz_array1 = pagesize / 2; 1729 array1 = malloc(sz_array1 * sizeof(*array1)); 1730 if (!array1) 1731 return 2; 1732 1733 for (idx = 0; idx < sz_array1; idx++) 1734 array1[idx] = idx; 1735 1736 sz_array2 = pagesize * 2; 1737 array2 = calloc(sz_array2, sizeof(*array2)); 1738 if (!array2) { 1739 free(array1); 1740 return 3; 1741 } 1742 1743 for (idx = 0; idx < sz_array2; idx++) { 1744 if (array2[idx] != 0) { 1745 free(array2); 1746 return 4; 1747 } 1748 array2[idx] = idx + sz_array1; 1749 } 1750 1751 /* Resize array1 into array3 and append array2 at the end. */ 1752 sz_array3 = sz_array1 + sz_array2; 1753 array3 = realloc(array1, sz_array3 * sizeof(*array3)); 1754 if (!array3) { 1755 free(array2); 1756 free(array1); 1757 return 5; 1758 } 1759 memcpy(array3 + sz_array1, array2, sizeof(*array2) * sz_array2); 1760 free(array2); 1761 1762 /* The contents must be contiguous now. */ 1763 for (idx = 0; idx < sz_array3; idx++) 1764 if (array3[idx] != (int)idx) 1765 return 6; 1766 1767 free(array3); 1768 return 0; 1769 } 1770 1771 int run_stdlib(int min, int max) 1772 { 1773 int test; 1774 int ret = 0; 1775 1776 for (test = min; test >= 0 && test <= max; test++) { 1777 int llen = 0; /* line length */ 1778 1779 /* For functions that take a long buffer, like strlcat() 1780 * Add some more chars after the \0, to test functions that overwrite the buffer set 1781 * the \0 at the exact right position. 1782 */ 1783 char buf[11] = "test123456"; 1784 buf[4] = '\0'; 1785 1786 1787 /* avoid leaving empty lines below, this will insert holes into 1788 * test numbers. 1789 */ 1790 switch (test + __LINE__ + 1) { 1791 CASE_TEST(getenv_TERM); EXPECT_STRNZ(1, getenv("TERM")); break; 1792 CASE_TEST(getenv_blah); EXPECT_STRZR(1, getenv("blah")); break; 1793 CASE_TEST(setcmp_blah_blah); EXPECT_EQ(1, strcmp("blah", "blah"), 0); break; 1794 CASE_TEST(setcmp_blah_blah2); EXPECT_NE(1, strcmp("blah", "blah2"), 0); break; 1795 CASE_TEST(setncmp_blah_blah); EXPECT_EQ(1, strncmp("blah", "blah", 10), 0); break; 1796 CASE_TEST(setncmp_blah_blah4); EXPECT_EQ(1, strncmp("blah", "blah4", 4), 0); break; 1797 CASE_TEST(setncmp_blah_blah5); EXPECT_NE(1, strncmp("blah", "blah5", 5), 0); break; 1798 CASE_TEST(setncmp_blah_blah6); EXPECT_NE(1, strncmp("blah", "blah6", 6), 0); break; 1799 CASE_TEST(strchr_foobar_o); EXPECT_STREQ(1, strchr("foobar", 'o'), "oobar"); break; 1800 CASE_TEST(strchr_foobar_z); EXPECT_STRZR(1, strchr("foobar", 'z')); break; 1801 CASE_TEST(strrchr_foobar_o); EXPECT_STREQ(1, strrchr("foobar", 'o'), "obar"); break; 1802 CASE_TEST(strrchr_foobar_z); EXPECT_STRZR(1, strrchr("foobar", 'z')); break; 1803 CASE_TEST(strlcat_0); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 0), buf, 3, "test"); break; 1804 CASE_TEST(strlcat_1); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 1), buf, 4, "test"); break; 1805 CASE_TEST(strlcat_5); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 5), buf, 7, "test"); break; 1806 CASE_TEST(strlcat_6); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 6), buf, 7, "testb"); break; 1807 CASE_TEST(strlcat_7); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 7), buf, 7, "testba"); break; 1808 CASE_TEST(strlcat_8); EXPECT_STRBUFEQ(is_nolibc, strlcat(buf, "bar", 8), buf, 7, "testbar"); break; 1809 CASE_TEST(strlcpy_0); EXPECT_STRBUFEQ(is_nolibc, strlcpy(buf, "bar", 0), buf, 3, "test"); break; 1810 CASE_TEST(strlcpy_1); EXPECT_STRBUFEQ(is_nolibc, strlcpy(buf, "bar", 1), buf, 3, ""); break; 1811 CASE_TEST(strlcpy_2); EXPECT_STRBUFEQ(is_nolibc, strlcpy(buf, "bar", 2), buf, 3, "b"); break; 1812 CASE_TEST(strlcpy_3); EXPECT_STRBUFEQ(is_nolibc, strlcpy(buf, "bar", 3), buf, 3, "ba"); break; 1813 CASE_TEST(strlcpy_4); EXPECT_STRBUFEQ(is_nolibc, strlcpy(buf, "bar", 4), buf, 3, "bar"); break; 1814 CASE_TEST(strstr_foobar_foo); EXPECT_STREQ(1, strstr("foobar", "foo"), "foobar"); break; 1815 CASE_TEST(strstr_foobar_bar); EXPECT_STREQ(1, strstr("foobar", "bar"), "bar"); break; 1816 CASE_TEST(strstr_foobar_baz); EXPECT_PTREQ(1, strstr("foobar", "baz"), NULL); break; 1817 CASE_TEST(memcmp_20_20); EXPECT_EQ(1, memcmp("aaa\x20", "aaa\x20", 4), 0); break; 1818 CASE_TEST(memcmp_20_60); EXPECT_LT(1, memcmp("aaa\x20", "aaa\x60", 4), 0); break; 1819 CASE_TEST(memcmp_60_20); EXPECT_GT(1, memcmp("aaa\x60", "aaa\x20", 4), 0); break; 1820 CASE_TEST(memcmp_20_e0); EXPECT_LT(1, memcmp("aaa\x20", "aaa\xe0", 4), 0); break; 1821 CASE_TEST(memcmp_e0_20); EXPECT_GT(1, memcmp("aaa\xe0", "aaa\x20", 4), 0); break; 1822 CASE_TEST(memcmp_80_e0); EXPECT_LT(1, memcmp("aaa\x80", "aaa\xe0", 4), 0); break; 1823 CASE_TEST(memcmp_e0_80); EXPECT_GT(1, memcmp("aaa\xe0", "aaa\x80", 4), 0); break; 1824 CASE_TEST(limit_int8_max); EXPECT_EQ(1, INT8_MAX, (int8_t) 0x7f); break; 1825 CASE_TEST(limit_int8_min); EXPECT_EQ(1, INT8_MIN, (int8_t) 0x80); break; 1826 CASE_TEST(limit_uint8_max); EXPECT_EQ(1, UINT8_MAX, (uint8_t) 0xff); break; 1827 CASE_TEST(limit_int16_max); EXPECT_EQ(1, INT16_MAX, (int16_t) 0x7fff); break; 1828 CASE_TEST(limit_int16_min); EXPECT_EQ(1, INT16_MIN, (int16_t) 0x8000); break; 1829 CASE_TEST(limit_uint16_max); EXPECT_EQ(1, UINT16_MAX, (uint16_t) 0xffff); break; 1830 CASE_TEST(limit_int32_max); EXPECT_EQ(1, INT32_MAX, (int32_t) 0x7fffffff); break; 1831 CASE_TEST(limit_int32_min); EXPECT_EQ(1, INT32_MIN, (int32_t) 0x80000000); break; 1832 CASE_TEST(limit_uint32_max); EXPECT_EQ(1, UINT32_MAX, (uint32_t) 0xffffffff); break; 1833 CASE_TEST(limit_int64_max); EXPECT_EQ(1, INT64_MAX, (int64_t) 0x7fffffffffffffff); break; 1834 CASE_TEST(limit_int64_min); EXPECT_EQ(1, INT64_MIN, (int64_t) 0x8000000000000000); break; 1835 CASE_TEST(limit_uint64_max); EXPECT_EQ(1, UINT64_MAX, (uint64_t) 0xffffffffffffffff); break; 1836 CASE_TEST(limit_int_least8_max); EXPECT_EQ(1, INT_LEAST8_MAX, (int_least8_t) 0x7f); break; 1837 CASE_TEST(limit_int_least8_min); EXPECT_EQ(1, INT_LEAST8_MIN, (int_least8_t) 0x80); break; 1838 CASE_TEST(limit_uint_least8_max); EXPECT_EQ(1, UINT_LEAST8_MAX, (uint_least8_t) 0xff); break; 1839 CASE_TEST(limit_int_least16_max); EXPECT_EQ(1, INT_LEAST16_MAX, (int_least16_t) 0x7fff); break; 1840 CASE_TEST(limit_int_least16_min); EXPECT_EQ(1, INT_LEAST16_MIN, (int_least16_t) 0x8000); break; 1841 CASE_TEST(limit_uint_least16_max); EXPECT_EQ(1, UINT_LEAST16_MAX, (uint_least16_t) 0xffff); break; 1842 CASE_TEST(limit_int_least32_max); EXPECT_EQ(1, INT_LEAST32_MAX, (int_least32_t) 0x7fffffff); break; 1843 CASE_TEST(limit_int_least32_min); EXPECT_EQ(1, INT_LEAST32_MIN, (int_least32_t) 0x80000000); break; 1844 CASE_TEST(limit_uint_least32_max); EXPECT_EQ(1, UINT_LEAST32_MAX, (uint_least32_t) 0xffffffffU); break; 1845 CASE_TEST(limit_int_least64_min); EXPECT_EQ(1, INT_LEAST64_MIN, (int_least64_t) 0x8000000000000000LL); break; 1846 CASE_TEST(limit_int_least64_max); EXPECT_EQ(1, INT_LEAST64_MAX, (int_least64_t) 0x7fffffffffffffffLL); break; 1847 CASE_TEST(limit_uint_least64_max); EXPECT_EQ(1, UINT_LEAST64_MAX, (uint_least64_t) 0xffffffffffffffffULL); break; 1848 CASE_TEST(limit_int_fast8_max); EXPECT_EQ(1, INT_FAST8_MAX, (int_fast8_t) 0x7f); break; 1849 CASE_TEST(limit_int_fast8_min); EXPECT_EQ(1, INT_FAST8_MIN, (int_fast8_t) 0x80); break; 1850 CASE_TEST(limit_uint_fast8_max); EXPECT_EQ(1, UINT_FAST8_MAX, (uint_fast8_t) 0xff); break; 1851 CASE_TEST(limit_int_fast16_min); EXPECT_EQ(1, INT_FAST16_MIN, (int_fast16_t) SINT_MIN_OF_TYPE(int_fast16_t)); break; 1852 CASE_TEST(limit_int_fast16_max); EXPECT_EQ(1, INT_FAST16_MAX, (int_fast16_t) SINT_MAX_OF_TYPE(int_fast16_t)); break; 1853 CASE_TEST(limit_uint_fast16_max); EXPECT_EQ(1, UINT_FAST16_MAX, (uint_fast16_t) UINTPTR_MAX); break; 1854 CASE_TEST(limit_int_fast32_min); EXPECT_EQ(1, INT_FAST32_MIN, (int_fast32_t) SINT_MIN_OF_TYPE(int_fast32_t)); break; 1855 CASE_TEST(limit_int_fast32_max); EXPECT_EQ(1, INT_FAST32_MAX, (int_fast32_t) SINT_MAX_OF_TYPE(int_fast32_t)); break; 1856 CASE_TEST(limit_uint_fast32_max); EXPECT_EQ(1, UINT_FAST32_MAX, (uint_fast32_t) UINTPTR_MAX); break; 1857 CASE_TEST(limit_int_fast64_min); EXPECT_EQ(1, INT_FAST64_MIN, (int_fast64_t) INT64_MIN); break; 1858 CASE_TEST(limit_int_fast64_max); EXPECT_EQ(1, INT_FAST64_MAX, (int_fast64_t) INT64_MAX); break; 1859 CASE_TEST(limit_uint_fast64_max); EXPECT_EQ(1, UINT_FAST64_MAX, (uint_fast64_t) UINT64_MAX); break; 1860 CASE_TEST(sizeof_long_sane); EXPECT_EQ(1, sizeof(long) == 8 || sizeof(long) == 4, 1); break; 1861 CASE_TEST(limit_intptr_min); EXPECT_EQ(1, INTPTR_MIN, sizeof(long) == 8 ? (intptr_t) 0x8000000000000000LL : (intptr_t) 0x80000000); break; 1862 CASE_TEST(limit_intptr_max); EXPECT_EQ(1, INTPTR_MAX, sizeof(long) == 8 ? (intptr_t) 0x7fffffffffffffffLL : (intptr_t) 0x7fffffff); break; 1863 CASE_TEST(limit_uintptr_max); EXPECT_EQ(1, UINTPTR_MAX, sizeof(long) == 8 ? (uintptr_t) 0xffffffffffffffffULL : (uintptr_t) 0xffffffffU); break; 1864 CASE_TEST(limit_ptrdiff_min); EXPECT_EQ(1, PTRDIFF_MIN, sizeof(long) == 8 ? (ptrdiff_t) 0x8000000000000000LL : (ptrdiff_t) 0x80000000); break; 1865 CASE_TEST(limit_ptrdiff_max); EXPECT_EQ(1, PTRDIFF_MAX, sizeof(long) == 8 ? (ptrdiff_t) 0x7fffffffffffffffLL : (ptrdiff_t) 0x7fffffff); break; 1866 CASE_TEST(limit_size_max); EXPECT_EQ(1, SIZE_MAX, sizeof(long) == 8 ? (size_t) 0xffffffffffffffffULL : (size_t) 0xffffffffU); break; 1867 CASE_TEST(strtol_simple); EXPECT_STRTOX(1, strtol, "35", 10, 35, -1, 0); break; 1868 CASE_TEST(strtol_positive); EXPECT_STRTOX(1, strtol, "+35", 10, 35, -1, 0); break; 1869 CASE_TEST(strtol_negative); EXPECT_STRTOX(1, strtol, "-35", 10, -35, -1, 0); break; 1870 CASE_TEST(strtol_hex_auto); EXPECT_STRTOX(1, strtol, "0xFF", 0, 255, -1, 0); break; 1871 CASE_TEST(strtol_base36); EXPECT_STRTOX(1, strtol, "12yZ", 36, 50507, -1, 0); break; 1872 CASE_TEST(strtol_cutoff); EXPECT_STRTOX(1, strtol, "1234567890", 8, 342391, 7, 0); break; 1873 CASE_TEST(strtol_octal_auto); EXPECT_STRTOX(1, strtol, "011", 0, 9, -1, 0); break; 1874 CASE_TEST(strtol_hex_00); EXPECT_STRTOX(1, strtol, "0x00", 16, 0, -1, 0); break; 1875 CASE_TEST(strtol_hex_FF); EXPECT_STRTOX(1, strtol, "FF", 16, 255, -1, 0); break; 1876 CASE_TEST(strtol_hex_ff); EXPECT_STRTOX(1, strtol, "ff", 16, 255, -1, 0); break; 1877 CASE_TEST(strtol_hex_prefix); EXPECT_STRTOX(1, strtol, "0xFF", 16, 255, -1, 0); break; 1878 CASE_TEST(strtol_trailer); EXPECT_STRTOX(1, strtol, "35foo", 10, 35, 2, 0); break; 1879 CASE_TEST(strtol_overflow); EXPECT_STRTOX(1, strtol, "0x8000000000000000", 16, LONG_MAX, -1, ERANGE); break; 1880 CASE_TEST(strtol_underflow); EXPECT_STRTOX(1, strtol, "-0x8000000000000001", 16, LONG_MIN, -1, ERANGE); break; 1881 CASE_TEST(strtoul_negative); EXPECT_STRTOX(1, strtoul, "-0x1", 16, ULONG_MAX, 4, 0); break; 1882 CASE_TEST(strtoul_overflow); EXPECT_STRTOX(1, strtoul, "0x10000000000000000", 16, ULONG_MAX, -1, ERANGE); break; 1883 CASE_TEST(strerror_success); EXPECT_STREQ(is_nolibc, strerror(0), "errno=0"); break; 1884 CASE_TEST(strerror_EINVAL); EXPECT_STREQ(is_nolibc, strerror(EINVAL), "errno=22"); break; 1885 CASE_TEST(strerror_int_max); EXPECT_STREQ(is_nolibc, strerror(INT_MAX), "errno=2147483647"); break; 1886 CASE_TEST(strerror_int_min); EXPECT_STREQ(is_nolibc, strerror(INT_MIN), "errno=-2147483648"); break; 1887 CASE_TEST(tolower); EXPECT_EQ(1, tolower('A'), 'a'); break; 1888 CASE_TEST(tolower_noop); EXPECT_EQ(1, tolower('a'), 'a'); break; 1889 CASE_TEST(toupper); EXPECT_EQ(1, toupper('a'), 'A'); break; 1890 CASE_TEST(toupper_noop); EXPECT_EQ(1, toupper('A'), 'A'); break; 1891 CASE_TEST(abs); EXPECT_EQ(1, abs(-10), 10); break; 1892 CASE_TEST(abs_noop); EXPECT_EQ(1, abs(10), 10); break; 1893 CASE_TEST(alloca); EXPECT_ZR(1, test_alloca()); break; 1894 CASE_TEST(difftime); EXPECT_ZR(1, test_difftime()); break; 1895 CASE_TEST(memchr_foobar6_o); EXPECT_STREQ(1, memchr("foobar", 'o', 6), "oobar"); break; 1896 CASE_TEST(memchr_foobar3_b); EXPECT_STRZR(1, memchr("foobar", 'b', 3)); break; 1897 CASE_TEST(time_types); EXPECT_ZR(is_nolibc, test_time_types()); break; 1898 CASE_TEST(makedev); EXPECT_EQ(1, makedev(0x12, 0x34), 0x1234); break; 1899 CASE_TEST(major); EXPECT_EQ(1, major(0x1234), 0x12); break; 1900 CASE_TEST(minor); EXPECT_EQ(1, minor(0x1234), 0x34); break; 1901 CASE_TEST(makedev_big); EXPECT_EQ(1, makedev(0x11223344, 0x55667788), 0x1122355667734488); break; 1902 CASE_TEST(major_big); EXPECT_EQ(1, major(0x1122355667734488), 0x11223344); break; 1903 CASE_TEST(minor_big); EXPECT_EQ(1, minor(0x1122355667734488), 0x55667788); break; 1904 CASE_TEST(malloc); EXPECT_ZR(1, test_malloc()); break; 1905 CASE_TEST(bswap_16); EXPECT_EQ(1, bswap_16(0x0123), 0x2301); break; 1906 CASE_TEST(bswap_32); EXPECT_EQ(1, bswap_32(0x01234567), 0x67452301); break; 1907 CASE_TEST(bswap_64); EXPECT_EQ(1, bswap_64(0x0123456789abcdef), 0xefcdab8967452301); break; 1908 CASE_TEST(htobe16); EXPECT_EQ(1, htobe16(is_le ? 0x0123 : 0x2301), 0x2301); break; 1909 CASE_TEST(htole16); EXPECT_EQ(1, htole16(is_le ? 0x0123 : 0x2301), 0x0123); break; 1910 CASE_TEST(htobe32); EXPECT_EQ(1, htobe32(is_le ? 0x01234567 : 0x67452301), 0x67452301); break; 1911 CASE_TEST(htole32); EXPECT_EQ(1, htole32(is_le ? 0x01234567 : 0x67452301), 0x01234567); break; 1912 CASE_TEST(htobe64); EXPECT_EQ(1, htobe64(is_le ? 0x0123456789000000 : 0x8967452301), 0x8967452301); break; 1913 CASE_TEST(htole64); EXPECT_EQ(1, htole64(is_le ? 0x0123456789 : 0x8967452301000000), 0x0123456789); break; 1914 1915 case __LINE__: 1916 return ret; /* must be last */ 1917 /* note: do not set any defaults so as to permit holes above */ 1918 } 1919 } 1920 return ret; 1921 } 1922 1923 #define EXPECT_VFPRINTF(cond, expected, fmt, ...) \ 1924 do { if (!(cond)) result(llen, SKIPPED); else ret += expect_vfprintf(llen, expected, fmt, ##__VA_ARGS__); } while (0) 1925 1926 #define VFPRINTF_LEN 25 1927 static int expect_vfprintf(int llen, const char *expected, const char *fmt, ...) 1928 { 1929 char buf[VFPRINTF_LEN + 80]; 1930 unsigned int cmp_len; 1931 va_list args; 1932 ssize_t written, expected_len; 1933 1934 /* Fill and terminate buf[] to check for overlong/absent writes */ 1935 memset(buf, 0xa5, sizeof(buf) - 1); 1936 buf[sizeof(buf) - 1] = 0; 1937 1938 va_start(args, fmt); 1939 /* Limit buffer length to test truncation */ 1940 written = vsnprintf(buf, VFPRINTF_LEN + 1, fmt, args); 1941 va_end(args); 1942 1943 llen += printf(" \"%s\"", buf); 1944 1945 expected_len = strlen(expected); 1946 if (expected_len > VFPRINTF_LEN) { 1947 /* Indicate truncated in test output */ 1948 llen += printf("+"); 1949 cmp_len = VFPRINTF_LEN; 1950 } else { 1951 cmp_len = expected_len; 1952 } 1953 1954 if (memcmp(expected, buf, cmp_len) || buf[cmp_len]) { 1955 llen += printf(" should be \"%.*s\"", VFPRINTF_LEN, expected); 1956 result(llen, FAIL); 1957 return 1; 1958 } 1959 1960 if (written != expected_len) { 1961 llen += printf(" written(%d) != %d", (int)written, (int)expected_len); 1962 result(llen, FAIL); 1963 return 1; 1964 } 1965 1966 /* Check for any overwrites after the actual data. */ 1967 while (++cmp_len < sizeof(buf) - 1) { 1968 if ((unsigned char)buf[cmp_len] != 0xa5) { 1969 llen += printf(" overwrote buf[%d] with 0x%x", cmp_len, buf[cmp_len]); 1970 result(llen, FAIL); 1971 return 1; 1972 } 1973 } 1974 1975 result(llen, OK); 1976 return 0; 1977 } 1978 1979 static int test_scanf(void) 1980 { 1981 unsigned long long ull; 1982 unsigned long ul; 1983 unsigned int u; 1984 long long ll; 1985 long l; 1986 void *p; 1987 int i; 1988 1989 /* return __LINE__ to point to the specific failure */ 1990 1991 /* test EOF */ 1992 if (sscanf("", "foo") != EOF) 1993 return __LINE__; 1994 1995 /* test simple literal without placeholder */ 1996 if (sscanf("foo", "foo") != 0) 1997 return __LINE__; 1998 1999 /* test single placeholder */ 2000 if (sscanf("123", "%d", &i) != 1) 2001 return __LINE__; 2002 2003 if (i != 123) 2004 return __LINE__; 2005 2006 /* test multiple place holders and separators */ 2007 if (sscanf("a123b456c0x90", "a%db%uc%p", &i, &u, &p) != 3) 2008 return __LINE__; 2009 2010 if (i != 123) 2011 return __LINE__; 2012 2013 if (u != 456) 2014 return __LINE__; 2015 2016 if (p != (void *)0x90) 2017 return __LINE__; 2018 2019 /* test space handling */ 2020 if (sscanf("a b1", "a b%d", &i) != 1) 2021 return __LINE__; 2022 2023 if (i != 1) 2024 return __LINE__; 2025 2026 /* test literal percent */ 2027 if (sscanf("a%1", "a%%%d", &i) != 1) 2028 return __LINE__; 2029 2030 if (i != 1) 2031 return __LINE__; 2032 2033 /* test stdint.h types */ 2034 if (sscanf("1|2|3|4|5|6", 2035 "%d|%ld|%lld|%u|%lu|%llu", 2036 &i, &l, &ll, &u, &ul, &ull) != 6) 2037 return __LINE__; 2038 2039 if (i != 1 || l != 2 || ll != 3 || 2040 u != 4 || ul != 5 || ull != 6) 2041 return __LINE__; 2042 2043 return 0; 2044 } 2045 2046 static int test_printf_error(void) 2047 { 2048 int fd, ret, saved_errno; 2049 2050 fd = open("/dev/full", O_RDWR); 2051 if (fd == -1) 2052 return 1; 2053 2054 errno = 0; 2055 ret = dprintf(fd, "foo"); 2056 saved_errno = errno; 2057 close(fd); 2058 2059 if (ret != -1) 2060 return 2; 2061 2062 if (saved_errno != ENOSPC) 2063 return 3; 2064 2065 return 0; 2066 } 2067 2068 int test_asprintf(void) 2069 { 2070 char *str; 2071 int ret; 2072 2073 ret = asprintf(&str, "foo%s", "bar"); 2074 if (ret == -1) 2075 return 1; 2076 2077 if (ret != 6) { 2078 free(str); 2079 return 2; 2080 } 2081 2082 if (memcmp(str, "foobar", 6) != 0) { 2083 free(str); 2084 return 3; 2085 } 2086 2087 free(str); 2088 return 0; 2089 } 2090 2091 static int run_printf(int min, int max) 2092 { 2093 int test; 2094 int ret = 0; 2095 2096 for (test = min; test >= 0 && test <= max; test++) { 2097 int llen = 0; /* line length */ 2098 2099 /* avoid leaving empty lines below, this will insert holes into 2100 * test numbers. 2101 */ 2102 switch (test + __LINE__ + 1) { 2103 CASE_TEST(empty); EXPECT_VFPRINTF(1, "", ""); break; 2104 CASE_TEST(simple); EXPECT_VFPRINTF(1, "foo", "foo"); break; 2105 CASE_TEST(string); EXPECT_VFPRINTF(1, "foo", "%s", "foo"); break; 2106 CASE_TEST(number); EXPECT_VFPRINTF(1, "1234", "%d", 1234); break; 2107 CASE_TEST(negnumber); EXPECT_VFPRINTF(1, "-1234", "%d", -1234); break; 2108 CASE_TEST(num_sign); EXPECT_VFPRINTF(1, "| 1|+2|+3|+4|5|", "|% d|%+d|% +d|%+ d|%#d|", 1, 2, 3, 4, 5); break; 2109 CASE_TEST(unsigned); EXPECT_VFPRINTF(1, "12345", "%u", 12345); break; 2110 CASE_TEST(signed_max); EXPECT_VFPRINTF(1, "2147483647", "%i", ~0u >> 1); break; 2111 CASE_TEST(signed_min); EXPECT_VFPRINTF(1, "-2147483648", "%i", (~0u >> 1) + 1); break; 2112 CASE_TEST(unsigned_max); EXPECT_VFPRINTF(1, "4294967295", "%u", ~0u); break; 2113 CASE_TEST(char); EXPECT_VFPRINTF(1, "|c|d| e|", "|%c|%.0c|%4c|", 'c', 'd', 'e'); break; 2114 CASE_TEST(octal); EXPECT_VFPRINTF(1, "|17| 0033||", "|%o|%6.4o|%.0o|", 017, 033, 0); break; 2115 CASE_TEST(octal_max); EXPECT_VFPRINTF(1, "1777777777777777777777", "%llo", ~0ULL); break; 2116 CASE_TEST(octal_alt); EXPECT_VFPRINTF(1, "|0|01|02|034|0|0|", "|%#o|%#o|%#02o|%#02o|%#.0o|%0-#o|", 0, 1, 2, 034, 0, 0); break; 2117 CASE_TEST(hex_nolibc); EXPECT_VFPRINTF(is_nolibc, "|f|d|", "|%x|%X|", 0xf, 0xd); break; 2118 CASE_TEST(hex_libc); EXPECT_VFPRINTF(!is_nolibc, "|f|D|", "|%x|%X|", 0xf, 0xd); break; 2119 CASE_TEST(hex_alt); EXPECT_VFPRINTF(1, "|0x1| 0x2| 0|", "|%#x|%#5x|%#5x|", 1, 2, 0); break; 2120 CASE_TEST(hex_alt_prec); EXPECT_VFPRINTF(1, "| 0x02|0x03| 0x123|", "|%#5.2x|%#04x|%#6.2x|", 2, 3, 0x123); break; 2121 CASE_TEST(hex_0_alt); EXPECT_VFPRINTF(1, "|0|0000| 00|", "|%#x|%#04x|%#5.2x|", 0, 0, 0); break; 2122 CASE_TEST(pointer); EXPECT_VFPRINTF(1, "0x1", "%p", (void *) 0x1); break; 2123 CASE_TEST(pointer_NULL); EXPECT_VFPRINTF(is_nolibc || is_glibc, "|(nil)|(nil)|", "|%p|%.4p|", (void *)0, (void *)0); break; 2124 CASE_TEST(string_NULL); EXPECT_VFPRINTF(is_nolibc || is_glibc, "|(null)||(null)|", "|%s|%.5s|%.6s|", (void *)0, (void *)0, (void *)0); break; 2125 CASE_TEST(percent); EXPECT_VFPRINTF(1, "a%d42%69%", "a%%d%d%%%d%%", 42, 69); break; 2126 CASE_TEST(perc_qual); EXPECT_VFPRINTF(is_nolibc || is_glibc, "a%d2", "a%-14l%d%d", 2); break; 2127 CASE_TEST(invalid); EXPECT_VFPRINTF(is_nolibc || is_glibc, "a%12yx3%y42%P", "a%12yx%d%y%d%P", 3, 42); break; 2128 CASE_TEST(intmax_max); EXPECT_VFPRINTF(1, "9223372036854775807", "%lld", ~0ULL >> 1); break; 2129 CASE_TEST(intmax_min); EXPECT_VFPRINTF(is_nolibc || is_glibc, "-9223372036854775808", "%Li", (~0ULL >> 1) + 1); break; 2130 CASE_TEST(uintmax_max); EXPECT_VFPRINTF(1, "18446744073709551615", "%ju", ~0ULL); break; 2131 CASE_TEST(truncation); EXPECT_VFPRINTF(1, "012345678901234567890123456789", "%s", "012345678901234567890123456789"); break; 2132 CASE_TEST(string_width); EXPECT_VFPRINTF(1, " 1", "%10s", "1"); break; 2133 CASE_TEST(string_trunc); EXPECT_VFPRINTF(1, " 12345", "%10.5s", "1234567890"); break; 2134 CASE_TEST(string_var); EXPECT_VFPRINTF(1, "| ab|ef | ij|kl |", "|%*.*s|%*.*s|%*.*s|%*.*s|", 3, 2, "abcd", -3, 2, "efgh", 3, -1, "ij", -3, -1, "kl"); break; 2135 CASE_TEST(number_width); EXPECT_VFPRINTF(1, " 1", "%10d", 1); break; 2136 CASE_TEST(number_left); EXPECT_VFPRINTF(1, "|-5 |", "|%-8d|", -5); break; 2137 CASE_TEST(string_align); EXPECT_VFPRINTF(1, "|foo |", "|%-8s|", "foo"); break; 2138 CASE_TEST(width_trunc); EXPECT_VFPRINTF(1, " 1", "%30d", 1); break; 2139 CASE_TEST(width_tr_lft); EXPECT_VFPRINTF(1, "1 ", "%-30d", 1); break; 2140 CASE_TEST(number_pad); EXPECT_VFPRINTF(1, "0000000005", "%010d", 5); break; 2141 CASE_TEST(number_pad); EXPECT_VFPRINTF(1, "|0000000005|0x1234|", "|%010d|%#01x|", 5, 0x1234); break; 2142 CASE_TEST(num_pad_neg); EXPECT_VFPRINTF(1, "-000000005", "%010d", -5); break; 2143 CASE_TEST(num_pad_hex); EXPECT_VFPRINTF(1, "00fffffffb", "%010x", -5); break; 2144 CASE_TEST(num_pad_trunc);EXPECT_VFPRINTF(is_nolibc, " 0000000000000000000000000000005", "%035d", 5); break; /* max 31 '0' can be added */ 2145 CASE_TEST(num_p_tr_libc);EXPECT_VFPRINTF(!is_nolibc, "00000000000000000000000000000000005", "%035d", 5); break; 2146 CASE_TEST(number_prec); EXPECT_VFPRINTF(1, " 00005", "%10.5d", 5); break; 2147 CASE_TEST(num_prec_neg); EXPECT_VFPRINTF(1, " -00005", "%10.5d", -5); break; 2148 CASE_TEST(number_var); EXPECT_VFPRINTF(1, "| -00005|5 |", "|%*.*d|%*.*d|", 10, 5, -5, -2, -10, 5); break; 2149 CASE_TEST(num_0_prec_0); EXPECT_VFPRINTF(1, "|| |+||||", "|%.0d|% .0d|%+.0d|%.0u|%.0x|%#.0x|", 0, 0, 0, 0, 0, 0); break; 2150 CASE_TEST(errno); errno = 22; EXPECT_VFPRINTF(is_nolibc, "errno=22", "%m"); break; 2151 CASE_TEST(errno-neg); errno = -22; EXPECT_VFPRINTF(is_nolibc, "errno=-22 ", "%-12m"); break; 2152 CASE_TEST(scanf); EXPECT_ZR(1, test_scanf()); break; 2153 CASE_TEST(printf_error); EXPECT_ZR(1, test_printf_error()); break; 2154 CASE_TEST(asprintf); EXPECT_ZR(1, test_asprintf()); break; 2155 case __LINE__: 2156 return ret; /* must be last */ 2157 /* note: do not set any defaults so as to permit holes above */ 2158 } 2159 } 2160 return ret; 2161 } 2162 2163 __attribute__((no_sanitize("undefined"))) 2164 static int smash_stack(void) 2165 { 2166 char buf[100]; 2167 volatile char *ptr = buf; 2168 size_t i; 2169 2170 for (i = 0; i < 200; i++) 2171 ptr[i] = 'P'; 2172 2173 return 1; 2174 } 2175 2176 static int run_protection(int min __attribute__((unused)), 2177 int max __attribute__((unused))) 2178 { 2179 pid_t pid; 2180 int llen = 0, status; 2181 struct rlimit rlimit = { 0, 0 }; 2182 2183 llen += printf("0 -fstackprotector "); 2184 2185 #if !defined(_NOLIBC_STACKPROTECTOR) 2186 llen += printf("not supported"); 2187 result(llen, SKIPPED); 2188 return 0; 2189 #endif 2190 2191 #if defined(_NOLIBC_STACKPROTECTOR) 2192 if (!__stack_chk_guard) { 2193 llen += printf("__stack_chk_guard not initialized"); 2194 result(llen, FAIL); 2195 return 1; 2196 } 2197 #endif 2198 2199 pid = -1; 2200 pid = fork(); 2201 2202 switch (pid) { 2203 case -1: 2204 llen += printf("fork()"); 2205 result(llen, FAIL); 2206 return 1; 2207 2208 case 0: 2209 close(STDOUT_FILENO); 2210 close(STDERR_FILENO); 2211 2212 prctl(PR_SET_DUMPABLE, 0, 0, 0, 0); 2213 setrlimit(RLIMIT_CORE, &rlimit); 2214 smash_stack(); 2215 return 1; 2216 2217 default: 2218 pid = waitpid(pid, &status, 0); 2219 2220 if (pid == -1 || !WIFSIGNALED(status) || WTERMSIG(status) != SIGABRT) { 2221 llen += printf("waitpid()"); 2222 result(llen, FAIL); 2223 return 1; 2224 } 2225 result(llen, OK); 2226 return 0; 2227 } 2228 } 2229 2230 /* prepare what needs to be prepared for pid 1 (stdio, /dev, /proc, etc) */ 2231 int prepare(void) 2232 { 2233 struct stat stat_buf; 2234 2235 /* It's possible that /dev doesn't even exist or was not mounted, so 2236 * we'll try to create it, mount it, or create minimal entries into it. 2237 * We want at least /dev/null and /dev/console. 2238 */ 2239 if (stat("/dev/.", &stat_buf) == 0 || mkdir("/dev", 0755) == 0) { 2240 if (stat("/dev/console", &stat_buf) != 0 || 2241 stat("/dev/null", &stat_buf) != 0 || 2242 stat("/dev/zero", &stat_buf) != 0 || 2243 stat("/dev/full", &stat_buf) != 0) { 2244 /* try devtmpfs first, otherwise fall back to manual creation */ 2245 if (mount("/dev", "/dev", "devtmpfs", 0, 0) != 0) { 2246 mknod("/dev/console", 0600 | S_IFCHR, makedev(5, 1)); 2247 mknod("/dev/null", 0666 | S_IFCHR, makedev(1, 3)); 2248 mknod("/dev/zero", 0666 | S_IFCHR, makedev(1, 5)); 2249 mknod("/dev/full", 0666 | S_IFCHR, makedev(1, 7)); 2250 } 2251 } 2252 } 2253 2254 /* If no /dev/console was found before calling init, stdio is closed so 2255 * we need to reopen it from /dev/console. If it failed above, it will 2256 * still fail here and we cannot emit a message anyway. 2257 */ 2258 if (close(dup(1)) == -1) { 2259 int fd = open("/dev/console", O_RDWR); 2260 2261 if (fd >= 0) { 2262 if (fd != 0) 2263 dup2(fd, 0); 2264 if (fd != 1) 2265 dup2(fd, 1); 2266 if (fd != 2) 2267 dup2(fd, 2); 2268 if (fd > 2) 2269 close(fd); 2270 puts("\nSuccessfully reopened /dev/console."); 2271 } 2272 } 2273 2274 /* try to mount /proc if not mounted. Silently fail otherwise */ 2275 if (stat("/proc/.", &stat_buf) == 0 || mkdir("/proc", 0755) == 0) { 2276 if (stat("/proc/self", &stat_buf) != 0) { 2277 /* If not mountable, remove /proc completely to avoid misuse */ 2278 if (mount("none", "/proc", "proc", 0, 0) != 0) 2279 rmdir("/proc"); 2280 } 2281 } 2282 2283 /* some tests rely on a writable /tmp */ 2284 mkdir("/tmp", 0755); 2285 2286 return 0; 2287 } 2288 2289 /* This is the definition of known test names, with their functions */ 2290 static const struct test test_names[] = { 2291 /* add new tests here */ 2292 { .name = "startup", .func = run_startup }, 2293 { .name = "syscall", .func = run_syscall }, 2294 { .name = "stdlib", .func = run_stdlib }, 2295 { .name = "printf", .func = run_printf }, 2296 { .name = "protection", .func = run_protection }, 2297 { 0 } 2298 }; 2299 2300 static int is_setting_valid(char *test) 2301 { 2302 int idx, len, test_len, valid = 0; 2303 char delimiter; 2304 2305 if (!test) 2306 return valid; 2307 2308 test_len = strlen(test); 2309 2310 for (idx = 0; test_names[idx].name; idx++) { 2311 len = strlen(test_names[idx].name); 2312 if (test_len < len) 2313 continue; 2314 2315 if (strncmp(test, test_names[idx].name, len) != 0) 2316 continue; 2317 2318 delimiter = test[len]; 2319 if (delimiter != ':' && delimiter != ',' && delimiter != '\0') 2320 continue; 2321 2322 valid = 1; 2323 break; 2324 } 2325 2326 return valid; 2327 } 2328 2329 int main(int argc, char **argv, char **envp) 2330 { 2331 int min = 0; 2332 int max = INT_MAX; 2333 int ret = 0; 2334 int err; 2335 int idx; 2336 char *test; 2337 2338 argv0 = argv[0]; 2339 test_argc = argc; 2340 test_argv = argv; 2341 test_envp = envp; 2342 2343 /* when called as init, it's possible that no console was opened, for 2344 * example if no /dev file system was provided. We'll check that fd#1 2345 * was opened, and if not we'll attempt to create and open /dev/console 2346 * and /dev/null that we'll use for later tests. 2347 */ 2348 if (getpid() == 1) 2349 prepare(); 2350 2351 /* the definition of a series of tests comes from either argv[1] or the 2352 * "NOLIBC_TEST" environment variable. It's made of a comma-delimited 2353 * series of test names and optional ranges: 2354 * syscall:5-15[:.*],stdlib:8-10 2355 */ 2356 test = argv[1]; 2357 if (!is_setting_valid(test)) 2358 test = getenv("NOLIBC_TEST"); 2359 2360 if (is_setting_valid(test)) { 2361 char *comma, *colon, *dash, *value; 2362 2363 do { 2364 comma = strchr(test, ','); 2365 if (comma) 2366 *(comma++) = '\0'; 2367 2368 colon = strchr(test, ':'); 2369 if (colon) 2370 *(colon++) = '\0'; 2371 2372 for (idx = 0; test_names[idx].name; idx++) { 2373 if (strcmp(test, test_names[idx].name) == 0) 2374 break; 2375 } 2376 2377 if (test_names[idx].name) { 2378 /* The test was named, it will be called at least 2379 * once. We may have an optional range at <colon> 2380 * here, which defaults to the full range. 2381 */ 2382 do { 2383 min = 0; max = INT_MAX; 2384 value = colon; 2385 if (value && *value) { 2386 colon = strchr(value, ':'); 2387 if (colon) 2388 *(colon++) = '\0'; 2389 2390 dash = strchr(value, '-'); 2391 if (dash) 2392 *(dash++) = '\0'; 2393 2394 /* support :val: :min-max: :min-: :-max: */ 2395 if (*value) 2396 min = atoi(value); 2397 if (!dash) 2398 max = min; 2399 else if (*dash) 2400 max = atoi(dash); 2401 2402 value = colon; 2403 } 2404 2405 /* now's time to call the test */ 2406 printf("Running test '%s'\n", test_names[idx].name); 2407 err = test_names[idx].func(min, max); 2408 ret += err; 2409 printf("Errors during this test: %d\n\n", err); 2410 } while (colon && *colon); 2411 } else 2412 printf("Ignoring unknown test name '%s'\n", test); 2413 2414 test = comma; 2415 } while (test && *test); 2416 } else { 2417 /* no test mentioned, run everything */ 2418 for (idx = 0; test_names[idx].name; idx++) { 2419 printf("Running test '%s'\n", test_names[idx].name); 2420 err = test_names[idx].func(min, max); 2421 ret += err; 2422 printf("Errors during this test: %d\n\n", err); 2423 } 2424 } 2425 2426 printf("Total number of errors: %d\n", ret); 2427 2428 if (getpid() == 1) { 2429 /* we're running as init, there's no other process on the 2430 * system, thus likely started from a VM for a quick check. 2431 * Exiting will provoke a kernel panic that may be reported 2432 * as an error by Qemu or the hypervisor, while stopping 2433 * cleanly will often be reported as a success. This allows 2434 * to use the output of this program for bisecting kernels. 2435 */ 2436 printf("Leaving init with final status: %d\n", !!ret); 2437 if (ret == 0) 2438 reboot(RB_POWER_OFF); 2439 #if defined(__x86_64__) 2440 /* QEMU started with "-device isa-debug-exit -no-reboot" will 2441 * exit with status code 2N+1 when N is written to 0x501. We 2442 * hard-code the syscall here as it's arch-dependent. 2443 */ 2444 else if (syscall(__NR_ioperm, 0x501, 1, 1) == 0) 2445 __asm__ volatile ("outb %%al, %%dx" :: "d"(0x501), "a"(0)); 2446 /* if it does nothing, fall back to the regular panic */ 2447 #endif 2448 } 2449 2450 printf("Exiting with status %d\n", !!ret); 2451 return !!ret; 2452 } 2453