1*9b9d2a55Sguenther /* $OpenBSD: getbsize.c,v 1.11 2015/08/31 02:53:57 guenther Exp $ */
2df930be7Sderaadt /*-
3df930be7Sderaadt * Copyright (c) 1991, 1993
4df930be7Sderaadt * The Regents of the University of California. All rights reserved.
5df930be7Sderaadt *
6df930be7Sderaadt * Redistribution and use in source and binary forms, with or without
7df930be7Sderaadt * modification, are permitted provided that the following conditions
8df930be7Sderaadt * are met:
9df930be7Sderaadt * 1. Redistributions of source code must retain the above copyright
10df930be7Sderaadt * notice, this list of conditions and the following disclaimer.
11df930be7Sderaadt * 2. Redistributions in binary form must reproduce the above copyright
12df930be7Sderaadt * notice, this list of conditions and the following disclaimer in the
13df930be7Sderaadt * documentation and/or other materials provided with the distribution.
146580fee3Smillert * 3. Neither the name of the University nor the names of its contributors
15df930be7Sderaadt * may be used to endorse or promote products derived from this software
16df930be7Sderaadt * without specific prior written permission.
17df930be7Sderaadt *
18df930be7Sderaadt * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
19df930be7Sderaadt * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20df930be7Sderaadt * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21df930be7Sderaadt * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
22df930be7Sderaadt * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
23df930be7Sderaadt * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
24df930be7Sderaadt * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25df930be7Sderaadt * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
26df930be7Sderaadt * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
27df930be7Sderaadt * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
28df930be7Sderaadt * SUCH DAMAGE.
29df930be7Sderaadt */
30df930be7Sderaadt
31df930be7Sderaadt #include <err.h>
32df930be7Sderaadt #include <stdio.h>
33df930be7Sderaadt #include <stdlib.h>
34df930be7Sderaadt #include <string.h>
35df930be7Sderaadt
36df930be7Sderaadt char *
getbsize(int * headerlenp,long * blocksizep)37f723aa39Sderaadt getbsize(int *headerlenp, long *blocksizep)
38df930be7Sderaadt {
39df930be7Sderaadt static char header[20];
40df930be7Sderaadt long n, max, mul, blocksize;
41df930be7Sderaadt char *ep, *p, *form;
42df930be7Sderaadt
43fa4719eaSmillert #define KB (1024)
44fa4719eaSmillert #define MB (1024 * 1024)
45fa4719eaSmillert #define GB (1024 * 1024 * 1024)
46df930be7Sderaadt #define MAXB GB /* No tera, peta, nor exa. */
47df930be7Sderaadt form = "";
48df930be7Sderaadt if ((p = getenv("BLOCKSIZE")) != NULL && *p != '\0') {
49df930be7Sderaadt if ((n = strtol(p, &ep, 10)) < 0)
50df930be7Sderaadt goto underflow;
51df930be7Sderaadt if (n == 0)
52df930be7Sderaadt n = 1;
53df930be7Sderaadt if (*ep && ep[1])
54df930be7Sderaadt goto fmterr;
55df930be7Sderaadt switch (*ep) {
56df930be7Sderaadt case 'G': case 'g':
57df930be7Sderaadt form = "G";
58df930be7Sderaadt max = MAXB / GB;
59df930be7Sderaadt mul = GB;
60df930be7Sderaadt break;
61df930be7Sderaadt case 'K': case 'k':
62df930be7Sderaadt form = "K";
63df930be7Sderaadt max = MAXB / KB;
64df930be7Sderaadt mul = KB;
65df930be7Sderaadt break;
66df930be7Sderaadt case 'M': case 'm':
67df930be7Sderaadt form = "M";
68df930be7Sderaadt max = MAXB / MB;
69df930be7Sderaadt mul = MB;
70df930be7Sderaadt break;
71df930be7Sderaadt case '\0':
72df930be7Sderaadt max = MAXB;
73df930be7Sderaadt mul = 1;
74df930be7Sderaadt break;
75df930be7Sderaadt default:
76*9b9d2a55Sguenther fmterr: warnx("%s: unknown blocksize", p);
77df930be7Sderaadt n = 512;
78b0f29dd7Smillert max = MAXB;
79df930be7Sderaadt mul = 1;
80df930be7Sderaadt break;
81df930be7Sderaadt }
82df930be7Sderaadt if (n > max) {
83*9b9d2a55Sguenther warnx("maximum blocksize is %dG", MAXB / GB);
84df930be7Sderaadt n = max;
85df930be7Sderaadt }
86df930be7Sderaadt if ((blocksize = n * mul) < 512) {
87*9b9d2a55Sguenther underflow: warnx("%s: minimum blocksize is 512", p);
88df930be7Sderaadt form = "";
89df930be7Sderaadt blocksize = n = 512;
90df930be7Sderaadt }
91df930be7Sderaadt } else
92df930be7Sderaadt blocksize = n = 512;
93df930be7Sderaadt
94b0f29dd7Smillert *headerlenp = snprintf(header, sizeof(header), "%ld%s-blocks", n, form);
950c24db81Sderaadt if (*headerlenp < 0)
960c24db81Sderaadt *headerlenp = 0;
970c24db81Sderaadt else if (*headerlenp >= sizeof(header))
9857d1eca6Smillert *headerlenp = sizeof(header) - 1;
99df930be7Sderaadt *blocksizep = blocksize;
100df930be7Sderaadt return (header);
101df930be7Sderaadt }
102