Date: Sat, 20 Jun 2020 04:19:18 +0000 (UTC) From: Warner Losh <imp@FreeBSD.org> To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r362422 - head/sbin/dump Message-ID: <202006200419.05K4JIJ6029148@repo.freebsd.org>
next in thread | raw e-mail | index | archive | help
Author: imp Date: Sat Jun 20 04:19:17 2020 New Revision: 362422 URL: https://svnweb.freebsd.org/changeset/base/362422 Log: Increase the whimsy in this file by famring dump's work out to minions. Adjust variables accordingly. Thankfully, we are able to do this without additional banana expenditures. Modified: head/sbin/dump/tape.c Modified: head/sbin/dump/tape.c ============================================================================== --- head/sbin/dump/tape.c Sat Jun 20 04:07:58 2020 (r362421) +++ head/sbin/dump/tape.c Sat Jun 20 04:19:17 2020 (r362422) @@ -75,19 +75,19 @@ static char *nexttape; static FILE *popenfp = NULL; static int atomic(ssize_t (*)(), int, char *, int); -static void doslave(int, int); -static void enslave(void); +static void dominion(int, int); +static void enminion(void); static void flushtape(void); static void killall(void); static void rollforward(void); /* * Concurrent dump mods (Caltech) - disk block reading and tape writing - * are exported to several slave processes. While one slave writes the + * are exported to several minion processes. While one minion writes the * tape, the others read disk blocks; they pass control of the tape in * a ring via signals. The parent process traverses the file system and - * sends writeheader()'s and lists of daddr's to the slaves via pipes. - * The following structure defines the instruction packets sent to slaves. + * sends writeheader()'s and lists of daddr's to the minions via pipes. + * The following structure defines the instruction packets sent to minions. */ struct req { ufs2_daddr_t dblk; @@ -95,20 +95,20 @@ struct req { }; static int reqsiz; -#define SLAVES 3 /* 1 slave writing, 1 reading, 1 for slack */ -static struct slave { +#define MINIONS 3 /* 1 minion writing, 1 reading, 1 for slack */ +static struct minion { int64_t tapea; /* header number at start of this chunk */ int64_t firstrec; /* record number of this block */ int count; /* count to next header (used for TS_TAPE */ /* after EOT) */ int inode; /* inode that we are currently dealing with */ - int fd; /* FD for this slave */ - int pid; /* PID for this slave */ - int sent; /* 1 == we've sent this slave requests */ + int fd; /* FD for this minion */ + int pid; /* PID for this minion */ + int sent; /* 1 == we've sent this minion requests */ char (*tblock)[TP_BSIZE]; /* buffer for data blocks */ struct req *req; /* buffer for requests */ -} slaves[SLAVES+1]; -static struct slave *slp; +} minions[MINIONS+1]; +static struct minion *mlp; static char (*nextblock)[TP_BSIZE]; @@ -116,9 +116,9 @@ static int master; /* pid of master, for sending error static int tenths; /* length of tape used per block written */ static volatile sig_atomic_t caught; /* have we caught the signal to proceed? */ static volatile sig_atomic_t ready; /* reached the lock point without having */ - /* received the SIGUSR2 signal from the prev slave? */ + /* received the SIGUSR2 signal from the prev minion? */ static jmp_buf jmpbuf; /* where to jump to if we are ready when the */ - /* SIGUSR2 arrives from the previous slave */ + /* SIGUSR2 arrives from the previous minion */ int alloctape(void) @@ -143,20 +143,20 @@ alloctape(void) * packets, so flushtape() can write them together with one write(). * Align tape buffer on page boundary to speed up tape write(). */ - for (i = 0; i <= SLAVES; i++) { + for (i = 0; i <= MINIONS; i++) { buf = (char *) malloc((unsigned)(reqsiz + writesize + pgoff + TP_BSIZE)); if (buf == NULL) return(0); - slaves[i].tblock = (char (*)[TP_BSIZE]) + minions[i].tblock = (char (*)[TP_BSIZE]) (((long)&buf[ntrec + 1] + pgoff) &~ pgoff); - slaves[i].req = (struct req *)slaves[i].tblock - ntrec - 1; + minions[i].req = (struct req *)minions[i].tblock - ntrec - 1; } - slp = &slaves[0]; - slp->count = 1; - slp->tapea = 0; - slp->firstrec = 0; - nextblock = slp->tblock; + mlp = &minions[0]; + mlp->count = 1; + mlp->tapea = 0; + mlp->firstrec = 0; + nextblock = mlp->tblock; return(1); } @@ -164,8 +164,8 @@ void writerec(char *dp, int isspcl) { - slp->req[trecno].dblk = (ufs2_daddr_t)0; - slp->req[trecno].count = 1; + mlp->req[trecno].dblk = (ufs2_daddr_t)0; + mlp->req[trecno].count = 1; /* Can't do a structure assignment due to alignment problems */ bcopy(dp, *(nextblock)++, sizeof (union u_spcl)); if (isspcl) @@ -185,8 +185,8 @@ dumpblock(ufs2_daddr_t blkno, int size) dblkno = fsbtodb(sblock, blkno); tpblks = size >> tp_bshift; while ((avail = MIN(tpblks, ntrec - trecno)) > 0) { - slp->req[trecno].dblk = dblkno; - slp->req[trecno].count = avail; + mlp->req[trecno].dblk = dblkno; + mlp->req[trecno].count = avail; trecno += avail; spcl.c_tapea += avail; if (trecno >= ntrec) @@ -232,27 +232,27 @@ flushtape(void) int i, blks, got; int64_t lastfirstrec; - int siz = (char *)nextblock - (char *)slp->req; + int siz = (char *)nextblock - (char *)mlp->req; - slp->req[trecno].count = 0; /* Sentinel */ + mlp->req[trecno].count = 0; /* Sentinel */ - if (atomic(write, slp->fd, (char *)slp->req, siz) != siz) + if (atomic(write, mlp->fd, (char *)mlp->req, siz) != siz) quit("error writing command pipe: %s\n", strerror(errno)); - slp->sent = 1; /* we sent a request, read the response later */ + mlp->sent = 1; /* we sent a request, read the response later */ - lastfirstrec = slp->firstrec; + lastfirstrec = mlp->firstrec; - if (++slp >= &slaves[SLAVES]) - slp = &slaves[0]; + if (++mlp >= &minions[MINIONS]) + mlp = &minions[0]; - /* Read results back from next slave */ - if (slp->sent) { - if (atomic(read, slp->fd, (char *)&got, sizeof got) + /* Read results back from next minion */ + if (mlp->sent) { + if (atomic(read, mlp->fd, (char *)&got, sizeof got) != sizeof got) { perror(" DUMP: error reading command pipe in master"); dumpabort(0); } - slp->sent = 0; + mlp->sent = 0; /* Check for end of tape */ if (got < writesize) { @@ -262,15 +262,15 @@ flushtape(void) * Drain the results, don't care what the values were. * If we read them here then trewind won't... */ - for (i = 0; i < SLAVES; i++) { - if (slaves[i].sent) { - if (atomic(read, slaves[i].fd, + for (i = 0; i < MINIONS; i++) { + if (minions[i].sent) { + if (atomic(read, minions[i].fd, (char *)&got, sizeof got) != sizeof got) { perror(" DUMP: error reading command pipe in master"); dumpabort(0); } - slaves[i].sent = 0; + minions[i].sent = 0; } } @@ -288,11 +288,11 @@ flushtape(void) if (spcl.c_addr[i] != 0) blks++; } - slp->count = lastspclrec + blks + 1 - spcl.c_tapea; - slp->tapea = spcl.c_tapea; - slp->firstrec = lastfirstrec + ntrec; - slp->inode = curino; - nextblock = slp->tblock; + mlp->count = lastspclrec + blks + 1 - spcl.c_tapea; + mlp->tapea = spcl.c_tapea; + mlp->firstrec = lastfirstrec + ntrec; + mlp->inode = curino; + nextblock = mlp->tblock; trecno = 0; asize += tenths; blockswritten += ntrec; @@ -312,7 +312,7 @@ trewind(void) int f; int got; - for (f = 0; f < SLAVES; f++) { + for (f = 0; f < MINIONS; f++) { /* * Drain the results, but unlike EOT we DO (or should) care * what the return values were, since if we detect EOT after @@ -321,22 +321,22 @@ trewind(void) * * fixme: punt for now. */ - if (slaves[f].sent) { - if (atomic(read, slaves[f].fd, (char *)&got, sizeof got) + if (minions[f].sent) { + if (atomic(read, minions[f].fd, (char *)&got, sizeof got) != sizeof got) { perror(" DUMP: error reading command pipe in master"); dumpabort(0); } - slaves[f].sent = 0; + minions[f].sent = 0; if (got != writesize) { msg("EOT detected in last 2 tape records!\n"); msg("Use a longer tape, decrease the size estimate\n"); quit("or use no size estimate at all.\n"); } } - (void) close(slaves[f].fd); + (void) close(minions[f].fd); } - while (wait((int *)NULL) >= 0) /* wait for any signals from slaves */ + while (wait((int *)NULL) >= 0) /* wait for any signals from minions */ /* void */; if (pipeout) @@ -396,29 +396,29 @@ void rollforward(void) { struct req *p, *q, *prev; - struct slave *tslp; + struct minion *tmlp; int i, size, got; int64_t savedtapea; union u_spcl *ntb, *otb; - tslp = &slaves[SLAVES]; - ntb = (union u_spcl *)tslp->tblock[1]; + tmlp = &minions[MINIONS]; + ntb = (union u_spcl *)tmlp->tblock[1]; /* - * Each of the N slaves should have requests that need to - * be replayed on the next tape. Use the extra slave buffers - * (slaves[SLAVES]) to construct request lists to be sent to - * each slave in turn. + * Each of the N minions should have requests that need to + * be replayed on the next tape. Use the extra minion buffers + * (minions[MINIONS]) to construct request lists to be sent to + * each minion in turn. */ - for (i = 0; i < SLAVES; i++) { - q = &tslp->req[1]; - otb = (union u_spcl *)slp->tblock; + for (i = 0; i < MINIONS; i++) { + q = &tmlp->req[1]; + otb = (union u_spcl *)mlp->tblock; /* - * For each request in the current slave, copy it to tslp. + * For each request in the current minion, copy it to tmlp. */ prev = NULL; - for (p = slp->req; p->count > 0; p += p->count) { + for (p = mlp->req; p->count > 0; p += p->count) { *q = *p; if (p->dblk == 0) *ntb++ = *otb++; /* copy the datablock also */ @@ -433,26 +433,26 @@ rollforward(void) ntb--; q -= 1; q->count = 0; - q = &tslp->req[0]; + q = &tmlp->req[0]; if (i == 0) { q->dblk = 0; q->count = 1; trecno = 0; - nextblock = tslp->tblock; + nextblock = tmlp->tblock; savedtapea = spcl.c_tapea; - spcl.c_tapea = slp->tapea; + spcl.c_tapea = mlp->tapea; startnewtape(0); spcl.c_tapea = savedtapea; lastspclrec = savedtapea - 1; } size = (char *)ntb - (char *)q; - if (atomic(write, slp->fd, (char *)q, size) != size) { + if (atomic(write, mlp->fd, (char *)q, size) != size) { perror(" DUMP: error writing command pipe"); dumpabort(0); } - slp->sent = 1; - if (++slp >= &slaves[SLAVES]) - slp = &slaves[0]; + mlp->sent = 1; + if (++mlp >= &minions[MINIONS]) + mlp = &minions[0]; q->count = 1; @@ -464,34 +464,34 @@ rollforward(void) */ q->dblk = prev->dblk + prev->count * (TP_BSIZE / DEV_BSIZE); - ntb = (union u_spcl *)tslp->tblock; + ntb = (union u_spcl *)tmlp->tblock; } else { /* * It wasn't a disk block. Copy the data to its * new location in the buffer. */ q->dblk = 0; - *((union u_spcl *)tslp->tblock) = *ntb; - ntb = (union u_spcl *)tslp->tblock[1]; + *((union u_spcl *)tmlp->tblock) = *ntb; + ntb = (union u_spcl *)tmlp->tblock[1]; } } - slp->req[0] = *q; - nextblock = slp->tblock; + mlp->req[0] = *q; + nextblock = mlp->tblock; if (q->dblk == 0) nextblock++; trecno = 1; /* - * Clear the first slaves' response. One hopes that it + * Clear the first minions' response. One hopes that it * worked ok, otherwise the tape is much too short! */ - if (slp->sent) { - if (atomic(read, slp->fd, (char *)&got, sizeof got) + if (mlp->sent) { + if (atomic(read, mlp->fd, (char *)&got, sizeof got) != sizeof got) { perror(" DUMP: error reading command pipe in master"); dumpabort(0); } - slp->sent = 0; + mlp->sent = 0; if (got != writesize) { quit("EOT detected at start of the tape!\n"); @@ -634,7 +634,7 @@ restore_check_point: } } - enslave(); /* Share open tape file descriptor with slaves */ + enminion(); /* Share open tape file descriptor with minions */ if (popenout) close(tapefd); /* Give up our copy of it. */ signal(SIGINFO, infosch); @@ -643,18 +643,18 @@ restore_check_point: blocksthisvol = 0; if (top) newtape++; /* new tape signal */ - spcl.c_count = slp->count; + spcl.c_count = mlp->count; /* * measure firstrec in TP_BSIZE units since restore doesn't * know the correct ntrec value... */ - spcl.c_firstrec = slp->firstrec; + spcl.c_firstrec = mlp->firstrec; spcl.c_volume++; spcl.c_type = TS_TAPE; - writeheader((ino_t)slp->inode); + writeheader((ino_t)mlp->inode); if (tapeno > 1) msg("Volume %d begins with blocks from inode %d\n", - tapeno, slp->inode); + tapeno, mlp->inode); } } @@ -687,7 +687,7 @@ Exit(status) } /* - * proceed - handler for SIGUSR2, used to synchronize IO between the slaves. + * proceed - handler for SIGUSR2, used to synchronize IO between the minions. */ void proceed(int signo __unused) @@ -699,45 +699,45 @@ proceed(int signo __unused) } void -enslave(void) +enminion(void) { int cmd[2]; int i, j; master = getpid(); - signal(SIGTERM, dumpabort); /* Slave sends SIGTERM on dumpabort() */ + signal(SIGTERM, dumpabort); /* Minion sends SIGTERM on dumpabort() */ signal(SIGPIPE, sigpipe); - signal(SIGUSR1, tperror); /* Slave sends SIGUSR1 on tape errors */ - signal(SIGUSR2, proceed); /* Slave sends SIGUSR2 to next slave */ + signal(SIGUSR1, tperror); /* Minion sends SIGUSR1 on tape errors */ + signal(SIGUSR2, proceed); /* Minion sends SIGUSR2 to next minion */ - for (i = 0; i < SLAVES; i++) { - if (i == slp - &slaves[0]) { + for (i = 0; i < MINIONS; i++) { + if (i == mlp - &minions[0]) { caught = 1; } else { caught = 0; } if (socketpair(AF_UNIX, SOCK_STREAM, 0, cmd) < 0 || - (slaves[i].pid = fork()) < 0) - quit("too many slaves, %d (recompile smaller): %s\n", + (minions[i].pid = fork()) < 0) + quit("too many minions, %d (recompile smaller): %s\n", i, strerror(errno)); - slaves[i].fd = cmd[1]; - slaves[i].sent = 0; - if (slaves[i].pid == 0) { /* Slave starts up here */ + minions[i].fd = cmd[1]; + minions[i].sent = 0; + if (minions[i].pid == 0) { /* Minion starts up here */ for (j = 0; j <= i; j++) - (void) close(slaves[j].fd); + (void) close(minions[j].fd); signal(SIGINT, SIG_IGN); /* Master handles this */ - doslave(cmd[0], i); + dominion(cmd[0], i); Exit(X_FINOK); } } - for (i = 0; i < SLAVES; i++) - (void) atomic(write, slaves[i].fd, - (char *) &slaves[(i + 1) % SLAVES].pid, - sizeof slaves[0].pid); + for (i = 0; i < MINIONS; i++) + (void) atomic(write, minions[i].fd, + (char *) &minions[(i + 1) % MINIONS].pid, + sizeof minions[0].pid); master = 0; } @@ -747,10 +747,10 @@ killall(void) { int i; - for (i = 0; i < SLAVES; i++) - if (slaves[i].pid > 0) { - (void) kill(slaves[i].pid, SIGKILL); - slaves[i].sent = 0; + for (i = 0; i < MINIONS; i++) + if (minions[i].pid > 0) { + (void) kill(minions[i].pid, SIGKILL); + minions[i].sent = 0; } } @@ -762,42 +762,42 @@ killall(void) * get the lock back for the next cycle by swapping descriptors. */ static void -doslave(int cmd, int slave_number) +dominion(int cmd, int minion_number) { int nread; - int nextslave, size, wrote, eot_count; + int nextminion, size, wrote, eot_count; /* * Need our own seek pointer. */ (void) close(diskfd); if ((diskfd = open(disk, O_RDONLY)) < 0) - quit("slave couldn't reopen disk: %s\n", strerror(errno)); + quit("minion couldn't reopen disk: %s\n", strerror(errno)); /* - * Need the pid of the next slave in the loop... + * Need the pid of the next minion in the loop... */ - if ((nread = atomic(read, cmd, (char *)&nextslave, sizeof nextslave)) - != sizeof nextslave) { - quit("master/slave protocol botched - didn't get pid of next slave.\n"); + if ((nread = atomic(read, cmd, (char *)&nextminion, sizeof nextminion)) + != sizeof nextminion) { + quit("master/minion protocol botched - didn't get pid of next minion.\n"); } /* * Get list of blocks to dump, read the blocks into tape buffer */ - while ((nread = atomic(read, cmd, (char *)slp->req, reqsiz)) == reqsiz) { - struct req *p = slp->req; + while ((nread = atomic(read, cmd, (char *)mlp->req, reqsiz)) == reqsiz) { + struct req *p = mlp->req; for (trecno = 0; trecno < ntrec; trecno += p->count, p += p->count) { if (p->dblk) { - blkread(p->dblk, slp->tblock[trecno], + blkread(p->dblk, mlp->tblock[trecno], p->count * TP_BSIZE); } else { if (p->count != 1 || atomic(read, cmd, - (char *)slp->tblock[trecno], + (char *)mlp->tblock[trecno], TP_BSIZE) != TP_BSIZE) - quit("master/slave protocol botched.\n"); + quit("master/minion protocol botched.\n"); } } if (setjmp(jmpbuf) == 0) { @@ -816,14 +816,14 @@ doslave(int cmd, int slave_number) while (eot_count < 10 && size < writesize) { #ifdef RDUMP if (host) - wrote = rmtwrite(slp->tblock[0]+size, + wrote = rmtwrite(mlp->tblock[0]+size, writesize-size); else #endif - wrote = write(tapefd, slp->tblock[0]+size, + wrote = write(tapefd, mlp->tblock[0]+size, writesize-size); #ifdef WRITEDEBUG - printf("slave %d wrote %d\n", slave_number, wrote); + printf("minion %d wrote %d\n", minion_number, wrote); #endif if (wrote < 0) break; @@ -834,8 +834,8 @@ doslave(int cmd, int slave_number) #ifdef WRITEDEBUG if (size != writesize) - printf("slave %d only wrote %d out of %d bytes and gave up.\n", - slave_number, size, writesize); + printf("minion %d only wrote %d out of %d bytes and gave up.\n", + minion_number, size, writesize); #endif /* @@ -862,10 +862,10 @@ doslave(int cmd, int slave_number) } /* - * If partial write, don't want next slave to go. + * If partial write, don't want next minion to go. * Also jolts him awake. */ - (void) kill(nextslave, SIGUSR2); + (void) kill(nextminion, SIGUSR2); } if (nread != 0) quit("error reading command pipe: %s\n", strerror(errno));
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?202006200419.05K4JIJ6029148>