home *** CD-ROM | disk | FTP | other *** search
/ Telecom / 1996-04-telecom-walnutcreek.iso / technical / ixo.tap.protocol < prev    next >
Internet Message Format  |  1993-02-14  |  42KB

  1. From: mc/G=Brad/S=Hicks/OU=0205925@mhs.attmail.com
  2. Date: 11 Feb 93 22:58:48 GMT
  3. Subject: IXO.TAP.protocol part 1 
  4.  
  5.  
  6. TRANSCRIBER'S FOREWORD: Items like [1] are their footnotes, and usually
  7. follow the table they're in.  Items like {1} are my notes, based on my
  8. experience implementing from this crummy document, and follow at the end.
  9. If you have questions about this, consult your paging vendor's linesmen or
  10. engineers, not me. If you just want to say thanks, grumble, or complain,
  11. you can reach me at mc!Brad_Hicks@mhs.attmail.com, or at
  12. jbhicks@mcimail.com, or (X400) c=US, admd=ATTMail, prmd=MasterCard,
  13. sn=Hicks, gn=Brad.
  14.    I work for MasterCard as a senior PC specialist, and that's why their
  15. name appears in my X.400 address. This document is 100% my responsibility;
  16. if you have a beef, it's with me, not with them.
  17.  
  18.  
  19. Glenayre Electronics
  20. GLP-3000-180
  21. Issue 5: 91/01/30
  22.  
  23. Print Date: 2/13/91
  24. Copyright (c) 1991 Glenayre Electronics. All Rights Reserved.
  25. Pages 7-1 through 7-12
  26.  
  27.  
  28. 7. TELOCATOR ALPHANUMERIC PROTOCOL (TAP)
  29.  
  30. 7.1 Introduction
  31.  
  32. In order to decrease holding times on input lines to alphanumeric systems,
  33. it was desirable to promote input devices which will allow off-line entry
  34. of paging information and dump this data quickly after connection to the
  35. central paging terminal. This protocol was known as the IXO alphanumeric
  36. protocol until it was adopted for the input of paging requests. It is now
  37. referred to as the Telocator Alphanumeric Protocol (TAP).
  38.  
  39. Table 7-1 Call Delivery Sequence
  40.  
  41.     +----------------------+----------------------+----------------------+
  42.     | REM. ENTRY DEV. DOES | PAGING CENTRAL DOES  | COMMENTS             |
  43. +---+----------------------+----------------------+----------------------+
  44. | 1 | Off hook-access DDD  |                      |                      |
  45. |   | line.                |                      |                      |
  46. |   | Await dial tone.     |                      |                      |
  47. |   | Dial stored access   |                      |                      |
  48. |   | number               | Ring Answer          |                      |
  49. +---+----------------------+----------------------+----------------------+
  50. | 2 | Carrier up           | Carrier up           |                      |
  51. +---+----------------------+----------------------+----------------------+
  52. | 3 | "<CR>" [1]           |                      | <CR> is repeated at  |
  53. |   |                      |                      | two second intervals |
  54. |   |                      |                      | until paging central |
  55. |   |                      |                      | responds with ID= at |
  56. |   |                      |                      | correct baud rate or |
  57. |   |                      |                      | until three trans-   |
  58. |   |                      |                      | missions have been   |
  59. |   |                      |                      | completed. (This     |
  60. |   |                      |                      | step exists to allow |
  61. |   |                      |                      | for possible future  |
  62. |   |                      |                      | baud rate recogni-   |
  63. |   |                      |                      | tion).               |
  64. |   |                      |                      |                      |
  65. |   |                      |                      | Some systems have    |
  66. |   |                      |                      | chosen to send ID=   |
  67. |   |                      |                      | from the central if  |
  68. |   |                      |                      | they do not receive  |
  69. |   |                      |                      | <CR> in about two    |
  70. |   |                      |                      | seconds. This vari-  |
  71. |   |                      |                      | ation appears to be  |
  72. |   |                      |                      | acceptable as the    |
  73. |   |                      |                      | central continues to |
  74. |   |                      |                      | respond to <CR>s     |
  75. |   |                      |                      | with ID= s.          |
  76. +---+----------------------+----------------------+----------------------+
  77. | 4 |                      | "ID= " {1}           | Request for ID re-   |
  78. |   |                      |                      | turned within one    |
  79. |   |                      |                      | second of receipt of |
  80. |   |                      |                      | <CR>. Paging central |
  81. |   |                      |                      | may, at its option,  |
  82. |   |                      |                      | send <CR> or <CR><LF>|
  83. |   |                      |                      | after ID=.           |
  84. |   |                      |                      |                      |
  85. |   |                      |                      | Paging central may   |
  86. |   |                      |                      | optionally choose to |
  87. |   |                      |                      | send ID= if it does  |
  88. |   |                      |                      | not receive <CR>     |
  89. |   |                      |                      | after an appropriate |
  90. |   |                      |                      | waiting time.        |
  91. +---+----------------------+----------------------+----------------------+
  92.  
  93. [1] All quotation marks or the symbols <> shown are used for notation
  94.     and are not transmitted.
  95.  
  96. Two options exist at this point:
  97.  
  98. * Automatic Mode (see section 5A)
  99. * Manual Mode (see section 5M)
  100.  
  101.     +----------------------+----------------------+----------------------+
  102.     | REM. ENTRY DEV. DOES | PAGING CENTRAL DOES  | COMMENTS             |
  103. +---+----------------------+----------------------+----------------------+
  104. | 5 | For automatic remote |                      | <ESC> signifies      |
  105. | A | entry devices.       |                      | entry device intends |
  106. |   |                      |                      | to talk in automatic |
  107. |   | "<ESC>SST" {2}       |                      | dump mode. SS is a   |
  108. |   |                      |                      | set of two alpha-    |
  109. |   | Typical Example:     |                      | numeric characters   |
  110. |   | "<ESC>PG1"           |                      | signifying a type of |
  111. |   |                      |                      | service to be ac-    |
  112. |   |                      |                      | cessed.              |
  113. |   |                      |                      |                      |
  114. |   |                      |                      | For a paging service |
  115. |   |                      |                      | where:               |
  116. |   |                      |                      | Field 1 = 'Pager ID' |
  117. |   |                      |                      | and                  |
  118. |   |                      |                      | Field 2 = 'Message'. |
  119. |   |                      |                      |                      |
  120. |   |                      |                      | SS will be sent as   |
  121. |   |                      |                      | 'PG'.                |
  122. |   |                      |                      |                      |
  123. |   |                      |                      | Where T is a single  |
  124. |   |                      |                      | alphanumeric char-   |
  125. |   |                      |                      | acter relate to the  |
  126. |   |                      |                      | type of terminal or  |
  127. |   |                      |                      | device attempting to |
  128. |   |                      |                      | send the message.    |
  129. |   |                      |                      |                      |
  130. |   |                      |                      | T = '1' is a cate-   |
  131. |   |                      |                      | gory using the same  |
  132. |   |                      |                      | protocol. The PETs   |
  133. |   |                      |                      | and IXO devices are  |
  134. |   |                      |                      | members of this      |
  135. |   |                      |                      | category.            |
  136. |   |                      |                      | T = '7,8,9' are re-  |
  137. |   |                      |                      | served for wild card |
  138. |   |                      |                      | terminals or devices |
  139. |   |                      |                      | which may relate to  |
  140. |   |                      |                      | a specific users'    |
  141. |   |                      |                      | system.              |
  142. +---+----------------------+----------------------+----------------------+
  143. | 6 | "PPPPPP<CR>" {3}     |                      | This 6-character     |
  144. |   |                      |                      | alphanumeric pass-   |
  145. |   | GL-3000 will ignore  |                      | word comes from      |
  146. |   | password             |                      | automatic terminals. |
  147. |   |                      |                      | (Password is optional|
  148. |   | Typical password for |                      | and is, in general,  |
  149. |   | IXO is "000000"      |                      | reserved for future  |
  150. |   |                      |                      | services. Password   |
  151. |   |                      |                      | may be interpreted   |
  152. |   |                      |                      | as either a caller   |
  153. |   |                      |                      | ID or a system entry |
  154. |   |                      |                      | key. Length of pass- |
  155. |   |                      |                      | word, when used, may |
  156. |   |                      |                      | be different in some |
  157. |   |                      |                      | systems.)            |
  158. |   |                      |                      |                      |
  159. |   |                      |                      | When an incorrect    |
  160. |   |                      |                      | logon sequence       |
  161. |   |                      |                      | beginning with <ESC> |
  162. |   |                      |                      | is received, the     |
  163. |   |                      |                      | paging central may   |
  164. |   |                      |                      | respond with an ID=  |
  165. |   |                      |                      | if it requires a     |
  166. |   |                      |                      | retransmission.      |
  167. +---+----------------------+----------------------+----------------------+
  168. |   |                      | "Message sequence    | Logon accepted       |
  169. |   |                      | <CR><ACK><CR>"       |                      |
  170. |   |                      |                      |                      |
  171. |   |                      | or                   | or                   |
  172. |   |                      |                      |                      |
  173. |   |                      | "Message sequence    | Requested again      |
  174. |   |                      | <CR><NAK><CR>"       |                      |
  175. |   |                      |                      |                      |
  176. |   |                      | or                   | or                   |
  177. |   |                      |                      |                      |
  178. |   |                      | "Message sequence    | Forced disconnect    |
  179. |   |                      | <CR><ESC><EOT><CR>"  |                      |
  180. +---+----------------------+----------------------+----------------------+
  181.   * Gl3000 Typical Message Sequence: "Processing - Please Wait" or
  182.                                      "4 pages sent"             or
  183.                                      "Bad Phone Line Call Again".
  184.     +----------------------+----------------------+----------------------+
  185.     | REMOTE ENTRY         | PAGING CENTRAL DOES  | COMMENTS             |
  186. +---+----------------------+----------------------+----------------------+
  187. |   |                      |                      | A message sequence   |
  188. |   |                      |                      | is defined as a      |
  189. |   |                      |                      | series of short      |
  190. |   |                      |                      | messages separated   |
  191. |   |                      |                      | by <CR>s. A <CR>     |
  192. |   |                      |                      | always follows a     |
  193. |   |                      |                      | message sequence.    |
  194. |   |                      |                      | Message sequences    |
  195. |   |                      |                      | are totally optional.|
  196. +---+----------------------+----------------------+----------------------+
  197. | 6 |                      | Optional message     | Central may insert   |
  198. | a |                      | sequence <CR>        | short message        |
  199. |   |                      |                      | sequence between     |
  200. |   |                      |                      | steps 6 and 7.       |
  201. +---+----------------------+----------------------+----------------------+
  202. | 7 |                      | "<ESC> [p <CR>"      | Message go ahead is  |
  203. |   |                      |                      | sent when paging     |
  204. |   |                      |                      | central is ready for |
  205. |   |                      |                      | new information.     |
  206. |   |                      |                      | The 'p' is in lower  |
  207. |   |                      |                      | case.                |
  208. +---+----------------------+----------------------+----------------------+
  209. | 8 | TRANSACTION #1       |                      | A block is up to 256 |
  210. |   |      : "<STX>        |                      | characters in length,|
  211. |   |      : FIELD #1 <CR> | {4}                  | with up to 250 char- |
  212. |   | BLOCK: FIELD #2 <CR> | {5}                  | acters of info, plus |
  213. |   | #1   :               |                      | 3 control characters |
  214. |   |      : FIELD #N <CR> |                      | and a 3 character    |
  215. |   |      : <ETX>         |                      | checksum. The block  |
  216. |   |      : <CHECKSUM>    |                      | carries one trans-   |
  217. |   |      : <CR>"         |                      | action (one set of   |
  218. |   |                      |                      | fields 1 through N)  |
  219. |   |                      |                      | or a portion of one  |
  220. |   |                      |                      | transaction. A block |
  221. |   |                      |                      | may be less than 256 |
  222. |   |                      |                      | characters to        |
  223. |   |                      |                      | accommodate short    |
  224. |   |                      |                      | transactions.        |
  225. +---+----------------------+----------------------+----------------------+
  226. |   |                      |                      | A field may be any   |
  227. |   |                      |                      | length and where     |
  228. |   |                      |                      | necessary may be     |
  229. |   |                      |                      | continued in         |
  230. |   |                      |                      | following blocks.    |
  231. |   |                      |                      | A field always ends  |
  232. |   |                      |                      | with a <CR>. The     |
  233. |   |                      |                      | <CR> field delimiter |
  234. |   |                      |                      | suggests <CR> may    |
  235. |   |                      |                      | not be used within a |
  236. |   |                      |                      | field.               |
  237. |   |                      |                      |                      |
  238. |   |                      |                      | A block always       |
  239. |   |                      |                      | begins with an <STX> |
  240. |   |                      |                      | and ends with a      |
  241. |   |                      |                      | checksum followed by |
  242. |   |                      |                      | a <CR>. The char-    |
  243. |   |                      |                      | acters preceding the |
  244. |   |                      |                      | checksum depends on  |
  245. |   |                      |                      | what, if anything,   |
  246. |   |                      |                      | is continued beyond  |
  247. |   |                      |                      | the block boundary.  |
  248. |   |                      |                      |                      |
  249. |   |                      |                      | The <ETX> is used as |
  250. |   |                      |                      | a block termination  |
  251. |   |                      |                      | indicator if a given |
  252. |   |                      |                      | transaction (fields  |
  253. |   |                      |                      | 1 through N) ends    |
  254. |   |                      |                      | within the block     |
  255. |   |                      |                      | currently being      |
  256. |   |                      |                      | transmitted.         |
  257. +---+----------------------+----------------------+----------------------+
  258. |   | TRANSACTION #2 {6}   |                      | The <ETB> is used as |
  259. |   |      : "<STX>        |                      | a block terminator   |
  260. |   |      : FIELD #1 <CR> |                      | if the transaction   |
  261. |   | BLOCK:               |                      | is continued into    |
  262. |   | #2   : FIELD #J <CR> |                      | the next block, but  |
  263. |   |      : <ETB>         |                      | the last field in    |
  264. |   |      : <CHECKSUM>    |                      | the current block is |
  265. |   |      : <CR>"         |                      | complete.            |
  266. |   |                      |                      |                      |
  267. |   |      : "<STX>        |                      | If the last field    |
  268. |   |      : FIELD #J+1<CR>|                      | within the current   |
  269. |   | BLOCK:               |                      | block is to be       |
  270. |   | #3   : FIELD #L <US> |                      | continued in the     |
  271. |   |      : <CHECKSUM>    |                      | next block, no <CR>  |
  272. |   |      : <CR>          |                      | is inserted at the   |
  273. |   |                      |                      | end of the first     |
  274. |   |      : "<STX>        |                      | portion of the field |
  275. |   |      : FIELD #L      |                      | and the <US> char-   |
  276. |   |      : (CONTINUED)   |                      | acter is used as a   |
  277. |   |      : <CR>          |                      | block termination    |
  278. |   | BLOCK:               |                      | character. The <CR>  |
  279. |   | #4   : FIELD <CR>    |                      | terminating the      |
  280. |   |      : <ETX>         |                      | broken field is sent |
  281. |   |      : <CHECKSUM>    |                      | at the end of the    |
  282. |   |      : <CR>          |                      | field in whatever    |
  283. |   |                      |                      | block the field      |
  284. |   |                      |                      | actually terminates. |
  285. |   |                      |                      |                      |
  286. |   |                      |                      | No limit is estab-   |
  287. |   |                      |                      | lished within the    |
  288. |   |                      |                      | protocol itself      |
  289. |   |                      |                      | regarding the number |
  290. |   |                      |                      | of transactions, the |
  291. |   |                      |                      | number of fields or  |
  292. |   |                      |                      | the number of blocks |
  293. |   |                      |                      | per field; however,  |
  294. |   |                      |                      | a particular user    |
  295. |   |                      |                      | system may have      |
  296. |   |                      |                      | limits on any of     |
  297. |   |                      |                      | these items.         |
  298. |   |                      |                      |                      |
  299. |   | LAST TRANSACTION     |                      | Some systems may be  |
  300. |   |                      |                      | limited to one block |
  301. |   |                      |                      | per transaction and  |
  302. |   |                      |                      | one transaction per  |
  303. |   |                      |                      | telephone connection.|
  304. |   |                      |                      |                      |
  305. |   |                      |                      | Each checksum is     |
  306. |   |                      |                      | computed by perfor-  |
  307. |   |                      |                      | ming the simple      |
  308. |   |                      |                      | arithmetic sum of    |
  309. |   |                      |                      | the 7-bit values of  |
  310. |   |                      |                      | all values of all    |
  311. |   |                      |                      | characters preceding |
  312. |   |                      |                      | it in that block.    |
  313. |   |                      |                      | (This means that the |
  314. |   |                      |                      | STX and ETB/ETX are  |
  315. |   |                      |                      | included in the sum).|
  316. |   |                      |                      | The checksum is then |
  317. |   |                      |                      | the least signifi-   |
  318. |   |                      |                      | cant 12 bits of this |
  319. |   |                      |                      | resulting sum.       |
  320. +---+----------------------+----------------------+----------------------+
  321. |   |                      |                      | The checksum is      |
  322. |   |                      |                      | transmitted as three |
  323. |   |                      |                      | printable ASCII      |
  324. |   |                      |                      | characters having    |
  325. |   |                      |                      | values between HEX   |
  326. |   |                      |                      | 30 and HEX 3F (the   |
  327. |   |                      |                      | characters 012345678 |
  328. |   |                      |                      | 9:;<=>?). The most   |
  329. |   |                      |                      | significant four     |
  330. |   |                      |                      | bits of the sum are  |
  331. |   |                      |                      | encoded as the 4 LSB |
  332. |   |                      |                      | of the third char-   |
  333. |   |                      |                      | cter. See example.   |
  334. |   |                      |                      |                      |
  335. |   |                      |                      | A normal paging sys- |
  336. |   |      : "<STX>        |                      | tem will have two    |
  337. |   |      : FIELD #1 <CR> |                      | fields only:         |
  338. |   | LAST :               |                      |                      |
  339. |   | BLOCK: FIELD #N <CR> |                      | Field 1 = Pager ID   |
  340. |   |      : <ETX>         |                      | (normally up to      |
  341. |   |      : <CHECKSUM>    |                      | eight digits. May    |
  342. |   |      : <CR>"         |                      | include function and |
  343. |   |                      |                      | check digit).        |
  344. |   |                      |                      |                      |
  345. |   |                      |                      | Field 2 = Message    |
  346. |   |                      |                      |                      |
  347. |   |                      |                      | Field 1 or field 2   |
  348. |   |                      |                      | may be empty. For    |
  349. |   |                      |                      | example, when a page |
  350. |   |                      |                      | is tone only, field  |
  351. |   |                      |                      | 2 will be empty.     |
  352. |   |                      |                      | Even when empty, a   |
  353. |   |                      |                      | field is followed by |
  354. |   |                      |                      | a <CR>. Some systems |
  355. |   |                      |                      | will reject trans-   |
  356. |   |                      |                      | actions which have   |
  357. |   |                      |                      | an empty field 2 for |
  358. |   |                      |                      | a display page or    |
  359. |   |                      |                      | transactions which   |
  360. |   |                      |                      | have an empty field  |
  361. |   |                      |                      | 1. Other systems are |
  362. |   |                      |                      | less restrictive.    |
  363. +---+----------------------+----------------------+----------------------+
  364. |   |                      |                      | The response to each |
  365. |   |                      |                      | block is one of four:|
  366. |   |                      |                      |                      |
  367.                      |                      | "Message sequence    |
  368. <ACK><CR> = OK, send |
  369. |   |                      | <CR> <ACK> <CR>"     | next block.          |
  370. |   |                      |                      |                      |
  371. |   |                      | or                   |                      |
  372. |   |                      |                      |                      |
  373. |   |                      | "Message sequence    | <NAK><CR> = checksum |
  374. |   |                      | <CR> <NAK> <CR>"     | or transmission      |
  375. |   |                      |                      | error, send last     |
  376. |   |                      |                      | block again.         |
  377. |   |                      | or                   |                      |
  378. |   |                      | "Message sequence    | <RS><CR> = abandon   |
  379. |   |                      | <CR> <RS> <CR>"      | current transaction  |
  380. |   |                      |                      | and go to next. RS   |
  381. |   |                      |                      | may occur when the   |
  382. |   |                      |                      | checksum is OK, but  |
  383. |   |                      |                      | the current trans-   |
  384. |   |                      |                      | action violates a    |
  385. |   |                      |                      | system rule. At the  |
  386. |   |                      |                      | option of the system,|
  387. |   |                      |                      | it may occur in      |
  388. |   |                      |                      | other cases.         |
  389. |   |                      | or                   |                      |
  390. |   |                      |                      |                      |
  391. |   |                      | "Message sequence    | <ESC><EOT><CR> =     |
  392. |   |                      | <CR> <ESC> <EOT>     | begin disconnect.    |
  393. |   |                      | <CR>"                |                      |
  394. |   |                      |                      | Any of the responses |
  395. |   |                      |                      | may have an optional |
  396. |   |                      |                      | message sequence     |
  397. |   |                      |                      | before them,         |
  398. |   |                      |                      | although the system  |
  399. |   |                      |                      | designer should      |
  400. |   |                      |                      | understand the con-  |
  401. |   |                      |                      | sequences to the     |
  402. |   |                      |                      | user with all        |
  403. |   |                      |                      | planned entry        |
  404. |   |                      |                      | devices.             |
  405. +---+----------------------+----------------------+----------------------+
  406. |   |                      |                      | It is expected that  |
  407. |   |                      |                      | many systems will    |
  408. |   |                      |                      | save their message   |
  409. |   |                      |                      | sequence responses   |
  410. |   |                      |                      | until immediately    |
  411. |   |                      |                      | before disconnect.   |
  412. |   |                      |                      | For some entry       |
  413. |   |                      |                      | devices, it may also |
  414. |   |                      |                      | be desirable that    |
  415. |   |                      |                      | messages describing  |
  416. |   |                      |                      | non-checksum errors  |
  417. |   |                      |                      | associated with a    |
  418. |   |                      |                      | particular trans-    |
  419. |   |                      |                      | action in a PG       |
  420. |   |                      |                      | service will begin   |
  421. |   |                      |                      | with the letter ID   |
  422. |   |                      |                      | followed by the      |
  423. |   |                      |                      | contents of field 1  |
  424. |   |                      |                      | for that transaction.|
  425. +---+----------------------+----------------------+----------------------+
  426. | 9 | "<EOT> <CR>"         |                      | After reception of   |
  427. |   |                      |                      | an <ACK> or <RS> for |
  428. |   |                      |                      | the last transaction |
  429. |   |                      |                      | in a given service,  |
  430. |   |                      |                      | the entry device     |
  431. |   |                      |                      | sends <EOT> <CR>     |
  432. |   |                      |                      | meaning there are no |
  433. |   |                      |                      | more transactions    |
  434. |   |                      |                      | remaining in this    |
  435. |   |                      |                      | service.             |
  436. +---+----------------------+----------------------+----------------------+
  437. |10 |                      | "<Message sequence>  | An optional message  |
  438. |a  |                      | <CR>"                | may be sent at this  |
  439. |   |                      |                      | point to indicate    |
  440. |   |                      |                      | the degree of accep- |
  441. |   |                      |                      | tability of infor-   |
  442. |   |                      |                      | mation in all trans- |
  443. |   |                      |                      | actions received     |
  444. |   |                      |                      | during the current   |
  445. |   |                      |                      | interchange.         |
  446. |   |                      |                      | Although optional,   |
  447. |   |                      |                      | this message is      |
  448. |   |                      |                      | highly desirable.    |
  449. +---+----------------------+----------------------+----------------------+
  450. |10 |                      | "<RS> <CR>"          | An <RS> <CR> should  |
  451. |b  |                      |                      | be sent at this      |
  452. |   |                      |                      | point if the paging  |
  453. |   |                      |                      | central finds any    |
  454. |   |                      |                      | data <ACK> in step 8 |
  455. |   |                      |                      | to be unacceptable   |
  456. |   |                      |                      | because of content   |
  457. |   |                      |                      | (e.g. an invalid     |
  458. |   |                      |                      | pager number or a    |
  459. |   |                      |                      | message field inap-  |
  460. |   |                      |                      | propriate for the    |
  461. |   |                      |                      | type of pages, etc.) |
  462. |   |                      |                      | [2]                  |
  463. +---+----------------------+----------------------+----------------------+
  464. |10 |                      | "<ESC> <EOT> <CR>"   | <ESC> <EOT> = begin  |
  465. |c  |                      |                      | disconnect.          |
  466. |   |                      | followed by dropping |                      |
  467. |   |                      | of carrier and       |                      |
  468. |   |                      | hanging up.          |                      |
  469. +---+----------------------+----------------------+----------------------+
  470. |11 | Drops carrier and    |                      |                      |
  471. |   | hangs up.            |                      |                      |
  472. +---+----------------------+----------------------+----------------------+
  473.  [2] It is desirable to catch all types of errors in step 8, but
  474.      practically, some systems will be too slow to catch content
  475.      errors as they happen.
  476.  
  477. Table 7-1 (continued) Call Delivery Sequence
  478.  
  479. Manual Entry procedure
  480.  
  481.     +----------------------+----------------------+----------------------+
  482.     | REM. ENTRY DEV. DOES | PAGING CENTRAL DOES  | COMMENTS             |
  483. +---+----------------------+----------------------+----------------------+
  484. | 5 | (For manual remote   |                      | Lack of <ESC> at     |
  485. | M | entry as opposed to  |                      | at beginning of      |
  486. |   | Automatic Entry      |                      | response to ID=      |
  487. |   | shown previously in  |                      | signifies manual     |
  488. |   | this table under 5A) |                      | operation where      |
  489. |   |                      |                      | applicable.          |
  490. |   | "M <CR>"             |                      |                      |
  491. +---+----------------------+----------------------+----------------------+
  492. |   |                      | "Enter pager ID(s):  | Any manual operation |
  493. |   |                      | (Tone only or        | is user defined      |
  494. |   |                      | voice)"           or | after logon.         |
  495. +---+----------------------+----------------------+----------------------+
  496. |   | e.g.                 |                      | Echo transmission is |
  497. |   | "1000 2000 1247 400  |                      | allowed after manual |
  498. |   | <CR>"                |                      | conversation is      |
  499. +---+----------------------+----------------------+ established. M <CR>  |
  500. |   |                      | "Enter Alphanumeric  | can be replaced by   |
  501. |   |                      | message (alpha):" or | any non-null         |
  502. |   |                      | "Enter Numeric       | sequence ending in   |
  503. |   |                      | message (numeric):"  | <CR> and not         |
  504. +---+----------------------+----------------------+ beginning with       |
  505. |   | "Message <CR>"       |                      | <ESC>.               |
  506. +---+----------------------+----------------------+                      |
  507. |   |                      | "Can't Deliver Page  |                      |
  508. |   |                      | ID xxxxxx"        or |                      |
  509. |   |                      | "Too Slow - Good     |                      |
  510. |   |                      | Bye" (40 second      |                      |
  511. |   |                      | timeout)          or |                      |
  512. |   |                      | "Too Many Errors -   |                      |
  513. |   |                      | Good Bye" (occurs if |                      |
  514. |   |                      | 3 or more errors) or |                      |
  515. |   |                      | "Page Blocked"       |                      |
  516. +---+----------------------+----------------------+----------------------+
  517.  
  518.  
  519. 7.2 Modems
  520.  
  521. For initial implementation of the protocol, it is recommended that Bell
  522. 103 compatible modems be used to receive at 300 baud. Additional speeds or
  523. modem types may be used if desired.
  524.  
  525. The standard practice will be ASCII with XON, XOFF either direction using
  526. a 10-bit code (1 start, 7 data, 1 parity, 1 stop) with even parity. {7}
  527.  
  528. In the case of delays, the paging central shall wait at least four seconds
  529. (eight seconds in steps 3 and 4) before disconnecting the remote entry
  530. device; the remote entry device shall wait at least ten seconds for a
  531. character from the central before hanging up.
  532.  
  533. The paging central may, at its option, send <CR><LF> in place of <CR> at
  534. the end of any sequence.
  535.  
  536. For initial use of the protocol, the paging central shall be equipped to
  537. receive full duplex using a Bell 103 compatible modem at 300 baud.
  538. Optionally, certain inputs may be capable of receiving 110 baud Bell 103
  539. full duplex, 300/1200 baud Bell 212 full duplex. No echo shall be employed
  540. in full duplex mode. Any attempts at automatic baud rate determination
  541. shall be within the restraints of the specified protocol.
  542.  
  543.  
  544. Example:
  545.  
  546. Leaving a message TEST for customer #1
  547. Data: 7 Bits/1 Stop Bit/No Even Parity {8}
  548.  
  549. USER                               GL-3000
  550.  
  551. <CR> every 1 second unit ...
  552.                                    ID=
  553. <ESC> PG1 <CR>
  554.                                    <ESC> [p <CR>
  555. <STX> 1 <CR> TEST <CR> <ETX>
  556. 190 <CR>
  557. ("TEST" is the message)            Processing - Please Wait<CR>
  558. ("190" is the Checksum)            <ACK><CR>
  559.  
  560.                                    +++,,,,,,,,,,ATH0<CR> {9}
  561.                                    Carrier Drop
  562.  
  563.    Figure 7-2 Example of Typical Command - Acknowledge Sequence
  564.  
  565.  
  566. 7.3 Telocator Protocol (TAP) Checksum Example {9}
  567.  
  568. The following table shows an example of a complete block containing a
  569. correct checksum which is: <STX>123<CR>ABC<CR><ETX>17;<CR>
  570.  
  571. +---------+---------+---------+
  572. |  STX  *|    000        *|   0010        *|
  573. |   1     |    011      *|   0001  |
  574. |   2     |    011      *|   0010        *|
  575. |   3   *|    011  |   0011      *|
  576. |  CR   *|    000        *|   1101        *|
  577. |   A   *|    100  |   0001      *|
  578. |   B   *|    100        *|   0010        *|
  579. |   C   *|    100        *|   0011        *|
  580. |  CR     |    000      *|   1101        *|
  581. |  ETX  *|    000        *|   0011        *|
  582. |       *+---------+---------+
  583. |       *| 1 0111  |   1011  |
  584. |       *| 1   7   |     ;       *|
  585. +---------+---------+---------+
  586.                 Checksum = 17;
  587.  
  588.  
  589. TRANSCRIBER'S FOOTNOTES:
  590.  
  591. {1} It lies. All the way through this document, it lies. BEWARE OF EXTRA
  592.     SPACES! The only time there should be a space in this protocol is
  593.     in message sequences or in the user's field 2.
  594.  
  595. {2} Protocol didn't say, "Simon says." Notice that there IS NO <CR> here.
  596.     The <CR> is way down at the end of the optional password field, in
  597.     step 6.
  598.  
  599. {3} I have yet to run into a system that used anything OTHER than
  600.     <ESC>PG1<CR> for the login sequence. But to follow up on what I said
  601.     in note {2}, if you do find one, it's <ESC>PG1paswrd<CR>, not
  602.     <ESC>PG1<CR>paswrd<CR>.
  603.  
  604. {4} They take forever to get around to telling you what you most want to
  605.     know: field 1 is pager ID, field 2 is message. On both of the systems
  606.     I've tried, pager ID does not work if there is ANY punctuation in it,
  607.     so strip out those dashes and spaces. I'm told that some systems
  608.     require eight digits, so it may be safe to zero pad to that length.
  609.  
  610. {5} Field 2 is the message. The rest of transaction 8 goes into gory
  611.     detail on how to handle message blocks longer than 250 characters,
  612.     but you probably shouldn't waste your time: most pagers can't handle
  613.     more than 180. Numeric pagers can typically only handle 12 to 20.
  614.     On the numeric pagers I tried, zero to nine, space, and dash are the
  615.     only legal characters.  No, not asterisk, even though that's what key
  616.     you hit to include an extra dash when you're touch-toning it.
  617.  
  618. {6} They go out of their way to confuse this, and as I said in note {5},
  619.     even if you do get it to work it probably won't work.  But let me
  620.     try to break this down into simple rules:
  621.  
  622.     Every packet starts with <STX> and ends with a three-byte checksum
  623.     and <CR>.
  624.  
  625.     The last character before the checksum is:
  626.  
  627.         IF this the last packet in the transaction THEN
  628.            it's <ETX>
  629.         ELSE IF the packet ends on a boundary between fields,
  630.                 that is to say, with a <CR>, THEN
  631.            it's <US>
  632.         ELSE
  633.            it's <ETB>
  634.         END IF
  635.  
  636.     How do you know whether or not to break a field across more than one
  637.     packet?  The easy way is to build the whole transaction, break it into
  638.     250 byte chunks, look at the end of each chunk for a <CR>.  If you
  639.     find the <CR>, send <ETB>, else <US>.  After the last packet, send
  640.     <ETX> instead.
  641.  
  642. {7} Who ever heard of calling this a ten-bit code?  Here's what they mean:
  643.     300 bps, 7 bits, even parity, 1 stop bit.  They mean it, too; neither
  644.     of the ones I've tried would sync at above 1200 bps.
  645.  
  646. {8} Egregious typo. I fixed some others, but this is too weird. I THINK
  647.     they mean even parity; maybe they mean it works with either even or
  648.     no parity.
  649.  
  650. {9} Their example almost clears it up, but maybe a code example will help
  651.     more.  The following HyperTalk code was what I wrote to calculate the
  652.     checksum and put it onto the end of a packet:
  653.  
  654.     repeat with i = 1 to the length of TempPacket
  655.        add charToNum(char i of TempPacket) to checkSum
  656.     end repeat
  657.     put numToChar((checkSum div 256) mod 16 + 48) into checkSumString
  658.     put numToChar((checkSum div 16) mod 16 + 48) after checkSumString
  659.     put numToChar(checkSum mod 16 + 48) after checkSumString
  660.     put checkSumString & CR after TempPacket
  661.  
  662.  
  663.  
  664.