blob: a57235616294a3af1cc6d17a3adcaa1af5d3217e [file] [log] [blame]
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -03001===========================================================
Linus Torvalds1da177e2005-04-16 15:20:36 -07002Release Notes for Linux on Intel's IXP4xx Network Processor
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -03003===========================================================
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
5Maintained by Deepak Saxena <dsaxena@plexity.net>
6-------------------------------------------------------------------------
7
81. Overview
9
10Intel's IXP4xx network processor is a highly integrated SOC that
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030011is targeted for network applications, though it has become popular
Linus Torvalds1da177e2005-04-16 15:20:36 -070012in industrial control and other areas due to low cost and power
13consumption. The IXP4xx family currently consists of several processors
14that support different network offload functions such as encryption,
15routing, firewalling, etc. The IXP46x family is an updated version which
16supports faster speeds, new memory and flash configurations, and more
17integration such as an on-chip I2C controller.
18
19For more information on the various versions of the CPU, see:
20
21 http://developer.intel.com/design/network/products/npfamily/ixp4xx.htm
22
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030023Intel also made the IXCP1100 CPU for sometime which is an IXP4xx
Linus Torvalds1da177e2005-04-16 15:20:36 -070024stripped of much of the network intelligence.
25
262. Linux Support
27
28Linux currently supports the following features on the IXP4xx chips:
29
30- Dual serial ports
31- PCI interface
32- Flash access (MTD/JFFS)
33- I2C through GPIO on IXP42x
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030034- GPIO for input/output/interrupts
Russell Kinga09e64f2008-08-05 16:14:15 +010035 See arch/arm/mach-ixp4xx/include/mach/platform.h for access functions.
Linus Torvalds1da177e2005-04-16 15:20:36 -070036- Timers (watchdog, OS)
37
38The following components of the chips are not supported by Linux and
Stefan Huber6d1ee2c2013-06-05 12:24:39 +020039require the use of Intel's proprietary CSR software:
Linus Torvalds1da177e2005-04-16 15:20:36 -070040
41- USB device interface
42- Network interfaces (HSS, Utopia, NPEs, etc)
43- Network offload functionality
44
45If you need to use any of the above, you need to download Intel's
46software from:
47
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030048 http://developer.intel.com/design/network/products/npfamily/ixp425.htm
Linus Torvalds1da177e2005-04-16 15:20:36 -070049
Lucas De Marchi25985ed2011-03-30 22:57:33 -030050DO NOT POST QUESTIONS TO THE LINUX MAILING LISTS REGARDING THE PROPRIETARY
Linus Torvalds1da177e2005-04-16 15:20:36 -070051SOFTWARE.
52
53There are several websites that provide directions/pointers on using
54Intel's software:
55
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030056 - http://sourceforge.net/projects/ixp4xx-osdg/
57 Open Source Developer's Guide for using uClinux and the Intel libraries
Linus Torvalds1da177e2005-04-16 15:20:36 -070058
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030059 - http://gatewaymaker.sourceforge.net/
60 Simple one page summary of building a gateway using an IXP425 and Linux
Linus Torvalds1da177e2005-04-16 15:20:36 -070061
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030062 - http://ixp425.sourceforge.net/
63 ATM device driver for IXP425 that relies on Intel's libraries
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
653. Known Issues/Limitations
66
673a. Limited inbound PCI window
68
69The IXP4xx family allows for up to 256MB of memory but the PCI interface
70can only expose 64MB of that memory to the PCI bus. This means that if
71you are running with > 64MB, all PCI buffers outside of the accessible
72range will be bounced using the routines in arch/arm/common/dmabounce.c.
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030073
Linus Torvalds1da177e2005-04-16 15:20:36 -0700743b. Limited outbound PCI window
75
76IXP4xx provides two methods of accessing PCI memory space:
77
781) A direct mapped window from 0x48000000 to 0x4bffffff (64MB).
79 To access PCI via this space, we simply ioremap() the BAR
80 into the kernel and we can use the standard read[bwl]/write[bwl]
81 macros. This is the preffered method due to speed but it
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030082 limits the system to just 64MB of PCI memory. This can be
Linus Torvalds1da177e2005-04-16 15:20:36 -070083 problamatic if using video cards and other memory-heavy devices.
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030084
852) If > 64MB of memory space is required, the IXP4xx can be
86 configured to use indirect registers to access PCI This allows
87 for up to 128MB (0x48000000 to 0x4fffffff) of memory on the bus.
88 The disadvantage of this is that every PCI access requires
89 three local register accesses plus a spinlock, but in some
90 cases the performance hit is acceptable. In addition, you cannot
Linus Torvalds1da177e2005-04-16 15:20:36 -070091 mmap() PCI devices in this case due to the indirect nature
92 of the PCI window.
93
94By default, the direct method is used for performance reasons. If
95you need more PCI memory, enable the IXP4XX_INDIRECT_PCI config option.
96
973c. GPIO as Interrupts
98
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -030099Currently the code only handles level-sensitive GPIO interrupts
Linus Torvalds1da177e2005-04-16 15:20:36 -0700100
1014. Supported platforms
102
103ADI Engineering Coyote Gateway Reference Platform
104http://www.adiengineering.com/productsCoyote.html
105
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -0300106 The ADI Coyote platform is reference design for those building
Linus Torvalds1da177e2005-04-16 15:20:36 -0700107 small residential/office gateways. One NPE is connected to a 10/100
108 interface, one to 4-port 10/100 switch, and the third to and ADSL
109 interface. In addition, it also supports to POTs interfaces connected
110 via SLICs. Note that those are not supported by Linux ATM. Finally,
111 the platform has two mini-PCI slots used for 802.11[bga] cards.
112 Finally, there is an IDE port hanging off the expansion bus.
113
114Gateworks Avila Network Platform
Justin P. Mattock0ea6e612010-07-23 20:51:24 -0700115http://www.gateworks.com/support/overview.php
Linus Torvalds1da177e2005-04-16 15:20:36 -0700116
117 The Avila platform is basically and IXDP425 with the 4 PCI slots
118 replaced with mini-PCI slots and a CF IDE interface hanging off
119 the expansion bus.
120
121Intel IXDP425 Development Platform
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -0300122http://www.intel.com/design/network/products/npfamily/ixdpg425.htm
Linus Torvalds1da177e2005-04-16 15:20:36 -0700123
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -0300124 This is Intel's standard reference platform for the IXDP425 and is
Linus Torvalds1da177e2005-04-16 15:20:36 -0700125 also known as the Richfield board. It contains 4 PCI slots, 16MB
126 of flash, two 10/100 ports and one ADSL port.
127
128Intel IXDP465 Development Platform
Justin P. Mattock0ea6e612010-07-23 20:51:24 -0700129http://www.intel.com/design/network/products/npfamily/ixdp465.htm
Linus Torvalds1da177e2005-04-16 15:20:36 -0700130
131 This is basically an IXDP425 with an IXP465 and 32M of flash instead
132 of just 16.
133
134Intel IXDPG425 Development Platform
135
136 This is basically and ADI Coyote board with a NEC EHCI controller
137 added. One issue with this board is that the mini-PCI slots only
138 have the 3.3v line connected, so you can't use a PCI to mini-PCI
139 adapter with an E100 card. So to NFS root you need to use either
140 the CSR or a WiFi card and a ramdisk that BOOTPs and then does
141 a pivot_root to NFS.
142
143Motorola PrPMC1100 Processor Mezanine Card
Justin P. Mattock0ea6e612010-07-23 20:51:24 -0700144http://www.fountainsys.com
Linus Torvalds1da177e2005-04-16 15:20:36 -0700145
146 The PrPMC1100 is based on the IXCP1100 and is meant to plug into
147 and IXP2400/2800 system to act as the system controller. It simply
148 contains a CPU and 16MB of flash on the board and needs to be
149 plugged into a carrier board to function. Currently Linux only
150 supports the Motorola PrPMC carrier board for this platform.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700151
1525. TODO LIST
153
154- Add support for Coyote IDE
155- Add support for edge-based GPIO interrupts
156- Add support for CF IDE on expansion bus
157
1586. Thanks
159
160The IXP4xx work has been funded by Intel Corp. and MontaVista Software, Inc.
161
162The following people have contributed patches/comments/etc:
163
Mauro Carvalho Chehabdc7a12b2019-04-14 15:51:10 -0300164- Lennerty Buytenhek
165- Lutz Jaenicke
166- Justin Mayfield
167- Robert E. Ranslam
168
169[I know I've forgotten others, please email me to be added]
Linus Torvalds1da177e2005-04-16 15:20:36 -0700170
171-------------------------------------------------------------------------
172
173Last Update: 01/04/2005