1 /* $NetBSD: regular.c,v 1.21 2009/04/11 12:16:12 lukem Exp $ */
4 * Copyright (c) 1991, 1993, 1994
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 #include <sys/cdefs.h>
35 static char sccsid
[] = "@(#)regular.c 8.3 (Berkeley) 4/2/94";
37 __RCSID("$NetBSD: regular.c,v 1.21 2009/04/11 12:16:12 lukem Exp $");
41 #include <sys/param.h>
54 c_regular(int fd1
, const char *file1
, off_t skip1
, off_t len1
,
55 int fd2
, const char *file2
, off_t skip2
, off_t len2
)
58 off_t byte
, length
, line
;
60 size_t blk_sz
, blk_cnt
;
62 if (sflag
&& len1
!= len2
)
66 eofmsg(file1
, len1
+ 1, 0);
69 eofmsg(file2
, len2
+ 1, 0);
74 length
= MIN(len1
, len2
);
75 for (blk_sz
= 1024 * 1024; length
!= 0; length
-= blk_sz
) {
76 if ((uintmax_t)blk_sz
> (uintmax_t)length
)
78 p1
= mmap(NULL
, blk_sz
, PROT_READ
, MAP_FILE
|MAP_SHARED
,
83 p2
= mmap(NULL
, blk_sz
, PROT_READ
, MAP_FILE
|MAP_SHARED
,
85 if (p2
== MAP_FAILED
) {
91 for (; blk_cnt
--; ++p1
, ++p2
, ++byte
) {
92 if ((ch
= *p1
) != *p2
) {
94 diffmsg(file1
, file2
, byte
, line
);
98 (void)printf("%6lld %3o %3o\n",
99 (long long)byte
, ch
, *p2
);
104 munmap(p1
- blk_sz
, blk_sz
);
105 munmap(p2
- blk_sz
, blk_sz
);
111 eofmsg(len1
> len2
? file2
: file1
, byte
, line
);
117 c_special(fd1
, file1
, skip1
, fd2
, file2
, skip2
);