| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | Generic HDLC layer | 
|  | 2 | Krzysztof Halasa <khc@pm.waw.pl> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 |  | 
|  | 4 |  | 
|  | 5 | Generic HDLC layer currently supports: | 
| Krzysztof Hałasa | e022c2f | 2008-08-14 19:17:38 +0200 | [diff] [blame] | 6 | 1. Frame Relay (ANSI, CCITT, Cisco and no LMI) | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 7 | - Normal (routed) and Ethernet-bridged (Ethernet device emulation) | 
|  | 8 | interfaces can share a single PVC. | 
|  | 9 | - ARP support (no InARP support in the kernel - there is an | 
|  | 10 | experimental InARP user-space daemon available on: | 
|  | 11 | http://www.kernel.org/pub/linux/utils/net/hdlc/). | 
| Krzysztof Hałasa | e022c2f | 2008-08-14 19:17:38 +0200 | [diff] [blame] | 12 | 2. raw HDLC - either IP (IPv4) interface or Ethernet device emulation | 
|  | 13 | 3. Cisco HDLC | 
|  | 14 | 4. PPP | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 15 | 5. X.25 (uses X.25 routines). | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 |  | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 17 | Generic HDLC is a protocol driver only - it needs a low-level driver | 
|  | 18 | for your particular hardware. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 |  | 
|  | 20 | Ethernet device emulation (using HDLC or Frame-Relay PVC) is compatible | 
|  | 21 | with IEEE 802.1Q (VLANs) and 802.1D (Ethernet bridging). | 
|  | 22 |  | 
|  | 23 |  | 
|  | 24 | Make sure the hdlc.o and the hardware driver are loaded. It should | 
|  | 25 | create a number of "hdlc" (hdlc0 etc) network devices, one for each | 
|  | 26 | WAN port. You'll need the "sethdlc" utility, get it from: | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 27 | http://www.kernel.org/pub/linux/utils/net/hdlc/ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 28 |  | 
|  | 29 | Compile sethdlc.c utility: | 
|  | 30 | gcc -O2 -Wall -o sethdlc sethdlc.c | 
|  | 31 | Make sure you're using a correct version of sethdlc for your kernel. | 
|  | 32 |  | 
|  | 33 | Use sethdlc to set physical interface, clock rate, HDLC mode used, | 
|  | 34 | and add any required PVCs if using Frame Relay. | 
|  | 35 | Usually you want something like: | 
|  | 36 |  | 
|  | 37 | sethdlc hdlc0 clock int rate 128000 | 
|  | 38 | sethdlc hdlc0 cisco interval 10 timeout 25 | 
|  | 39 | or | 
|  | 40 | sethdlc hdlc0 rs232 clock ext | 
|  | 41 | sethdlc hdlc0 fr lmi ansi | 
|  | 42 | sethdlc hdlc0 create 99 | 
|  | 43 | ifconfig hdlc0 up | 
|  | 44 | ifconfig pvc0 localIP pointopoint remoteIP | 
|  | 45 |  | 
|  | 46 | In Frame Relay mode, ifconfig master hdlc device up (without assigning | 
|  | 47 | any IP address to it) before using pvc devices. | 
|  | 48 |  | 
|  | 49 |  | 
|  | 50 | Setting interface: | 
|  | 51 |  | 
|  | 52 | * v35 | rs232 | x21 | t1 | e1 - sets physical interface for a given port | 
|  | 53 | if the card has software-selectable interfaces | 
|  | 54 | loopback - activate hardware loopback (for testing only) | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 55 | * clock ext - both RX clock and TX clock external | 
|  | 56 | * clock int - both RX clock and TX clock internal | 
|  | 57 | * clock txint - RX clock external, TX clock internal | 
|  | 58 | * clock txfromrx - RX clock external, TX clock derived from RX clock | 
|  | 59 | * rate - sets clock rate in bps (for "int" or "txint" clock only) | 
|  | 60 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 61 |  | 
|  | 62 | Setting protocol: | 
|  | 63 |  | 
|  | 64 | * hdlc - sets raw HDLC (IP-only) mode | 
|  | 65 | nrz / nrzi / fm-mark / fm-space / manchester - sets transmission code | 
|  | 66 | no-parity / crc16 / crc16-pr0 (CRC16 with preset zeros) / crc32-itu | 
|  | 67 | crc16-itu (CRC16 with ITU-T polynomial) / crc16-itu-pr0 - sets parity | 
|  | 68 |  | 
|  | 69 | * hdlc-eth - Ethernet device emulation using HDLC. Parity and encoding | 
|  | 70 | as above. | 
|  | 71 |  | 
|  | 72 | * cisco - sets Cisco HDLC mode (IP, IPv6 and IPX supported) | 
|  | 73 | interval - time in seconds between keepalive packets | 
|  | 74 | timeout - time in seconds after last received keepalive packet before | 
|  | 75 | we assume the link is down | 
|  | 76 |  | 
|  | 77 | * ppp - sets synchronous PPP mode | 
|  | 78 |  | 
|  | 79 | * x25 - sets X.25 mode | 
|  | 80 |  | 
|  | 81 | * fr - Frame Relay mode | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 82 | lmi ansi / ccitt / cisco / none - LMI (link management) type | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 83 | dce - Frame Relay DCE (network) side LMI instead of default DTE (user). | 
|  | 84 | It has nothing to do with clocks! | 
|  | 85 | t391 - link integrity verification polling timer (in seconds) - user | 
|  | 86 | t392 - polling verification timer (in seconds) - network | 
|  | 87 | n391 - full status polling counter - user | 
|  | 88 | n392 - error threshold - both user and network | 
|  | 89 | n393 - monitored events count - both user and network | 
|  | 90 |  | 
|  | 91 | Frame-Relay only: | 
|  | 92 | * create n | delete n - adds / deletes PVC interface with DLCI #n. | 
|  | 93 | Newly created interface will be named pvc0, pvc1 etc. | 
|  | 94 |  | 
|  | 95 | * create ether n | delete ether n - adds a device for Ethernet-bridged | 
|  | 96 | frames. The device will be named pvceth0, pvceth1 etc. | 
|  | 97 |  | 
|  | 98 |  | 
|  | 99 |  | 
|  | 100 |  | 
|  | 101 | Board-specific issues | 
|  | 102 | --------------------- | 
|  | 103 |  | 
|  | 104 | n2.o and c101.o need parameters to work: | 
|  | 105 |  | 
|  | 106 | insmod n2 hw=io,irq,ram,ports[:io,irq,...] | 
|  | 107 | example: | 
|  | 108 | insmod n2 hw=0x300,10,0xD0000,01 | 
|  | 109 |  | 
|  | 110 | or | 
|  | 111 | insmod c101 hw=irq,ram[:irq,...] | 
|  | 112 | example: | 
|  | 113 | insmod c101 hw=9,0xdc000 | 
|  | 114 |  | 
|  | 115 | If built into the kernel, these drivers need kernel (command line) parameters: | 
|  | 116 | n2.hw=io,irq,ram,ports:... | 
|  | 117 | or | 
|  | 118 | c101.hw=irq,ram:... | 
|  | 119 |  | 
|  | 120 |  | 
|  | 121 |  | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 122 | If you have a problem with N2, C101 or PLX200SYN card, you can issue the | 
|  | 123 | "private" command to see port's packet descriptor rings (in kernel logs): | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 124 |  | 
|  | 125 | sethdlc hdlc0 private | 
|  | 126 |  | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 127 | The hardware driver has to be build with #define DEBUG_RINGS. | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 128 | Attaching this info to bug reports would be helpful. Anyway, let me know | 
|  | 129 | if you have problems using this. | 
|  | 130 |  | 
| Krzysztof Halasa | b3dd65f | 2005-04-21 15:57:25 +0200 | [diff] [blame] | 131 | For patches and other info look at: | 
|  | 132 | <http://www.kernel.org/pub/linux/utils/net/hdlc/>. |