3270.txt 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. IBM 3270 Display System support
  2. This file describes the driver that supports local channel attachment
  3. of IBM 3270 devices. It consists of three sections:
  4. * Introduction
  5. * Installation
  6. * Operation
  7. INTRODUCTION.
  8. This paper describes installing and operating 3270 devices under
  9. Linux/390. A 3270 device is a block-mode rows-and-columns terminal of
  10. which I'm sure hundreds of millions were sold by IBM and clonemakers
  11. twenty and thirty years ago.
  12. You may have 3270s in-house and not know it. If you're using the
  13. VM-ESA operating system, define a 3270 to your virtual machine by using
  14. the command "DEF GRAF <hex-address>" This paper presumes you will be
  15. defining four 3270s with the CP/CMS commands
  16. DEF GRAF 620
  17. DEF GRAF 621
  18. DEF GRAF 622
  19. DEF GRAF 623
  20. Your network connection from VM-ESA allows you to use x3270, tn3270, or
  21. another 3270 emulator, started from an xterm window on your PC or
  22. workstation. With the DEF GRAF command, an application such as xterm,
  23. and this Linux-390 3270 driver, you have another way of talking to your
  24. Linux box.
  25. This paper covers installation of the driver and operation of a
  26. dialed-in x3270.
  27. INSTALLATION.
  28. You install the driver by installing a patch, doing a kernel build, and
  29. running the configuration script (config3270.sh, in this directory).
  30. WARNING: If you are using 3270 console support, you must rerun the
  31. configuration script every time you change the console's address (perhaps
  32. by using the condev= parameter in silo's /boot/parmfile). More precisely,
  33. you should rerun the configuration script every time your set of 3270s,
  34. including the console 3270, changes subchannel identifier relative to
  35. one another. ReIPL as soon as possible after running the configuration
  36. script and the resulting /tmp/mkdev3270.
  37. If you have chosen to make tub3270 a module, you add a line to a
  38. configuration file under /etc/modprobe.d/. If you are working on a VM
  39. virtual machine, you can use DEF GRAF to define virtual 3270 devices.
  40. You may generate both 3270 and 3215 console support, or one or the
  41. other, or neither. If you generate both, the console type under VM is
  42. not changed. Use #CP Q TERM to see what the current console type is.
  43. Use #CP TERM CONMODE 3270 to change it to 3270. If you generate only
  44. 3270 console support, then the driver automatically converts your console
  45. at boot time to a 3270 if it is a 3215.
  46. In brief, these are the steps:
  47. 1. Install the tub3270 patch
  48. 2. (If a module) add a line to a file in /etc/modprobe.d/*.conf
  49. 3. (If VM) define devices with DEF GRAF
  50. 4. Reboot
  51. 5. Configure
  52. To test that everything works, assuming VM and x3270,
  53. 1. Bring up an x3270 window.
  54. 2. Use the DIAL command in that window.
  55. 3. You should immediately see a Linux login screen.
  56. Here are the installation steps in detail:
  57. 1. The 3270 driver is a part of the official Linux kernel
  58. source. Build a tree with the kernel source and any necessary
  59. patches. Then do
  60. make oldconfig
  61. (If you wish to disable 3215 console support, edit
  62. .config; change CONFIG_TN3215's value to "n";
  63. and rerun "make oldconfig".)
  64. make image
  65. make modules
  66. make modules_install
  67. 2. (Perform this step only if you have configured tub3270 as a
  68. module.) Add a line to a file /etc/modprobe.d/*.conf to automatically
  69. load the driver when it's needed. With this line added, you will see
  70. login prompts appear on your 3270s as soon as boot is complete (or
  71. with emulated 3270s, as soon as you dial into your vm guest using the
  72. command "DIAL <vmguestname>"). Since the line-mode major number is
  73. 227, the line to add should be:
  74. alias char-major-227 tub3270
  75. 3. Define graphic devices to your vm guest machine, if you
  76. haven't already. Define them before you reboot (reipl):
  77. DEFINE GRAF 620
  78. DEFINE GRAF 621
  79. DEFINE GRAF 622
  80. DEFINE GRAF 623
  81. 4. Reboot. The reboot process scans hardware devices, including
  82. 3270s, and this enables the tub3270 driver once loaded to respond
  83. correctly to the configuration requests of the next step. If
  84. you have chosen 3270 console support, your console now behaves
  85. as a 3270, not a 3215.
  86. 5. Run the 3270 configuration script config3270. It is
  87. distributed in this same directory, Documentation/s390, as
  88. config3270.sh. Inspect the output script it produces,
  89. /tmp/mkdev3270, and then run that script. This will create the
  90. necessary character special device files and make the necessary
  91. changes to /etc/inittab.
  92. Then notify /sbin/init that /etc/inittab has changed, by issuing
  93. the telinit command with the q operand:
  94. cd Documentation/s390
  95. sh config3270.sh
  96. sh /tmp/mkdev3270
  97. telinit q
  98. This should be sufficient for your first time. If your 3270
  99. configuration has changed and you're reusing config3270, you
  100. should follow these steps:
  101. Change 3270 configuration
  102. Reboot
  103. Run config3270 and /tmp/mkdev3270
  104. Reboot
  105. Here are the testing steps in detail:
  106. 1. Bring up an x3270 window, or use an actual hardware 3278 or
  107. 3279, or use the 3270 emulator of your choice. You would be
  108. running the emulator on your PC or workstation. You would use
  109. the command, for example,
  110. x3270 vm-esa-domain-name &
  111. if you wanted a 3278 Model 4 with 43 rows of 80 columns, the
  112. default model number. The driver does not take advantage of
  113. extended attributes.
  114. The screen you should now see contains a VM logo with input
  115. lines near the bottom. Use TAB to move to the bottom line,
  116. probably labeled "COMMAND ===>".
  117. 2. Use the DIAL command instead of the LOGIN command to connect
  118. to one of the virtual 3270s you defined with the DEF GRAF
  119. commands:
  120. dial my-vm-guest-name
  121. 3. You should immediately see a login prompt from your
  122. Linux-390 operating system. If that does not happen, you would
  123. see instead the line "DIALED TO my-vm-guest-name 0620".
  124. To troubleshoot: do these things.
  125. A. Is the driver loaded? Use the lsmod command (no operands)
  126. to find out. Probably it isn't. Try loading it manually, with
  127. the command "insmod tub3270". Does that command give error
  128. messages? Ha! There's your problem.
  129. B. Is the /etc/inittab file modified as in installation step 3
  130. above? Use the grep command to find out; for instance, issue
  131. "grep 3270 /etc/inittab". Nothing found? There's your
  132. problem!
  133. C. Are the device special files created, as in installation
  134. step 2 above? Use the ls -l command to find out; for instance,
  135. issue "ls -l /dev/3270/tty620". The output should start with the
  136. letter "c" meaning character device and should contain "227, 1"
  137. just to the left of the device name. No such file? no "c"?
  138. Wrong major number? Wrong minor number? There's your
  139. problem!
  140. D. Do you get the message
  141. "HCPDIA047E my-vm-guest-name 0620 does not exist"?
  142. If so, you must issue the command "DEF GRAF 620" from your VM
  143. 3215 console and then reboot the system.
  144. OPERATION.
  145. The driver defines three areas on the 3270 screen: the log area, the
  146. input area, and the status area.
  147. The log area takes up all but the bottom two lines of the screen. The
  148. driver writes terminal output to it, starting at the top line and going
  149. down. When it fills, the status area changes from "Linux Running" to
  150. "Linux More...". After a scrolling timeout of (default) 5 sec, the
  151. screen clears and more output is written, from the top down.
  152. The input area extends from the beginning of the second-to-last screen
  153. line to the start of the status area. You type commands in this area
  154. and hit ENTER to execute them.
  155. The status area initializes to "Linux Running" to give you a warm
  156. fuzzy feeling. When the log area fills up and output awaits, it
  157. changes to "Linux More...". At this time you can do several things or
  158. nothing. If you do nothing, the screen will clear in (default) 5 sec
  159. and more output will appear. You may hit ENTER with nothing typed in
  160. the input area to toggle between "Linux More..." and "Linux Holding",
  161. which indicates no scrolling will occur. (If you hit ENTER with "Linux
  162. Running" and nothing typed, the application receives a newline.)
  163. You may change the scrolling timeout value. For example, the following
  164. command line:
  165. echo scrolltime=60 > /proc/tty/driver/tty3270
  166. changes the scrolling timeout value to 60 sec. Set scrolltime to 0 if
  167. you wish to prevent scrolling entirely.
  168. Other things you may do when the log area fills up are: hit PA2 to
  169. clear the log area and write more output to it, or hit CLEAR to clear
  170. the log area and the input area and write more output to the log area.
  171. Some of the Program Function (PF) and Program Attention (PA) keys are
  172. preassigned special functions. The ones that are not yield an alarm
  173. when pressed.
  174. PA1 causes a SIGINT to the currently running application. You may do
  175. the same thing from the input area, by typing "^C" and hitting ENTER.
  176. PA2 causes the log area to be cleared. If output awaits, it is then
  177. written to the log area.
  178. PF3 causes an EOF to be received as input by the application. You may
  179. cause an EOF also by typing "^D" and hitting ENTER.
  180. No PF key is preassigned to cause a job suspension, but you may cause a
  181. job suspension by typing "^Z" and hitting ENTER. You may wish to
  182. assign this function to a PF key. To make PF7 cause job suspension,
  183. execute the command:
  184. echo pf7=^z > /proc/tty/driver/tty3270
  185. If the input you type does not end with the two characters "^n", the
  186. driver appends a newline character and sends it to the tty driver;
  187. otherwise the driver strips the "^n" and does not append a newline.
  188. The IBM 3215 driver behaves similarly.
  189. Pf10 causes the most recent command to be retrieved from the tube's
  190. command stack (default depth 20) and displayed in the input area. You
  191. may hit PF10 again for the next-most-recent command, and so on. A
  192. command is entered into the stack only when the input area is not made
  193. invisible (such as for password entry) and it is not identical to the
  194. current top entry. PF10 rotates backward through the command stack;
  195. PF11 rotates forward. You may assign the backward function to any PF
  196. key (or PA key, for that matter), say, PA3, with the command:
  197. echo -e pa3=\\033k > /proc/tty/driver/tty3270
  198. This assigns the string ESC-k to PA3. Similarly, the string ESC-j
  199. performs the forward function. (Rationale: In bash with vi-mode line
  200. editing, ESC-k and ESC-j retrieve backward and forward history.
  201. Suggestions welcome.)
  202. Is a stack size of twenty commands not to your liking? Change it on
  203. the fly. To change to saving the last 100 commands, execute the
  204. command:
  205. echo recallsize=100 > /proc/tty/driver/tty3270
  206. Have a command you issue frequently? Assign it to a PF or PA key! Use
  207. the command
  208. echo pf24="mkdir foobar; cd foobar" > /proc/tty/driver/tty3270
  209. to execute the commands mkdir foobar and cd foobar immediately when you
  210. hit PF24. Want to see the command line first, before you execute it?
  211. Use the -n option of the echo command:
  212. echo -n pf24="mkdir foo; cd foo" > /proc/tty/driver/tty3270
  213. Happy testing! I welcome any and all comments about this document, the
  214. driver, etc etc.
  215. Dick Hitt <[email protected]>