/[RFID]/3m-810.pl
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /3m-810.pl

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 29 by dpavlin, Mon Apr 6 13:10:40 2009 UTC revision 39 by dpavlin, Mon Jun 1 21:07:11 2009 UTC
# Line 19  sub meteor { Line 19  sub meteor {
19          push @a, scalar localtime() if $a[0] =~ m{^info};          push @a, scalar localtime() if $a[0] =~ m{^info};
20    
21          if ( ! defined $meteor_fh ) {          if ( ! defined $meteor_fh ) {
22                  warn "# open connection to $meteor_server";                  if ( $meteor_fh =
23                  $meteor_fh = IO::Socket::INET->new(                                  IO::Socket::INET->new(
24                                  PeerAddr => $meteor_server,                                          PeerAddr => $meteor_server,
25                                  Timeout => 1,                                          Timeout => 1,
26                  ) || warn "can't connect to meteor $meteor_server: $!"; # FIXME warn => die for production                                  )
27                  $meteor_fh = 0; # don't try again                  ) {
28                            warn "# meteor connected to $meteor_server";
29                    } else {
30                            warn "can't connect to meteor $meteor_server: $!";
31                            $meteor_fh = 0;
32                    }
33          }          }
34    
35          warn ">> meteor ",dump( @a );          if ( $meteor_fh ) {
36          print $meteor_fh "ADDMESSAGE test ",join('|',@a),"\n" if $meteor_fh;                  warn ">> meteor ",dump( @a );
37                    print $meteor_fh "ADDMESSAGE test ",join('|',@a),"\n"
38            }
39  }  }
40    
41  my $debug = 0;  my $debug = 0;
# Line 41  my $stopbits  = "1"; Line 48  my $stopbits  = "1";
48  my $handshake = "none";  my $handshake = "none";
49    
50  my $program_path = './program/';  my $program_path = './program/';
51    my $secure_path = './secure/';
52    
53  my $response = {  my $response = {
54          'd500090400110a0500027250'                              => 'version?',          'd500090400110a0500027250'                              => 'version?',
# Line 101  it under the same terms ans Perl itself. Line 109  it under the same terms ans Perl itself.
109  my $tags_data;  my $tags_data;
110  my $visible_tags;  my $visible_tags;
111    
112    my $item_type = {
113            1 => 'Book',
114            6 => 'CD/CD ROM',
115            2 => 'Magazine',
116            13 => 'Book with Audio Tape',
117            9 => 'Book with CD/CD ROM',
118            0 => 'Other',
119    
120            5 => 'Video',
121            4 => 'Audio Tape',
122            3 => 'Bound Journal',
123            8 => 'Book with Diskette',
124            7 => 'Diskette',
125    };
126    
127    warn "## known item type: ",dump( $item_type ) if $debug;
128    
129  my $port=new Device::SerialPort($device) || die "can't open serial port $device: $!\n";  my $port=new Device::SerialPort($device) || die "can't open serial port $device: $!\n";
130  warn "using $device $handshake $baudrate $databits $parity $stopbits" if $debug;  warn "using $device $handshake $baudrate $databits $parity $stopbits" if $debug;
131  $handshake=$port->handshake($handshake);  $handshake=$port->handshake($handshake);
# Line 190  sub update_visible_tags { Line 215  sub update_visible_tags {
215                                  meteor( 'write', $tag );                                  meteor( 'write', $tag );
216                                  write_tag( $tag );                                  write_tag( $tag );
217                  }                  }
218                    if ( -e "$secure_path/$tag" ) {
219                                    meteor( 'secure', $tag );
220                                    secure_tag( $tag );
221                    }
222          }          }
223    
224          foreach my $tag ( keys %$last_visible_tags ) {          foreach my $tag ( keys %$last_visible_tags ) {
# Line 222  sub read_tag_data { Line 251  sub read_tag_data {
251                  $tag_data_block->{$tag}->[ $ord ] = $data;                  $tag_data_block->{$tag}->[ $ord ] = $data;
252          }          }
253          $tags_data->{ $tag } = join('', @{ $tag_data_block->{$tag} });          $tags_data->{ $tag } = join('', @{ $tag_data_block->{$tag} });
254          print "DATA $tag ",dump( $tags_data ), "\n";  
255            my $item_type_nr = ord(substr( $tags_data->{$tag}, 3, 1 ));
256            print "DATA $tag ",dump( $tags_data ), " item type: ", ( $item_type->{ $item_type_nr } || "UNKWOWN '$item_type_nr' in " . dump( $item_type ) ), "\n";
257  }  }
258    
259  sub read_tag {  sub read_tag {
# Line 249  sub read_tag { Line 280  sub read_tag {
280                  }                  }
281          );          );
282    
283            my $security;
284    
285            cmd(
286                    "D6 00 0B 0A $tag 1234", "check security $tag",
287                    "D6 00 0D 0A 00", sub {
288                            my $rest = shift;
289                            my $from_tag;
290                            ( $from_tag, $security ) = ( substr($rest,0,8), substr($rest,8,1) );
291                            die "security from other tag: ",as_hex( $from_tag ) if $from_tag ne str2bytes( $tag );
292                            $security = as_hex( $security );
293                            warn "# SECURITY $tag = $security\n";
294                    }
295            );
296    
297            my $data = $tags_data->{$tag} || die "no data for $tag";
298            my ( $u1, $set_item, $u2, $type, $content, $br_lib, $custom ) = unpack('C4Z16Nl>',$data);
299            my $set   = ( $set_item & 0xf0 ) >> 4;
300            my $total = ( $set_item & 0x0f );
301            my $branch  = $br_lib >> 20;
302            my $library = $br_lib & 0x000fffff;
303            print "TAG $tag [$u1] set: $set/$total [$u2] type: $type '$content' library: $library branch: $branch custom: $custom security: $security\n";
304    
305  }  }
306    
307  sub write_tag {  sub write_tag {
# Line 257  sub write_tag { Line 310  sub write_tag {
310          my $path = "$program_path/$tag";          my $path = "$program_path/$tag";
311    
312          my $data = read_file( $path );          my $data = read_file( $path );
313            my $hex_data;
314    
315            if ( $data =~ s{^hex\s+}{} ) {
316                    $hex_data = $data;
317                    $hex_data =~ s{\s+}{}g;
318            } else {
319    
320                    # pad to block size
321                    $data .= "\0" x ( 4 - ( length($data) % 4 ) );
322    
323                    my $max_len = 7 * 4;
324    
325                    if ( length($data) > $max_len ) {
326                            $data = substr($data,0,$max_len);
327                            warn "strip content to $max_len bytes\n";
328                    }
329    
330                    $hex_data = unpack('H*', $data);
331            }
332    
333          print "write_tag $tag = $data\n";          my $len = length($hex_data) / 2;
334            my $blocks = sprintf('%02x', $len / 4);
335    
336            print "write_tag $tag = ",dump( $data ), " [$len/$blocks] == $hex_data\n";
337    
338          cmd(          cmd(
339                  "D6 00  26  04  $tag  00 06 00  04 11 00 01  61 61 61 61  62 62 62 62  63 63 63 63  64 64 64 64  00 00 00 00  FD3B", "write $tag",                  "d6 00  ff  04  $tag  00 $blocks 00  $hex_data  ffff", "write $tag",
340                  "D6 00  0D  04 00  $tag  06  AFB1", sub { assert() },                  "d6 00  0d  04 00  $tag  $blocks  afb1", sub { assert() },
341          ) foreach ( 1 .. 3 ); # XXX 3M software does this three times!          ) foreach ( 1 .. 3 ); # xxx 3m software does this three times!
342    
343          my $to = $path;          my $to = $path;
344          $to .= '.' . time();          $to .= '.' . time();
# Line 271  sub write_tag { Line 346  sub write_tag {
346          rename $path, $to;          rename $path, $to;
347          print ">> $to\n";          print ">> $to\n";
348    
349            delete $tags_data->{$tag};      # force re-read of tag
350    }
351    
352    sub secure_tag {
353            my ($tag) = @_;
354    
355            my $path = "$secure_path/$tag";
356            my $data = substr(read_file( $path ),0,2);
357    
358            cmd(
359                    "d6 00  0c  09  $tag $data 1234", "secure $tag -> $data",
360                    "d6 00  0c  09 00  $tag  1234", sub { assert() },
361            );
362    
363            my $to = $path;
364            $to .= '.' . time();
365    
366            rename $path, $to;
367            print ">> $to\n";
368  }  }
369    
370  exit;  exit;
# Line 305  sub writechunk Line 399  sub writechunk
399  {  {
400          my $str=shift;          my $str=shift;
401          my $count = $port->write($str);          my $count = $port->write($str);
402            my $len = length($str);
403            die "wrong write length $count != $len in ",as_hex( $str ) if $count != $len;
404          print "#> ", as_hex( $str ), "\t[$count]\n" if $debug;          print "#> ", as_hex( $str ), "\t[$count]\n" if $debug;
405  }  }
406    
# Line 343  sub skip_assert { Line 439  sub skip_assert {
439  sub assert {  sub assert {
440          my ( $from, $to ) = @_;          my ( $from, $to ) = @_;
441    
442            return unless $assert->{expect};
443    
444          $from ||= 0;          $from ||= 0;
445          $to = length( $assert->{expect} ) if ! defined $to;          $to = length( $assert->{expect} ) if ! defined $to;
446    
# Line 371  sub crcccitt { Line 469  sub crcccitt {
469  sub checksum {  sub checksum {
470          my ( $bytes, $checksum ) = @_;          my ( $bytes, $checksum ) = @_;
471    
         my $xor = crcccitt( substr($bytes,1) ); # skip D6  
         warn "## checksum ",dump( $bytes, $xor, $checksum ) if $debug;  
   
472          my $len = ord(substr($bytes,2,1));          my $len = ord(substr($bytes,2,1));
473          my $len_real = length($bytes) - 1;          my $len_real = length($bytes) - 1;
474    
475          if ( $len_real != $len ) {          if ( $len_real != $len ) {
476                  print "length wrong: $len_real != $len\n";                  print "length wrong: $len_real != $len\n";
477                  $bytes = substr($bytes,0,2) . chr($len_real) . substr($bytes,4);                  $bytes = substr($bytes,0,2) . chr($len_real) . substr($bytes,3);
478          }          }
479    
480            my $xor = crcccitt( substr($bytes,1) ); # skip D6
481            warn "## checksum ",dump( $bytes, $xor, $checksum ) if $debug;
482    
483          if ( defined $checksum && $xor ne $checksum ) {          if ( defined $checksum && $xor ne $checksum ) {
484                  print "checksum doesn't match: ", as_hex($xor), " != ", as_hex($checksum), " data: ", as_hex($bytes), "\n";                  print "checksum doesn't match: ", as_hex($xor), " != ", as_hex($checksum), " data: ", as_hex($bytes), "\n";
485                  return $bytes . $xor;                  return $bytes . $xor;
# Line 420  sub readchunk { Line 518  sub readchunk {
518          } sort { length($a) <=> length($b) } keys %$dispatch;          } sort { length($a) <=> length($b) } keys %$dispatch;
519          warn "?? payload dispatch to ",dump( $payload, $dispatch, $to ) if $debug;          warn "?? payload dispatch to ",dump( $payload, $dispatch, $to ) if $debug;
520    
521          if ( defined $to ) {          if ( defined $to && $payload ) {
522                  my $rest = substr( $payload, length($to) );                  my $rest = substr( $payload, length($to) );
523                  warn "## DISPATCH payload to with rest", dump( $payload, $to, $rest ) if $debug;                  warn "## DISPATCH payload to with rest", dump( $payload, $to, $rest ) if $debug;
524                  $dispatch->{ $to }->( $rest );                  $dispatch->{ $to }->( $rest );

Legend:
Removed from v.29  
changed lines
  Added in v.39

  ViewVC Help
Powered by ViewVC 1.1.26