X-Git-Url: https://git.cryptolib.org/?a=blobdiff_plain;f=host%2Fget_test.rb;h=9d60a4a82551fbee4f0f4549bb37ba64329786ea;hb=47d2a52aeb2ef0150c252b8aa8b21b2139216feb;hp=7c9ea3cf0e3617582209045aa77feb26b3de38c4;hpb=0542221a3e793e4455e84b271b07aa0959d5dfb3;p=avr-crypto-lib.git diff --git a/host/get_test.rb b/host/get_test.rb index 7c9ea3c..9d60a4a 100644 --- a/host/get_test.rb +++ b/host/get_test.rb @@ -21,13 +21,23 @@ require 'rubygems' require 'serialport' +$debug = false + def read_line(error_msg=true) - s = $sp.gets() - if s==nil - puts("ERROR: read timeout!\n") if error_msg - return nil - end - s.gsub(/\006/, ''); + begin + i = $extended_wait + begin + s = $sp.gets() + i -= 1 + end while !s && i > 0 + if s==nil + puts("ERROR: read timeout!\n") if error_msg + return nil + end + putc('.') if s.include?(6.chr) + puts(s.inspect) if $debug + end while s == 6.chr + s.gsub(/\006/, '') end def readTestVector(param) @@ -112,13 +122,13 @@ param=(ARGV.size>=7)?ARGV[6]:""; puts("\nPort: "+ARGV[0]+ "@"+ARGV[1]+" "+ARGV[2]+"N"+ARGV[3]+"\n"); $linewidth = 16 $sp = SerialPort.new(ARGV[0], ARGV[1].to_i, ARGV[2].to_i, ARGV[3].to_i, SerialPort::NONE); -$sp.read_timeout=1000; # 1 secound -$extended_wait=100; +$sp.read_timeout=1000; # 1 second +$extended_wait=10; $sp.write(command); if(readTestVector(param)==false) puts("ERROR: test seems not to be implemented"); - exit(3); + exit(0); # 3 end while(readTestVector(param))