| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427 | <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2//EN"><html><head>	  <meta name="GENERATOR" content="Visual Page 1.0 for Windows">	  <meta http-equiv="Content-Type" content="text/html;CHARSET=iso-8859-1">  <title>TI-73 Link Protocol Guide - Packet formats</title></head><body bgcolor="#ffffe8"><p><b>TI-73 Link Protocol Guide v1.0</b> - Packet formats</p><center><h2><hr align="center"> Packet Formats</h2></center><p>Texas Instruments calculators always send data and responses inself-contained "packets."<br>Packets have the following format:<br><i>Note - all 2-byte integers are transmitted little-endian Intel-style(least significant byte first).</i></p><p><table border="1" cellspacing="0" width="92%">	<tbody>    <tr>		<th width="7%" bgcolor="#008800"><font color="#ffffff">Offset</font></th>		<th width="8%" bgcolor="#008800"><font color="#ffffff">Length</font></th>		<th width="85%" bgcolor="#008800"><font color="#ffffff">Description</font></th>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">0</td>		<td width="8%" bgcolor="#ffffff">1 byte</td>		<td width="85%" bgcolor="#ffffff">Machine ID byte</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">1</td>		<td width="8%" bgcolor="#ffffff">1 byte</td>		<td width="85%" bgcolor="#ffffff">Command ID byte</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">2</td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		<td width="85%" bgcolor="#ffffff">Length of data (see note below)</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">4</td>		<td width="8%" bgcolor="#ffffff"><i>n</i> bytes</td>		<td width="85%" bgcolor="#ffffff">Data (if attached)</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">4+<i>n</i></td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		<td width="85%" bgcolor="#ffffff">Checksum (if data is attached)</td>	</tr>  </tbody></table><i>Note - The "Length of data" element may not be equal to zero if thepacket contains no data. In this case, the Command ID byte willindicate that the packet contains no data.</i></p><p></p><h4>The Machine ID Byte</h4><p>The Machine ID byte identifies the machine that is sending thepacket. It can have one of the following values:<table border="1" cellspacing="0" width="66%">  <tbody>    <tr>      <th width="13%" bgcolor="#dddddd">Value</th>      <th bgcolor="#dddddd">Description</th>    </tr>    <tr>      <td width="13%">07h</td>      <td>Computer sending TI-73 data</td>    </tr>    <tr>      <td width="13%">74h</td>      <td>TI-73</td>    </tr>  </tbody></table></p><p></p><h4>The Command ID Byte</h4><p>The Command ID byte identifies the request or response that themachine is sending. It can have one of the following values:</p><p><table border="1" cellspacing="0" width="66%">	<tbody>    <tr>		<th width="22%" bgcolor="#dddddd">Value</th>		<th width="259" bgcolor="#dddddd">Description</th>		<th bgcolor="#dddddd">Data Included</th>	</tr>	<tr>		<td width="22%">06h</td>		<td width="259">Variable Header (VAR)</td>		 <td>A fixed-length, NUL padded <a href="#varheader">variableheader</a></td>	</tr>	<tr>		<td width="22%">09h</td>		<td width="259">Clear to send (CTS)</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">15h</td>		<td width="259">Data packet (DATA)</td>		<td>Screenshot/variable/backup data</td>	</tr>	<tr>		<td width="22%">36h</td>		<td width="259">Skip/Exit (SKIP/EXIT)</td>		<td>A one-byte rejection code (see codes below)</td>	</tr>	<tr>		<td width="22%">56h</td>		<td width="259">Acknowledge (ACK)</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">5Ah</td>		<td width="259">Checksum Error (ERR)<br>			The previous packet must be sent again.</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">68h</td>		<td width="259">Check ready (RDY)</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">6Dh</td>		<td width="259"><i>Silent</i> - Request Screenshot (SCR)</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">92h</td>		<td width="259">End of Transmission (EOT)</td>		<td><i>None</i></td>	</tr>	<tr>		<td width="22%">A2h</td>		<td width="259"><i>Silent</i> - Request Variable (REQ)</td>		 <td>A fixed-length, NUL padded <a href="#varheader">variableheader</a></td>	</tr>	<tr>		<td width="22%">C9h</td>		<td width="259"><i>Silent</i> - Request to Send Variable (RTS)</td>		 <td>A fixed-length, NUL padded <a href="#varheader">variableheader</a></td>	</tr>  </tbody></table></p><p></p><p>Rejection codes (used with Command ID 36h) can have one of thefollowing values:</p><p><table border="1" cellspacing="0" width="66%">	<tbody>    <tr>		<th width="13%" bgcolor="#dddddd">Value</th>		<th bgcolor="#dddddd">Description</th>	</tr>	<tr>		<td width="13%">01h</td>		<td>EXIT - The entire transmission has been cancelled.</td>	</tr>	<tr>		<td width="13%">02h</td>		<td>SKIP - The current variable has been skipped.</td>	</tr>	<tr>		<td width="13%">03h</td>		<td>OUT OF MEMORY (silent transmissions only) - The receivingcalculator is out of memory.</td>	</tr>  </tbody></table></p><p></p><h4>The Checksum</h4><p>The checksum is a 16-bit value used to verify the integrity of thedata in the packet. It only present if data is present.<br>The checksum is calculated by taking the lower 16 bits of the sum ofthe data bytes, as shown below:</p><pre>int calculateChecksum(unsigned char* data, unsigned short datalength) {<br>   unsigned short x, checksum;<br>   for(x=0; x<datalength; x++) {<br>      checksum+=data[x];  //overflow automatically limits to 16 bits<br>   }<br>   return checksum;<br>}</pre><center><h3><hr align="center"> <a name="varheader"></a>Variable Headers</h3></center><p>A Variable header contains information about one variable in thecalculator.<br><table border="1" cellspacing="0" width="92%">  <tbody>    <tr>      <th width="7%" bgcolor="#008800"><font color="#ffffff">Offset</font></th>      <th width="8%" bgcolor="#008800"><font color="#ffffff">Length</font></th>      <th width="85%" bgcolor="#008800"><font color="#ffffff">Description</font></th>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">0</td>      <td width="8%" bgcolor="#ffffff">2 bytes</td>      <td width="85%" bgcolor="#ffffff">Size of actual variable data,in bytes</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">2</td>      <td width="8%" bgcolor="#ffffff">1 byte</td>      <td width="85%" bgcolor="#ffffff">Type ID Byte (see type ID'sbelow)</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">3</td>      <td width="8%" bgcolor="#ffffff">8 bytes</td>      <td width="85%" bgcolor="#ffffff">Variable name, padded on theright with       NULL characters (0h). This field is always tokenized.Not used for ID list.<i></i></td>    </tr>  </tbody></table><i>Note: These bytes only make up the "data" section of the packet.<br></i><i>Note2:<br></i><i> - for lists (L1..L6), the first token is a 5D byte followed byanother byte:   01 for L1 to 06 for L6.</i><br></p><p></p><h4><a name="vartypes"></a>The Type ID Byte</h4><p>The type ID byte specifies the type of variable that is beingtransmitted. It can have one of the following values:</p><p><table border="1" cellspacing="0" width="66%">  <tbody>    <tr>      <th width="13%" bgcolor="#dddddd">Value</th>      <th bgcolor="#dddddd">Description (click for variable format)</th>    </tr>    <tr>      <td width="13%">00h</td>      <td><a href="vars.html#real">Real Number</a></td>    </tr>    <tr>      <td width="13%">01h</td>      <td><a href="vars.html#list">Real List</a></td>    </tr>    <tr>      <td width="13%">02h</td>      <td><a href="vars.html#equation">Y-Variable</a></td>    </tr>    <tr>      <td width="13%">05h</td>      <td><a href="vars.html#program">Program</a></td>    </tr>    <tr>      <td width="13%">06h</td>      <td>Assembly <a href="vars.html#program">Program</a> ?</td>    </tr>    <tr>      <td width="13%">07h</td>      <td><a href="vars.html#picture">Picture</a></td>    </tr>    <tr>      <td width="13%">0Bh</td>      <td><a href="vars.html#window">Window Settings</a><i> (See notebelow)</i></td>    </tr>    <tr>      <td width="13%">0Fh</td>      <td><a href="vars.html#window">Window Settings</a><i> (See notebelow)</i></td>    </tr>    <tr>      <td width="13%">11h</td>      <td><a href="vars.html#table">Table Setup</a><i> (See note below)</i></td>    </tr>    <tr>      <td width="13%">13h</td>      <td><a href="backup.html">Backup</a></td>    </tr>    <tr>      <td width="13%">19h</td>      <td><a name="19h"></a><a href="silent.html">Directory</a> <i>(Seenote below) </i>- only used when requesting a directory</td>    </tr>    <tr>      <td width="13%">23h</td>      <td><a name="19h"></a><a href="flash.html">FLASH</a> OperatingSystem</td>    </tr>    <tr>      <td width="13%">24h</td>      <td><a name="19h"></a><a href="flash.html">FLASH</a> Application</td>    </tr>    <tr>      <td width="13%">26h</td>      <td><a name="FLASH"></a><a href="flash.html">ID list</a></td>    </tr>    <tr>      <td width="13%">27h</td>      <td><a name="19h"></a><a href="flash.html">Get Certificate</a></td>    </tr>  </tbody></table></p><p></p><h4><a name="backup"></a>Backup Header Format</h4><p>If the type ID byte specifies a backup, the variable header takesthe following   9-byte format :</p><p><table border="1" cellspacing="0" width="92%">	<tbody>    <tr>		<th width="7%" bgcolor="#008800"><font color="#ffffff">Offset</font></th>		<th width="8%" bgcolor="#008800"><font color="#ffffff">Length</font></th>		<th width="85%" bgcolor="#008800"><font color="#ffffff">Description</font></th>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">0</td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		 <td width="85%" bgcolor="#ffffff">Size of first backup section(flags area),       in bytes</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">2</td>		<td width="8%" bgcolor="#ffffff">1 byte</td>		 <td width="85%" bgcolor="#ffffff">Type ID Byte (13h in thiscase)</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">3</td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		 <td width="85%" bgcolor="#ffffff">Size of second backup section(data area),       in bytes</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">5</td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		 <td width="85%" bgcolor="#ffffff">Size of third backup section(symbol area),       in bytes</td>	</tr>	<tr>		<td width="7%" bgcolor="#ffffff">7</td>		<td width="8%" bgcolor="#ffffff">2 bytes</td>		 <td width="85%" bgcolor="#ffffff">Start User Area Address</td>	</tr>  </tbody></table></p><h4><a name="FLASH"></a>FLASH Header Format<br></h4><p>If the type ID byte is in the range 22...28h, the variable headertakes the   following 10-byte format : </p><table border="1" cellspacing="0" width="92%">  <tbody>    <tr>      <th width="7%" bgcolor="#008800"><font color="#ffffff">Offset</font></th>      <th width="8%" bgcolor="#008800"><font color="#ffffff">Length</font></th>      <th width="85%" bgcolor="#008800"><font color="#ffffff">Description</font></th>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">0</td>      <td width="8%" bgcolor="#ffffff">2 bytes</td>      <td width="85%" bgcolor="#ffffff">Size of actual data, in bytes(LSB).</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">2</td>      <td width="8%" bgcolor="#ffffff">1 byte</td>      <td width="85%" bgcolor="#ffffff">Type ID Byte (see type ID'sbelow)</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">3</td>      <td width="8%" bgcolor="#ffffff">2 bytes</td>      <td width="85%" bgcolor="#ffffff">Size of actual data, in bytes(MSB).</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">5</td>      <td width="8%" bgcolor="#ffffff">1 byte</td>      <td width="85%" bgcolor="#ffffff">Flag - Always has a value of 0hbut bit       7 is set if archived.</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">6</td>      <td width="8%" bgcolor="#ffffff">2 bytes</td>      <td width="85%" bgcolor="#ffffff">FLASH offset</td>    </tr>    <tr>      <td width="7%" bgcolor="#ffffff">8</td>      <td width="8%" bgcolor="#ffffff">2 bytes</td>      <td width="85%" bgcolor="#ffffff">FLASH page</td>    </tr>  </tbody></table><br><p></p><p><table border="0" cellspacing="0" width="100%">	<tbody>    <tr>		<td width="32%"> 			      <p align="center"><a href="cable.html"><img src="graphics/prevpage.gif" width="32" height="32" align="bottom" alt="[previous page]" border="2"><br>			Link Cables</a> 		</p>      </td>		<td width="34%"> 			      <p align="center"><a href="index.html"><img src="graphics/home.gif" width="32" height="32" align="bottom" alt="[home]" border="2"><br>			Table of Contents</a> 		</p>      </td>		<td width="34%"> 			      <p align="center"><a href="screenshot.html"><img src="graphics/nextpage.gif" width="32" height="32" align="bottom" alt="[next page]" border="2"><br>			Screenshots</a> 		</p>      </td>	</tr>  </tbody></table></p><hr align="center"> <i>Site maintained by Romain Liévin (</i><a href="mailto:roms@lpg.ticalc.org"><i>roms@lpg.ticalc.org</i></a><i>)and Tim Singer (</i><a href="mailto:tsinger@gladstone.uoregon.edu"><i>tsinger@gladstone.uoregon.edu</i></a><i>)</i></body></html>
 |