2013-06-14 12:39:38 +02:00
|
|
|
#!/usr/bin/env perl
|
2012-04-29 19:55:17 +02:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use Device::SerialPort;
|
|
|
|
use Getopt::Long;
|
|
|
|
use Pod::Usage;
|
|
|
|
|
2013-06-14 12:39:38 +02:00
|
|
|
my %Opt =
|
|
|
|
(
|
2012-04-29 19:55:17 +02:00
|
|
|
period => 0.1,
|
|
|
|
);
|
|
|
|
|
2013-06-14 12:39:38 +02:00
|
|
|
GetOptions(\%Opt,
|
2013-07-03 00:18:29 +02:00
|
|
|
"period=f", # width of reset pulse in seconds
|
|
|
|
"verbose!",
|
|
|
|
"help!",
|
|
|
|
"info!",
|
|
|
|
"caterina!",
|
|
|
|
);
|
2012-04-29 19:55:17 +02:00
|
|
|
|
|
|
|
if ($Opt{help} || $Opt{info})
|
|
|
|
{
|
|
|
|
usage();
|
|
|
|
}
|
|
|
|
|
|
|
|
die "No Arduinos found!\n"
|
|
|
|
unless @ARGV;
|
|
|
|
|
|
|
|
foreach my $dev (@ARGV)
|
|
|
|
{
|
|
|
|
my $p = Device::SerialPort->new($dev)
|
|
|
|
or die "Unable to open $dev: $!\n";
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2013-07-03 00:18:29 +02:00
|
|
|
if ($Opt{caterina})
|
2013-06-14 12:39:38 +02:00
|
|
|
{
|
|
|
|
$p->baudrate(1200);
|
|
|
|
$p->write_settings;
|
|
|
|
$p->close;
|
|
|
|
|
2013-07-02 05:11:19 +02:00
|
|
|
print STDERR "Forcing reset using 1200bps open/close on port $dev\n"
|
|
|
|
if $Opt{verbose};
|
|
|
|
|
|
|
|
# wait for it to come back
|
|
|
|
sleep 1;
|
|
|
|
while( ! -e $dev ) {
|
|
|
|
print STDERR "Waiting for $dev to come back\n"
|
|
|
|
if $Opt{verbose};
|
|
|
|
sleep 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
print STDERR "$dev has come back after reset\n"
|
2013-06-14 12:39:38 +02:00
|
|
|
if $Opt{verbose};
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2012-04-29 19:55:17 +02:00
|
|
|
my $dt = $Opt{period};
|
|
|
|
|
|
|
|
print STDERR "Setting DTR high for ${dt}s on $dev\n"
|
|
|
|
if $Opt{verbose};
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
die "Invalid pulse width ($dt), "
|
|
|
|
unless $dt > 0.0;
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
$p->pulse_dtr_on($dt * 1000.0);
|
2013-06-14 12:39:38 +02:00
|
|
|
}
|
2012-04-29 19:55:17 +02:00
|
|
|
}
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
## here endeth the main
|
|
|
|
|
2013-06-14 12:39:38 +02:00
|
|
|
sub usage
|
2012-04-29 19:55:17 +02:00
|
|
|
{
|
|
|
|
pod2usage(-verbose => 2);
|
|
|
|
}
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 NAME
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
ard-reset-arduino - Reset an Arduino
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=head1 USAGE
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
$ ard-reset-arduino /dev/cu.usb*
|
|
|
|
|
|
|
|
$ ard-reset-arduino --verbose --period=0.1 /dev/cu.usb*
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2013-07-03 00:18:29 +02:00
|
|
|
$ ard-reset-arduino --verbose --caterina /dev/ttyUSB0
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
To reset (most) Arduinos, it's enough to just pulse the DTR line.
|
|
|
|
|
2013-06-14 12:39:38 +02:00
|
|
|
You can do that from the shell with stty, but there's an interesting
|
2012-04-29 19:55:17 +02:00
|
|
|
diversity of command flags. This little program gives a uniform interface
|
|
|
|
at the cost of requiring C<Device::SerialPort>.
|
|
|
|
|
|
|
|
=head1 OPTIONS
|
|
|
|
|
|
|
|
=over
|
|
|
|
|
|
|
|
=item --verbose
|
|
|
|
|
|
|
|
Watch what's going on on STDERR.
|
|
|
|
|
|
|
|
=item --period=0.25
|
|
|
|
|
|
|
|
Specify the DTR pulse width in seconds.
|
|
|
|
|
2013-07-03 00:18:29 +02:00
|
|
|
=item --caterina
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2013-07-03 00:18:29 +02:00
|
|
|
Reset a Leonardo, Micro, Robot or LilyPadUSB.
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=back
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=head1 BUGS AND LIMITATIONS
|
|
|
|
|
|
|
|
There are no known bugs in this application.
|
|
|
|
|
|
|
|
Please report problems to the author.
|
|
|
|
|
|
|
|
Patches are welcome.
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=head1 AUTHOR
|
|
|
|
|
|
|
|
Martin Oldfield, ex-atelier@mjo.tc
|
|
|
|
|
2013-06-20 21:34:40 +02:00
|
|
|
Support for Leonardo/Micro added by sej7278, https://github.com/sej7278
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
Thanks to Daniele Vergini who suggested this to me, and supplied
|
|
|
|
a command line version.
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
=head1 LICENCE AND COPYRIGHT
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
Copyright (c) 2012, Martin Oldfield. All rights reserved.
|
2013-06-14 12:39:38 +02:00
|
|
|
|
2012-04-29 19:55:17 +02:00
|
|
|
This file is free software; you can redistribute it and/or modify it
|
|
|
|
under the terms of the GNU Lesser General Public License as published
|
|
|
|
by the Free Software Foundation; either version 2.1 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
2013-06-14 12:39:38 +02:00
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
2012-04-29 19:55:17 +02:00
|
|
|
|
|
|
|
|