/*- * Copyright (c) 2008 Peter Holm * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * */ #include #include #include #include #include #include #include #include #include #include "stress.h" static char path[128]; static unsigned long size; int setup(int nb) { int64_t in; int64_t bl; int64_t reserve_in; int64_t reserve_bl; int pct; umask(0); if (nb == 0) { getdf(&bl, &in); size = in / op->incarnations; pct = 90; if (op->hog == 0) pct = random_int(1, 90); size = size / 100 * pct + 1; if (size > 16000) size = 16000; /* arbitrary limit number of files pr. dir */ /* Resource requirements: */ while (size > 0) { reserve_in = 1 * size * op->incarnations + op->incarnations; reserve_bl = 26 * size * op->incarnations; if (reserve_bl <= bl && reserve_in <= in) break; size = size / 2; } if (size == 0) reserve_bl = reserve_in = 0; if (op->verbose > 1) printf("symlink(size=%lu, incarnations=%d). Free(%jdk, %jd), reserve(%jdk, %jd)\n", size, op->incarnations, bl/1024, in, reserve_bl/1024, reserve_in); reservedf(reserve_bl, reserve_in); putval(size); } else { size = getval(); } if (size == 0) exit(0); sprintf(path,"%s.%05d", getprogname(), getpid()); if (mkdir(path, 0770) < 0) err(1, "mkdir(%s), %s:%d", path, __FILE__, __LINE__); if (chdir(path) == -1) err(1, "chdir(%s), %s:%d", path, __FILE__, __LINE__); return (0); } void cleanup(void) { if (path[0] != 0) { (void)chdir(".."); if (rmdir(path) == -1) { warn("rmdir(%s), %s:%d", path, __FILE__, __LINE__); } } } int test(void) { pid_t pid; int i, j, error = 0; char file[128]; pid = getpid(); for (j = 0; j < (int)size && done_testing == 0; j++) { sprintf(file,"p%05d.%05d", pid, j); if (symlink("/tmp/not/there", file) == -1) { if (errno != EINTR) { warn("symlink(%s). %s.%d", file, __FILE__, __LINE__); error = 1; exit(1); break; } } } for (i = --j; i >= 0; i--) { sprintf(file,"p%05d.%05d", pid, i); if (unlink(file) == -1) err(3, "unlink(%s)", file); } if (error != 0) exit(1); return (0); }