From owner-p4-projects@FreeBSD.ORG Fri Sep 5 01:00:04 2003 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 8798A16A4C1; Fri, 5 Sep 2003 01:00:04 -0700 (PDT) Delivered-To: perforce@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 3465A16A4BF for ; Fri, 5 Sep 2003 01:00:04 -0700 (PDT) Received: from repoman.freebsd.org (repoman.freebsd.org [216.136.204.115]) by mx1.FreeBSD.org (Postfix) with ESMTP id B883043FF7 for ; Fri, 5 Sep 2003 01:00:03 -0700 (PDT) (envelope-from marcel@freebsd.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.12.6/8.12.6) with ESMTP id h858030U002015 for ; Fri, 5 Sep 2003 01:00:03 -0700 (PDT) (envelope-from marcel@freebsd.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.12.6/8.12.6/Submit) id h85803l1002012 for perforce@freebsd.org; Fri, 5 Sep 2003 01:00:03 -0700 (PDT) Date: Fri, 5 Sep 2003 01:00:03 -0700 (PDT) Message-Id: <200309050800.h85803l1002012@repoman.freebsd.org> X-Authentication-Warning: repoman.freebsd.org: perforce set sender to marcel@freebsd.org using -f From: Marcel Moolenaar To: Perforce Change Reviews Subject: PERFORCE change 37557 for review X-BeenThere: p4-projects@freebsd.org X-Mailman-Version: 2.1.1 Precedence: list List-Id: p4 projects tree changes List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 05 Sep 2003 08:00:05 -0000 http://perforce.freebsd.org/chv.cgi?CH=37557 Change 37557 by marcel@marcel_nfs on 2003/09/05 00:59:42 Send a pattern that allows us to detect lost data or (god forbid) spontaneous data. Affected files ... .. //depot/projects/uart/dev/uart/uarttest.c#3 edit Differences ... ==== //depot/projects/uart/dev/uart/uarttest.c#3 (text+ko) ==== @@ -48,7 +48,7 @@ int fd, how; -char buffer[16384*4]; +u_char buffer[16384*4]; static int getsig(const char *dev, size_t count, int oldsig) @@ -85,6 +85,9 @@ ssize_t count, wc; int sig; + for (count = 0; count < sizeof(buffer); count++) + buffer[count] = count; + count = 0; errno = 0; sig = 0; @@ -103,9 +106,10 @@ dce(void) { ssize_t count, rc; - int sig; + int delta, diff, sig; count = 0; + delta = 0; errno = 0; sig = 0; while (count < sizeof(buffer)) { @@ -113,11 +117,20 @@ rc = MIN(16, sizeof(buffer) - count); rc = read(fd, buffer + count, rc); if (rc > 0) { - count += rc; + while (rc--) { + diff = buffer[count] - (u_char)count - delta; + if (diff) { + printf("ERR: %u (%d): ", count, delta); + printf("lost %d bytes\n", diff); + delta += diff; + } + count++; + } errno = 0; } else { - printf("sleeping after %u bytes...\n", count); - sleep(1); + printf("sleeping after %u (%d) bytes...\n", count, + delta); + sleep(2); } } @@ -198,8 +211,8 @@ break; } + sleep(2); tcsetattr(fd, TCSADRAIN, &t0); - sleep(1); close(fd); return (EX_OK); }