xref: /illumos-gate/usr/src/cmd/dd/dd.c (revision 4cddff70)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
57c478bd9Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
67c478bd9Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
77c478bd9Sstevel@tonic-gate  * with the License.
87c478bd9Sstevel@tonic-gate  *
97c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
107c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
117c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
127c478bd9Sstevel@tonic-gate  * and limitations under the License.
137c478bd9Sstevel@tonic-gate  *
147c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
157c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
167c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
177c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
187c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
197c478bd9Sstevel@tonic-gate  *
207c478bd9Sstevel@tonic-gate  * CDDL HEADER END
217c478bd9Sstevel@tonic-gate  */
227c478bd9Sstevel@tonic-gate 
237c478bd9Sstevel@tonic-gate /*
24a77d64afScf  * Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
257c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
26*4cddff70SJosef 'Jeff' Sipek  * Copyright 2012, Josef 'Jeff' Sipek <jeffpc@31bits.net>. All rights reserved.
277c478bd9Sstevel@tonic-gate  */
287c478bd9Sstevel@tonic-gate 
29a77d64afScf /*	Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T	*/
30a77d64afScf /*	  All Rights Reserved  	*/
31a77d64afScf 
327c478bd9Sstevel@tonic-gate /*
337c478bd9Sstevel@tonic-gate  *	convert and copy
347c478bd9Sstevel@tonic-gate  */
357c478bd9Sstevel@tonic-gate 
367c478bd9Sstevel@tonic-gate #include	<stdio.h>
377c478bd9Sstevel@tonic-gate #include	<signal.h>
387c478bd9Sstevel@tonic-gate #include	<fcntl.h>
397c478bd9Sstevel@tonic-gate #include	<sys/param.h>
407c478bd9Sstevel@tonic-gate #include	<sys/types.h>
417c478bd9Sstevel@tonic-gate #include	<sys/sysmacros.h>
427c478bd9Sstevel@tonic-gate #include	<sys/stat.h>
437c478bd9Sstevel@tonic-gate #include	<unistd.h>
447c478bd9Sstevel@tonic-gate #include	<stdlib.h>
457c478bd9Sstevel@tonic-gate #include	<locale.h>
467c478bd9Sstevel@tonic-gate #include	<string.h>
477c478bd9Sstevel@tonic-gate 
487c478bd9Sstevel@tonic-gate /* The BIG parameter is machine dependent.  It should be a long integer	*/
497c478bd9Sstevel@tonic-gate /* constant that can be used by the number parser to check the validity	*/
507c478bd9Sstevel@tonic-gate /* of numeric parameters.  On 16-bit machines, it should probably be	*/
517c478bd9Sstevel@tonic-gate /* the maximum unsigned integer, 0177777L.  On 32-bit machines where	*/
527c478bd9Sstevel@tonic-gate /* longs are the same size as ints, the maximum signed integer is more	*/
537c478bd9Sstevel@tonic-gate /* appropriate.  This value is 017777777777L. In 64 bit environments,   */
547c478bd9Sstevel@tonic-gate /* the maximum signed integer value is 0777777777777777777777LL		*/
557c478bd9Sstevel@tonic-gate 
567c478bd9Sstevel@tonic-gate #define	BIG	0777777777777777777777LL
577c478bd9Sstevel@tonic-gate 
587c478bd9Sstevel@tonic-gate #define	BSIZE	512
597c478bd9Sstevel@tonic-gate 
607c478bd9Sstevel@tonic-gate /* Option parameters */
617c478bd9Sstevel@tonic-gate 
627c478bd9Sstevel@tonic-gate #define	COPY		0	/* file copy, preserve input block size */
637c478bd9Sstevel@tonic-gate #define	REBLOCK		1	/* file copy, change block size */
647c478bd9Sstevel@tonic-gate #define	LCREBLOCK	2	/* file copy, convert to lower case */
657c478bd9Sstevel@tonic-gate #define	UCREBLOCK	3	/* file copy, convert to upper case */
667c478bd9Sstevel@tonic-gate #define	NBASCII		4	/* file copy, convert from EBCDIC to ASCII */
677c478bd9Sstevel@tonic-gate #define	LCNBASCII	5	/* file copy, EBCDIC to lower case ASCII */
687c478bd9Sstevel@tonic-gate #define	UCNBASCII	6	/* file copy, EBCDIC to upper case ASCII */
697c478bd9Sstevel@tonic-gate #define	NBEBCDIC	7	/* file copy, convert from ASCII to EBCDIC */
707c478bd9Sstevel@tonic-gate #define	LCNBEBCDIC	8	/* file copy, ASCII to lower case EBCDIC */
717c478bd9Sstevel@tonic-gate #define	UCNBEBCDIC	9	/* file copy, ASCII to upper case EBCDIC */
727c478bd9Sstevel@tonic-gate #define	NBIBM		10	/* file copy, convert from ASCII to IBM */
737c478bd9Sstevel@tonic-gate #define	LCNBIBM		11	/* file copy, ASCII to lower case IBM */
747c478bd9Sstevel@tonic-gate #define	UCNBIBM		12	/* file copy, ASCII to upper case IBM */
757c478bd9Sstevel@tonic-gate #define	UNBLOCK		13	/* convert blocked ASCII to ASCII */
767c478bd9Sstevel@tonic-gate #define	LCUNBLOCK	14	/* convert blocked ASCII to lower case ASCII */
777c478bd9Sstevel@tonic-gate #define	UCUNBLOCK	15	/* convert blocked ASCII to upper case ASCII */
787c478bd9Sstevel@tonic-gate #define	ASCII		16	/* convert blocked EBCDIC to ASCII */
797c478bd9Sstevel@tonic-gate #define	LCASCII		17	/* convert blocked EBCDIC to lower case ASCII */
807c478bd9Sstevel@tonic-gate #define	UCASCII		18	/* convert blocked EBCDIC to upper case ASCII */
817c478bd9Sstevel@tonic-gate #define	BLOCK		19	/* convert ASCII to blocked ASCII */
827c478bd9Sstevel@tonic-gate #define	LCBLOCK		20	/* convert ASCII to lower case blocked ASCII */
837c478bd9Sstevel@tonic-gate #define	UCBLOCK		21	/* convert ASCII to upper case blocked ASCII */
847c478bd9Sstevel@tonic-gate #define	EBCDIC		22	/* convert ASCII to blocked EBCDIC */
857c478bd9Sstevel@tonic-gate #define	LCEBCDIC	23	/* convert ASCII to lower case blocked EBCDIC */
867c478bd9Sstevel@tonic-gate #define	UCEBCDIC	24	/* convert ASCII to upper case blocked EBCDIC */
877c478bd9Sstevel@tonic-gate #define	IBM		25	/* convert ASCII to blocked IBM */
887c478bd9Sstevel@tonic-gate #define	LCIBM		26	/* convert ASCII to lower case blocked IBM */
897c478bd9Sstevel@tonic-gate #define	UCIBM		27	/* convert ASCII to upper case blocked IBM */
907c478bd9Sstevel@tonic-gate #define	LCASE		01	/* flag - convert to lower case */
917c478bd9Sstevel@tonic-gate #define	UCASE		02	/* flag - convert to upper case */
927c478bd9Sstevel@tonic-gate #define	SWAB		04	/* flag - swap bytes before conversion */
937c478bd9Sstevel@tonic-gate #define	NERR		010	/* flag - proceed on input errors */
947c478bd9Sstevel@tonic-gate #define	SYNC		020	/* flag - pad short input blocks with nulls */
957c478bd9Sstevel@tonic-gate #define	BADLIMIT	5	/* give up if no progress after BADLIMIT trys */
967c478bd9Sstevel@tonic-gate #define	SVR4XLATE	0	/* use default EBCDIC translation */
977c478bd9Sstevel@tonic-gate #define	BSDXLATE	1	/* use BSD-compatible EBCDIC translation */
987c478bd9Sstevel@tonic-gate 
997c478bd9Sstevel@tonic-gate #define	USAGE\
1007c478bd9Sstevel@tonic-gate 	"usage: dd [if=file] [of=file] [ibs=n|nk|nb|nxm] [obs=n|nk|nb|nxm]\n"\
1017c478bd9Sstevel@tonic-gate 	"	   [bs=n|nk|nb|nxm] [cbs=n|nk|nb|nxm] [files=n] [skip=n]\n"\
1027c478bd9Sstevel@tonic-gate 	"	   [iseek=n] [oseek=n] [seek=n] [count=n] [conv=[ascii]\n"\
1037c478bd9Sstevel@tonic-gate 	"	   [,ebcdic][,ibm][,asciib][,ebcdicb][,ibmb]\n"\
1047c478bd9Sstevel@tonic-gate 	"	   [,block|unblock][,lcase|ucase][,swab]\n"\
1057c478bd9Sstevel@tonic-gate 	"	   [,noerror][,notrunc][,sync]]\n"
1067c478bd9Sstevel@tonic-gate 
1077c478bd9Sstevel@tonic-gate /* Global references */
1087c478bd9Sstevel@tonic-gate 
1097c478bd9Sstevel@tonic-gate /* Local routine declarations */
1107c478bd9Sstevel@tonic-gate 
1117c478bd9Sstevel@tonic-gate static int	match(char *);
1127c478bd9Sstevel@tonic-gate static void		term();
1137c478bd9Sstevel@tonic-gate static unsigned long long	number();
1147c478bd9Sstevel@tonic-gate static unsigned char	*flsh();
1157c478bd9Sstevel@tonic-gate static void		stats();
1167c478bd9Sstevel@tonic-gate 
1177c478bd9Sstevel@tonic-gate /* Local data definitions */
1187c478bd9Sstevel@tonic-gate 
1197c478bd9Sstevel@tonic-gate static unsigned ibs;	/* input buffer size */
1207c478bd9Sstevel@tonic-gate static unsigned obs;	/* output buffer size */
1217c478bd9Sstevel@tonic-gate static unsigned bs;	/* buffer size, overrules ibs and obs */
1227c478bd9Sstevel@tonic-gate static unsigned cbs;	/* conversion buffer size, used for block conversions */
1237c478bd9Sstevel@tonic-gate static unsigned ibc;	/* number of bytes still in the input buffer */
1247c478bd9Sstevel@tonic-gate static unsigned obc;	/* number of bytes in the output buffer */
1257c478bd9Sstevel@tonic-gate static unsigned cbc;	/* number of bytes in the conversion buffer */
1267c478bd9Sstevel@tonic-gate 
1277c478bd9Sstevel@tonic-gate static int	ibf;	/* input file descriptor */
1287c478bd9Sstevel@tonic-gate static int	obf;	/* output file descriptor */
1297c478bd9Sstevel@tonic-gate static int	cflag;	/* conversion option flags */
1307c478bd9Sstevel@tonic-gate static int	skipf;	/* if skipf == 1, skip rest of input line */
1317c478bd9Sstevel@tonic-gate static unsigned long long	nifr;	/* count of full input records */
1327c478bd9Sstevel@tonic-gate static unsigned long long	nipr;	/* count of partial input records */
1337c478bd9Sstevel@tonic-gate static unsigned long long	nofr;	/* count of full output records */
1347c478bd9Sstevel@tonic-gate static unsigned long long	nopr;	/* count of partial output records */
1357c478bd9Sstevel@tonic-gate static unsigned long long	ntrunc;	/* count of truncated input lines */
1367c478bd9Sstevel@tonic-gate static unsigned long long	nbad;	/* count of bad records since last */
1377c478bd9Sstevel@tonic-gate 					/* good one */
1387c478bd9Sstevel@tonic-gate static int	files;	/* number of input files to concatenate (tape only) */
1397c478bd9Sstevel@tonic-gate static off_t	skip;	/* number of input records to skip */
1407c478bd9Sstevel@tonic-gate static off_t	iseekn;	/* number of input records to seek past */
1417c478bd9Sstevel@tonic-gate static off_t	oseekn;	/* number of output records to seek past */
1427c478bd9Sstevel@tonic-gate static unsigned long long	count;	/* number of input records to copy */
1437c478bd9Sstevel@tonic-gate 			/* (0 = all) */
1447c478bd9Sstevel@tonic-gate static int	trantype; /* BSD or SVr4 compatible EBCDIC */
1457c478bd9Sstevel@tonic-gate 
1467c478bd9Sstevel@tonic-gate static char		*string;	/* command arg pointer */
1477c478bd9Sstevel@tonic-gate static char		*ifile;		/* input file name pointer */
1487c478bd9Sstevel@tonic-gate static char		*ofile;		/* output file name pointer */
1497c478bd9Sstevel@tonic-gate static unsigned char	*ibuf;		/* input buffer pointer */
1507c478bd9Sstevel@tonic-gate static unsigned char	*obuf;		/* output buffer pointer */
1517c478bd9Sstevel@tonic-gate 
1527c478bd9Sstevel@tonic-gate /* This is an EBCDIC to ASCII conversion table	*/
1537c478bd9Sstevel@tonic-gate /* from a proposed BTL standard April 16, 1979	*/
1547c478bd9Sstevel@tonic-gate 
1557c478bd9Sstevel@tonic-gate static unsigned char svr4_etoa [] =
1567c478bd9Sstevel@tonic-gate {
1577c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0234, 0011, 0206, 0177,
1587c478bd9Sstevel@tonic-gate 	0227, 0215, 0216, 0013, 0014, 0015, 0016, 0017,
1597c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0235, 0205, 0010, 0207,
1607c478bd9Sstevel@tonic-gate 	0030, 0031, 0222, 0217, 0034, 0035, 0036, 0037,
1617c478bd9Sstevel@tonic-gate 	0200, 0201, 0202, 0203, 0204, 0012, 0027, 0033,
1627c478bd9Sstevel@tonic-gate 	0210, 0211, 0212, 0213, 0214, 0005, 0006, 0007,
1637c478bd9Sstevel@tonic-gate 	0220, 0221, 0026, 0223, 0224, 0225, 0226, 0004,
1647c478bd9Sstevel@tonic-gate 	0230, 0231, 0232, 0233, 0024, 0025, 0236, 0032,
1657c478bd9Sstevel@tonic-gate 	0040, 0240, 0241, 0242, 0243, 0244, 0245, 0246,
1667c478bd9Sstevel@tonic-gate 	0247, 0250, 0325, 0056, 0074, 0050, 0053, 0174,
1677c478bd9Sstevel@tonic-gate 	0046, 0251, 0252, 0253, 0254, 0255, 0256, 0257,
1687c478bd9Sstevel@tonic-gate 	0260, 0261, 0041, 0044, 0052, 0051, 0073, 0176,
1697c478bd9Sstevel@tonic-gate 	0055, 0057, 0262, 0263, 0264, 0265, 0266, 0267,
1707c478bd9Sstevel@tonic-gate 	0270, 0271, 0313, 0054, 0045, 0137, 0076, 0077,
1717c478bd9Sstevel@tonic-gate 	0272, 0273, 0274, 0275, 0276, 0277, 0300, 0301,
1727c478bd9Sstevel@tonic-gate 	0302, 0140, 0072, 0043, 0100, 0047, 0075, 0042,
1737c478bd9Sstevel@tonic-gate 	0303, 0141, 0142, 0143, 0144, 0145, 0146, 0147,
1747c478bd9Sstevel@tonic-gate 	0150, 0151, 0304, 0305, 0306, 0307, 0310, 0311,
1757c478bd9Sstevel@tonic-gate 	0312, 0152, 0153, 0154, 0155, 0156, 0157, 0160,
1767c478bd9Sstevel@tonic-gate 	0161, 0162, 0136, 0314, 0315, 0316, 0317, 0320,
1777c478bd9Sstevel@tonic-gate 	0321, 0345, 0163, 0164, 0165, 0166, 0167, 0170,
1787c478bd9Sstevel@tonic-gate 	0171, 0172, 0322, 0323, 0324, 0133, 0326, 0327,
1797c478bd9Sstevel@tonic-gate 	0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337,
1807c478bd9Sstevel@tonic-gate 	0340, 0341, 0342, 0343, 0344, 0135, 0346, 0347,
1817c478bd9Sstevel@tonic-gate 	0173, 0101, 0102, 0103, 0104, 0105, 0106, 0107,
1827c478bd9Sstevel@tonic-gate 	0110, 0111, 0350, 0351, 0352, 0353, 0354, 0355,
1837c478bd9Sstevel@tonic-gate 	0175, 0112, 0113, 0114, 0115, 0116, 0117, 0120,
1847c478bd9Sstevel@tonic-gate 	0121, 0122, 0356, 0357, 0360, 0361, 0362, 0363,
1857c478bd9Sstevel@tonic-gate 	0134, 0237, 0123, 0124, 0125, 0126, 0127, 0130,
1867c478bd9Sstevel@tonic-gate 	0131, 0132, 0364, 0365, 0366, 0367, 0370, 0371,
1877c478bd9Sstevel@tonic-gate 	0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067,
1887c478bd9Sstevel@tonic-gate 	0070, 0071, 0372, 0373, 0374, 0375, 0376, 0377,
1897c478bd9Sstevel@tonic-gate };
1907c478bd9Sstevel@tonic-gate 
1917c478bd9Sstevel@tonic-gate /* This is an ASCII to EBCDIC conversion table	*/
1927c478bd9Sstevel@tonic-gate /* from a proposed BTL standard April 16, 1979	*/
1937c478bd9Sstevel@tonic-gate 
1947c478bd9Sstevel@tonic-gate static unsigned char svr4_atoe [] =
1957c478bd9Sstevel@tonic-gate {
1967c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0067, 0055, 0056, 0057,
1977c478bd9Sstevel@tonic-gate 	0026, 0005, 0045, 0013, 0014, 0015, 0016, 0017,
1987c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0074, 0075, 0062, 0046,
1997c478bd9Sstevel@tonic-gate 	0030, 0031, 0077, 0047, 0034, 0035, 0036, 0037,
2007c478bd9Sstevel@tonic-gate 	0100, 0132, 0177, 0173, 0133, 0154, 0120, 0175,
2017c478bd9Sstevel@tonic-gate 	0115, 0135, 0134, 0116, 0153, 0140, 0113, 0141,
2027c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
2037c478bd9Sstevel@tonic-gate 	0370, 0371, 0172, 0136, 0114, 0176, 0156, 0157,
2047c478bd9Sstevel@tonic-gate 	0174, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
2057c478bd9Sstevel@tonic-gate 	0310, 0311, 0321, 0322, 0323, 0324, 0325, 0326,
2067c478bd9Sstevel@tonic-gate 	0327, 0330, 0331, 0342, 0343, 0344, 0345, 0346,
2077c478bd9Sstevel@tonic-gate 	0347, 0350, 0351, 0255, 0340, 0275, 0232, 0155,
2087c478bd9Sstevel@tonic-gate 	0171, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
2097c478bd9Sstevel@tonic-gate 	0210, 0211, 0221, 0222, 0223, 0224, 0225, 0226,
2107c478bd9Sstevel@tonic-gate 	0227, 0230, 0231, 0242, 0243, 0244, 0245, 0246,
2117c478bd9Sstevel@tonic-gate 	0247, 0250, 0251, 0300, 0117, 0320, 0137, 0007,
2127c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0025, 0006, 0027,
2137c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0011, 0012, 0033,
2147c478bd9Sstevel@tonic-gate 	0060, 0061, 0032, 0063, 0064, 0065, 0066, 0010,
2157c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0004, 0024, 0076, 0341,
2167c478bd9Sstevel@tonic-gate 	0101, 0102, 0103, 0104, 0105, 0106, 0107, 0110,
2177c478bd9Sstevel@tonic-gate 	0111, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
2187c478bd9Sstevel@tonic-gate 	0130, 0131, 0142, 0143, 0144, 0145, 0146, 0147,
2197c478bd9Sstevel@tonic-gate 	0150, 0151, 0160, 0161, 0162, 0163, 0164, 0165,
2207c478bd9Sstevel@tonic-gate 	0166, 0167, 0170, 0200, 0212, 0213, 0214, 0215,
2217c478bd9Sstevel@tonic-gate 	0216, 0217, 0220, 0152, 0233, 0234, 0235, 0236,
2227c478bd9Sstevel@tonic-gate 	0237, 0240, 0252, 0253, 0254, 0112, 0256, 0257,
2237c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
2247c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0241, 0276, 0277,
2257c478bd9Sstevel@tonic-gate 	0312, 0313, 0314, 0315, 0316, 0317, 0332, 0333,
2267c478bd9Sstevel@tonic-gate 	0334, 0335, 0336, 0337, 0352, 0353, 0354, 0355,
2277c478bd9Sstevel@tonic-gate 	0356, 0357, 0372, 0373, 0374, 0375, 0376, 0377,
2287c478bd9Sstevel@tonic-gate };
2297c478bd9Sstevel@tonic-gate 
2307c478bd9Sstevel@tonic-gate /* Table for ASCII to IBM (alternate EBCDIC) code conversion	*/
2317c478bd9Sstevel@tonic-gate 
2327c478bd9Sstevel@tonic-gate static unsigned char svr4_atoibm[] =
2337c478bd9Sstevel@tonic-gate {
2347c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0067, 0055, 0056, 0057,
2357c478bd9Sstevel@tonic-gate 	0026, 0005, 0045, 0013, 0014, 0015, 0016, 0017,
2367c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0074, 0075, 0062, 0046,
2377c478bd9Sstevel@tonic-gate 	0030, 0031, 0077, 0047, 0034, 0035, 0036, 0037,
2387c478bd9Sstevel@tonic-gate 	0100, 0132, 0177, 0173, 0133, 0154, 0120, 0175,
2397c478bd9Sstevel@tonic-gate 	0115, 0135, 0134, 0116, 0153, 0140, 0113, 0141,
2407c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
2417c478bd9Sstevel@tonic-gate 	0370, 0371, 0172, 0136, 0114, 0176, 0156, 0157,
2427c478bd9Sstevel@tonic-gate 	0174, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
2437c478bd9Sstevel@tonic-gate 	0310, 0311, 0321, 0322, 0323, 0324, 0325, 0326,
2447c478bd9Sstevel@tonic-gate 	0327, 0330, 0331, 0342, 0343, 0344, 0345, 0346,
2457c478bd9Sstevel@tonic-gate 	0347, 0350, 0351, 0255, 0340, 0275, 0137, 0155,
2467c478bd9Sstevel@tonic-gate 	0171, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
2477c478bd9Sstevel@tonic-gate 	0210, 0211, 0221, 0222, 0223, 0224, 0225, 0226,
2487c478bd9Sstevel@tonic-gate 	0227, 0230, 0231, 0242, 0243, 0244, 0245, 0246,
2497c478bd9Sstevel@tonic-gate 	0247, 0250, 0251, 0300, 0117, 0320, 0241, 0007,
2507c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0025, 0006, 0027,
2517c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0011, 0012, 0033,
2527c478bd9Sstevel@tonic-gate 	0060, 0061, 0032, 0063, 0064, 0065, 0066, 0010,
2537c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0004, 0024, 0076, 0341,
2547c478bd9Sstevel@tonic-gate 	0101, 0102, 0103, 0104, 0105, 0106, 0107, 0110,
2557c478bd9Sstevel@tonic-gate 	0111, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
2567c478bd9Sstevel@tonic-gate 	0130, 0131, 0142, 0143, 0144, 0145, 0146, 0147,
2577c478bd9Sstevel@tonic-gate 	0150, 0151, 0160, 0161, 0162, 0163, 0164, 0165,
2587c478bd9Sstevel@tonic-gate 	0166, 0167, 0170, 0200, 0212, 0213, 0214, 0215,
2597c478bd9Sstevel@tonic-gate 	0216, 0217, 0220, 0232, 0233, 0234, 0235, 0236,
2607c478bd9Sstevel@tonic-gate 	0237, 0240, 0252, 0253, 0254, 0255, 0256, 0257,
2617c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
2627c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
2637c478bd9Sstevel@tonic-gate 	0312, 0313, 0314, 0315, 0316, 0317, 0332, 0333,
2647c478bd9Sstevel@tonic-gate 	0334, 0335, 0336, 0337, 0352, 0353, 0354, 0355,
2657c478bd9Sstevel@tonic-gate 	0356, 0357, 0372, 0373, 0374, 0375, 0376, 0377,
2667c478bd9Sstevel@tonic-gate };
2677c478bd9Sstevel@tonic-gate 
2687c478bd9Sstevel@tonic-gate /* Table for conversion of ASCII to lower case ASCII	*/
2697c478bd9Sstevel@tonic-gate 
2707c478bd9Sstevel@tonic-gate static unsigned char utol[] =
2717c478bd9Sstevel@tonic-gate {
2727c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0004, 0005, 0006, 0007,
2737c478bd9Sstevel@tonic-gate 	0010, 0011, 0012, 0013, 0014, 0015, 0016, 0017,
2747c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0024, 0025, 0026, 0027,
2757c478bd9Sstevel@tonic-gate 	0030, 0031, 0032, 0033, 0034, 0035, 0036, 0037,
2767c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0045, 0046, 0047,
2777c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0055, 0056, 0057,
2787c478bd9Sstevel@tonic-gate 	0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067,
2797c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0074, 0075, 0076, 0077,
2807c478bd9Sstevel@tonic-gate 	0100, 0141, 0142, 0143, 0144, 0145, 0146, 0147,
2817c478bd9Sstevel@tonic-gate 	0150, 0151, 0152, 0153, 0154, 0155, 0156, 0157,
2827c478bd9Sstevel@tonic-gate 	0160, 0161, 0162, 0163, 0164, 0165, 0166, 0167,
2837c478bd9Sstevel@tonic-gate 	0170, 0171, 0172, 0133, 0134, 0135, 0136, 0137,
2847c478bd9Sstevel@tonic-gate 	0140, 0141, 0142, 0143, 0144, 0145, 0146, 0147,
2857c478bd9Sstevel@tonic-gate 	0150, 0151, 0152, 0153, 0154, 0155, 0156, 0157,
2867c478bd9Sstevel@tonic-gate 	0160, 0161, 0162, 0163, 0164, 0165, 0166, 0167,
2877c478bd9Sstevel@tonic-gate 	0170, 0171, 0172, 0173, 0174, 0175, 0176, 0177,
2887c478bd9Sstevel@tonic-gate 	0200, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
2897c478bd9Sstevel@tonic-gate 	0210, 0211, 0212, 0213, 0214, 0215, 0216, 0217,
2907c478bd9Sstevel@tonic-gate 	0220, 0221, 0222, 0223, 0224, 0225, 0226, 0227,
2917c478bd9Sstevel@tonic-gate 	0230, 0231, 0232, 0233, 0234, 0235, 0236, 0237,
2927c478bd9Sstevel@tonic-gate 	0240, 0241, 0242, 0243, 0244, 0245, 0246, 0247,
2937c478bd9Sstevel@tonic-gate 	0250, 0251, 0252, 0253, 0254, 0255, 0256, 0257,
2947c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
2957c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
2967c478bd9Sstevel@tonic-gate 	0300, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
2977c478bd9Sstevel@tonic-gate 	0310, 0311, 0312, 0313, 0314, 0315, 0316, 0317,
2987c478bd9Sstevel@tonic-gate 	0320, 0321, 0322, 0323, 0324, 0325, 0326, 0327,
2997c478bd9Sstevel@tonic-gate 	0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337,
3007c478bd9Sstevel@tonic-gate 	0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347,
3017c478bd9Sstevel@tonic-gate 	0350, 0351, 0352, 0353, 0354, 0355, 0356, 0357,
3027c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
3037c478bd9Sstevel@tonic-gate 	0370, 0371, 0372, 0373, 0374, 0375, 0376, 0377,
3047c478bd9Sstevel@tonic-gate };
3057c478bd9Sstevel@tonic-gate 
3067c478bd9Sstevel@tonic-gate /* Table for conversion of ASCII to upper case ASCII	*/
3077c478bd9Sstevel@tonic-gate 
3087c478bd9Sstevel@tonic-gate static unsigned char ltou[] =
3097c478bd9Sstevel@tonic-gate {
3107c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0004, 0005, 0006, 0007,
3117c478bd9Sstevel@tonic-gate 	0010, 0011, 0012, 0013, 0014, 0015, 0016, 0017,
3127c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0024, 0025, 0026, 0027,
3137c478bd9Sstevel@tonic-gate 	0030, 0031, 0032, 0033, 0034, 0035, 0036, 0037,
3147c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0045, 0046, 0047,
3157c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0055, 0056, 0057,
3167c478bd9Sstevel@tonic-gate 	0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067,
3177c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0074, 0075, 0076, 0077,
3187c478bd9Sstevel@tonic-gate 	0100, 0101, 0102, 0103, 0104, 0105, 0106, 0107,
3197c478bd9Sstevel@tonic-gate 	0110, 0111, 0112, 0113, 0114, 0115, 0116, 0117,
3207c478bd9Sstevel@tonic-gate 	0120, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
3217c478bd9Sstevel@tonic-gate 	0130, 0131, 0132, 0133, 0134, 0135, 0136, 0137,
3227c478bd9Sstevel@tonic-gate 	0140, 0101, 0102, 0103, 0104, 0105, 0106, 0107,
3237c478bd9Sstevel@tonic-gate 	0110, 0111, 0112, 0113, 0114, 0115, 0116, 0117,
3247c478bd9Sstevel@tonic-gate 	0120, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
3257c478bd9Sstevel@tonic-gate 	0130, 0131, 0132, 0173, 0174, 0175, 0176, 0177,
3267c478bd9Sstevel@tonic-gate 	0200, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
3277c478bd9Sstevel@tonic-gate 	0210, 0211, 0212, 0213, 0214, 0215, 0216, 0217,
3287c478bd9Sstevel@tonic-gate 	0220, 0221, 0222, 0223, 0224, 0225, 0226, 0227,
3297c478bd9Sstevel@tonic-gate 	0230, 0231, 0232, 0233, 0234, 0235, 0236, 0237,
3307c478bd9Sstevel@tonic-gate 	0240, 0241, 0242, 0243, 0244, 0245, 0246, 0247,
3317c478bd9Sstevel@tonic-gate 	0250, 0251, 0252, 0253, 0254, 0255, 0256, 0257,
3327c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
3337c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
3347c478bd9Sstevel@tonic-gate 	0300, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
3357c478bd9Sstevel@tonic-gate 	0310, 0311, 0312, 0313, 0314, 0315, 0316, 0317,
3367c478bd9Sstevel@tonic-gate 	0320, 0321, 0322, 0323, 0324, 0325, 0326, 0327,
3377c478bd9Sstevel@tonic-gate 	0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337,
3387c478bd9Sstevel@tonic-gate 	0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347,
3397c478bd9Sstevel@tonic-gate 	0350, 0351, 0352, 0353, 0354, 0355, 0356, 0357,
3407c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
3417c478bd9Sstevel@tonic-gate 	0370, 0371, 0372, 0373, 0374, 0375, 0376, 0377,
3427c478bd9Sstevel@tonic-gate };
3437c478bd9Sstevel@tonic-gate 
3447c478bd9Sstevel@tonic-gate /* BSD-compatible EBCDIC to ASCII translate table */
3457c478bd9Sstevel@tonic-gate 
3467c478bd9Sstevel@tonic-gate static unsigned char	bsd_etoa[] =
3477c478bd9Sstevel@tonic-gate {
3487c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0234, 0011, 0206, 0177,
3497c478bd9Sstevel@tonic-gate 	0227, 0215, 0216, 0013, 0014, 0015, 0016, 0017,
3507c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0235, 0205, 0010, 0207,
3517c478bd9Sstevel@tonic-gate 	0030, 0031, 0222, 0217, 0034, 0035, 0036, 0037,
3527c478bd9Sstevel@tonic-gate 	0200, 0201, 0202, 0203, 0204, 0012, 0027, 0033,
3537c478bd9Sstevel@tonic-gate 	0210, 0211, 0212, 0213, 0214, 0005, 0006, 0007,
3547c478bd9Sstevel@tonic-gate 	0220, 0221, 0026, 0223, 0224, 0225, 0226, 0004,
3557c478bd9Sstevel@tonic-gate 	0230, 0231, 0232, 0233, 0024, 0025, 0236, 0032,
3567c478bd9Sstevel@tonic-gate 	0040, 0240, 0241, 0242, 0243, 0244, 0245, 0246,
3577c478bd9Sstevel@tonic-gate 	0247, 0250, 0133, 0056, 0074, 0050, 0053, 0041,
3587c478bd9Sstevel@tonic-gate 	0046, 0251, 0252, 0253, 0254, 0255, 0256, 0257,
3597c478bd9Sstevel@tonic-gate 	0260, 0261, 0135, 0044, 0052, 0051, 0073, 0136,
3607c478bd9Sstevel@tonic-gate 	0055, 0057, 0262, 0263, 0264, 0265, 0266, 0267,
3617c478bd9Sstevel@tonic-gate 	0270, 0271, 0174, 0054, 0045, 0137, 0076, 0077,
3627c478bd9Sstevel@tonic-gate 	0272, 0273, 0274, 0275, 0276, 0277, 0300, 0301,
3637c478bd9Sstevel@tonic-gate 	0302, 0140, 0072, 0043, 0100, 0047, 0075, 0042,
3647c478bd9Sstevel@tonic-gate 	0303, 0141, 0142, 0143, 0144, 0145, 0146, 0147,
3657c478bd9Sstevel@tonic-gate 	0150, 0151, 0304, 0305, 0306, 0307, 0310, 0311,
3667c478bd9Sstevel@tonic-gate 	0312, 0152, 0153, 0154, 0155, 0156, 0157, 0160,
3677c478bd9Sstevel@tonic-gate 	0161, 0162, 0313, 0314, 0315, 0316, 0317, 0320,
3687c478bd9Sstevel@tonic-gate 	0321, 0176, 0163, 0164, 0165, 0166, 0167, 0170,
3697c478bd9Sstevel@tonic-gate 	0171, 0172, 0322, 0323, 0324, 0325, 0326, 0327,
3707c478bd9Sstevel@tonic-gate 	0330, 0331, 0332, 0333, 0334, 0335, 0336, 0337,
3717c478bd9Sstevel@tonic-gate 	0340, 0341, 0342, 0343, 0344, 0345, 0346, 0347,
3727c478bd9Sstevel@tonic-gate 	0173, 0101, 0102, 0103, 0104, 0105, 0106, 0107,
3737c478bd9Sstevel@tonic-gate 	0110, 0111, 0350, 0351, 0352, 0353, 0354, 0355,
3747c478bd9Sstevel@tonic-gate 	0175, 0112, 0113, 0114, 0115, 0116, 0117, 0120,
3757c478bd9Sstevel@tonic-gate 	0121, 0122, 0356, 0357, 0360, 0361, 0362, 0363,
3767c478bd9Sstevel@tonic-gate 	0134, 0237, 0123, 0124, 0125, 0126, 0127, 0130,
3777c478bd9Sstevel@tonic-gate 	0131, 0132, 0364, 0365, 0366, 0367, 0370, 0371,
3787c478bd9Sstevel@tonic-gate 	0060, 0061, 0062, 0063, 0064, 0065, 0066, 0067,
3797c478bd9Sstevel@tonic-gate 	0070, 0071, 0372, 0373, 0374, 0375, 0376, 0377,
3807c478bd9Sstevel@tonic-gate };
3817c478bd9Sstevel@tonic-gate 
3827c478bd9Sstevel@tonic-gate /* BSD-compatible ASCII to EBCDIC translate table */
3837c478bd9Sstevel@tonic-gate 
3847c478bd9Sstevel@tonic-gate static unsigned char	bsd_atoe[] =
3857c478bd9Sstevel@tonic-gate {
3867c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0067, 0055, 0056, 0057,
3877c478bd9Sstevel@tonic-gate 	0026, 0005, 0045, 0013, 0014, 0015, 0016, 0017,
3887c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0074, 0075, 0062, 0046,
3897c478bd9Sstevel@tonic-gate 	0030, 0031, 0077, 0047, 0034, 0035, 0036, 0037,
3907c478bd9Sstevel@tonic-gate 	0100, 0117, 0177, 0173, 0133, 0154, 0120, 0175,
3917c478bd9Sstevel@tonic-gate 	0115, 0135, 0134, 0116, 0153, 0140, 0113, 0141,
3927c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
3937c478bd9Sstevel@tonic-gate 	0370, 0371, 0172, 0136, 0114, 0176, 0156, 0157,
3947c478bd9Sstevel@tonic-gate 	0174, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
3957c478bd9Sstevel@tonic-gate 	0310, 0311, 0321, 0322, 0323, 0324, 0325, 0326,
3967c478bd9Sstevel@tonic-gate 	0327, 0330, 0331, 0342, 0343, 0344, 0345, 0346,
3977c478bd9Sstevel@tonic-gate 	0347, 0350, 0351, 0112, 0340, 0132, 0137, 0155,
3987c478bd9Sstevel@tonic-gate 	0171, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
3997c478bd9Sstevel@tonic-gate 	0210, 0211, 0221, 0222, 0223, 0224, 0225, 0226,
4007c478bd9Sstevel@tonic-gate 	0227, 0230, 0231, 0242, 0243, 0244, 0245, 0246,
4017c478bd9Sstevel@tonic-gate 	0247, 0250, 0251, 0300, 0152, 0320, 0241, 0007,
4027c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0025, 0006, 0027,
4037c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0011, 0012, 0033,
4047c478bd9Sstevel@tonic-gate 	0060, 0061, 0032, 0063, 0064, 0065, 0066, 0010,
4057c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0004, 0024, 0076, 0341,
4067c478bd9Sstevel@tonic-gate 	0101, 0102, 0103, 0104, 0105, 0106, 0107, 0110,
4077c478bd9Sstevel@tonic-gate 	0111, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
4087c478bd9Sstevel@tonic-gate 	0130, 0131, 0142, 0143, 0144, 0145, 0146, 0147,
4097c478bd9Sstevel@tonic-gate 	0150, 0151, 0160, 0161, 0162, 0163, 0164, 0165,
4107c478bd9Sstevel@tonic-gate 	0166, 0167, 0170, 0200, 0212, 0213, 0214, 0215,
4117c478bd9Sstevel@tonic-gate 	0216, 0217, 0220, 0232, 0233, 0234, 0235, 0236,
4127c478bd9Sstevel@tonic-gate 	0237, 0240, 0252, 0253, 0254, 0255, 0256, 0257,
4137c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
4147c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
4157c478bd9Sstevel@tonic-gate 	0312, 0313, 0314, 0315, 0316, 0317, 0332, 0333,
4167c478bd9Sstevel@tonic-gate 	0334, 0335, 0336, 0337, 0352, 0353, 0354, 0355,
4177c478bd9Sstevel@tonic-gate 	0356, 0357, 0372, 0373, 0374, 0375, 0376, 0377,
4187c478bd9Sstevel@tonic-gate };
4197c478bd9Sstevel@tonic-gate 
4207c478bd9Sstevel@tonic-gate /* BSD-compatible ASCII to IBM translate table */
4217c478bd9Sstevel@tonic-gate 
4227c478bd9Sstevel@tonic-gate static unsigned char	bsd_atoibm[] =
4237c478bd9Sstevel@tonic-gate {
4247c478bd9Sstevel@tonic-gate 	0000, 0001, 0002, 0003, 0067, 0055, 0056, 0057,
4257c478bd9Sstevel@tonic-gate 	0026, 0005, 0045, 0013, 0014, 0015, 0016, 0017,
4267c478bd9Sstevel@tonic-gate 	0020, 0021, 0022, 0023, 0074, 0075, 0062, 0046,
4277c478bd9Sstevel@tonic-gate 	0030, 0031, 0077, 0047, 0034, 0035, 0036, 0037,
4287c478bd9Sstevel@tonic-gate 	0100, 0132, 0177, 0173, 0133, 0154, 0120, 0175,
4297c478bd9Sstevel@tonic-gate 	0115, 0135, 0134, 0116, 0153, 0140, 0113, 0141,
4307c478bd9Sstevel@tonic-gate 	0360, 0361, 0362, 0363, 0364, 0365, 0366, 0367,
4317c478bd9Sstevel@tonic-gate 	0370, 0371, 0172, 0136, 0114, 0176, 0156, 0157,
4327c478bd9Sstevel@tonic-gate 	0174, 0301, 0302, 0303, 0304, 0305, 0306, 0307,
4337c478bd9Sstevel@tonic-gate 	0310, 0311, 0321, 0322, 0323, 0324, 0325, 0326,
4347c478bd9Sstevel@tonic-gate 	0327, 0330, 0331, 0342, 0343, 0344, 0345, 0346,
4357c478bd9Sstevel@tonic-gate 	0347, 0350, 0351, 0255, 0340, 0275, 0137, 0155,
4367c478bd9Sstevel@tonic-gate 	0171, 0201, 0202, 0203, 0204, 0205, 0206, 0207,
4377c478bd9Sstevel@tonic-gate 	0210, 0211, 0221, 0222, 0223, 0224, 0225, 0226,
4387c478bd9Sstevel@tonic-gate 	0227, 0230, 0231, 0242, 0243, 0244, 0245, 0246,
4397c478bd9Sstevel@tonic-gate 	0247, 0250, 0251, 0300, 0117, 0320, 0241, 0007,
4407c478bd9Sstevel@tonic-gate 	0040, 0041, 0042, 0043, 0044, 0025, 0006, 0027,
4417c478bd9Sstevel@tonic-gate 	0050, 0051, 0052, 0053, 0054, 0011, 0012, 0033,
4427c478bd9Sstevel@tonic-gate 	0060, 0061, 0032, 0063, 0064, 0065, 0066, 0010,
4437c478bd9Sstevel@tonic-gate 	0070, 0071, 0072, 0073, 0004, 0024, 0076, 0341,
4447c478bd9Sstevel@tonic-gate 	0101, 0102, 0103, 0104, 0105, 0106, 0107, 0110,
4457c478bd9Sstevel@tonic-gate 	0111, 0121, 0122, 0123, 0124, 0125, 0126, 0127,
4467c478bd9Sstevel@tonic-gate 	0130, 0131, 0142, 0143, 0144, 0145, 0146, 0147,
4477c478bd9Sstevel@tonic-gate 	0150, 0151, 0160, 0161, 0162, 0163, 0164, 0165,
4487c478bd9Sstevel@tonic-gate 	0166, 0167, 0170, 0200, 0212, 0213, 0214, 0215,
4497c478bd9Sstevel@tonic-gate 	0216, 0217, 0220, 0232, 0233, 0234, 0235, 0236,
4507c478bd9Sstevel@tonic-gate 	0237, 0240, 0252, 0253, 0254, 0255, 0256, 0257,
4517c478bd9Sstevel@tonic-gate 	0260, 0261, 0262, 0263, 0264, 0265, 0266, 0267,
4527c478bd9Sstevel@tonic-gate 	0270, 0271, 0272, 0273, 0274, 0275, 0276, 0277,
4537c478bd9Sstevel@tonic-gate 	0312, 0313, 0314, 0315, 0316, 0317, 0332, 0333,
4547c478bd9Sstevel@tonic-gate 	0334, 0335, 0336, 0337, 0352, 0353, 0354, 0355,
4557c478bd9Sstevel@tonic-gate 	0356, 0357, 0372, 0373, 0374, 0375, 0376, 0377,
4567c478bd9Sstevel@tonic-gate };
4577c478bd9Sstevel@tonic-gate 
4587c478bd9Sstevel@tonic-gate /* set up to use SVr4 ascii-ebcdic translation by default */
4597c478bd9Sstevel@tonic-gate 
4607c478bd9Sstevel@tonic-gate static unsigned char *atoe = svr4_atoe;
4617c478bd9Sstevel@tonic-gate static unsigned char *etoa = svr4_etoa;
4627c478bd9Sstevel@tonic-gate static unsigned char *atoibm = svr4_atoibm;
4637c478bd9Sstevel@tonic-gate 
4647c478bd9Sstevel@tonic-gate 
465a77d64afScf int
466a77d64afScf main(int argc, char **argv)
4677c478bd9Sstevel@tonic-gate {
4687c478bd9Sstevel@tonic-gate 	unsigned char *ip, *op; /* input and output buffer pointers */
4697c478bd9Sstevel@tonic-gate 	int c;		/* character counter */
4707c478bd9Sstevel@tonic-gate 	int ic;		/* input character */
4717c478bd9Sstevel@tonic-gate 	int conv;		/* conversion option code */
4727c478bd9Sstevel@tonic-gate 	int trunc;		/* whether output file is truncated */
4737c478bd9Sstevel@tonic-gate 	struct stat file_stat;
4747c478bd9Sstevel@tonic-gate 
4757c478bd9Sstevel@tonic-gate 	/* Set option defaults */
4767c478bd9Sstevel@tonic-gate 
4777c478bd9Sstevel@tonic-gate 	ibs = BSIZE;
4787c478bd9Sstevel@tonic-gate 	obs = BSIZE;
4797c478bd9Sstevel@tonic-gate 	files = 1;
4807c478bd9Sstevel@tonic-gate 	conv = COPY;
4817c478bd9Sstevel@tonic-gate 	trunc = 1;			/* default: truncate output file */
4827c478bd9Sstevel@tonic-gate 	trantype = SVR4XLATE;  /* use SVR4 EBCDIC by default */
4837c478bd9Sstevel@tonic-gate 
4847c478bd9Sstevel@tonic-gate 	/* Parse command options */
4857c478bd9Sstevel@tonic-gate 
4867c478bd9Sstevel@tonic-gate 	(void) setlocale(LC_ALL, "");
4877c478bd9Sstevel@tonic-gate #if !defined(TEXT_DOMAIN)	/* Should be defined by cc -D */
4887c478bd9Sstevel@tonic-gate #define	TEXT_DOMAIN "SYS_TEST"	/* Use this only if it weren't */
4897c478bd9Sstevel@tonic-gate #endif
4907c478bd9Sstevel@tonic-gate 	(void) textdomain(TEXT_DOMAIN);
4917c478bd9Sstevel@tonic-gate 
4927c478bd9Sstevel@tonic-gate 	while ((c = getopt(argc, argv, "")) != EOF)
4937c478bd9Sstevel@tonic-gate 		switch (c) {
4947c478bd9Sstevel@tonic-gate 			case '?':
4957c478bd9Sstevel@tonic-gate 			(void) fprintf(stderr, USAGE);
4967c478bd9Sstevel@tonic-gate 			exit(2);
4977c478bd9Sstevel@tonic-gate 		}
4987c478bd9Sstevel@tonic-gate 
4997c478bd9Sstevel@tonic-gate 	/* not getopt()'ed because dd has no options but only operand(s) */
5007c478bd9Sstevel@tonic-gate 
5017c478bd9Sstevel@tonic-gate 	for (c = optind; c < argc; c++)
5027c478bd9Sstevel@tonic-gate 	{
5037c478bd9Sstevel@tonic-gate 		string = argv[c];
5047c478bd9Sstevel@tonic-gate 		if (match("ibs="))
5057c478bd9Sstevel@tonic-gate 		{
5067c478bd9Sstevel@tonic-gate 			ibs = (unsigned)number(BIG);
5077c478bd9Sstevel@tonic-gate 			continue;
5087c478bd9Sstevel@tonic-gate 		}
5097c478bd9Sstevel@tonic-gate 		if (match("obs="))
5107c478bd9Sstevel@tonic-gate 		{
5117c478bd9Sstevel@tonic-gate 			obs = (unsigned)number(BIG);
5127c478bd9Sstevel@tonic-gate 			continue;
5137c478bd9Sstevel@tonic-gate 		}
5147c478bd9Sstevel@tonic-gate 		if (match("cbs="))
5157c478bd9Sstevel@tonic-gate 		{
5167c478bd9Sstevel@tonic-gate 			cbs = (unsigned)number(BIG);
5177c478bd9Sstevel@tonic-gate 			continue;
5187c478bd9Sstevel@tonic-gate 		}
5197c478bd9Sstevel@tonic-gate 		if (match("bs="))
5207c478bd9Sstevel@tonic-gate 		{
5217c478bd9Sstevel@tonic-gate 			bs = (unsigned)number(BIG);
5227c478bd9Sstevel@tonic-gate 			continue;
5237c478bd9Sstevel@tonic-gate 		}
5247c478bd9Sstevel@tonic-gate 		if (match("if="))
5257c478bd9Sstevel@tonic-gate 		{
5267c478bd9Sstevel@tonic-gate 			ifile = string;
5277c478bd9Sstevel@tonic-gate 			continue;
5287c478bd9Sstevel@tonic-gate 		}
5297c478bd9Sstevel@tonic-gate 		if (match("of="))
5307c478bd9Sstevel@tonic-gate 		{
5317c478bd9Sstevel@tonic-gate 			ofile = string;
5327c478bd9Sstevel@tonic-gate 			continue;
5337c478bd9Sstevel@tonic-gate 		}
5347c478bd9Sstevel@tonic-gate 		if (match("skip="))
5357c478bd9Sstevel@tonic-gate 		{
5367c478bd9Sstevel@tonic-gate 			skip = number(BIG);
5377c478bd9Sstevel@tonic-gate 			continue;
5387c478bd9Sstevel@tonic-gate 		}
5397c478bd9Sstevel@tonic-gate 		if (match("iseek="))
5407c478bd9Sstevel@tonic-gate 		{
5417c478bd9Sstevel@tonic-gate 			iseekn = number(BIG);
5427c478bd9Sstevel@tonic-gate 			continue;
5437c478bd9Sstevel@tonic-gate 		}
5447c478bd9Sstevel@tonic-gate 		if (match("oseek="))
5457c478bd9Sstevel@tonic-gate 		{
5467c478bd9Sstevel@tonic-gate 			oseekn = number(BIG);
5477c478bd9Sstevel@tonic-gate 			continue;
5487c478bd9Sstevel@tonic-gate 		}
5497c478bd9Sstevel@tonic-gate 		if (match("seek="))		/* retained for compatibility */
5507c478bd9Sstevel@tonic-gate 		{
5517c478bd9Sstevel@tonic-gate 			oseekn = number(BIG);
5527c478bd9Sstevel@tonic-gate 			continue;
5537c478bd9Sstevel@tonic-gate 		}
5547c478bd9Sstevel@tonic-gate 		if (match("count="))
5557c478bd9Sstevel@tonic-gate 		{
5567c478bd9Sstevel@tonic-gate 			count = number(BIG);
5577c478bd9Sstevel@tonic-gate 			continue;
5587c478bd9Sstevel@tonic-gate 		}
5597c478bd9Sstevel@tonic-gate 		if (match("files="))
5607c478bd9Sstevel@tonic-gate 		{
5617c478bd9Sstevel@tonic-gate 			files = (int)number(BIG);
5627c478bd9Sstevel@tonic-gate 			continue;
5637c478bd9Sstevel@tonic-gate 		}
5647c478bd9Sstevel@tonic-gate 		if (match("conv="))
5657c478bd9Sstevel@tonic-gate 		{
5667c478bd9Sstevel@tonic-gate 			for (;;)
5677c478bd9Sstevel@tonic-gate 			{
5687c478bd9Sstevel@tonic-gate 				if (match(","))
5697c478bd9Sstevel@tonic-gate 				{
5707c478bd9Sstevel@tonic-gate 					continue;
5717c478bd9Sstevel@tonic-gate 				}
5727c478bd9Sstevel@tonic-gate 				if (*string == '\0')
5737c478bd9Sstevel@tonic-gate 				{
5747c478bd9Sstevel@tonic-gate 					break;
5757c478bd9Sstevel@tonic-gate 				}
5767c478bd9Sstevel@tonic-gate 				if (match("block"))
5777c478bd9Sstevel@tonic-gate 				{
5787c478bd9Sstevel@tonic-gate 					conv = BLOCK;
5797c478bd9Sstevel@tonic-gate 					continue;
5807c478bd9Sstevel@tonic-gate 				}
5817c478bd9Sstevel@tonic-gate 				if (match("unblock"))
5827c478bd9Sstevel@tonic-gate 				{
5837c478bd9Sstevel@tonic-gate 					conv = UNBLOCK;
5847c478bd9Sstevel@tonic-gate 					continue;
5857c478bd9Sstevel@tonic-gate 				}
5867c478bd9Sstevel@tonic-gate 
5877c478bd9Sstevel@tonic-gate 				/* ebcdicb, ibmb, and asciib must precede */
5887c478bd9Sstevel@tonic-gate 				/* ebcdic, ibm, and ascii in this test */
5897c478bd9Sstevel@tonic-gate 
5907c478bd9Sstevel@tonic-gate 				if (match("ebcdicb"))
5917c478bd9Sstevel@tonic-gate 				{
5927c478bd9Sstevel@tonic-gate 					conv = EBCDIC;
5937c478bd9Sstevel@tonic-gate 					trantype = BSDXLATE;
5947c478bd9Sstevel@tonic-gate 					continue;
5957c478bd9Sstevel@tonic-gate 				}
5967c478bd9Sstevel@tonic-gate 				if (match("ibmb"))
5977c478bd9Sstevel@tonic-gate 				{
5987c478bd9Sstevel@tonic-gate 					conv = IBM;
5997c478bd9Sstevel@tonic-gate 					trantype = BSDXLATE;
6007c478bd9Sstevel@tonic-gate 					continue;
6017c478bd9Sstevel@tonic-gate 				}
6027c478bd9Sstevel@tonic-gate 				if (match("asciib"))
6037c478bd9Sstevel@tonic-gate 				{
6047c478bd9Sstevel@tonic-gate 					conv = ASCII;
6057c478bd9Sstevel@tonic-gate 					trantype = BSDXLATE;
6067c478bd9Sstevel@tonic-gate 					continue;
6077c478bd9Sstevel@tonic-gate 				}
6087c478bd9Sstevel@tonic-gate 				if (match("ebcdic"))
6097c478bd9Sstevel@tonic-gate 				{
6107c478bd9Sstevel@tonic-gate 					conv = EBCDIC;
6117c478bd9Sstevel@tonic-gate 					trantype = SVR4XLATE;
6127c478bd9Sstevel@tonic-gate 					continue;
6137c478bd9Sstevel@tonic-gate 				}
6147c478bd9Sstevel@tonic-gate 				if (match("ibm"))
6157c478bd9Sstevel@tonic-gate 				{
6167c478bd9Sstevel@tonic-gate 					conv = IBM;
6177c478bd9Sstevel@tonic-gate 					trantype = SVR4XLATE;
6187c478bd9Sstevel@tonic-gate 					continue;
6197c478bd9Sstevel@tonic-gate 				}
6207c478bd9Sstevel@tonic-gate 				if (match("ascii"))
6217c478bd9Sstevel@tonic-gate 				{
6227c478bd9Sstevel@tonic-gate 					conv = ASCII;
6237c478bd9Sstevel@tonic-gate 					trantype = SVR4XLATE;
6247c478bd9Sstevel@tonic-gate 					continue;
6257c478bd9Sstevel@tonic-gate 				}
6267c478bd9Sstevel@tonic-gate 				if (match("lcase"))
6277c478bd9Sstevel@tonic-gate 				{
6287c478bd9Sstevel@tonic-gate 					cflag |= LCASE;
6297c478bd9Sstevel@tonic-gate 					continue;
6307c478bd9Sstevel@tonic-gate 				}
6317c478bd9Sstevel@tonic-gate 				if (match("ucase"))
6327c478bd9Sstevel@tonic-gate 				{
6337c478bd9Sstevel@tonic-gate 					cflag |= UCASE;
6347c478bd9Sstevel@tonic-gate 					continue;
6357c478bd9Sstevel@tonic-gate 				}
6367c478bd9Sstevel@tonic-gate 				if (match("swab"))
6377c478bd9Sstevel@tonic-gate 				{
6387c478bd9Sstevel@tonic-gate 					cflag |= SWAB;
6397c478bd9Sstevel@tonic-gate 					continue;
6407c478bd9Sstevel@tonic-gate 				}
6417c478bd9Sstevel@tonic-gate 				if (match("noerror"))
6427c478bd9Sstevel@tonic-gate 				{
6437c478bd9Sstevel@tonic-gate 					cflag |= NERR;
6447c478bd9Sstevel@tonic-gate 					continue;
6457c478bd9Sstevel@tonic-gate 				}
6467c478bd9Sstevel@tonic-gate 				if (match("notrunc"))
6477c478bd9Sstevel@tonic-gate 				{
6487c478bd9Sstevel@tonic-gate 					trunc = 0;
6497c478bd9Sstevel@tonic-gate 					continue;
6507c478bd9Sstevel@tonic-gate 				}
6517c478bd9Sstevel@tonic-gate 				if (match("sync"))
6527c478bd9Sstevel@tonic-gate 				{
6537c478bd9Sstevel@tonic-gate 					cflag |= SYNC;
6547c478bd9Sstevel@tonic-gate 					continue;
6557c478bd9Sstevel@tonic-gate 				}
6567c478bd9Sstevel@tonic-gate 				goto badarg;
6577c478bd9Sstevel@tonic-gate 			}
6587c478bd9Sstevel@tonic-gate 			continue;
6597c478bd9Sstevel@tonic-gate 		}
6607c478bd9Sstevel@tonic-gate 		badarg:
6617c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr, "dd: %s \"%s\"\n",
6627c478bd9Sstevel@tonic-gate 			gettext("bad argument:"), string);
6637c478bd9Sstevel@tonic-gate 		exit(2);
6647c478bd9Sstevel@tonic-gate 	}
6657c478bd9Sstevel@tonic-gate 
6667c478bd9Sstevel@tonic-gate 	/* Perform consistency checks on options, decode strange conventions */
6677c478bd9Sstevel@tonic-gate 
6687c478bd9Sstevel@tonic-gate 	if (bs)
6697c478bd9Sstevel@tonic-gate 	{
6707c478bd9Sstevel@tonic-gate 		ibs = obs = bs;
6717c478bd9Sstevel@tonic-gate 	}
6727c478bd9Sstevel@tonic-gate 	if ((ibs == 0) || (obs == 0))
6737c478bd9Sstevel@tonic-gate 	{
6747c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr, "dd: %s\n",
6757c478bd9Sstevel@tonic-gate 			gettext("buffer sizes cannot be zero"));
6767c478bd9Sstevel@tonic-gate 		exit(2);
6777c478bd9Sstevel@tonic-gate 	}
6787c478bd9Sstevel@tonic-gate 	if (conv == COPY)
6797c478bd9Sstevel@tonic-gate 	{
6807c478bd9Sstevel@tonic-gate 		if ((bs == 0) || (cflag&(LCASE|UCASE)))
6817c478bd9Sstevel@tonic-gate 		{
6827c478bd9Sstevel@tonic-gate 			conv = REBLOCK;
6837c478bd9Sstevel@tonic-gate 		}
6847c478bd9Sstevel@tonic-gate 	}
6857c478bd9Sstevel@tonic-gate 	if (cbs == 0)
6867c478bd9Sstevel@tonic-gate 	{
6877c478bd9Sstevel@tonic-gate 		switch (conv)
6887c478bd9Sstevel@tonic-gate 		{
6897c478bd9Sstevel@tonic-gate 		case BLOCK:
6907c478bd9Sstevel@tonic-gate 		case UNBLOCK:
6917c478bd9Sstevel@tonic-gate 			conv = REBLOCK;
6927c478bd9Sstevel@tonic-gate 			break;
6937c478bd9Sstevel@tonic-gate 
6947c478bd9Sstevel@tonic-gate 		case ASCII:
6957c478bd9Sstevel@tonic-gate 			conv = NBASCII;
6967c478bd9Sstevel@tonic-gate 			break;
6977c478bd9Sstevel@tonic-gate 
6987c478bd9Sstevel@tonic-gate 		case EBCDIC:
6997c478bd9Sstevel@tonic-gate 			conv = NBEBCDIC;
7007c478bd9Sstevel@tonic-gate 			break;
7017c478bd9Sstevel@tonic-gate 
7027c478bd9Sstevel@tonic-gate 		case IBM:
7037c478bd9Sstevel@tonic-gate 			conv = NBIBM;
7047c478bd9Sstevel@tonic-gate 			break;
7057c478bd9Sstevel@tonic-gate 		}
7067c478bd9Sstevel@tonic-gate 	}
7077c478bd9Sstevel@tonic-gate 
7087c478bd9Sstevel@tonic-gate 	/* Expand options into lower and upper case versions if necessary */
7097c478bd9Sstevel@tonic-gate 
7107c478bd9Sstevel@tonic-gate 	switch (conv)
7117c478bd9Sstevel@tonic-gate 	{
7127c478bd9Sstevel@tonic-gate 	case REBLOCK:
7137c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7147c478bd9Sstevel@tonic-gate 			conv = LCREBLOCK;
7157c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7167c478bd9Sstevel@tonic-gate 			conv = UCREBLOCK;
7177c478bd9Sstevel@tonic-gate 		break;
7187c478bd9Sstevel@tonic-gate 
7197c478bd9Sstevel@tonic-gate 	case UNBLOCK:
7207c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7217c478bd9Sstevel@tonic-gate 			conv = LCUNBLOCK;
7227c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7237c478bd9Sstevel@tonic-gate 			conv = UCUNBLOCK;
7247c478bd9Sstevel@tonic-gate 		break;
7257c478bd9Sstevel@tonic-gate 
7267c478bd9Sstevel@tonic-gate 	case BLOCK:
7277c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7287c478bd9Sstevel@tonic-gate 			conv = LCBLOCK;
7297c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7307c478bd9Sstevel@tonic-gate 			conv = UCBLOCK;
7317c478bd9Sstevel@tonic-gate 		break;
7327c478bd9Sstevel@tonic-gate 
7337c478bd9Sstevel@tonic-gate 	case ASCII:
7347c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7357c478bd9Sstevel@tonic-gate 			conv = LCASCII;
7367c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7377c478bd9Sstevel@tonic-gate 			conv = UCASCII;
7387c478bd9Sstevel@tonic-gate 		break;
7397c478bd9Sstevel@tonic-gate 
7407c478bd9Sstevel@tonic-gate 	case NBASCII:
7417c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7427c478bd9Sstevel@tonic-gate 			conv = LCNBASCII;
7437c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7447c478bd9Sstevel@tonic-gate 			conv = UCNBASCII;
7457c478bd9Sstevel@tonic-gate 		break;
7467c478bd9Sstevel@tonic-gate 
7477c478bd9Sstevel@tonic-gate 	case EBCDIC:
7487c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7497c478bd9Sstevel@tonic-gate 			conv = LCEBCDIC;
7507c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7517c478bd9Sstevel@tonic-gate 			conv = UCEBCDIC;
7527c478bd9Sstevel@tonic-gate 		break;
7537c478bd9Sstevel@tonic-gate 
7547c478bd9Sstevel@tonic-gate 	case NBEBCDIC:
7557c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7567c478bd9Sstevel@tonic-gate 			conv = LCNBEBCDIC;
7577c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7587c478bd9Sstevel@tonic-gate 			conv = UCNBEBCDIC;
7597c478bd9Sstevel@tonic-gate 		break;
7607c478bd9Sstevel@tonic-gate 
7617c478bd9Sstevel@tonic-gate 	case IBM:
7627c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7637c478bd9Sstevel@tonic-gate 			conv = LCIBM;
7647c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7657c478bd9Sstevel@tonic-gate 			conv = UCIBM;
7667c478bd9Sstevel@tonic-gate 		break;
7677c478bd9Sstevel@tonic-gate 
7687c478bd9Sstevel@tonic-gate 	case NBIBM:
7697c478bd9Sstevel@tonic-gate 		if (cflag&LCASE)
7707c478bd9Sstevel@tonic-gate 			conv = LCNBIBM;
7717c478bd9Sstevel@tonic-gate 		else if (cflag&UCASE)
7727c478bd9Sstevel@tonic-gate 			conv = UCNBIBM;
7737c478bd9Sstevel@tonic-gate 		break;
7747c478bd9Sstevel@tonic-gate 	}
7757c478bd9Sstevel@tonic-gate 
7767c478bd9Sstevel@tonic-gate 	/* If BSD-compatible translation is selected, change the tables */
7777c478bd9Sstevel@tonic-gate 
7787c478bd9Sstevel@tonic-gate 	if (trantype == BSDXLATE) {
7797c478bd9Sstevel@tonic-gate 		atoe = bsd_atoe;
7807c478bd9Sstevel@tonic-gate 		atoibm = bsd_atoibm;
7817c478bd9Sstevel@tonic-gate 		etoa = bsd_etoa;
7827c478bd9Sstevel@tonic-gate 	}
7837c478bd9Sstevel@tonic-gate 	/* Open the input file, or duplicate standard input */
7847c478bd9Sstevel@tonic-gate 
7857c478bd9Sstevel@tonic-gate 	ibf = -1;
7867c478bd9Sstevel@tonic-gate 	if (ifile)
7877c478bd9Sstevel@tonic-gate 	{
7887c478bd9Sstevel@tonic-gate 		ibf = open(ifile, 0);
7897c478bd9Sstevel@tonic-gate 	}
7907c478bd9Sstevel@tonic-gate #ifndef STANDALONE
7917c478bd9Sstevel@tonic-gate 	else
7927c478bd9Sstevel@tonic-gate 	{
7937c478bd9Sstevel@tonic-gate 		ifile = "";
7947c478bd9Sstevel@tonic-gate 		ibf = dup(0);
7957c478bd9Sstevel@tonic-gate 	}
7967c478bd9Sstevel@tonic-gate #endif
7977c478bd9Sstevel@tonic-gate 	if (ibf == -1)
7987c478bd9Sstevel@tonic-gate 	{
7997c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr, "dd: %s: ", ifile);
8007c478bd9Sstevel@tonic-gate 		perror("open");
8017c478bd9Sstevel@tonic-gate 		exit(2);
8027c478bd9Sstevel@tonic-gate 	}
8037c478bd9Sstevel@tonic-gate 
8047c478bd9Sstevel@tonic-gate 	/* Open the output file, or duplicate standard output */
8057c478bd9Sstevel@tonic-gate 
8067c478bd9Sstevel@tonic-gate 	obf = -1;
8077c478bd9Sstevel@tonic-gate 	if (ofile)
8087c478bd9Sstevel@tonic-gate 	{
8097c478bd9Sstevel@tonic-gate 		if (trunc == 0)	/* do not truncate output file */
8107c478bd9Sstevel@tonic-gate 			obf = open(ofile, (O_WRONLY|O_CREAT),
8117c478bd9Sstevel@tonic-gate 			(S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH));
8127c478bd9Sstevel@tonic-gate 		else if (oseekn && (trunc == 1))
8137c478bd9Sstevel@tonic-gate 		{
8147c478bd9Sstevel@tonic-gate 			obf = open(ofile, O_WRONLY|O_CREAT,
8157c478bd9Sstevel@tonic-gate 			(S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH));
8167c478bd9Sstevel@tonic-gate 			if (obf == -1)
8177c478bd9Sstevel@tonic-gate 			{
8187c478bd9Sstevel@tonic-gate 				(void) fprintf(stderr, "dd: %s: ", ofile);
8197c478bd9Sstevel@tonic-gate 				perror("open");
8207c478bd9Sstevel@tonic-gate 				exit(2);
8217c478bd9Sstevel@tonic-gate 			}
8227c478bd9Sstevel@tonic-gate 			(void) fstat(obf, &file_stat);
8237c478bd9Sstevel@tonic-gate 			if (((file_stat.st_mode & S_IFMT) == S_IFREG) &&
8247c478bd9Sstevel@tonic-gate 			    (ftruncate(obf, (((off_t)oseekn) * ((off_t)obs)))
8257c478bd9Sstevel@tonic-gate 				== -1))
8267c478bd9Sstevel@tonic-gate 			{
8277c478bd9Sstevel@tonic-gate 				perror("ftruncate");
8287c478bd9Sstevel@tonic-gate 				exit(2);
8297c478bd9Sstevel@tonic-gate 			}
8307c478bd9Sstevel@tonic-gate 		}
8317c478bd9Sstevel@tonic-gate 		else
8327c478bd9Sstevel@tonic-gate 			obf = creat(ofile,
8337c478bd9Sstevel@tonic-gate 			(S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH));
8347c478bd9Sstevel@tonic-gate 	}
8357c478bd9Sstevel@tonic-gate #ifndef STANDALONE
8367c478bd9Sstevel@tonic-gate 	else
8377c478bd9Sstevel@tonic-gate 	{
8387c478bd9Sstevel@tonic-gate 		ofile = "";
8397c478bd9Sstevel@tonic-gate 		obf = dup(1);
8407c478bd9Sstevel@tonic-gate 	}
8417c478bd9Sstevel@tonic-gate #endif
8427c478bd9Sstevel@tonic-gate 	if (obf == -1)
8437c478bd9Sstevel@tonic-gate 	{
8447c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr, "dd: %s: ", ofile);
8457c478bd9Sstevel@tonic-gate 		perror("open");
8467c478bd9Sstevel@tonic-gate 		exit(2);
8477c478bd9Sstevel@tonic-gate 	}
8487c478bd9Sstevel@tonic-gate 
8497c478bd9Sstevel@tonic-gate 	/* Expand memory to get an input buffer */
8507c478bd9Sstevel@tonic-gate 
8517c478bd9Sstevel@tonic-gate 	ibuf = (unsigned char *)valloc(ibs + 10);
8527c478bd9Sstevel@tonic-gate 
8537c478bd9Sstevel@tonic-gate 	/* If no conversions, the input buffer is the output buffer */
8547c478bd9Sstevel@tonic-gate 
8557c478bd9Sstevel@tonic-gate 	if (conv == COPY)
8567c478bd9Sstevel@tonic-gate 	{
8577c478bd9Sstevel@tonic-gate 		obuf = ibuf;
8587c478bd9Sstevel@tonic-gate 	}
8597c478bd9Sstevel@tonic-gate 
8607c478bd9Sstevel@tonic-gate 	/* Expand memory to get an output buffer. Leave enough room at the */
8617c478bd9Sstevel@tonic-gate 	/* end to convert a logical record when doing block conversions. */
8627c478bd9Sstevel@tonic-gate 
8637c478bd9Sstevel@tonic-gate 	else
8647c478bd9Sstevel@tonic-gate 	{
8657c478bd9Sstevel@tonic-gate 		obuf = (unsigned char *)valloc(obs + cbs + 10);
8667c478bd9Sstevel@tonic-gate 	}
8677c478bd9Sstevel@tonic-gate 	if ((ibuf == (unsigned char *)NULL) || (obuf == (unsigned char *)NULL))
8687c478bd9Sstevel@tonic-gate 	{
8697c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr,
8707c478bd9Sstevel@tonic-gate 			"dd: %s\n", gettext("not enough memory"));
8717c478bd9Sstevel@tonic-gate 		exit(2);
8727c478bd9Sstevel@tonic-gate 	}
8737c478bd9Sstevel@tonic-gate 
8747c478bd9Sstevel@tonic-gate 	/* Enable a statistics message on SIGINT */
8757c478bd9Sstevel@tonic-gate 
8767c478bd9Sstevel@tonic-gate #ifndef STANDALONE
8777c478bd9Sstevel@tonic-gate 	if (signal(SIGINT, SIG_IGN) != SIG_IGN)
8787c478bd9Sstevel@tonic-gate 	{
8797c478bd9Sstevel@tonic-gate 		(void) signal(SIGINT, term);
8807c478bd9Sstevel@tonic-gate 	}
8817c478bd9Sstevel@tonic-gate #endif
8827c478bd9Sstevel@tonic-gate 	/* Skip input blocks */
8837c478bd9Sstevel@tonic-gate 
8847c478bd9Sstevel@tonic-gate 	while (skip)
8857c478bd9Sstevel@tonic-gate 	{
8867c478bd9Sstevel@tonic-gate 		ibc = read(ibf, (char *)ibuf, ibs);
8877c478bd9Sstevel@tonic-gate 		if (ibc == (unsigned)-1)
8887c478bd9Sstevel@tonic-gate 		{
8897c478bd9Sstevel@tonic-gate 			if (++nbad > BADLIMIT)
8907c478bd9Sstevel@tonic-gate 			{
8917c478bd9Sstevel@tonic-gate 				(void) fprintf(stderr, "dd: %s\n",
8927c478bd9Sstevel@tonic-gate 					gettext("skip failed"));
8937c478bd9Sstevel@tonic-gate 				exit(2);
8947c478bd9Sstevel@tonic-gate 			}
8957c478bd9Sstevel@tonic-gate 			else
8967c478bd9Sstevel@tonic-gate 			{
8977c478bd9Sstevel@tonic-gate 				perror("read");
8987c478bd9Sstevel@tonic-gate 			}
8997c478bd9Sstevel@tonic-gate 		}
9007c478bd9Sstevel@tonic-gate 		else
9017c478bd9Sstevel@tonic-gate 		{
9027c478bd9Sstevel@tonic-gate 			if (ibc == 0)
9037c478bd9Sstevel@tonic-gate 			{
9047c478bd9Sstevel@tonic-gate 				(void) fprintf(stderr, "dd: %s\n",
9057c478bd9Sstevel@tonic-gate 				gettext("cannot skip past end-of-file"));
9067c478bd9Sstevel@tonic-gate 				exit(3);
9077c478bd9Sstevel@tonic-gate 			}
9087c478bd9Sstevel@tonic-gate 			else
9097c478bd9Sstevel@tonic-gate 			{
9107c478bd9Sstevel@tonic-gate 				nbad = 0;
9117c478bd9Sstevel@tonic-gate 			}
9127c478bd9Sstevel@tonic-gate 		}
9137c478bd9Sstevel@tonic-gate 		skip--;
9147c478bd9Sstevel@tonic-gate 	}
9157c478bd9Sstevel@tonic-gate 
9167c478bd9Sstevel@tonic-gate 	/* Seek past input blocks */
9177c478bd9Sstevel@tonic-gate 
9187c478bd9Sstevel@tonic-gate 	if (iseekn && lseek(ibf, (((off_t)iseekn) * ((off_t)ibs)), 1) == -1)
9197c478bd9Sstevel@tonic-gate 	{
9207c478bd9Sstevel@tonic-gate 		perror("lseek");
9217c478bd9Sstevel@tonic-gate 		exit(2);
9227c478bd9Sstevel@tonic-gate 	}
9237c478bd9Sstevel@tonic-gate 
9247c478bd9Sstevel@tonic-gate 	/* Seek past output blocks */
9257c478bd9Sstevel@tonic-gate 
9267c478bd9Sstevel@tonic-gate 	if (oseekn && lseek(obf, (((off_t)oseekn) * ((off_t)obs)), 1) == -1)
9277c478bd9Sstevel@tonic-gate 	{
9287c478bd9Sstevel@tonic-gate 		perror("lseek");
9297c478bd9Sstevel@tonic-gate 		exit(2);
9307c478bd9Sstevel@tonic-gate 	}
9317c478bd9Sstevel@tonic-gate 
9327c478bd9Sstevel@tonic-gate 	/* Initialize all buffer pointers */
9337c478bd9Sstevel@tonic-gate 
9347c478bd9Sstevel@tonic-gate 	skipf = 0;	/* not skipping an input line */
9357c478bd9Sstevel@tonic-gate 	ibc = 0;	/* no input characters yet */
9367c478bd9Sstevel@tonic-gate 	obc = 0;	/* no output characters yet */
9377c478bd9Sstevel@tonic-gate 	cbc = 0;	/* the conversion buffer is empty */
9387c478bd9Sstevel@tonic-gate 	op = obuf;	/* point to the output buffer */
9397c478bd9Sstevel@tonic-gate 
9407c478bd9Sstevel@tonic-gate 	/* Read and convert input blocks until end of file(s) */
9417c478bd9Sstevel@tonic-gate 
9427c478bd9Sstevel@tonic-gate 	for (;;)
9437c478bd9Sstevel@tonic-gate 	{
9447c478bd9Sstevel@tonic-gate 		if ((count == 0) || (nifr+nipr < count))
9457c478bd9Sstevel@tonic-gate 		{
9467c478bd9Sstevel@tonic-gate 		/* If proceed on error is enabled, zero the input buffer */
9477c478bd9Sstevel@tonic-gate 
9487c478bd9Sstevel@tonic-gate 			if (cflag&NERR)
9497c478bd9Sstevel@tonic-gate 			{
9507c478bd9Sstevel@tonic-gate 				ip = ibuf + ibs;
9517c478bd9Sstevel@tonic-gate 				c = ibs;
9527c478bd9Sstevel@tonic-gate 				if (c & 1)	/* if the size is odd, */
9537c478bd9Sstevel@tonic-gate 				{
9547c478bd9Sstevel@tonic-gate 					*--ip = 0;	/* clear the odd byte */
9557c478bd9Sstevel@tonic-gate 				}
9567c478bd9Sstevel@tonic-gate 				if (c >>= 1)		/* divide by two */
9577c478bd9Sstevel@tonic-gate 				{
9587c478bd9Sstevel@tonic-gate 					do {	/* clear two at a time */
9597c478bd9Sstevel@tonic-gate 						*--ip = 0;
9607c478bd9Sstevel@tonic-gate 						*--ip = 0;
9617c478bd9Sstevel@tonic-gate 					} while (--c);
9627c478bd9Sstevel@tonic-gate 				}
9637c478bd9Sstevel@tonic-gate 			}
9647c478bd9Sstevel@tonic-gate 
9657c478bd9Sstevel@tonic-gate 			/* Read the next input block */
9667c478bd9Sstevel@tonic-gate 
9677c478bd9Sstevel@tonic-gate 			ibc = read(ibf, (char *)ibuf, ibs);
9687c478bd9Sstevel@tonic-gate 
9697c478bd9Sstevel@tonic-gate 			/* Process input errors */
9707c478bd9Sstevel@tonic-gate 
9717c478bd9Sstevel@tonic-gate 			if (ibc == (unsigned)-1)
9727c478bd9Sstevel@tonic-gate 			{
9737c478bd9Sstevel@tonic-gate 				perror("read");
9747c478bd9Sstevel@tonic-gate 				if (((cflag&NERR) == 0) || (++nbad > BADLIMIT))
9757c478bd9Sstevel@tonic-gate 				{
9767c478bd9Sstevel@tonic-gate 					while (obc)
9777c478bd9Sstevel@tonic-gate 					{
9787c478bd9Sstevel@tonic-gate 						(void) flsh();
9797c478bd9Sstevel@tonic-gate 					}
9807c478bd9Sstevel@tonic-gate 					term(2);
9817c478bd9Sstevel@tonic-gate 				}
9827c478bd9Sstevel@tonic-gate 				else
9837c478bd9Sstevel@tonic-gate 				{
9847c478bd9Sstevel@tonic-gate 					stats();
9857c478bd9Sstevel@tonic-gate 					ibc = ibs; /* assume a full block */
9867c478bd9Sstevel@tonic-gate 				}
9877c478bd9Sstevel@tonic-gate 			}
9887c478bd9Sstevel@tonic-gate 			else
9897c478bd9Sstevel@tonic-gate 			{
9907c478bd9Sstevel@tonic-gate 				nbad = 0;
9917c478bd9Sstevel@tonic-gate 			}
9927c478bd9Sstevel@tonic-gate 		}
9937c478bd9Sstevel@tonic-gate 
9947c478bd9Sstevel@tonic-gate 		/* Record count satisfied, simulate end of file */
9957c478bd9Sstevel@tonic-gate 
9967c478bd9Sstevel@tonic-gate 		else
9977c478bd9Sstevel@tonic-gate 		{
9987c478bd9Sstevel@tonic-gate 			ibc = 0;
9997c478bd9Sstevel@tonic-gate 			files = 1;
10007c478bd9Sstevel@tonic-gate 		}
10017c478bd9Sstevel@tonic-gate 
10027c478bd9Sstevel@tonic-gate 		/* Process end of file */
10037c478bd9Sstevel@tonic-gate 
10047c478bd9Sstevel@tonic-gate 		if (ibc == 0)
10057c478bd9Sstevel@tonic-gate 		{
10067c478bd9Sstevel@tonic-gate 			switch (conv)
10077c478bd9Sstevel@tonic-gate 			{
10087c478bd9Sstevel@tonic-gate 			case UNBLOCK:
10097c478bd9Sstevel@tonic-gate 			case LCUNBLOCK:
10107c478bd9Sstevel@tonic-gate 			case UCUNBLOCK:
10117c478bd9Sstevel@tonic-gate 			case ASCII:
10127c478bd9Sstevel@tonic-gate 			case LCASCII:
10137c478bd9Sstevel@tonic-gate 			case UCASCII:
10147c478bd9Sstevel@tonic-gate 
10157c478bd9Sstevel@tonic-gate 				/* Trim trailing blanks from the last line */
10167c478bd9Sstevel@tonic-gate 
10177c478bd9Sstevel@tonic-gate 				if ((c = cbc) != 0)
10187c478bd9Sstevel@tonic-gate 				{
10197c478bd9Sstevel@tonic-gate 					do {
10207c478bd9Sstevel@tonic-gate 						if ((*--op) != ' ')
10217c478bd9Sstevel@tonic-gate 						{
10227c478bd9Sstevel@tonic-gate 							op++;
10237c478bd9Sstevel@tonic-gate 							break;
10247c478bd9Sstevel@tonic-gate 						}
10257c478bd9Sstevel@tonic-gate 					} while (--c);
10267c478bd9Sstevel@tonic-gate 					*op++ = '\n';
10277c478bd9Sstevel@tonic-gate 					obc -= cbc - c - 1;
10287c478bd9Sstevel@tonic-gate 					cbc = 0;
10297c478bd9Sstevel@tonic-gate 
10307c478bd9Sstevel@tonic-gate 					/* Flush the output buffer if full */
10317c478bd9Sstevel@tonic-gate 
10327c478bd9Sstevel@tonic-gate 					while (obc >= obs)
10337c478bd9Sstevel@tonic-gate 					{
10347c478bd9Sstevel@tonic-gate 						op = flsh();
10357c478bd9Sstevel@tonic-gate 					}
10367c478bd9Sstevel@tonic-gate 				}
10377c478bd9Sstevel@tonic-gate 				break;
10387c478bd9Sstevel@tonic-gate 
10397c478bd9Sstevel@tonic-gate 			case BLOCK:
10407c478bd9Sstevel@tonic-gate 			case LCBLOCK:
10417c478bd9Sstevel@tonic-gate 			case UCBLOCK:
10427c478bd9Sstevel@tonic-gate 			case EBCDIC:
10437c478bd9Sstevel@tonic-gate 			case LCEBCDIC:
10447c478bd9Sstevel@tonic-gate 			case UCEBCDIC:
10457c478bd9Sstevel@tonic-gate 			case IBM:
10467c478bd9Sstevel@tonic-gate 			case LCIBM:
10477c478bd9Sstevel@tonic-gate 			case UCIBM:
10487c478bd9Sstevel@tonic-gate 
10497c478bd9Sstevel@tonic-gate 			/* Pad trailing blanks if the last line is short */
10507c478bd9Sstevel@tonic-gate 
10517c478bd9Sstevel@tonic-gate 				if (cbc)
10527c478bd9Sstevel@tonic-gate 				{
10537c478bd9Sstevel@tonic-gate 					obc += c = cbs - cbc;
10547c478bd9Sstevel@tonic-gate 					cbc = 0;
10557c478bd9Sstevel@tonic-gate 					if (c > 0)
10567c478bd9Sstevel@tonic-gate 					{
10577c478bd9Sstevel@tonic-gate 					/* Use the right kind of blank */
10587c478bd9Sstevel@tonic-gate 
10597c478bd9Sstevel@tonic-gate 						switch (conv)
10607c478bd9Sstevel@tonic-gate 						{
10617c478bd9Sstevel@tonic-gate 						case BLOCK:
10627c478bd9Sstevel@tonic-gate 						case LCBLOCK:
10637c478bd9Sstevel@tonic-gate 						case UCBLOCK:
10647c478bd9Sstevel@tonic-gate 							ic = ' ';
10657c478bd9Sstevel@tonic-gate 							break;
10667c478bd9Sstevel@tonic-gate 
10677c478bd9Sstevel@tonic-gate 						case EBCDIC:
10687c478bd9Sstevel@tonic-gate 						case LCEBCDIC:
10697c478bd9Sstevel@tonic-gate 						case UCEBCDIC:
10707c478bd9Sstevel@tonic-gate 							ic = atoe[' '];
10717c478bd9Sstevel@tonic-gate 							break;
10727c478bd9Sstevel@tonic-gate 
10737c478bd9Sstevel@tonic-gate 						case IBM:
10747c478bd9Sstevel@tonic-gate 						case LCIBM:
10757c478bd9Sstevel@tonic-gate 						case UCIBM:
10767c478bd9Sstevel@tonic-gate 							ic = atoibm[' '];
10777c478bd9Sstevel@tonic-gate 							break;
10787c478bd9Sstevel@tonic-gate 						}
10797c478bd9Sstevel@tonic-gate 
10807c478bd9Sstevel@tonic-gate 						/* Pad with trailing blanks */
10817c478bd9Sstevel@tonic-gate 
10827c478bd9Sstevel@tonic-gate 						do {
10837c478bd9Sstevel@tonic-gate 							*op++ = ic;
10847c478bd9Sstevel@tonic-gate 						} while (--c);
10857c478bd9Sstevel@tonic-gate 					}
10867c478bd9Sstevel@tonic-gate 				}
10877c478bd9Sstevel@tonic-gate 
10887c478bd9Sstevel@tonic-gate 
10897c478bd9Sstevel@tonic-gate 				/* Flush the output buffer if full */
10907c478bd9Sstevel@tonic-gate 
10917c478bd9Sstevel@tonic-gate 				while (obc >= obs)
10927c478bd9Sstevel@tonic-gate 				{
10937c478bd9Sstevel@tonic-gate 					op = flsh();
10947c478bd9Sstevel@tonic-gate 				}
10957c478bd9Sstevel@tonic-gate 				break;
10967c478bd9Sstevel@tonic-gate 			}
10977c478bd9Sstevel@tonic-gate 
10987c478bd9Sstevel@tonic-gate 			/* If no more files to read, flush the output buffer */
10997c478bd9Sstevel@tonic-gate 
11007c478bd9Sstevel@tonic-gate 			if (--files <= 0)
11017c478bd9Sstevel@tonic-gate 			{
11027c478bd9Sstevel@tonic-gate 				(void) flsh();
11037c478bd9Sstevel@tonic-gate 				if ((close(obf) != 0) || (fclose(stdout) != 0))
11047c478bd9Sstevel@tonic-gate 				{
11057c478bd9Sstevel@tonic-gate 					perror(gettext("dd: close error"));
11067c478bd9Sstevel@tonic-gate 					exit(2);
11077c478bd9Sstevel@tonic-gate 				}
11087c478bd9Sstevel@tonic-gate 				term(0);	/* successful exit */
11097c478bd9Sstevel@tonic-gate 			}
11107c478bd9Sstevel@tonic-gate 			else
11117c478bd9Sstevel@tonic-gate 			{
11127c478bd9Sstevel@tonic-gate 				continue;	/* read the next file */
11137c478bd9Sstevel@tonic-gate 			}
11147c478bd9Sstevel@tonic-gate 		}
11157c478bd9Sstevel@tonic-gate 
11167c478bd9Sstevel@tonic-gate 		/* Normal read, check for special cases */
11177c478bd9Sstevel@tonic-gate 
11187c478bd9Sstevel@tonic-gate 		else if (ibc == ibs)
11197c478bd9Sstevel@tonic-gate 		{
11207c478bd9Sstevel@tonic-gate 			nifr++;		/* count another full input record */
11217c478bd9Sstevel@tonic-gate 		}
11227c478bd9Sstevel@tonic-gate 		else
11237c478bd9Sstevel@tonic-gate 		{
11247c478bd9Sstevel@tonic-gate 			nipr++;		/* count a partial input record */
11257c478bd9Sstevel@tonic-gate 
11267c478bd9Sstevel@tonic-gate 			/* If `sync' enabled, pad nulls */
11277c478bd9Sstevel@tonic-gate 
11287c478bd9Sstevel@tonic-gate 			if ((cflag&SYNC) && ((cflag&NERR) == 0))
11297c478bd9Sstevel@tonic-gate 			{
11307c478bd9Sstevel@tonic-gate 				c = ibs - ibc;
11317c478bd9Sstevel@tonic-gate 				ip = ibuf + ibs;
11327c478bd9Sstevel@tonic-gate 				do {
11337c478bd9Sstevel@tonic-gate 				if ((conv == BLOCK) || (conv == UNBLOCK))
11347c478bd9Sstevel@tonic-gate 					*--ip = ' ';
11357c478bd9Sstevel@tonic-gate 				else
11367c478bd9Sstevel@tonic-gate 					*--ip = '\0';
11377c478bd9Sstevel@tonic-gate 				} while (--c);
11387c478bd9Sstevel@tonic-gate 				ibc = ibs;
11397c478bd9Sstevel@tonic-gate 			}
11407c478bd9Sstevel@tonic-gate 		}
11417c478bd9Sstevel@tonic-gate 
11427c478bd9Sstevel@tonic-gate 		/* Swap the bytes in the input buffer if necessary */
11437c478bd9Sstevel@tonic-gate 
11447c478bd9Sstevel@tonic-gate 		if (cflag&SWAB)
11457c478bd9Sstevel@tonic-gate 		{
11467c478bd9Sstevel@tonic-gate 			ip = ibuf;
11477c478bd9Sstevel@tonic-gate 			if (ibc & 1)	/* if the byte count is odd, */
11487c478bd9Sstevel@tonic-gate 			{
11497c478bd9Sstevel@tonic-gate 				ip[ibc] = 0;  /* make it even, pad with zero */
11507c478bd9Sstevel@tonic-gate 			}
11517c478bd9Sstevel@tonic-gate 			c = ibc >> 1;	/* compute the pair count */
11527c478bd9Sstevel@tonic-gate 			do {
11537c478bd9Sstevel@tonic-gate 				ic = *ip++;
11547c478bd9Sstevel@tonic-gate 				ip[-1] = *ip;
11557c478bd9Sstevel@tonic-gate 				*ip++ = ic;
11567c478bd9Sstevel@tonic-gate 			} while (--c);		/* do two bytes at a time */
11577c478bd9Sstevel@tonic-gate 		}
11587c478bd9Sstevel@tonic-gate 
11597c478bd9Sstevel@tonic-gate 		/* Select the appropriate conversion loop */
11607c478bd9Sstevel@tonic-gate 
11617c478bd9Sstevel@tonic-gate 		ip = ibuf;
11627c478bd9Sstevel@tonic-gate 		switch (conv)
11637c478bd9Sstevel@tonic-gate 		{
11647c478bd9Sstevel@tonic-gate 
11657c478bd9Sstevel@tonic-gate 		/* Simple copy: no conversion, preserve the input block size */
11667c478bd9Sstevel@tonic-gate 
11677c478bd9Sstevel@tonic-gate 		case COPY:
11687c478bd9Sstevel@tonic-gate 			obc = ibc;
11697c478bd9Sstevel@tonic-gate 			(void) flsh();
11707c478bd9Sstevel@tonic-gate 			break;
11717c478bd9Sstevel@tonic-gate 
11727c478bd9Sstevel@tonic-gate 		/* Simple copy: pack all output into equal sized blocks */
11737c478bd9Sstevel@tonic-gate 
11747c478bd9Sstevel@tonic-gate 		case REBLOCK:
11757c478bd9Sstevel@tonic-gate 		case LCREBLOCK:
11767c478bd9Sstevel@tonic-gate 		case UCREBLOCK:
11777c478bd9Sstevel@tonic-gate 		case NBASCII:
11787c478bd9Sstevel@tonic-gate 		case LCNBASCII:
11797c478bd9Sstevel@tonic-gate 		case UCNBASCII:
11807c478bd9Sstevel@tonic-gate 		case NBEBCDIC:
11817c478bd9Sstevel@tonic-gate 		case LCNBEBCDIC:
11827c478bd9Sstevel@tonic-gate 		case UCNBEBCDIC:
11837c478bd9Sstevel@tonic-gate 		case NBIBM:
11847c478bd9Sstevel@tonic-gate 		case LCNBIBM:
11857c478bd9Sstevel@tonic-gate 		case UCNBIBM:
11867c478bd9Sstevel@tonic-gate 			while ((c = ibc) != 0)
11877c478bd9Sstevel@tonic-gate 			{
11887c478bd9Sstevel@tonic-gate 				if (c > (obs - obc))
11897c478bd9Sstevel@tonic-gate 				{
11907c478bd9Sstevel@tonic-gate 					c = obs - obc;
11917c478bd9Sstevel@tonic-gate 				}
11927c478bd9Sstevel@tonic-gate 				ibc -= c;
11937c478bd9Sstevel@tonic-gate 				obc += c;
11947c478bd9Sstevel@tonic-gate 				switch (conv)
11957c478bd9Sstevel@tonic-gate 				{
11967c478bd9Sstevel@tonic-gate 				case REBLOCK:
11977c478bd9Sstevel@tonic-gate 					do {
11987c478bd9Sstevel@tonic-gate 						*op++ = *ip++;
11997c478bd9Sstevel@tonic-gate 					} while (--c);
12007c478bd9Sstevel@tonic-gate 					break;
12017c478bd9Sstevel@tonic-gate 
12027c478bd9Sstevel@tonic-gate 				case LCREBLOCK:
12037c478bd9Sstevel@tonic-gate 					do {
12047c478bd9Sstevel@tonic-gate 						*op++ = utol[*ip++];
12057c478bd9Sstevel@tonic-gate 					} while (--c);
12067c478bd9Sstevel@tonic-gate 					break;
12077c478bd9Sstevel@tonic-gate 
12087c478bd9Sstevel@tonic-gate 				case UCREBLOCK:
12097c478bd9Sstevel@tonic-gate 					do {
12107c478bd9Sstevel@tonic-gate 						*op++ = ltou[*ip++];
12117c478bd9Sstevel@tonic-gate 					} while (--c);
12127c478bd9Sstevel@tonic-gate 					break;
12137c478bd9Sstevel@tonic-gate 
12147c478bd9Sstevel@tonic-gate 				case NBASCII:
12157c478bd9Sstevel@tonic-gate 					do {
12167c478bd9Sstevel@tonic-gate 						*op++ = etoa[*ip++];
12177c478bd9Sstevel@tonic-gate 					} while (--c);
12187c478bd9Sstevel@tonic-gate 					break;
12197c478bd9Sstevel@tonic-gate 
12207c478bd9Sstevel@tonic-gate 				case LCNBASCII:
12217c478bd9Sstevel@tonic-gate 					do {
12227c478bd9Sstevel@tonic-gate 						*op++ = utol[etoa[*ip++]];
12237c478bd9Sstevel@tonic-gate 					} while (--c);
12247c478bd9Sstevel@tonic-gate 					break;
12257c478bd9Sstevel@tonic-gate 
12267c478bd9Sstevel@tonic-gate 				case UCNBASCII:
12277c478bd9Sstevel@tonic-gate 					do {
12287c478bd9Sstevel@tonic-gate 						*op++ = ltou[etoa[*ip++]];
12297c478bd9Sstevel@tonic-gate 					} while (--c);
12307c478bd9Sstevel@tonic-gate 					break;
12317c478bd9Sstevel@tonic-gate 
12327c478bd9Sstevel@tonic-gate 				case NBEBCDIC:
12337c478bd9Sstevel@tonic-gate 					do {
12347c478bd9Sstevel@tonic-gate 						*op++ = atoe[*ip++];
12357c478bd9Sstevel@tonic-gate 					} while (--c);
12367c478bd9Sstevel@tonic-gate 					break;
12377c478bd9Sstevel@tonic-gate 
12387c478bd9Sstevel@tonic-gate 				case LCNBEBCDIC:
12397c478bd9Sstevel@tonic-gate 					do {
12407c478bd9Sstevel@tonic-gate 						*op++ = atoe[utol[*ip++]];
12417c478bd9Sstevel@tonic-gate 					} while (--c);
12427c478bd9Sstevel@tonic-gate 					break;
12437c478bd9Sstevel@tonic-gate 
12447c478bd9Sstevel@tonic-gate 				case UCNBEBCDIC:
12457c478bd9Sstevel@tonic-gate 					do {
12467c478bd9Sstevel@tonic-gate 						*op++ = atoe[ltou[*ip++]];
12477c478bd9Sstevel@tonic-gate 					} while (--c);
12487c478bd9Sstevel@tonic-gate 					break;
12497c478bd9Sstevel@tonic-gate 
12507c478bd9Sstevel@tonic-gate 				case NBIBM:
12517c478bd9Sstevel@tonic-gate 					do {
12527c478bd9Sstevel@tonic-gate 						*op++ = atoibm[*ip++];
12537c478bd9Sstevel@tonic-gate 					} while (--c);
12547c478bd9Sstevel@tonic-gate 					break;
12557c478bd9Sstevel@tonic-gate 
12567c478bd9Sstevel@tonic-gate 				case LCNBIBM:
12577c478bd9Sstevel@tonic-gate 					do {
12587c478bd9Sstevel@tonic-gate 						*op++ = atoibm[utol[*ip++]];
12597c478bd9Sstevel@tonic-gate 					} while (--c);
12607c478bd9Sstevel@tonic-gate 					break;
12617c478bd9Sstevel@tonic-gate 
12627c478bd9Sstevel@tonic-gate 				case UCNBIBM:
12637c478bd9Sstevel@tonic-gate 					do {
12647c478bd9Sstevel@tonic-gate 						*op++ = atoibm[ltou[*ip++]];
12657c478bd9Sstevel@tonic-gate 					} while (--c);
12667c478bd9Sstevel@tonic-gate 					break;
12677c478bd9Sstevel@tonic-gate 				}
12687c478bd9Sstevel@tonic-gate 				if (obc >= obs)
12697c478bd9Sstevel@tonic-gate 				{
12707c478bd9Sstevel@tonic-gate 					op = flsh();
12717c478bd9Sstevel@tonic-gate 				}
12727c478bd9Sstevel@tonic-gate 			}
12737c478bd9Sstevel@tonic-gate 			break;
12747c478bd9Sstevel@tonic-gate 
12757c478bd9Sstevel@tonic-gate 	/* Convert from blocked records to lines terminated by newline */
12767c478bd9Sstevel@tonic-gate 
12777c478bd9Sstevel@tonic-gate 		case UNBLOCK:
12787c478bd9Sstevel@tonic-gate 		case LCUNBLOCK:
12797c478bd9Sstevel@tonic-gate 		case UCUNBLOCK:
12807c478bd9Sstevel@tonic-gate 		case ASCII:
12817c478bd9Sstevel@tonic-gate 		case LCASCII:
12827c478bd9Sstevel@tonic-gate 		case UCASCII:
12837c478bd9Sstevel@tonic-gate 			while ((c = ibc) != 0)
12847c478bd9Sstevel@tonic-gate 			{
12857c478bd9Sstevel@tonic-gate 				if (c > (cbs - cbc))
12867c478bd9Sstevel@tonic-gate 						/* if more than one record, */
12877c478bd9Sstevel@tonic-gate 				{
12887c478bd9Sstevel@tonic-gate 					c = cbs - cbc;
12897c478bd9Sstevel@tonic-gate 						/* only copy one record */
12907c478bd9Sstevel@tonic-gate 				}
12917c478bd9Sstevel@tonic-gate 				ibc -= c;
12927c478bd9Sstevel@tonic-gate 				cbc += c;
12937c478bd9Sstevel@tonic-gate 				obc += c;
12947c478bd9Sstevel@tonic-gate 				switch (conv)
12957c478bd9Sstevel@tonic-gate 				{
12967c478bd9Sstevel@tonic-gate 				case UNBLOCK:
12977c478bd9Sstevel@tonic-gate 					do {
12987c478bd9Sstevel@tonic-gate 						*op++ = *ip++;
12997c478bd9Sstevel@tonic-gate 					} while (--c);
13007c478bd9Sstevel@tonic-gate 					break;
13017c478bd9Sstevel@tonic-gate 
13027c478bd9Sstevel@tonic-gate 				case LCUNBLOCK:
13037c478bd9Sstevel@tonic-gate 					do {
13047c478bd9Sstevel@tonic-gate 						*op++ = utol[*ip++];
13057c478bd9Sstevel@tonic-gate 					} while (--c);
13067c478bd9Sstevel@tonic-gate 					break;
13077c478bd9Sstevel@tonic-gate 
13087c478bd9Sstevel@tonic-gate 				case UCUNBLOCK:
13097c478bd9Sstevel@tonic-gate 					do {
13107c478bd9Sstevel@tonic-gate 						*op++ = ltou[*ip++];
13117c478bd9Sstevel@tonic-gate 					} while (--c);
13127c478bd9Sstevel@tonic-gate 					break;
13137c478bd9Sstevel@tonic-gate 
13147c478bd9Sstevel@tonic-gate 				case ASCII:
13157c478bd9Sstevel@tonic-gate 					do {
13167c478bd9Sstevel@tonic-gate 						*op++ = etoa[*ip++];
13177c478bd9Sstevel@tonic-gate 					} while (--c);
13187c478bd9Sstevel@tonic-gate 					break;
13197c478bd9Sstevel@tonic-gate 
13207c478bd9Sstevel@tonic-gate 				case LCASCII:
13217c478bd9Sstevel@tonic-gate 					do {
13227c478bd9Sstevel@tonic-gate 						*op++ = utol[etoa[*ip++]];
13237c478bd9Sstevel@tonic-gate 					} while (--c);
13247c478bd9Sstevel@tonic-gate 					break;
13257c478bd9Sstevel@tonic-gate 
13267c478bd9Sstevel@tonic-gate 				case UCASCII:
13277c478bd9Sstevel@tonic-gate 					do {
13287c478bd9Sstevel@tonic-gate 						*op++ = ltou[etoa[*ip++]];
13297c478bd9Sstevel@tonic-gate 					} while (--c);
13307c478bd9Sstevel@tonic-gate 					break;
13317c478bd9Sstevel@tonic-gate 				}
13327c478bd9Sstevel@tonic-gate 
13337c478bd9Sstevel@tonic-gate 				/* Trim trailing blanks if the line is full */
13347c478bd9Sstevel@tonic-gate 
13357c478bd9Sstevel@tonic-gate 				if (cbc == cbs)
13367c478bd9Sstevel@tonic-gate 				{
13377c478bd9Sstevel@tonic-gate 					c = cbs; /* `do - while' is usually */
13387c478bd9Sstevel@tonic-gate 					do {		/* faster than `for' */
13397c478bd9Sstevel@tonic-gate 						if ((*--op) != ' ')
13407c478bd9Sstevel@tonic-gate 						{
13417c478bd9Sstevel@tonic-gate 							op++;
13427c478bd9Sstevel@tonic-gate 							break;
13437c478bd9Sstevel@tonic-gate 						}
13447c478bd9Sstevel@tonic-gate 					} while (--c);
13457c478bd9Sstevel@tonic-gate 					*op++ = '\n';
13467c478bd9Sstevel@tonic-gate 					obc -= cbs - c - 1;
13477c478bd9Sstevel@tonic-gate 					cbc = 0;
13487c478bd9Sstevel@tonic-gate 
13497c478bd9Sstevel@tonic-gate 					/* Flush the output buffer if full */
13507c478bd9Sstevel@tonic-gate 
13517c478bd9Sstevel@tonic-gate 					while (obc >= obs)
13527c478bd9Sstevel@tonic-gate 					{
13537c478bd9Sstevel@tonic-gate 						op = flsh();
13547c478bd9Sstevel@tonic-gate 					}
13557c478bd9Sstevel@tonic-gate 				}
13567c478bd9Sstevel@tonic-gate 			}
13577c478bd9Sstevel@tonic-gate 			break;
13587c478bd9Sstevel@tonic-gate 
13597c478bd9Sstevel@tonic-gate 		/* Convert to blocked records */
13607c478bd9Sstevel@tonic-gate 
13617c478bd9Sstevel@tonic-gate 		case BLOCK:
13627c478bd9Sstevel@tonic-gate 		case LCBLOCK:
13637c478bd9Sstevel@tonic-gate 		case UCBLOCK:
13647c478bd9Sstevel@tonic-gate 		case EBCDIC:
13657c478bd9Sstevel@tonic-gate 		case LCEBCDIC:
13667c478bd9Sstevel@tonic-gate 		case UCEBCDIC:
13677c478bd9Sstevel@tonic-gate 		case IBM:
13687c478bd9Sstevel@tonic-gate 		case LCIBM:
13697c478bd9Sstevel@tonic-gate 		case UCIBM:
13707c478bd9Sstevel@tonic-gate 			while ((c = ibc) != 0)
13717c478bd9Sstevel@tonic-gate 			{
13727c478bd9Sstevel@tonic-gate 				int nlflag = 0;
13737c478bd9Sstevel@tonic-gate 
13747c478bd9Sstevel@tonic-gate 			/* We may have to skip to the end of a long line */
13757c478bd9Sstevel@tonic-gate 
13767c478bd9Sstevel@tonic-gate 				if (skipf)
13777c478bd9Sstevel@tonic-gate 				{
13787c478bd9Sstevel@tonic-gate 					do {
13797c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) == '\n')
13807c478bd9Sstevel@tonic-gate 						{
13817c478bd9Sstevel@tonic-gate 							skipf = 0;
13827c478bd9Sstevel@tonic-gate 							c--;
13837c478bd9Sstevel@tonic-gate 							break;
13847c478bd9Sstevel@tonic-gate 						}
13857c478bd9Sstevel@tonic-gate 					} while (--c);
13867c478bd9Sstevel@tonic-gate 					if ((ibc = c) == 0)
13877c478bd9Sstevel@tonic-gate 					{
13887c478bd9Sstevel@tonic-gate 						continue;
13897c478bd9Sstevel@tonic-gate 							/* read another block */
13907c478bd9Sstevel@tonic-gate 					}
13917c478bd9Sstevel@tonic-gate 				}
13927c478bd9Sstevel@tonic-gate 
13937c478bd9Sstevel@tonic-gate 				/* If anything left, copy until newline */
13947c478bd9Sstevel@tonic-gate 
13957c478bd9Sstevel@tonic-gate 				if (c > (cbs - cbc + 1))
13967c478bd9Sstevel@tonic-gate 				{
13977c478bd9Sstevel@tonic-gate 					c = cbs - cbc + 1;
13987c478bd9Sstevel@tonic-gate 				}
13997c478bd9Sstevel@tonic-gate 				ibc -= c;
14007c478bd9Sstevel@tonic-gate 				cbc += c;
14017c478bd9Sstevel@tonic-gate 				obc += c;
14027c478bd9Sstevel@tonic-gate 
14037c478bd9Sstevel@tonic-gate 				switch (conv)
14047c478bd9Sstevel@tonic-gate 				{
14057c478bd9Sstevel@tonic-gate 				case BLOCK:
14067c478bd9Sstevel@tonic-gate 					do {
14077c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14087c478bd9Sstevel@tonic-gate 						{
14097c478bd9Sstevel@tonic-gate 							*op++ = ic;
14107c478bd9Sstevel@tonic-gate 						}
14117c478bd9Sstevel@tonic-gate 						else
14127c478bd9Sstevel@tonic-gate 						{
14137c478bd9Sstevel@tonic-gate 							nlflag = 1;
14147c478bd9Sstevel@tonic-gate 							break;
14157c478bd9Sstevel@tonic-gate 						}
14167c478bd9Sstevel@tonic-gate 					} while (--c);
14177c478bd9Sstevel@tonic-gate 					break;
14187c478bd9Sstevel@tonic-gate 
14197c478bd9Sstevel@tonic-gate 				case LCBLOCK:
14207c478bd9Sstevel@tonic-gate 					do {
14217c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14227c478bd9Sstevel@tonic-gate 						{
14237c478bd9Sstevel@tonic-gate 							*op++ = utol[ic];
14247c478bd9Sstevel@tonic-gate 						}
14257c478bd9Sstevel@tonic-gate 						else
14267c478bd9Sstevel@tonic-gate 						{
14277c478bd9Sstevel@tonic-gate 							nlflag = 1;
14287c478bd9Sstevel@tonic-gate 							break;
14297c478bd9Sstevel@tonic-gate 						}
14307c478bd9Sstevel@tonic-gate 					} while (--c);
14317c478bd9Sstevel@tonic-gate 					break;
14327c478bd9Sstevel@tonic-gate 
14337c478bd9Sstevel@tonic-gate 				case UCBLOCK:
14347c478bd9Sstevel@tonic-gate 					do {
14357c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14367c478bd9Sstevel@tonic-gate 						{
14377c478bd9Sstevel@tonic-gate 							*op++ = ltou[ic];
14387c478bd9Sstevel@tonic-gate 						}
14397c478bd9Sstevel@tonic-gate 						else
14407c478bd9Sstevel@tonic-gate 						{
14417c478bd9Sstevel@tonic-gate 							nlflag = 1;
14427c478bd9Sstevel@tonic-gate 							break;
14437c478bd9Sstevel@tonic-gate 						}
14447c478bd9Sstevel@tonic-gate 					} while (--c);
14457c478bd9Sstevel@tonic-gate 					break;
14467c478bd9Sstevel@tonic-gate 
14477c478bd9Sstevel@tonic-gate 				case EBCDIC:
14487c478bd9Sstevel@tonic-gate 					do {
14497c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14507c478bd9Sstevel@tonic-gate 						{
14517c478bd9Sstevel@tonic-gate 							*op++ = atoe[ic];
14527c478bd9Sstevel@tonic-gate 						}
14537c478bd9Sstevel@tonic-gate 						else
14547c478bd9Sstevel@tonic-gate 						{
14557c478bd9Sstevel@tonic-gate 							nlflag = 1;
14567c478bd9Sstevel@tonic-gate 							break;
14577c478bd9Sstevel@tonic-gate 						}
14587c478bd9Sstevel@tonic-gate 					} while (--c);
14597c478bd9Sstevel@tonic-gate 					break;
14607c478bd9Sstevel@tonic-gate 
14617c478bd9Sstevel@tonic-gate 				case LCEBCDIC:
14627c478bd9Sstevel@tonic-gate 					do {
14637c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14647c478bd9Sstevel@tonic-gate 						{
14657c478bd9Sstevel@tonic-gate 							*op++ = atoe[utol[ic]];
14667c478bd9Sstevel@tonic-gate 						}
14677c478bd9Sstevel@tonic-gate 						else
14687c478bd9Sstevel@tonic-gate 						{
14697c478bd9Sstevel@tonic-gate 							nlflag = 1;
14707c478bd9Sstevel@tonic-gate 							break;
14717c478bd9Sstevel@tonic-gate 						}
14727c478bd9Sstevel@tonic-gate 					} while (--c);
14737c478bd9Sstevel@tonic-gate 					break;
14747c478bd9Sstevel@tonic-gate 
14757c478bd9Sstevel@tonic-gate 				case UCEBCDIC:
14767c478bd9Sstevel@tonic-gate 					do {
14777c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14787c478bd9Sstevel@tonic-gate 						{
14797c478bd9Sstevel@tonic-gate 							*op++ = atoe[ltou[ic]];
14807c478bd9Sstevel@tonic-gate 						}
14817c478bd9Sstevel@tonic-gate 						else
14827c478bd9Sstevel@tonic-gate 						{
14837c478bd9Sstevel@tonic-gate 							nlflag = 1;
14847c478bd9Sstevel@tonic-gate 							break;
14857c478bd9Sstevel@tonic-gate 						}
14867c478bd9Sstevel@tonic-gate 					} while (--c);
14877c478bd9Sstevel@tonic-gate 					break;
14887c478bd9Sstevel@tonic-gate 
14897c478bd9Sstevel@tonic-gate 				case IBM:
14907c478bd9Sstevel@tonic-gate 					do {
14917c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
14927c478bd9Sstevel@tonic-gate 						{
14937c478bd9Sstevel@tonic-gate 							*op++ = atoibm[ic];
14947c478bd9Sstevel@tonic-gate 						}
14957c478bd9Sstevel@tonic-gate 						else
14967c478bd9Sstevel@tonic-gate 						{
14977c478bd9Sstevel@tonic-gate 							nlflag = 1;
14987c478bd9Sstevel@tonic-gate 							break;
14997c478bd9Sstevel@tonic-gate 						}
15007c478bd9Sstevel@tonic-gate 					} while (--c);
15017c478bd9Sstevel@tonic-gate 					break;
15027c478bd9Sstevel@tonic-gate 
15037c478bd9Sstevel@tonic-gate 				case LCIBM:
15047c478bd9Sstevel@tonic-gate 					do {
15057c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
15067c478bd9Sstevel@tonic-gate 						{
15077c478bd9Sstevel@tonic-gate 						*op++ = atoibm[utol[ic]];
15087c478bd9Sstevel@tonic-gate 						}
15097c478bd9Sstevel@tonic-gate 						else
15107c478bd9Sstevel@tonic-gate 						{
15117c478bd9Sstevel@tonic-gate 							nlflag = 1;
15127c478bd9Sstevel@tonic-gate 							break;
15137c478bd9Sstevel@tonic-gate 						}
15147c478bd9Sstevel@tonic-gate 					} while (--c);
15157c478bd9Sstevel@tonic-gate 					break;
15167c478bd9Sstevel@tonic-gate 
15177c478bd9Sstevel@tonic-gate 				case UCIBM:
15187c478bd9Sstevel@tonic-gate 					do {
15197c478bd9Sstevel@tonic-gate 						if ((ic = *ip++) != '\n')
15207c478bd9Sstevel@tonic-gate 						{
15217c478bd9Sstevel@tonic-gate 						*op++ = atoibm[ltou[ic]];
15227c478bd9Sstevel@tonic-gate 						}
15237c478bd9Sstevel@tonic-gate 						else
15247c478bd9Sstevel@tonic-gate 						{
15257c478bd9Sstevel@tonic-gate 							nlflag = 1;
15267c478bd9Sstevel@tonic-gate 							break;
15277c478bd9Sstevel@tonic-gate 						}
15287c478bd9Sstevel@tonic-gate 					} while (--c);
15297c478bd9Sstevel@tonic-gate 					break;
15307c478bd9Sstevel@tonic-gate 				}
15317c478bd9Sstevel@tonic-gate 
15327c478bd9Sstevel@tonic-gate 			/* If newline found, update all the counters and */
15337c478bd9Sstevel@tonic-gate 			/* pointers, pad with trailing blanks if necessary */
15347c478bd9Sstevel@tonic-gate 
15357c478bd9Sstevel@tonic-gate 				if (nlflag)
15367c478bd9Sstevel@tonic-gate 				{
15377c478bd9Sstevel@tonic-gate 					ibc += c - 1;
15387c478bd9Sstevel@tonic-gate 					obc += cbs - cbc;
15397c478bd9Sstevel@tonic-gate 					c += cbs - cbc;
15407c478bd9Sstevel@tonic-gate 					cbc = 0;
15417c478bd9Sstevel@tonic-gate 					if (c > 0)
15427c478bd9Sstevel@tonic-gate 					{
15437c478bd9Sstevel@tonic-gate 					/* Use the right kind of blank */
15447c478bd9Sstevel@tonic-gate 
15457c478bd9Sstevel@tonic-gate 						switch (conv)
15467c478bd9Sstevel@tonic-gate 						{
15477c478bd9Sstevel@tonic-gate 						case BLOCK:
15487c478bd9Sstevel@tonic-gate 						case LCBLOCK:
15497c478bd9Sstevel@tonic-gate 						case UCBLOCK:
15507c478bd9Sstevel@tonic-gate 							ic = ' ';
15517c478bd9Sstevel@tonic-gate 							break;
15527c478bd9Sstevel@tonic-gate 
15537c478bd9Sstevel@tonic-gate 						case EBCDIC:
15547c478bd9Sstevel@tonic-gate 						case LCEBCDIC:
15557c478bd9Sstevel@tonic-gate 						case UCEBCDIC:
15567c478bd9Sstevel@tonic-gate 							ic = atoe[' '];
15577c478bd9Sstevel@tonic-gate 							break;
15587c478bd9Sstevel@tonic-gate 
15597c478bd9Sstevel@tonic-gate 						case IBM:
15607c478bd9Sstevel@tonic-gate 						case LCIBM:
15617c478bd9Sstevel@tonic-gate 						case UCIBM:
15627c478bd9Sstevel@tonic-gate 							ic = atoibm[' '];
15637c478bd9Sstevel@tonic-gate 							break;
15647c478bd9Sstevel@tonic-gate 						}
15657c478bd9Sstevel@tonic-gate 
15667c478bd9Sstevel@tonic-gate 						/* Pad with trailing blanks */
15677c478bd9Sstevel@tonic-gate 
15687c478bd9Sstevel@tonic-gate 						do {
15697c478bd9Sstevel@tonic-gate 							*op++ = ic;
15707c478bd9Sstevel@tonic-gate 						} while (--c);
15717c478bd9Sstevel@tonic-gate 					}
15727c478bd9Sstevel@tonic-gate 				}
15737c478bd9Sstevel@tonic-gate 
15747c478bd9Sstevel@tonic-gate 			/* If not end of line, this line may be too long */
15757c478bd9Sstevel@tonic-gate 
15767c478bd9Sstevel@tonic-gate 				else if (cbc > cbs)
15777c478bd9Sstevel@tonic-gate 				{
15787c478bd9Sstevel@tonic-gate 					skipf = 1; /* note skip in progress */
15797c478bd9Sstevel@tonic-gate 					obc--;
15807c478bd9Sstevel@tonic-gate 					op--;
15817c478bd9Sstevel@tonic-gate 					cbc = 0;
15827c478bd9Sstevel@tonic-gate 					ntrunc++;  /* count another long line */
15837c478bd9Sstevel@tonic-gate 				}
15847c478bd9Sstevel@tonic-gate 
15857c478bd9Sstevel@tonic-gate 				/* Flush the output buffer if full */
15867c478bd9Sstevel@tonic-gate 
15877c478bd9Sstevel@tonic-gate 				while (obc >= obs)
15887c478bd9Sstevel@tonic-gate 				{
15897c478bd9Sstevel@tonic-gate 					op = flsh();
15907c478bd9Sstevel@tonic-gate 				}
15917c478bd9Sstevel@tonic-gate 			}
15927c478bd9Sstevel@tonic-gate 			break;
15937c478bd9Sstevel@tonic-gate 		}
15947c478bd9Sstevel@tonic-gate 	}
1595a77d64afScf 	/* NOTREACHED */
1596a77d64afScf 	return (0);
15977c478bd9Sstevel@tonic-gate }
15987c478bd9Sstevel@tonic-gate 
15997c478bd9Sstevel@tonic-gate /* match ************************************************************** */
16007c478bd9Sstevel@tonic-gate /*									*/
16017c478bd9Sstevel@tonic-gate /* Compare two text strings for equality				*/
16027c478bd9Sstevel@tonic-gate /*									*/
16037c478bd9Sstevel@tonic-gate /* Arg:		s - pointer to string to match with a command arg	*/
16047c478bd9Sstevel@tonic-gate /* Global arg:	string - pointer to command arg				*/
16057c478bd9Sstevel@tonic-gate /*									*/
16067c478bd9Sstevel@tonic-gate /* Return:	1 if match, 0 if no match				*/
16077c478bd9Sstevel@tonic-gate /*		If match, also reset `string' to point to the text	*/
16087c478bd9Sstevel@tonic-gate /*		that follows the matching text.				*/
16097c478bd9Sstevel@tonic-gate /*									*/
16107c478bd9Sstevel@tonic-gate /* ********************************************************************	*/
16117c478bd9Sstevel@tonic-gate 
16127c478bd9Sstevel@tonic-gate static int
16137c478bd9Sstevel@tonic-gate match(s)
16147c478bd9Sstevel@tonic-gate char *s;
16157c478bd9Sstevel@tonic-gate {
16167c478bd9Sstevel@tonic-gate 	char *cs;
16177c478bd9Sstevel@tonic-gate 
16187c478bd9Sstevel@tonic-gate 	cs = string;
16197c478bd9Sstevel@tonic-gate 	while (*cs++ == *s)
16207c478bd9Sstevel@tonic-gate 	{
16217c478bd9Sstevel@tonic-gate 		if (*s++ == '\0')
16227c478bd9Sstevel@tonic-gate 		{
16237c478bd9Sstevel@tonic-gate 			goto true;
16247c478bd9Sstevel@tonic-gate 		}
16257c478bd9Sstevel@tonic-gate 	}
16267c478bd9Sstevel@tonic-gate 	if (*s != '\0')
16277c478bd9Sstevel@tonic-gate 	{
16287c478bd9Sstevel@tonic-gate 		return (0);
16297c478bd9Sstevel@tonic-gate 	}
16307c478bd9Sstevel@tonic-gate 
16317c478bd9Sstevel@tonic-gate true:
16327c478bd9Sstevel@tonic-gate 	cs--;
16337c478bd9Sstevel@tonic-gate 	string = cs;
16347c478bd9Sstevel@tonic-gate 	return (1);
16357c478bd9Sstevel@tonic-gate }
16367c478bd9Sstevel@tonic-gate 
16377c478bd9Sstevel@tonic-gate /* number ************************************************************* */
16387c478bd9Sstevel@tonic-gate /*									*/
16397c478bd9Sstevel@tonic-gate /* Convert a numeric arg to binary					*/
16407c478bd9Sstevel@tonic-gate /*									*/
16417c478bd9Sstevel@tonic-gate /* Arg:		big - maximum valid input number			*/
16427c478bd9Sstevel@tonic-gate /* Global arg:	string - pointer to command arg				*/
16437c478bd9Sstevel@tonic-gate /*									*/
1644*4cddff70SJosef 'Jeff' Sipek /* Valid forms:	123 | 123k | 123M | 123G | 123T | 123P | 123E | 123Z |	*/
1645*4cddff70SJosef 'Jeff' Sipek /*		123w | 123b | 123*123 | 123x123				*/
16467c478bd9Sstevel@tonic-gate /*		plus combinations such as 2b*3kw*4w			*/
16477c478bd9Sstevel@tonic-gate /*									*/
16487c478bd9Sstevel@tonic-gate /* Return:	converted number					*/
16497c478bd9Sstevel@tonic-gate /*									*/
16507c478bd9Sstevel@tonic-gate /* ********************************************************************	*/
16517c478bd9Sstevel@tonic-gate 
16527c478bd9Sstevel@tonic-gate static unsigned long long
16537c478bd9Sstevel@tonic-gate number(big)
16547c478bd9Sstevel@tonic-gate long long big;
16557c478bd9Sstevel@tonic-gate {
16567c478bd9Sstevel@tonic-gate 	char *cs;
16577c478bd9Sstevel@tonic-gate 	long long n;
16587c478bd9Sstevel@tonic-gate 	long long cut = BIG / 10;	/* limit to avoid overflow */
16597c478bd9Sstevel@tonic-gate 
16607c478bd9Sstevel@tonic-gate 	cs = string;
16617c478bd9Sstevel@tonic-gate 	n = 0;
16627c478bd9Sstevel@tonic-gate 	while ((*cs >= '0') && (*cs <= '9') && (n <= cut))
16637c478bd9Sstevel@tonic-gate 	{
16647c478bd9Sstevel@tonic-gate 		n = n*10 + *cs++ - '0';
16657c478bd9Sstevel@tonic-gate 	}
16667c478bd9Sstevel@tonic-gate 	for (;;)
16677c478bd9Sstevel@tonic-gate 	{
16687c478bd9Sstevel@tonic-gate 		switch (*cs++)
16697c478bd9Sstevel@tonic-gate 		{
16707c478bd9Sstevel@tonic-gate 
1671*4cddff70SJosef 'Jeff' Sipek 		case 'Z':
1672*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1673*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1674*4cddff70SJosef 'Jeff' Sipek 
1675*4cddff70SJosef 'Jeff' Sipek 		case 'E':
1676*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1677*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1678*4cddff70SJosef 'Jeff' Sipek 
1679*4cddff70SJosef 'Jeff' Sipek 		case 'P':
1680*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1681*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1682*4cddff70SJosef 'Jeff' Sipek 
1683*4cddff70SJosef 'Jeff' Sipek 		case 'T':
1684*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1685*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1686*4cddff70SJosef 'Jeff' Sipek 
1687*4cddff70SJosef 'Jeff' Sipek 		case 'G':
1688*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1689*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1690*4cddff70SJosef 'Jeff' Sipek 
1691*4cddff70SJosef 'Jeff' Sipek 		case 'M':
1692*4cddff70SJosef 'Jeff' Sipek 			n *= 1024;
1693*4cddff70SJosef 'Jeff' Sipek 			/* FALLTHROUGH */
1694*4cddff70SJosef 'Jeff' Sipek 
16957c478bd9Sstevel@tonic-gate 		case 'k':
16967c478bd9Sstevel@tonic-gate 			n *= 1024;
16977c478bd9Sstevel@tonic-gate 			continue;
16987c478bd9Sstevel@tonic-gate 
16997c478bd9Sstevel@tonic-gate 		case 'w':
17007c478bd9Sstevel@tonic-gate 			n *= 2;
17017c478bd9Sstevel@tonic-gate 			continue;
17027c478bd9Sstevel@tonic-gate 
17037c478bd9Sstevel@tonic-gate 		case 'b':
17047c478bd9Sstevel@tonic-gate 			n *= BSIZE;
17057c478bd9Sstevel@tonic-gate 			continue;
17067c478bd9Sstevel@tonic-gate 
17077c478bd9Sstevel@tonic-gate 		case '*':
17087c478bd9Sstevel@tonic-gate 		case 'x':
17097c478bd9Sstevel@tonic-gate 			string = cs;
17107c478bd9Sstevel@tonic-gate 			n *= number(BIG);
17117c478bd9Sstevel@tonic-gate 
17127c478bd9Sstevel@tonic-gate 		/* FALLTHROUGH */
17137c478bd9Sstevel@tonic-gate 		/* Fall into exit test, recursion has read rest of string */
17147c478bd9Sstevel@tonic-gate 		/* End of string, check for a valid number */
17157c478bd9Sstevel@tonic-gate 
17167c478bd9Sstevel@tonic-gate 		case '\0':
17177c478bd9Sstevel@tonic-gate 			if ((n > big) || (n < 0))
17187c478bd9Sstevel@tonic-gate 			{
17197c478bd9Sstevel@tonic-gate 				(void) fprintf(stderr, "dd: %s \"%llu\"\n",
17207c478bd9Sstevel@tonic-gate 					gettext("argument out of range:"), n);
17217c478bd9Sstevel@tonic-gate 				exit(2);
17227c478bd9Sstevel@tonic-gate 			}
17237c478bd9Sstevel@tonic-gate 			return (n);
17247c478bd9Sstevel@tonic-gate 
17257c478bd9Sstevel@tonic-gate 		default:
17267c478bd9Sstevel@tonic-gate 			(void) fprintf(stderr, "dd: %s \"%s\"\n",
17277c478bd9Sstevel@tonic-gate 				gettext("bad numeric argument:"), string);
17287c478bd9Sstevel@tonic-gate 			exit(2);
17297c478bd9Sstevel@tonic-gate 		}
17307c478bd9Sstevel@tonic-gate 	} /* never gets here */
17317c478bd9Sstevel@tonic-gate }
17327c478bd9Sstevel@tonic-gate 
17337c478bd9Sstevel@tonic-gate /* flsh *************************************************************** */
17347c478bd9Sstevel@tonic-gate /*									*/
17357c478bd9Sstevel@tonic-gate /* Flush the output buffer, move any excess bytes down to the beginning	*/
17367c478bd9Sstevel@tonic-gate /*									*/
17377c478bd9Sstevel@tonic-gate /* Arg:		none							*/
17387c478bd9Sstevel@tonic-gate /* Global args:	obuf, obc, obs, nofr, nopr				*/
17397c478bd9Sstevel@tonic-gate /*									*/
17407c478bd9Sstevel@tonic-gate /* Return:	Pointer to the first free byte in the output buffer.	*/
17417c478bd9Sstevel@tonic-gate /*		Also reset `obc' to account for moved bytes.		*/
17427c478bd9Sstevel@tonic-gate /*									*/
17437c478bd9Sstevel@tonic-gate /* ********************************************************************	*/
17447c478bd9Sstevel@tonic-gate 
17457c478bd9Sstevel@tonic-gate static unsigned char
17467c478bd9Sstevel@tonic-gate *flsh()
17477c478bd9Sstevel@tonic-gate {
17487c478bd9Sstevel@tonic-gate 	unsigned char *op, *cp;
17497c478bd9Sstevel@tonic-gate 	int bc;
17507c478bd9Sstevel@tonic-gate 	unsigned int oc;
17517c478bd9Sstevel@tonic-gate 
17527c478bd9Sstevel@tonic-gate 	if (obc)			/* don't flush if the buffer is empty */
17537c478bd9Sstevel@tonic-gate 	{
17547c478bd9Sstevel@tonic-gate 		if (obc >= obs) {
17557c478bd9Sstevel@tonic-gate 			oc = obs;
17567c478bd9Sstevel@tonic-gate 			nofr++;		/* count a full output buffer */
17577c478bd9Sstevel@tonic-gate 		}
17587c478bd9Sstevel@tonic-gate 		else
17597c478bd9Sstevel@tonic-gate 		{
17607c478bd9Sstevel@tonic-gate 			oc = obc;
17617c478bd9Sstevel@tonic-gate 			nopr++;		/* count a partial output buffer */
17627c478bd9Sstevel@tonic-gate 		}
17637c478bd9Sstevel@tonic-gate 		bc = write(obf, (char *)obuf, oc);
17647c478bd9Sstevel@tonic-gate 		if (bc != oc) {
17657c478bd9Sstevel@tonic-gate 			if (bc < 0)
17667c478bd9Sstevel@tonic-gate 				perror("write");
17677c478bd9Sstevel@tonic-gate 			else
17687c478bd9Sstevel@tonic-gate 			(void) fprintf(stderr,
17697c478bd9Sstevel@tonic-gate 				gettext("dd: unexpected short write, "
17707c478bd9Sstevel@tonic-gate 				"wrote %d bytes, expected %d\n"), bc, oc);
17717c478bd9Sstevel@tonic-gate 			term(2);
17727c478bd9Sstevel@tonic-gate 		}
17737c478bd9Sstevel@tonic-gate 		obc -= oc;
17747c478bd9Sstevel@tonic-gate 		op = obuf;
17757c478bd9Sstevel@tonic-gate 
17767c478bd9Sstevel@tonic-gate 		/* If any data in the conversion buffer, move it into */
17777c478bd9Sstevel@tonic-gate 		/* the output buffer */
17787c478bd9Sstevel@tonic-gate 
17797c478bd9Sstevel@tonic-gate 		if (obc) {
17807c478bd9Sstevel@tonic-gate 			cp = obuf + obs;
17817c478bd9Sstevel@tonic-gate 			bc = obc;
17827c478bd9Sstevel@tonic-gate 			do {
17837c478bd9Sstevel@tonic-gate 				*op++ = *cp++;
17847c478bd9Sstevel@tonic-gate 			} while (--bc);
17857c478bd9Sstevel@tonic-gate 		}
17867c478bd9Sstevel@tonic-gate 		return (op);
17877c478bd9Sstevel@tonic-gate 	}
17887c478bd9Sstevel@tonic-gate 	return (obuf);
17897c478bd9Sstevel@tonic-gate }
17907c478bd9Sstevel@tonic-gate 
17917c478bd9Sstevel@tonic-gate /* term *************************************************************** */
17927c478bd9Sstevel@tonic-gate /*									*/
17937c478bd9Sstevel@tonic-gate /* Write record statistics, then exit					*/
17947c478bd9Sstevel@tonic-gate /*									*/
17957c478bd9Sstevel@tonic-gate /* Arg:		c - exit status code					*/
17967c478bd9Sstevel@tonic-gate /*									*/
17977c478bd9Sstevel@tonic-gate /* Return:	no return, calls exit					*/
17987c478bd9Sstevel@tonic-gate /*									*/
17997c478bd9Sstevel@tonic-gate /* ********************************************************************	*/
18007c478bd9Sstevel@tonic-gate 
18017c478bd9Sstevel@tonic-gate static void
18027c478bd9Sstevel@tonic-gate term(c)
18037c478bd9Sstevel@tonic-gate int c;
18047c478bd9Sstevel@tonic-gate {
18057c478bd9Sstevel@tonic-gate 	stats();
18067c478bd9Sstevel@tonic-gate 	exit(c);
18077c478bd9Sstevel@tonic-gate }
18087c478bd9Sstevel@tonic-gate 
18097c478bd9Sstevel@tonic-gate /* stats ************************************************************** */
18107c478bd9Sstevel@tonic-gate /*									*/
18117c478bd9Sstevel@tonic-gate /* Write record statistics onto standard error				*/
18127c478bd9Sstevel@tonic-gate /*									*/
18137c478bd9Sstevel@tonic-gate /* Args:	none							*/
18147c478bd9Sstevel@tonic-gate /* Global args:	nifr, nipr, nofr, nopr, ntrunc				*/
18157c478bd9Sstevel@tonic-gate /*									*/
18167c478bd9Sstevel@tonic-gate /* Return:	void							*/
18177c478bd9Sstevel@tonic-gate /*									*/
18187c478bd9Sstevel@tonic-gate /* ********************************************************************	*/
18197c478bd9Sstevel@tonic-gate 
18207c478bd9Sstevel@tonic-gate static void
18217c478bd9Sstevel@tonic-gate stats()
18227c478bd9Sstevel@tonic-gate {
18237c478bd9Sstevel@tonic-gate 	(void) fprintf(stderr, gettext("%llu+%llu records in\n"), nifr, nipr);
18247c478bd9Sstevel@tonic-gate 	(void) fprintf(stderr, gettext("%llu+%llu records out\n"), nofr, nopr);
18257c478bd9Sstevel@tonic-gate 	if (ntrunc) {
18267c478bd9Sstevel@tonic-gate 		(void) fprintf(stderr,
18277c478bd9Sstevel@tonic-gate 			gettext("%llu truncated record(s)\n"), ntrunc);
18287c478bd9Sstevel@tonic-gate 	}
18297c478bd9Sstevel@tonic-gate }
1830