On Thu, 29 Jul 1999, Sheldon Hearn wrote: > > > On Thu, 29 Jul 1999 00:52:27 -0400, "Brian F. Feldman" wrote: > > > If noone has any objections, I will commit this and MFC it in a week or so. > > > > --- src/usr.bin/cmp/regular.c.orig Thu Jul 29 00:43:50 1999 > > +++ src/usr.bin/cmp/regular.c Thu Jul 29 00:44:54 1999 > > |--- src/usr.bin/cmp/regular.c.orig Thu Jul 29 00:43:50 1999 > |+++ src/usr.bin/cmp/regular.c Thu Jul 29 00:44:54 1999 > -------------------------- > Patching file regular.c using Plan A... > Hunk #1 succeeded at 57. > Hunk #2 failed at 76. > 1 out of 2 hunks failed--saving rejects to regular.c.rej > Hmm... Ignoring the trailing garbage. > done > > What's up? :-) >
I have a better version. It's much more proper. Index: src/usr.bin/cmp/regular.c =================================================================== RCS file: /home/ncvs/src/usr.bin/cmp/regular.c,v retrieving revision 1.6 diff -u -r1.6 regular.c --- regular.c 1999/04/25 22:37:57 1.6 +++ regular.c 1999/07/29 14:20:23 @@ -60,6 +60,7 @@ off_t byte, length, line; int dfound; off_t pagemask, off1, off2; + size_t pagesize; if (sflag && len1 != len2) exit(1); @@ -71,7 +72,8 @@ eofmsg(file2); len2 -= skip2; - pagemask = (off_t)getpagesize() - 1; + pagesize = getpagesize(); + pagemask = (off_t)pagesize - 1; off1 = ROUNDPAGE(skip1); off2 = ROUNDPAGE(skip2); @@ -79,15 +81,15 @@ if (length > SIZE_T_MAX) return (c_special(fd1, file1, skip1, fd2, file2, skip2)); - if ((p1 = (u_char *)mmap(NULL, - (size_t)length, PROT_READ, MAP_SHARED, fd1, off1)) == (u_char *)MAP_FAILED) + if ((p1 = (u_char *)mmap(NULL, (size_t)len1 + skip1 % pagesize, + PROT_READ, MAP_SHARED, fd1, off1)) == (u_char *)MAP_FAILED) err(ERR_EXIT, "%s", file1); - madvise(p1, length, MADV_SEQUENTIAL); - if ((p2 = (u_char *)mmap(NULL, - (size_t)length, PROT_READ, MAP_SHARED, fd2, off2)) == (u_char *)MAP_FAILED) + madvise(p1, len1 + skip1 % pagesize, MADV_SEQUENTIAL); + if ((p2 = (u_char *)mmap(NULL, (size_t)len2 + skip2 % pagesize, + PROT_READ, MAP_SHARED, fd2, off2)) == (u_char *)MAP_FAILED) err(ERR_EXIT, "%s", file2); - madvise(p2, length, MADV_SEQUENTIAL); + madvise(p2, len2 + skip2 % pagesize, MADV_SEQUENTIAL); dfound = 0; p1 += skip1 - off1; > Ciao, > Sheldon. > > > To Unsubscribe: send mail to majord...@freebsd.org > with "unsubscribe freebsd-hackers" in the body of the message > Brian Fundakowski Feldman _ __ ___ ____ ___ ___ ___ gr...@freebsd.org _ __ ___ | _ ) __| \ FreeBSD: The Power to Serve! _ __ | _ \._ \ |) | http://www.FreeBSD.org/ _ |___/___/___/ To Unsubscribe: send mail to majord...@freebsd.org with "unsubscribe freebsd-hackers" in the body of the message