Skip to content

escix/ibm-tape-drive-automatic-standalone

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 

Repository files navigation

ibm-tape-drive-automatic-standalone

How to turn an IBM Drive into automatic standalone mode

Hello all

I did get an IBM LTO 6 lately and was having trouble setting it in automatic drive online Mode. After a lot of reading of the barely available documentation and lending an oscilloscope from a friend, I was able to put things together and get the drive to work without an library. Hopefully I am able to save someone on this planet some time and struggle by sharing my documentation.

In the first place I did get an RS-422-USB cable with an screw terminal, but due to the undocumented pinout of the JST-SH 10 Pin connector I wasn’t successful in establishing an communication (maybe just bad luck).

The second step was to search out the circuit board and check the components. There I found an chip from TI, which is similar to this one THVD1451. TI has an great documentation for its components! https://www.ti.com/product/THVD1451

image image image

Perspective from the Drive Side ( Issue #1)

(The drive is Top Down on these pictures, the Top is on the table) image image

(The drive is in the position bottom to table, perspective from above) image Cabeling colors are from top to bottom:

  • white
  • grey
  • purple
  • blue
  • green
  • yellow
  • orange
  • red
  • brown
  • black

Following the Electrical Pathways I was assuming the following cabling:

  • Receive:
    • A → Yellow OR Orange
    • B → Orange OR Red
  • Send:
    • Z → Red OR Brown
    • Y → Brown OR Black

With the help of the oscilloscope it was possible to evaluate, although it was the fist time for me utilizing one.

image

image

image

Now I knew i was receiving signals on the YELLOW and the ORANGE Cables. The RS422 standard specifies differential signaling. In the picture above you can see the signals switching polarity which is causing an increased amplitude at the receiving side. I am not an electrical engineer and therefor can’t go any deeper in detail.

But what was it I was receiving? There would come the IBM Library/Drive Interface Specification in handy. http://t10.org/ftp/t10/document.02/02-022r0.pdf

There are the Control Characters which did appear 0x02 and 0x03 for Start an End of Text.

image

The middle Part seemed to be the Message for a Config_Request. To see them it is crucial to set the drive in non-polled Mode with the dip switches on the back. I have set them all to OFF.

image image image

Packets does have the following format: image

So this would make sense for an drive that was took out of an library. At page 30 is a description of the Interface Scenarios. The drive is operation in an non-polled Mode due to the dip switch. This means the drive is initiating the handshaking process and asking for a config.

image

To fulfill the handshake we need to “craft” an package. From Page 16 on is the description how an Set_Config message should look like.

image

And a useful information was in the interface scenario on Page 30.

image

If we would just craft the package with the first 54 bytes, we would be firmware independent.

Still we do not know what the sending cables are. The good news is there are packets we can try to send to the library which are outside of the package protocol, meaning we don’t need start-text, length, checksum, end-text, acknowledgments, or byte stuffing. If we send just hex 00 to the drive, we should receive something with “I” “B” “M”.

image

If you remember the lines I assumed as sending line have been:

  • Z → Red OR Brown
  • Y → Brown or Black

It turn out to be:

  • Z → Red

  • Y → Brown

  • Ground is Black.

After connecting Red to TxD+, Brown to TxD- and Black to GND on our RS-422-USB Adapter, we are ready to send the Set_Config package to the drive. The setting we try to accomplish is to set Bit 3 in Byte 53 to 0. This would allow the drive to raise the SCSI or Fiber Channel Ports without the need of receiving an Set_Config Package every time it powers up.

image

If we where successful, the drive would send and Acknowledge 0x06 an reboot like stated in the Scenario for Startup Process.

image

How to build the Package is described on the Pages 11 and 12 in the LDI Specification.

For transmitting the package I did use the following script:

#!/bin/bash 
stty -F /dev/ttyUSB0 speed 38400 -cstopb -parenb -echo

while read -r line
do 
	echo -en “$line” > /dev/ttyUSB0
done < “$1”

Save this as echo_hex and change the mode to execute

chmod +x ./echo_hex

Then we need an file with the hex code. Just name it code for example.

\x02\x00\x36\xAC\x01\x00\x00\x00\x01\xFF\xF2\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xE6\x03

Then we can issue the command

./echo_hex code

and see the Packages 0x06 0x03, for ACK and ETX on the receiving side.

image

Now the drive is rebooting and we can see the Link online. This qaucli is a command from qlogic (MARVELL) which in my case produced the HP Branded FC Card.

image

Also lsscsi is outputting the Tape now.

image

SUMMARY

  • Set all DIP Switches on the drive to off.
  • Connect the RS-422-USB Adapter as follows:
    • TxD+ → Red
    • TxD- → Brown
    • RxD+ → Yellow
    • RxD- → Orange
    • GND → Black
  • Send the Package to the drive: \x02\x00\x36\xAC\x01\x00\x00\x00\x01\xFF\xF2\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\xE6\x03
  • Drive restarts and goes online to SCSI or Fibre Channel automatically.

About

How to turn an IBM Drive into automatic standalone mode

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published