NAME

Ham::Device::FT817COMM - Library to control the Yaesu FT817 Ham Radio

VERSION

Version 0.9.0_03

SYNOPSIS

use HAM::Device::FT817COMM;

Constructor and Port Configurations

my $FT817 = new Ham::Device::FT817COMM (
serialport => '/dev/ttyUSB0',
baud => '38400',
lockfile => '/var/lock/ft817'
			               );

my $port = $FT817->{'serialport'};
my $baud = $FT817->{'baud'};
my $lockfile = $FT817->{'lockfile'};
my $version = $FT817->moduleVersion;

Destructor

$FT817->closePort;

Initialization

The instance of the device and options are created with the constructor and port configurations shown above. The variable which is an instance of the device may be named at that point. In this case $FT817. The serialport must be a valid port and not locked. You must consider that your login must have permission to access the port either being added to the group or giving the user suffucient privilages. The baudrate 'baud' must match the baudrate of the radio CAT RATE which is menu item 14.

Finally lockfile is recommended to ensure that no other software may access the port at the same time. The lockfile is removed as part of the invocation of the destructor method.

METHODS

1. Using Return Data From a Module

This allows for complete control of the rig through the sub routines all done through the cat interface

$output = 'rigname'->'command'('value');

an example is a follows

$output = $FT817->setLock('ENABLE');

Using this method, the output which is collected in the varible $output is designed to be minimal for use in applications that provide an already formatted output.

For example:

$output = $FT817->setLock('ENABLE');
print "$output";

Would simply return F0 if the command failed and 00 if the command was sucessfull. The outputs vary from module to module, depending on the function

