NAME
USB::TMC - Perl interface to USB Test & Measurement (USBTMC) backend.
SYNOPSIS
use USB::TMC;
# Open usb connection to Agilent 34410A digital multimeter
my $usbtmc = USB::TMC->new(
vid => 0x0957,
pid => 0x0607,
serial => 'MY47000419', # only needed if vid/pid is ambiguous
);
$usbtmc->write(data => "*CLS\n");
$usbtmc->write(data => "VOLT:NPLC 10\n");
print $usbtmc->query(data => ":read?\n", length => 100);
my $capabilities = $usbtmc->get_capabilities();
my $support_term_char = $capabilities->{support_term_char};
DESCRIPTION
This module provides a user-space USBTMC driver.
Internally this module is based on USB::LibUSB.
Does not yet support the additional features of USBTMC-USB488. But those could easily be added if needed.
METHODS
Errors with USB transfers will result in a croak.
Use default timeout if timeout
arg is not given.
new
my $usbtmc = USB::TMC->new(
vid => $vid,
pid => $pid,
serial => $serial, # optional
reset_device => 1, # default: do not reset device
debug_mode => 1, # print lots of debug messages
libusb_log_level => LIBUSB_LOG_LEVEL_DEBUG, # Import LIBUSB_LOG_LEVEL_* constant from USB::LibUSB
term_char => "\n", # Stop a read request if the term_char occurs in the
# byte stream. Default: do not use term char
timeout => 10, # timeout in seconds. default: 5
);
write
$usbtmc->write(data => $data, timeout => $timeout);
Do DEV_DEP_MSG_OUT transfer. So far this only supports USBTMC messages consisting of a single transfer.
read
my $data = $usbtmc->read(length => $read_length, timeout => $timeout);
Do REQUEST_DEV_DEP_MSG_IN and DEV_DEP_MSG_IN transfers.
clear
$usbtmc->clear(timeout => $timeout);
Do INITIATE_CLEAR / CHECK_CLEAR_STATUS split transaction. On success, send CLEAR_FEATURE request to clear the Bulk-OUT Halt.
get_capabilities
my $capabilites = $usbtmc->get_capabilities(timeout => $timeout);
Do GET_CAPABILITIES request.
The $capabilities
hash contains the following keys:
- bcdUSBTMC
- listen_only
- talk_only
- accept_indicator_pulse
- support_term_char