From owner-p4-projects@FreeBSD.ORG Sun Jan 30 08:32:04 2005 Return-Path: Delivered-To: p4-projects@freebsd.org Received: by hub.freebsd.org (Postfix, from userid 32767) id 3A56716A4D0; Sun, 30 Jan 2005 08:32:04 +0000 (GMT) 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 10DFF16A4CE for ; Sun, 30 Jan 2005 08:32:04 +0000 (GMT) Received: from repoman.freebsd.org (repoman.freebsd.org [216.136.204.115]) by mx1.FreeBSD.org (Postfix) with ESMTP id EE58043D45 for ; Sun, 30 Jan 2005 08:32:03 +0000 (GMT) (envelope-from marcel@freebsd.org) Received: from repoman.freebsd.org (localhost [127.0.0.1]) by repoman.freebsd.org (8.13.1/8.13.1) with ESMTP id j0U8W3Ul000520 for ; Sun, 30 Jan 2005 08:32:03 GMT (envelope-from marcel@freebsd.org) Received: (from perforce@localhost) by repoman.freebsd.org (8.13.1/8.13.1/Submit) id j0U8W3UT000517 for perforce@freebsd.org; Sun, 30 Jan 2005 08:32:03 GMT (envelope-from marcel@freebsd.org) Date: Sun, 30 Jan 2005 08:32:03 GMT Message-Id: <200501300832.j0U8W3UT000517@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 69963 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: Sun, 30 Jan 2005 08:32:04 -0000 http://perforce.freebsd.org/chv.cgi?CH=69963 Change 69963 by marcel@marcel_nfs on 2005/01/30 08:31:58 Make the DTE drain the output and wait for the DCE to drop DSR. This fixes termination problems when the DCE needs a lot of time to receive the data. Lower the speed to 19200. The Zilog Z8530 can't even be programmed for 115200. Affected files ... .. //depot/projects/uart/dev/uart/uarttest.c#4 edit Differences ... ==== //depot/projects/uart/dev/uart/uarttest.c#4 (text+ko) ==== @@ -100,6 +100,12 @@ } } printf("dte: %u bytes transmitted\n", count); + + ioctl(fd, TIOCDRAIN); + do { + sleep(1); + ioctl(fd, TIOCMGET, &sig); + } while (sig & TIOCM_DSR); } static void @@ -185,7 +191,7 @@ tcgetattr(fd, &t0); t1 = t0; cfmakeraw(&t1); - cfsetspeed(&t1, B115200); + cfsetspeed(&t1, B19200); switch (how) { case AS_DCE: t1.c_cflag |= CRTS_IFLOW; @@ -211,7 +217,6 @@ break; } - sleep(2); tcsetattr(fd, TCSADRAIN, &t0); close(fd); return (EX_OK);