2. Using setVerbose(#)

The module already has pre-formatted outputs for each subroutine. Using the same example in a different form and setting setVerbose(1) we have the following

setVerbose(1);
$FT817->setLock('ENABLE');

The output would be, for example:

Set Lock (ENABLE) Sucessfull.

Other verbose outputs exist to catch errors.

setVerbose(1);
$FT817->setLock('blabla');

The output would be:

Set Lock (blabla) Failed. Option:blabla invalid.

The setVerbose(2) flag is similar to the setVerbose(1) flag but also provides the bit value of the function at the specified memory address.

An example of all 3 is show below for the command getHome()

As return data: Y
As verbose(1) : At Home Frequency
As verbose(2) : getHome: bit is (1) Home is Y

We see that return data will be suitable for a program which needs just a boolean value, verbose(1) is suitable for a front-end app response, and verbose(2) for internal testing of module.

3. Build a sub-routine into a condition

Another use can be to use a subrouting as a value in a condition statment to test

if (gethome() eq 'Y') {
	warn "I guess we're home";
		      }

Call all of the modules, one at a time and look at the outputs, from which you can decide how the data can be used. At this time I have completed a command line front end for this module that makes testing all of the functionality easy.

DEBUGGER

FT817COMM has a built in robust debugger that makes available to the user all transactions between the software and the rig. Where verbose gave the outputs to user initiated subroutines, the debugger does very much the same but with internal functions not designed to be called directly in the userspace. That being said, you should never directly call these system functions or you will quickly turn your 817 into a paperweight or door stop. You have been warned.

Feel free to use the debugger to get an idea as to how the module and the radio communicate.

setDebug(1); # Turns on the debugger

The first output of which is:

DEBUGGER IS ON

Two distinct type of transactions happen with the debugger, they are:

CAT commands   :	Commands which use the Yaesu CAT protocol
EPROMM commands:	Commands which read and write to the EEPROM

With the command: getMode() we get the regular output expected, with verbose(1)

Mode is FM

However with the setDebug(1) we will see the following output to the same command:

sendcat:debug - DATA OUT ----> 00 00 00 00 0x03
sendcat:debug - DATA IN <----- 1471200008
Mode is FM

The sendcat:debug shows the request of 00 00 00 00 0x03 sent to the rig, and the rig returning 1471200008. What were looking at is the last two digits 08 which is parsed from the block of data. 08 is mode FM. FT817COMM does all of the parsing and conversion for you.

As you might have guessed, the first 8 digits are the current frequency, which in this case is 147.120 MHZ. The getFrequency() module would pull the exact same data, but parse it differently

The debugger works differently on read/write to the eeprom. The next example shown below used the function getNb(), the noiseblocker status.

eepromdecode:debug - Output from MSB:0 LSB:57 : 11000010
Noise Blocker is OFF

The output shows that the status of noise blocker lives at 0x57 it happens to be bit 5 of this data (0) that indicates that the noiseblocker is OFF.

Modules

agreewithwarning() =item closeport() =item dec2bin() =item closePort() =item eepromDecode() =item getAgc() =item getConfig() =item getDsp() =item getEeprom() =item getFasttuning() =item getFlags() =item getFrequency() =item getHome() =item getLock() =item getMode() =item getNb() =item getRfgain() =item getRxstatus() =item getSoftcal() =item getTuner() =item getTxpower() =item getTxstatus() =item getVfo() =item hex2bin() =item moduleVersion() =item new() =item restoreEeprom() =item sendCat() =item setClarifier() =item setClarifierfreq() =item setCtcssdcs() =item setCtcsstone() =item setDcscode() =item setDebug() =item setFrequency() =item setLock() =item setMode() =item setOffsetfreq() =item setOffsetmode() =item setPower() =item setPtt() =item setSplitfreq() =item setWriteallow() =item toggleRfgain() =item vfoToggle() =item writeEeprom()

AUTHOR

Jordan Rubin KJ4TLB, <jrubin at cpan.org>

BUGS

Please report any bugs or feature requests to bug-ham-device-ft817comm at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Ham-Device-FT817COMM. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

SUPPORT

You can find documentation for this module with the perldoc command. perldoc Ham::Device::FT817COMM

You can also look for information at:

ACKNOWLEDGEMENTS

Thank you to Clint Turner KA7OEI for his research on the FT817 and discovering the mysteries of the EEprom FT817 and Yaesu are a registered trademark of Vertex standard Inc.

LICENSE AND COPYRIGHT

Copyright 2014 Jordan Rubin.

This program is free software; you can redistribute it and/or modify it under the terms of the the Artistic License (2.0). You may obtain a copy of the full license at:

http://www.perlfoundation.org/artistic_license_2_0

Any use, modification, and distribution of the Standard or Modified Versions is governed by this Artistic License. By using, modifying or distributing the Package, you accept this license. Do not use, modify, or distribute the Package, if you do not accept this license.

If your Modified Version has been derived from a Modified Version made by someone other than you, you are nevertheless required to ensure that your Modified Version complies with the requirements of this license.

This license does not grant you the right to use any trademark, service mark, tradename, or logo of the Copyright Holder. This license includes the non-exclusive, worldwide, free-of-charge patent license to make, have made, use, offer to sell, sell, import and otherwise transfer the Package with respect to any patent claims licensable by the Copyright Holder that are necessarily infringed by the Package. If you institute patent litigation (including a cross-claim or counterclaim) against any party alleging that the Package constitutes direct or contributory patent infringement, then this Artistic License to you shall terminate on the date that such litigation is filed.

Disclaimer of Warranty: THE PACKAGE IS PROVIDED BY THE COPYRIGHT HOLDER AND CONTRIBUTORS "AS IS' AND WITHOUT ANY EXPRESS OR IMPLIED WARRANTIES. THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, OR NON-INFRINGEMENT ARE DISCLAIMED TO THE EXTENT PERMITTED BY YOUR LOCAL LAW. UNLESS REQUIRED BY LAW, NO COPYRIGHT HOLDER OR CONTRIBUTOR WILL BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL DAMAGES ARISING IN ANY WAY OUT OF THE USE OF THE PACKAGE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.