Files
meta-openembedded/meta-oe/recipes-devtools/serialcheck/serialcheck/0002-Restore-original-loopback-config.patch
T
Denys Dmytriyenko 6d8574da9b serialcheck: add version 1.0.0
Simple serial tester

Usage (as explained in Readme.txt, part of ${PN}-doc package):
 - Create a random file.
   dd if=/dev/urandom of=binary count=1 bs=4096

 - Copy the random file to both nodes.

 - Start the test
   receiving node:
        serialcheck -d /dev/ttyS0 -f binary -m r -l 10

   sending node:
        serialcheck -d /dev/ttyUSB0 -f binary -m t -l 10

   Start the receiving side before the sending side. This will transfer the
   "binary" file 10 times and the other side will expect the file 10 times.
   Once the program completes both sides should write something similar to:

|  Needed 0 reads 1 writes loops 10 / 10
|  cts: 0 dsr: 0 rng: 0 dcd: 0 rx: 0 tx: 40960 frame 0 ovr 0 par: 0 brk: 0 buf_ovrr: 0

   and in error case the receive side:

Needed 20 reads 0 writes Oh oh, inconsistency at pos 2273 (0x8e1).
Original sample:
000008b0: 28 b2 18 c9 ec b5 2c b3  3a a1 29 b1 fc 27 20 7f   (.....,.:.)..' .
000008c0: 42 f8 d5 cb d8 52 ec b5  c8 76 d3 4b d2 57 44 6a   B....R...v.K.WDj
000008d0: 40 81 6a 82 27 fd 8d 50  84 70 bc 24 6b 3d 88 fd   @.j.'..P.p.$k=..
000008e0: 9f ac 78 a4 76 9b f9 1c  74 2c d6 79 22 60 c5 de   ..x.v...t,.y"`..
000008f0: 02 9c fb 52 21 4b 40 6f  80 69 2e 80 df 12 ba a0   ...R!K@o.i......
00000900: 75 57 d5 22 33 c0 f3 bc  94 f8 aa 22 9d 02 59 20   uW."3......"..Y

Received sample:
000008b0: 28 b2 18 c9 ec b5 2c b3  3a a1 29 b1 fc 27 20 7f   (.....,.:.)..' .
000008c0: 42 f8 d5 cb d8 52 ec b5  c8 76 d3 4b d2 57 44 6a   B....R...v.K.WDj
000008d0: 40 81 6a 82 27 fd 8d 50  84 70 bc 24 6b 3d 88 fd   @.j.'..P.p.$k=..
000008e0: 9f 00 ac 78 a4 76 9b f9  1c 74 2c d6 79 22 60 c5   ...x.v...t,.y"`.
000008f0: de 02 9c fb 52 21 4b 40  6f 80 69 2e 80 df 12 ba   ....R!K@o.i.....
00000900: a0 75 57 d5 22 33 c0 f3  bc 94 f8 aa 22 9d 02 59   .uW."3......"..Y
loops 54878 / 4294967295

cts: 0 dsr: 0 rng: 0 dcd: 0 rx: 224792017 tx: 223379456 frame 0 ovr 1 par: 0 brk: 0 buf_ovrr: 0

Signed-off-by: Denys Dmytriyenko <denys@ti.com>
Signed-off-by: Martin Jansa <Martin.Jansa@gmail.com>
2015-04-21 13:03:09 +02:00

50 lines
1.2 KiB
Diff

From a6e5813d2f8402bf3a311c8bcda02623bfb76882 Mon Sep 17 00:00:00 2001
From: Carlos Hernandez <ceh@ti.com>
Date: Tue, 24 Feb 2015 16:00:34 -0500
Subject: [PATCH 2/2] Restore original loopback config
If loopback option is enabled, disable it at the end of the test.
Signed-off-by: Carlos Hernandez <ceh@ti.com>
Upstream-status: Pending
---
serialcheck.c | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/serialcheck.c b/serialcheck.c
index 4100c37..06470f7 100644
--- a/serialcheck.c
+++ b/serialcheck.c
@@ -427,6 +427,7 @@ int main(int argc, char *argv[])
unsigned char *data;
unsigned int open_mode;
off_t data_len;
+ unsigned int mcr;
argp_parse(&argp, argc, argv, 0, NULL, &opts);
if (!opts.file_trans)
@@ -496,8 +497,6 @@ int main(int argc, char *argv[])
}
if (opts.loopback) {
- unsigned int mcr;
-
ret = ioctl(fd, TIOCMGET, &mcr);
if (ret < 0)
die("mcr get failed: %m\n");
@@ -535,6 +534,12 @@ int main(int argc, char *argv[])
ret = tcsetattr(fd, TCSAFLUSH, &old_term);
if (ret)
printf("tcsetattr() of old ones failed: %m\n");
+ if (opts.loopback) {
+ mcr &= ~(TIOCM_LOOP);
+ ret = ioctl(fd, TIOCMSET, &mcr);
+ }
+ if (ret)
+ printf("disabling loopback failed: %m\n");
close(fd);
return status;
--
1.9.1