Merge branch 'linus' into core/ipi
This commit is contained in:
Коммит
25d500067d
|
@ -1,3 +1,46 @@
|
||||||
|
What: /sys/bus/pci/drivers/.../bind
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device location to this file will cause
|
||||||
|
the driver to attempt to bind to the device found at
|
||||||
|
this location. This is useful for overriding default
|
||||||
|
bindings. The format for the location is: DDDD:BB:DD.F.
|
||||||
|
That is Domain:Bus:Device.Function and is the same as
|
||||||
|
found in /sys/bus/pci/devices/. For example:
|
||||||
|
# echo 0000:00:19.0 > /sys/bus/pci/drivers/foo/bind
|
||||||
|
(Note: kernels before 2.6.28 may require echo -n).
|
||||||
|
|
||||||
|
What: /sys/bus/pci/drivers/.../unbind
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device location to this file will cause the
|
||||||
|
driver to attempt to unbind from the device found at
|
||||||
|
this location. This may be useful when overriding default
|
||||||
|
bindings. The format for the location is: DDDD:BB:DD.F.
|
||||||
|
That is Domain:Bus:Device.Function and is the same as
|
||||||
|
found in /sys/bus/pci/devices/. For example:
|
||||||
|
# echo 0000:00:19.0 > /sys/bus/pci/drivers/foo/unbind
|
||||||
|
(Note: kernels before 2.6.28 may require echo -n).
|
||||||
|
|
||||||
|
What: /sys/bus/pci/drivers/.../new_id
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device ID to this file will attempt to
|
||||||
|
dynamically add a new device ID to a PCI device driver.
|
||||||
|
This may allow the driver to support more hardware than
|
||||||
|
was included in the driver's static device ID support
|
||||||
|
table at compile time. The format for the device ID is:
|
||||||
|
VVVV DDDD SVVV SDDD CCCC MMMM PPPP. That is Vendor ID,
|
||||||
|
Device ID, Subsystem Vendor ID, Subsystem Device ID,
|
||||||
|
Class, Class Mask, and Private Driver Data. The Vendor ID
|
||||||
|
and Device ID fields are required, the rest are optional.
|
||||||
|
Upon successfully adding an ID, the driver will probe
|
||||||
|
for the device and attempt to bind to it. For example:
|
||||||
|
# echo "8086 10f5" > /sys/bus/pci/drivers/foo/new_id
|
||||||
|
|
||||||
What: /sys/bus/pci/devices/.../vpd
|
What: /sys/bus/pci/devices/.../vpd
|
||||||
Date: February 2008
|
Date: February 2008
|
||||||
Contact: Ben Hutchings <bhutchings@solarflare.com>
|
Contact: Ben Hutchings <bhutchings@solarflare.com>
|
||||||
|
|
|
@ -298,3 +298,15 @@ over a rather long period of time, but improvements are always welcome!
|
||||||
|
|
||||||
Note that, rcu_assign_pointer() and rcu_dereference() relate to
|
Note that, rcu_assign_pointer() and rcu_dereference() relate to
|
||||||
SRCU just as they do to other forms of RCU.
|
SRCU just as they do to other forms of RCU.
|
||||||
|
|
||||||
|
15. The whole point of call_rcu(), synchronize_rcu(), and friends
|
||||||
|
is to wait until all pre-existing readers have finished before
|
||||||
|
carrying out some otherwise-destructive operation. It is
|
||||||
|
therefore critically important to -first- remove any path
|
||||||
|
that readers can follow that could be affected by the
|
||||||
|
destructive operation, and -only- -then- invoke call_rcu(),
|
||||||
|
synchronize_rcu(), or friends.
|
||||||
|
|
||||||
|
Because these primitives only wait for pre-existing readers,
|
||||||
|
it is the caller's responsibility to guarantee safety to
|
||||||
|
any subsequent readers.
|
||||||
|
|
|
@ -1,205 +0,0 @@
|
||||||
This README escorted the skystar2-driver rewriting procedure. It describes the
|
|
||||||
state of the new flexcop-driver set and some internals are written down here
|
|
||||||
too.
|
|
||||||
|
|
||||||
This document hopefully describes things about the flexcop and its
|
|
||||||
device-offsprings. Goal was to write an easy-to-write and easy-to-read set of
|
|
||||||
drivers based on the skystar2.c and other information.
|
|
||||||
|
|
||||||
Remark: flexcop-pci.c was a copy of skystar2.c, but every line has been
|
|
||||||
touched and rewritten.
|
|
||||||
|
|
||||||
History & News
|
|
||||||
==============
|
|
||||||
2005-04-01 - correct USB ISOC transfers (thanks to Vadim Catana)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
General coding processing
|
|
||||||
=========================
|
|
||||||
|
|
||||||
We should proceed as follows (as long as no one complains):
|
|
||||||
|
|
||||||
0) Think before start writing code!
|
|
||||||
|
|
||||||
1) rewriting the skystar2.c with the help of the flexcop register descriptions
|
|
||||||
and splitting up the files to a pci-bus-part and a flexcop-part.
|
|
||||||
The new driver will be called b2c2-flexcop-pci.ko/b2c2-flexcop-usb.ko for the
|
|
||||||
device-specific part and b2c2-flexcop.ko for the common flexcop-functions.
|
|
||||||
|
|
||||||
2) Search for errors in the leftover of flexcop-pci.c (compare with pluto2.c
|
|
||||||
and other pci drivers)
|
|
||||||
|
|
||||||
3) make some beautification (see 'Improvements when rewriting (refactoring) is
|
|
||||||
done')
|
|
||||||
|
|
||||||
4) Testing the new driver and maybe substitute the skystar2.c with it, to reach
|
|
||||||
a wider tester audience.
|
|
||||||
|
|
||||||
5) creating an usb-bus-part using the already written flexcop code for the pci
|
|
||||||
card.
|
|
||||||
|
|
||||||
Idea: create a kernel-object for the flexcop and export all important
|
|
||||||
functions. This option saves kernel-memory, but maybe a lot of functions have
|
|
||||||
to be exported to kernel namespace.
|
|
||||||
|
|
||||||
|
|
||||||
Current situation
|
|
||||||
=================
|
|
||||||
|
|
||||||
0) Done :)
|
|
||||||
1) Done (some minor issues left)
|
|
||||||
2) Done
|
|
||||||
3) Not ready yet, more information is necessary
|
|
||||||
4) next to be done (see the table below)
|
|
||||||
5) USB driver is working (yes, there are some minor issues)
|
|
||||||
|
|
||||||
What seems to be ready?
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
1) Rewriting
|
|
||||||
1a) i2c is cut off from the flexcop-pci.c and seems to work
|
|
||||||
1b) moved tuner and demod stuff from flexcop-pci.c to flexcop-tuner-fe.c
|
|
||||||
1c) moved lnb and diseqc stuff from flexcop-pci.c to flexcop-tuner-fe.c
|
|
||||||
1e) eeprom (reading MAC address)
|
|
||||||
1d) sram (no dynamic sll size detection (commented out) (using default as JJ told me))
|
|
||||||
1f) misc. register accesses for reading parameters (e.g. resetting, revision)
|
|
||||||
1g) pid/mac filter (flexcop-hw-filter.c)
|
|
||||||
1i) dvb-stuff initialization in flexcop.c (done)
|
|
||||||
1h) dma stuff (now just using the size-irq, instead of all-together, to be done)
|
|
||||||
1j) remove flexcop initialization from flexcop-pci.c completely (done)
|
|
||||||
1l) use a well working dma IRQ method (done, see 'Known bugs and problems and TODO')
|
|
||||||
1k) cleanup flexcop-files (remove unused EXPORT_SYMBOLs, make static from
|
|
||||||
non-static where possible, moved code to proper places)
|
|
||||||
|
|
||||||
2) Search for errors in the leftover of flexcop-pci.c (partially done)
|
|
||||||
5a) add MAC address reading
|
|
||||||
5c) feeding of ISOC data to the software demux (format of the isochronous data
|
|
||||||
and speed optimization, no real error) (thanks to Vadim Catana)
|
|
||||||
|
|
||||||
What to do in the near future?
|
|
||||||
--------------------------------------
|
|
||||||
(no special order here)
|
|
||||||
|
|
||||||
5) USB driver
|
|
||||||
5b) optimize isoc-transfer (submitting/killing isoc URBs when transfer is starting)
|
|
||||||
|
|
||||||
Testing changes
|
|
||||||
---------------
|
|
||||||
|
|
||||||
O = item is working
|
|
||||||
P = item is partially working
|
|
||||||
X = item is not working
|
|
||||||
N = item does not apply here
|
|
||||||
<empty field> = item need to be examined
|
|
||||||
|
|
||||||
| PCI | USB
|
|
||||||
item | mt352 | nxt2002 | stv0299 | mt312 | mt352 | nxt2002 | stv0299 | mt312
|
|
||||||
-------+-------+---------+---------+-------+-------+---------+---------+-------
|
|
||||||
1a) | O | | | | N | N | N | N
|
|
||||||
1b) | O | | | | | | O |
|
|
||||||
1c) | N | N | | | N | N | O |
|
|
||||||
1d) | O | O
|
|
||||||
1e) | O | O
|
|
||||||
1f) | P
|
|
||||||
1g) | O
|
|
||||||
1h) | P |
|
|
||||||
1i) | O | N
|
|
||||||
1j) | O | N
|
|
||||||
1l) | O | N
|
|
||||||
2) | O | N
|
|
||||||
5a) | N | O
|
|
||||||
5b)* | N |
|
|
||||||
5c) | N | O
|
|
||||||
|
|
||||||
* - not done yet
|
|
||||||
|
|
||||||
Known bugs and problems and TODO
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
1g/h/l) when pid filtering is enabled on the pci card
|
|
||||||
|
|
||||||
DMA usage currently:
|
|
||||||
The DMA is splitted in 2 equal-sized subbuffers. The Flexcop writes to first
|
|
||||||
address and triggers an IRQ when it's full and starts writing to the second
|
|
||||||
address. When the second address is full, the IRQ is triggered again, and
|
|
||||||
the flexcop writes to first address again, and so on.
|
|
||||||
The buffersize of each address is currently 640*188 bytes.
|
|
||||||
|
|
||||||
Problem is, when using hw-pid-filtering and doing some low-bandwidth
|
|
||||||
operation (like scanning) the buffers won't be filled enough to trigger
|
|
||||||
the IRQ. That's why:
|
|
||||||
|
|
||||||
When PID filtering is activated, the timer IRQ is used. Every 1.97 ms the IRQ
|
|
||||||
is triggered. Is the current write address of DMA1 different to the one
|
|
||||||
during the last IRQ, then the data is passed to the demuxer.
|
|
||||||
|
|
||||||
There is an additional DMA-IRQ-method: packet count IRQ. This isn't
|
|
||||||
implemented correctly yet.
|
|
||||||
|
|
||||||
The solution is to disable HW PID filtering, but I don't know how the DVB
|
|
||||||
API software demux behaves on slow systems with 45MBit/s TS.
|
|
||||||
|
|
||||||
Solved bugs :)
|
|
||||||
--------------
|
|
||||||
1g) pid-filtering (somehow pid index 4 and 5 (EMM_PID and ECM_PID) aren't
|
|
||||||
working)
|
|
||||||
SOLUTION: also index 0 was affected, because net_translation is done for
|
|
||||||
these indexes by default
|
|
||||||
|
|
||||||
5b) isochronous transfer does only work in the first attempt (for the Sky2PC
|
|
||||||
USB, Air2PC is working) SOLUTION: the flexcop was going asleep and never really
|
|
||||||
woke up again (don't know if this need fixes, see
|
|
||||||
flexcop-fe-tuner.c:flexcop_sleep)
|
|
||||||
|
|
||||||
NEWS: when the driver is loaded and unloaded and loaded again (w/o doing
|
|
||||||
anything in the while the driver is loaded the first time), no transfers take
|
|
||||||
place anymore.
|
|
||||||
|
|
||||||
Improvements when rewriting (refactoring) is done
|
|
||||||
=================================================
|
|
||||||
|
|
||||||
- split sleeping of the flexcop (misc_204.ACPI3_sig = 1;) from lnb_control
|
|
||||||
(enable sleeping for other demods than dvb-s)
|
|
||||||
- add support for CableStar (stv0297 Microtune 203x/ALPS) (almost done, incompatibilities with the Nexus-CA)
|
|
||||||
|
|
||||||
Debugging
|
|
||||||
---------
|
|
||||||
- add verbose debugging to skystar2.c (dump the reg_dw_data) and compare it
|
|
||||||
with this flexcop, this is important, because i2c is now using the
|
|
||||||
flexcop_ibi_value union from flexcop-reg.h (do you have a better idea for
|
|
||||||
that, please tell us so).
|
|
||||||
|
|
||||||
Everything which is identical in the following table, can be put into a common
|
|
||||||
flexcop-module.
|
|
||||||
|
|
||||||
PCI USB
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Different:
|
|
||||||
Register access: accessing IO memory USB control message
|
|
||||||
I2C bus: I2C bus of the FC USB control message
|
|
||||||
Data transfer: DMA isochronous transfer
|
|
||||||
EEPROM transfer: through i2c bus not clear yet
|
|
||||||
|
|
||||||
Identical:
|
|
||||||
Streaming: accessing registers
|
|
||||||
PID Filtering: accessing registers
|
|
||||||
Sram destinations: accessing registers
|
|
||||||
Tuner/Demod: I2C bus
|
|
||||||
DVB-stuff: can be written for common use
|
|
||||||
|
|
||||||
Acknowledgements (just for the rewriting part)
|
|
||||||
================
|
|
||||||
|
|
||||||
Bjarne Steinsbo thought a lot in the first place of the pci part for this code
|
|
||||||
sharing idea.
|
|
||||||
|
|
||||||
Andreas Oberritter for providing a recent PCI initialization template
|
|
||||||
(pluto2.c).
|
|
||||||
|
|
||||||
Boleslaw Ciesielski for pointing out a problem with firmware loader.
|
|
||||||
|
|
||||||
Vadim Catana for correcting the USB transfer.
|
|
||||||
|
|
||||||
comments, critics and ideas to linux-dvb@linuxtv.org.
|
|
|
@ -1,5 +1,5 @@
|
||||||
How to set up the Technisat devices
|
How to set up the Technisat/B2C2 Flexcop devices
|
||||||
===================================
|
================================================
|
||||||
|
|
||||||
1) Find out what device you have
|
1) Find out what device you have
|
||||||
================================
|
================================
|
||||||
|
@ -16,54 +16,60 @@ DVB: registering frontend 0 (Conexant CX24123/CX24109)...
|
||||||
|
|
||||||
If the Technisat is the only TV device in your box get rid of unnecessary modules and check this one:
|
If the Technisat is the only TV device in your box get rid of unnecessary modules and check this one:
|
||||||
"Multimedia devices" => "Customise analog and hybrid tuner modules to build"
|
"Multimedia devices" => "Customise analog and hybrid tuner modules to build"
|
||||||
In this directory uncheck every driver which is activated there.
|
In this directory uncheck every driver which is activated there (except "Simple tuner support" for case 9 only).
|
||||||
|
|
||||||
Then please activate:
|
Then please activate:
|
||||||
2a) Main module part:
|
2a) Main module part:
|
||||||
|
|
||||||
a.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters"
|
a.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters"
|
||||||
b.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC PCI" in case of a PCI card OR
|
b.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC PCI" in case of a PCI card
|
||||||
|
OR
|
||||||
c.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC USB" in case of an USB 1.1 adapter
|
c.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC USB" in case of an USB 1.1 adapter
|
||||||
d.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Enable debug for the B2C2 FlexCop drivers"
|
d.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Enable debug for the B2C2 FlexCop drivers"
|
||||||
Notice: d.) is helpful for troubleshooting
|
Notice: d.) is helpful for troubleshooting
|
||||||
|
|
||||||
2b) Frontend module part:
|
2b) Frontend module part:
|
||||||
|
|
||||||
1.) Revision 2.3:
|
1.) SkyStar DVB-S Revision 2.3:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink VP310/MT312/ZL10313 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink VP310/MT312/ZL10313 based"
|
||||||
|
|
||||||
2.) Revision 2.6:
|
2.) SkyStar DVB-S Revision 2.6:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0299 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0299 based"
|
||||||
|
|
||||||
3.) Revision 2.7:
|
3.) SkyStar DVB-S Revision 2.7:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Samsung S5H1420 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Samsung S5H1420 based"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "Integrant ITD1000 Zero IF tuner for DVB-S/DSS"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Integrant ITD1000 Zero IF tuner for DVB-S/DSS"
|
||||||
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
||||||
|
|
||||||
4.) Revision 2.8:
|
4.) SkyStar DVB-S Revision 2.8:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24113/CX24128 tuner for DVB-S/DSS"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24113/CX24128 tuner for DVB-S/DSS"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24123 based"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24123 based"
|
||||||
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
||||||
|
|
||||||
5.) DVB-T card:
|
5.) AirStar DVB-T card:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink MT352 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink MT352 based"
|
||||||
|
|
||||||
6.) DVB-C card:
|
6.) CableStar DVB-C card:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0297 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0297 based"
|
||||||
|
|
||||||
7.) ATSC card 1st generation:
|
7.) AirStar ATSC card 1st generation:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Broadcom BCM3510"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Broadcom BCM3510"
|
||||||
|
|
||||||
8.) ATSC card 2nd generation:
|
8.) AirStar ATSC card 2nd generation:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "NxtWave Communications NXT2002/NXT2004 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "NxtWave Communications NXT2002/NXT2004 based"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "LG Electronics LGDT3302/LGDT3303 based"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Generic I2C PLL based tuners"
|
||||||
|
|
||||||
Author: Uwe Bugla <uwe.bugla@gmx.de> December 2008
|
9.) AirStar ATSC card 3rd generation:
|
||||||
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
|
b.)"Multimedia devices" => "Customise DVB frontends" => "LG Electronics LGDT3302/LGDT3303 based"
|
||||||
|
c.)"Multimedia devices" => "Customise analog and hybrid tuner modules to build" => "Simple tuner support"
|
||||||
|
|
||||||
|
Author: Uwe Bugla <uwe.bugla@gmx.de> February 2009
|
||||||
|
|
|
@ -335,3 +335,12 @@ Why: In 2.6.18 the Secmark concept was introduced to replace the "compat_net"
|
||||||
Secmark, it is time to deprecate the older mechanism and start the
|
Secmark, it is time to deprecate the older mechanism and start the
|
||||||
process of removing the old code.
|
process of removing the old code.
|
||||||
Who: Paul Moore <paul.moore@hp.com>
|
Who: Paul Moore <paul.moore@hp.com>
|
||||||
|
---------------------------
|
||||||
|
|
||||||
|
What: sysfs ui for changing p4-clockmod parameters
|
||||||
|
When: September 2009
|
||||||
|
Why: See commits 129f8ae9b1b5be94517da76009ea956e89104ce8 and
|
||||||
|
e088e4c9cdb618675874becb91b2fd581ee707e6.
|
||||||
|
Removal is subject to fixing any remaining bugs in ACPI which may
|
||||||
|
cause the thermal throttling not to happen at the right time.
|
||||||
|
Who: Dave Jones <davej@redhat.com>, Matthew Garrett <mjg@redhat.com>
|
||||||
|
|
|
@ -373,10 +373,10 @@ Filesystem Resizing http://ext2resize.sourceforge.net/
|
||||||
Compression (*) http://e2compr.sourceforge.net/
|
Compression (*) http://e2compr.sourceforge.net/
|
||||||
|
|
||||||
Implementations for:
|
Implementations for:
|
||||||
Windows 95/98/NT/2000 http://uranus.it.swin.edu.au/~jn/linux/Explore2fs.htm
|
Windows 95/98/NT/2000 http://www.chrysocome.net/explore2fs
|
||||||
Windows 95 (*) http://www.yipton.demon.co.uk/content.html#FSDEXT2
|
Windows 95 (*) http://www.yipton.net/content.html#FSDEXT2
|
||||||
DOS client (*) ftp://metalab.unc.edu/pub/Linux/system/filesystems/ext2/
|
DOS client (*) ftp://metalab.unc.edu/pub/Linux/system/filesystems/ext2/
|
||||||
OS/2 http://perso.wanadoo.fr/matthieu.willm/ext2-os2/
|
OS/2 (*) ftp://metalab.unc.edu/pub/Linux/system/filesystems/ext2/
|
||||||
RISC OS client ftp://ftp.barnet.ac.uk/pub/acorn/armlinux/iscafs/
|
RISC OS client http://www.esw-heim.tu-clausthal.de/~marco/smorbrod/IscaFS/
|
||||||
|
|
||||||
(*) no longer actively developed/supported (as of Apr 2001)
|
(*) no longer actively developed/supported (as of Mar 2009)
|
||||||
|
|
|
@ -198,5 +198,5 @@ kernel source: <file:fs/ext3/>
|
||||||
programs: http://e2fsprogs.sourceforge.net/
|
programs: http://e2fsprogs.sourceforge.net/
|
||||||
http://ext2resize.sourceforge.net
|
http://ext2resize.sourceforge.net
|
||||||
|
|
||||||
useful links: http://www-106.ibm.com/developerworks/linux/library/l-fs7/
|
useful links: http://www.ibm.com/developerworks/library/l-fs7.html
|
||||||
http://www-106.ibm.com/developerworks/linux/library/l-fs8/
|
http://www.ibm.com/developerworks/library/l-fs8.html
|
||||||
|
|
|
@ -22,7 +22,7 @@ Squashfs filesystem features versus Cramfs:
|
||||||
|
|
||||||
Squashfs Cramfs
|
Squashfs Cramfs
|
||||||
|
|
||||||
Max filesystem size: 2^64 16 MiB
|
Max filesystem size: 2^64 256 MiB
|
||||||
Max file size: ~ 2 TiB 16 MiB
|
Max file size: ~ 2 TiB 16 MiB
|
||||||
Max files: unlimited unlimited
|
Max files: unlimited unlimited
|
||||||
Max directories: unlimited unlimited
|
Max directories: unlimited unlimited
|
||||||
|
|
|
@ -42,6 +42,11 @@ Supported chips:
|
||||||
Addresses scanned: I2C 0x4e
|
Addresses scanned: I2C 0x4e
|
||||||
Datasheet: Publicly available at the Maxim website
|
Datasheet: Publicly available at the Maxim website
|
||||||
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3497
|
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3497
|
||||||
|
* Maxim MAX6648
|
||||||
|
Prefix: 'max6646'
|
||||||
|
Addresses scanned: I2C 0x4c
|
||||||
|
Datasheet: Publicly available at the Maxim website
|
||||||
|
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3500
|
||||||
* Maxim MAX6649
|
* Maxim MAX6649
|
||||||
Prefix: 'max6646'
|
Prefix: 'max6646'
|
||||||
Addresses scanned: I2C 0x4c
|
Addresses scanned: I2C 0x4c
|
||||||
|
@ -74,6 +79,11 @@ Supported chips:
|
||||||
0x4c, 0x4d and 0x4e
|
0x4c, 0x4d and 0x4e
|
||||||
Datasheet: Publicly available at the Maxim website
|
Datasheet: Publicly available at the Maxim website
|
||||||
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3370
|
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3370
|
||||||
|
* Maxim MAX6692
|
||||||
|
Prefix: 'max6646'
|
||||||
|
Addresses scanned: I2C 0x4c
|
||||||
|
Datasheet: Publicly available at the Maxim website
|
||||||
|
http://www.maxim-ic.com/quick_view2.cfm/qv_pk/3500
|
||||||
|
|
||||||
|
|
||||||
Author: Jean Delvare <khali@linux-fr.org>
|
Author: Jean Delvare <khali@linux-fr.org>
|
||||||
|
|
|
@ -114,7 +114,7 @@ In addition, the following text indicates that the option:
|
||||||
Parameters denoted with BOOT are actually interpreted by the boot
|
Parameters denoted with BOOT are actually interpreted by the boot
|
||||||
loader, and have no meaning to the kernel directly.
|
loader, and have no meaning to the kernel directly.
|
||||||
Do not modify the syntax of boot loader parameters without extreme
|
Do not modify the syntax of boot loader parameters without extreme
|
||||||
need or coordination with <Documentation/x86/i386/boot.txt>.
|
need or coordination with <Documentation/x86/boot.txt>.
|
||||||
|
|
||||||
There are also arch-specific kernel-parameters not documented here.
|
There are also arch-specific kernel-parameters not documented here.
|
||||||
See for example <Documentation/x86/x86_64/boot-options.txt>.
|
See for example <Documentation/x86/x86_64/boot-options.txt>.
|
||||||
|
@ -868,8 +868,10 @@ and is between 256 and 4096 characters. It is defined in the file
|
||||||
icn= [HW,ISDN]
|
icn= [HW,ISDN]
|
||||||
Format: <io>[,<membase>[,<icn_id>[,<icn_id2>]]]
|
Format: <io>[,<membase>[,<icn_id>[,<icn_id2>]]]
|
||||||
|
|
||||||
ide= [HW] (E)IDE subsystem
|
ide-core.nodma= [HW] (E)IDE subsystem
|
||||||
Format: ide=nodma or ide=doubler
|
Format: =0.0 to prevent dma on hda, =0.1 hdb =1.0 hdc
|
||||||
|
.vlb_clock .pci_clock .noflush .noprobe .nowerr .cdrom
|
||||||
|
.chs .ignore_cable are additional options
|
||||||
See Documentation/ide/ide.txt.
|
See Documentation/ide/ide.txt.
|
||||||
|
|
||||||
idebus= [HW] (E)IDE subsystem - VLB/PCI bus speed
|
idebus= [HW] (E)IDE subsystem - VLB/PCI bus speed
|
||||||
|
@ -2449,7 +2451,7 @@ and is between 256 and 4096 characters. It is defined in the file
|
||||||
See Documentation/fb/modedb.txt.
|
See Documentation/fb/modedb.txt.
|
||||||
|
|
||||||
vga= [BOOT,X86-32] Select a particular video mode
|
vga= [BOOT,X86-32] Select a particular video mode
|
||||||
See Documentation/x86/i386/boot.txt and
|
See Documentation/x86/boot.txt and
|
||||||
Documentation/svga.txt.
|
Documentation/svga.txt.
|
||||||
Use vga=ask for menu.
|
Use vga=ask for menu.
|
||||||
This is actually a boot loader parameter; the value is
|
This is actually a boot loader parameter; the value is
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
|
||||||
|
Options for the ipv6 module are supplied as parameters at load time.
|
||||||
|
|
||||||
|
Module options may be given as command line arguments to the insmod
|
||||||
|
or modprobe command, but are usually specified in either the
|
||||||
|
/etc/modules.conf or /etc/modprobe.conf configuration file, or in a
|
||||||
|
distro-specific configuration file.
|
||||||
|
|
||||||
|
The available ipv6 module parameters are listed below. If a parameter
|
||||||
|
is not specified the default value is used.
|
||||||
|
|
||||||
|
The parameters are as follows:
|
||||||
|
|
||||||
|
disable
|
||||||
|
|
||||||
|
Specifies whether to load the IPv6 module, but disable all
|
||||||
|
its functionality. This might be used when another module
|
||||||
|
has a dependency on the IPv6 module being loaded, but no
|
||||||
|
IPv6 addresses or operations are desired.
|
||||||
|
|
||||||
|
The possible values and their effects are:
|
||||||
|
|
||||||
|
0
|
||||||
|
IPv6 is enabled.
|
||||||
|
|
||||||
|
This is the default value.
|
||||||
|
|
||||||
|
1
|
||||||
|
IPv6 is disabled.
|
||||||
|
|
||||||
|
No IPv6 addresses will be added to interfaces, and
|
||||||
|
it will not be possible to open an IPv6 socket.
|
||||||
|
|
||||||
|
A reboot is required to enable IPv6.
|
||||||
|
|
|
@ -4,7 +4,7 @@ Introduction
|
||||||
============
|
============
|
||||||
|
|
||||||
The Chelsio T3 ASIC based Adapters (S310, S320, S302, S304, Mezz cards, etc.
|
The Chelsio T3 ASIC based Adapters (S310, S320, S302, S304, Mezz cards, etc.
|
||||||
series of products) supports iSCSI acceleration and iSCSI Direct Data Placement
|
series of products) support iSCSI acceleration and iSCSI Direct Data Placement
|
||||||
(DDP) where the hardware handles the expensive byte touching operations, such
|
(DDP) where the hardware handles the expensive byte touching operations, such
|
||||||
as CRC computation and verification, and direct DMA to the final host memory
|
as CRC computation and verification, and direct DMA to the final host memory
|
||||||
destination:
|
destination:
|
||||||
|
@ -31,9 +31,9 @@ destination:
|
||||||
the TCP segments onto the wire. It handles TCP retransmission if
|
the TCP segments onto the wire. It handles TCP retransmission if
|
||||||
needed.
|
needed.
|
||||||
|
|
||||||
On receving, S3 h/w recovers the iSCSI PDU by reassembling TCP
|
On receiving, S3 h/w recovers the iSCSI PDU by reassembling TCP
|
||||||
segments, separating the header and data, calculating and verifying
|
segments, separating the header and data, calculating and verifying
|
||||||
the digests, then forwards the header to the host. The payload data,
|
the digests, then forwarding the header to the host. The payload data,
|
||||||
if possible, will be directly placed into the pre-posted host DDP
|
if possible, will be directly placed into the pre-posted host DDP
|
||||||
buffer. Otherwise, the payload data will be sent to the host too.
|
buffer. Otherwise, the payload data will be sent to the host too.
|
||||||
|
|
||||||
|
@ -68,9 +68,8 @@ The following steps need to be taken to accelerates the open-iscsi initiator:
|
||||||
sure the ip address is unique in the network.
|
sure the ip address is unique in the network.
|
||||||
|
|
||||||
3. edit /etc/iscsi/iscsid.conf
|
3. edit /etc/iscsi/iscsid.conf
|
||||||
The default setting for MaxRecvDataSegmentLength (131072) is too big,
|
The default setting for MaxRecvDataSegmentLength (131072) is too big;
|
||||||
replace "node.conn[0].iscsi.MaxRecvDataSegmentLength" to be a value no
|
replace with a value no bigger than 15360 (for example 8192):
|
||||||
bigger than 15360 (for example 8192):
|
|
||||||
|
|
||||||
node.conn[0].iscsi.MaxRecvDataSegmentLength = 8192
|
node.conn[0].iscsi.MaxRecvDataSegmentLength = 8192
|
||||||
|
|
||||||
|
|
|
@ -1469,8 +1469,6 @@ L: linux-acpi@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
|
|
||||||
DOCUMENTATION (/Documentation directory)
|
DOCUMENTATION (/Documentation directory)
|
||||||
P: Michael Kerrisk
|
|
||||||
M: mtk.manpages@gmail.com
|
|
||||||
P: Randy Dunlap
|
P: Randy Dunlap
|
||||||
M: rdunlap@xenotime.net
|
M: rdunlap@xenotime.net
|
||||||
L: linux-doc@vger.kernel.org
|
L: linux-doc@vger.kernel.org
|
||||||
|
@ -2464,7 +2462,7 @@ S: Maintained
|
||||||
|
|
||||||
ISDN SUBSYSTEM
|
ISDN SUBSYSTEM
|
||||||
P: Karsten Keil
|
P: Karsten Keil
|
||||||
M: kkeil@suse.de
|
M: isdn@linux-pingi.de
|
||||||
L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
|
L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
|
||||||
W: http://www.isdn4linux.de
|
W: http://www.isdn4linux.de
|
||||||
T: git kernel.org:/pub/scm/linux/kernel/kkeil/isdn-2.6.git
|
T: git kernel.org:/pub/scm/linux/kernel/kkeil/isdn-2.6.git
|
||||||
|
@ -2879,7 +2877,7 @@ P: Michael Kerrisk
|
||||||
M: mtk.manpages@gmail.com
|
M: mtk.manpages@gmail.com
|
||||||
W: http://www.kernel.org/doc/man-pages
|
W: http://www.kernel.org/doc/man-pages
|
||||||
L: linux-man@vger.kernel.org
|
L: linux-man@vger.kernel.org
|
||||||
S: Supported
|
S: Maintained
|
||||||
|
|
||||||
MARVELL LIBERTAS WIRELESS DRIVER
|
MARVELL LIBERTAS WIRELESS DRIVER
|
||||||
P: Dan Williams
|
P: Dan Williams
|
||||||
|
|
20
Makefile
20
Makefile
|
@ -1,7 +1,7 @@
|
||||||
VERSION = 2
|
VERSION = 2
|
||||||
PATCHLEVEL = 6
|
PATCHLEVEL = 6
|
||||||
SUBLEVEL = 29
|
SUBLEVEL = 29
|
||||||
EXTRAVERSION = -rc6
|
EXTRAVERSION = -rc7
|
||||||
NAME = Erotic Pickled Herring
|
NAME = Erotic Pickled Herring
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -904,12 +904,18 @@ localver = $(subst $(space),, $(string) \
|
||||||
# and if the SCM is know a tag from the SCM is appended.
|
# and if the SCM is know a tag from the SCM is appended.
|
||||||
# The appended tag is determined by the SCM used.
|
# The appended tag is determined by the SCM used.
|
||||||
#
|
#
|
||||||
# Currently, only git is supported.
|
# .scmversion is used when generating rpm packages so we do not loose
|
||||||
# Other SCMs can edit scripts/setlocalversion and add the appropriate
|
# the version information from the SCM when we do the build of the kernel
|
||||||
# checks as needed.
|
# from the copied source
|
||||||
ifdef CONFIG_LOCALVERSION_AUTO
|
ifdef CONFIG_LOCALVERSION_AUTO
|
||||||
_localver-auto = $(shell $(CONFIG_SHELL) \
|
|
||||||
$(srctree)/scripts/setlocalversion $(srctree))
|
ifeq ($(wildcard .scmversion),)
|
||||||
|
_localver-auto = $(shell $(CONFIG_SHELL) \
|
||||||
|
$(srctree)/scripts/setlocalversion $(srctree))
|
||||||
|
else
|
||||||
|
_localver-auto = $(shell cat .scmversion 2> /dev/null)
|
||||||
|
endif
|
||||||
|
|
||||||
localver-auto = $(LOCALVERSION)$(_localver-auto)
|
localver-auto = $(LOCALVERSION)$(_localver-auto)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
@ -1537,7 +1543,7 @@ quiet_cmd_depmod = DEPMOD $(KERNELRELEASE)
|
||||||
cmd_depmod = \
|
cmd_depmod = \
|
||||||
if [ -r System.map -a -x $(DEPMOD) ]; then \
|
if [ -r System.map -a -x $(DEPMOD) ]; then \
|
||||||
$(DEPMOD) -ae -F System.map \
|
$(DEPMOD) -ae -F System.map \
|
||||||
$(if $(strip $(INSTALL_MOD_PATH)), -b $(INSTALL_MOD_PATH) -r) \
|
$(if $(strip $(INSTALL_MOD_PATH)), -b $(INSTALL_MOD_PATH) ) \
|
||||||
$(KERNELRELEASE); \
|
$(KERNELRELEASE); \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
|
@ -233,12 +233,13 @@ static void __init cacheid_init(void)
|
||||||
unsigned int cachetype = read_cpuid_cachetype();
|
unsigned int cachetype = read_cpuid_cachetype();
|
||||||
unsigned int arch = cpu_architecture();
|
unsigned int arch = cpu_architecture();
|
||||||
|
|
||||||
if (arch >= CPU_ARCH_ARMv7) {
|
if (arch >= CPU_ARCH_ARMv6) {
|
||||||
cacheid = CACHEID_VIPT_NONALIASING;
|
if ((cachetype & (7 << 29)) == 4 << 29) {
|
||||||
if ((cachetype & (3 << 14)) == 1 << 14)
|
/* ARMv7 register format */
|
||||||
cacheid |= CACHEID_ASID_TAGGED;
|
cacheid = CACHEID_VIPT_NONALIASING;
|
||||||
} else if (arch >= CPU_ARCH_ARMv6) {
|
if ((cachetype & (3 << 14)) == 1 << 14)
|
||||||
if (cachetype & (1 << 23))
|
cacheid |= CACHEID_ASID_TAGGED;
|
||||||
|
} else if (cachetype & (1 << 23))
|
||||||
cacheid = CACHEID_VIPT_ALIASING;
|
cacheid = CACHEID_VIPT_ALIASING;
|
||||||
else
|
else
|
||||||
cacheid = CACHEID_VIPT_NONALIASING;
|
cacheid = CACHEID_VIPT_NONALIASING;
|
||||||
|
|
|
@ -347,6 +347,111 @@ void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data)
|
||||||
void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {}
|
void __init at91_add_device_mmc(short mmc_id, struct at91_mmc_data *data) {}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------
|
||||||
|
* Compact Flash (PCMCIA or IDE)
|
||||||
|
* -------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
#if defined(CONFIG_AT91_CF) || defined(CONFIG_AT91_CF_MODULE) || \
|
||||||
|
defined(CONFIG_BLK_DEV_IDE_AT91) || defined(CONFIG_BLK_DEV_IDE_AT91_MODULE)
|
||||||
|
|
||||||
|
static struct at91_cf_data cf0_data;
|
||||||
|
|
||||||
|
static struct resource cf0_resources[] = {
|
||||||
|
[0] = {
|
||||||
|
.start = AT91_CHIPSELECT_4,
|
||||||
|
.end = AT91_CHIPSELECT_4 + SZ_256M - 1,
|
||||||
|
.flags = IORESOURCE_MEM | IORESOURCE_MEM_8AND16BIT,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device cf0_device = {
|
||||||
|
.id = 0,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &cf0_data,
|
||||||
|
},
|
||||||
|
.resource = cf0_resources,
|
||||||
|
.num_resources = ARRAY_SIZE(cf0_resources),
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct at91_cf_data cf1_data;
|
||||||
|
|
||||||
|
static struct resource cf1_resources[] = {
|
||||||
|
[0] = {
|
||||||
|
.start = AT91_CHIPSELECT_5,
|
||||||
|
.end = AT91_CHIPSELECT_5 + SZ_256M - 1,
|
||||||
|
.flags = IORESOURCE_MEM | IORESOURCE_MEM_8AND16BIT,
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device cf1_device = {
|
||||||
|
.id = 1,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &cf1_data,
|
||||||
|
},
|
||||||
|
.resource = cf1_resources,
|
||||||
|
.num_resources = ARRAY_SIZE(cf1_resources),
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init at91_add_device_cf(struct at91_cf_data *data)
|
||||||
|
{
|
||||||
|
unsigned long ebi0_csa;
|
||||||
|
struct platform_device *pdev;
|
||||||
|
|
||||||
|
if (!data)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* assign CS4 or CS5 to SMC with Compact Flash logic support,
|
||||||
|
* we assume SMC timings are configured by board code,
|
||||||
|
* except True IDE where timings are controlled by driver
|
||||||
|
*/
|
||||||
|
ebi0_csa = at91_sys_read(AT91_MATRIX_EBI0CSA);
|
||||||
|
switch (data->chipselect) {
|
||||||
|
case 4:
|
||||||
|
at91_set_A_periph(AT91_PIN_PD6, 0); /* EBI0_NCS4/CFCS0 */
|
||||||
|
ebi0_csa |= AT91_MATRIX_EBI0_CS4A_SMC_CF1;
|
||||||
|
cf0_data = *data;
|
||||||
|
pdev = &cf0_device;
|
||||||
|
break;
|
||||||
|
case 5:
|
||||||
|
at91_set_A_periph(AT91_PIN_PD7, 0); /* EBI0_NCS5/CFCS1 */
|
||||||
|
ebi0_csa |= AT91_MATRIX_EBI0_CS5A_SMC_CF2;
|
||||||
|
cf1_data = *data;
|
||||||
|
pdev = &cf1_device;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printk(KERN_ERR "AT91 CF: bad chip-select requested (%u)\n",
|
||||||
|
data->chipselect);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
at91_sys_write(AT91_MATRIX_EBI0CSA, ebi0_csa);
|
||||||
|
|
||||||
|
if (data->det_pin) {
|
||||||
|
at91_set_gpio_input(data->det_pin, 1);
|
||||||
|
at91_set_deglitch(data->det_pin, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (data->irq_pin) {
|
||||||
|
at91_set_gpio_input(data->irq_pin, 1);
|
||||||
|
at91_set_deglitch(data->irq_pin, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (data->vcc_pin)
|
||||||
|
/* initially off */
|
||||||
|
at91_set_gpio_output(data->vcc_pin, 0);
|
||||||
|
|
||||||
|
/* enable EBI controlled pins */
|
||||||
|
at91_set_A_periph(AT91_PIN_PD5, 1); /* NWAIT */
|
||||||
|
at91_set_A_periph(AT91_PIN_PD8, 0); /* CFCE1 */
|
||||||
|
at91_set_A_periph(AT91_PIN_PD9, 0); /* CFCE2 */
|
||||||
|
at91_set_A_periph(AT91_PIN_PD14, 0); /* CFNRW */
|
||||||
|
|
||||||
|
pdev->name = (data->flags & AT91_CF_TRUE_IDE) ? "at91_ide" : "at91_cf";
|
||||||
|
platform_device_register(pdev);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
void __init at91_add_device_cf(struct at91_cf_data *data) {}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* --------------------------------------------------------------------
|
/* --------------------------------------------------------------------
|
||||||
* NAND / SmartMedia
|
* NAND / SmartMedia
|
||||||
|
|
|
@ -56,6 +56,9 @@ struct at91_cf_data {
|
||||||
u8 vcc_pin; /* power switching */
|
u8 vcc_pin; /* power switching */
|
||||||
u8 rst_pin; /* card reset */
|
u8 rst_pin; /* card reset */
|
||||||
u8 chipselect; /* EBI Chip Select number */
|
u8 chipselect; /* EBI Chip Select number */
|
||||||
|
u8 flags;
|
||||||
|
#define AT91_CF_TRUE_IDE 0x01
|
||||||
|
#define AT91_IDE_SWAP_A0_A2 0x02
|
||||||
};
|
};
|
||||||
extern void __init at91_add_device_cf(struct at91_cf_data *data);
|
extern void __init at91_add_device_cf(struct at91_cf_data *data);
|
||||||
|
|
||||||
|
|
|
@ -332,7 +332,6 @@ static int at91_pm_enter(suspend_state_t state)
|
||||||
at91_sys_read(AT91_AIC_IPR) & at91_sys_read(AT91_AIC_IMR));
|
at91_sys_read(AT91_AIC_IPR) & at91_sys_read(AT91_AIC_IMR));
|
||||||
|
|
||||||
error:
|
error:
|
||||||
sdram_selfrefresh_disable();
|
|
||||||
target_state = PM_SUSPEND_ON;
|
target_state = PM_SUSPEND_ON;
|
||||||
at91_irq_resume();
|
at91_irq_resume();
|
||||||
at91_gpio_resume();
|
at91_gpio_resume();
|
||||||
|
|
|
@ -311,6 +311,9 @@ evm_u35_setup(struct i2c_client *client, int gpio, unsigned ngpio, void *c)
|
||||||
gpio_request(gpio + 7, "nCF_SEL");
|
gpio_request(gpio + 7, "nCF_SEL");
|
||||||
gpio_direction_output(gpio + 7, 1);
|
gpio_direction_output(gpio + 7, 1);
|
||||||
|
|
||||||
|
/* irlml6401 sustains over 3A, switches 5V in under 8 msec */
|
||||||
|
setup_usb(500, 8);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -417,9 +420,6 @@ static __init void davinci_evm_init(void)
|
||||||
platform_add_devices(davinci_evm_devices,
|
platform_add_devices(davinci_evm_devices,
|
||||||
ARRAY_SIZE(davinci_evm_devices));
|
ARRAY_SIZE(davinci_evm_devices));
|
||||||
evm_init_i2c();
|
evm_init_i2c();
|
||||||
|
|
||||||
/* irlml6401 sustains over 3A, switches 5V in under 8 msec */
|
|
||||||
setup_usb(500, 8);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static __init void davinci_evm_irq_init(void)
|
static __init void davinci_evm_irq_init(void)
|
||||||
|
|
|
@ -230,6 +230,11 @@ static struct clk davinci_clks[] = {
|
||||||
.rate = &commonrate,
|
.rate = &commonrate,
|
||||||
.lpsc = DAVINCI_LPSC_GPIO,
|
.lpsc = DAVINCI_LPSC_GPIO,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.name = "usb",
|
||||||
|
.rate = &commonrate,
|
||||||
|
.lpsc = DAVINCI_LPSC_USB,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = "AEMIFCLK",
|
.name = "AEMIFCLK",
|
||||||
.rate = &commonrate,
|
.rate = &commonrate,
|
||||||
|
|
|
@ -47,6 +47,7 @@ static struct musb_hdrc_platform_data usb_data = {
|
||||||
#elif defined(CONFIG_USB_MUSB_HOST)
|
#elif defined(CONFIG_USB_MUSB_HOST)
|
||||||
.mode = MUSB_HOST,
|
.mode = MUSB_HOST,
|
||||||
#endif
|
#endif
|
||||||
|
.clock = "usb",
|
||||||
.config = &musb_config,
|
.config = &musb_config,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -81,7 +81,7 @@ static inline void __init ldp_init_smc911x(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
ldp_smc911x_resources[0].start = cs_mem_base + 0x0;
|
ldp_smc911x_resources[0].start = cs_mem_base + 0x0;
|
||||||
ldp_smc911x_resources[0].end = cs_mem_base + 0xf;
|
ldp_smc911x_resources[0].end = cs_mem_base + 0xff;
|
||||||
udelay(100);
|
udelay(100);
|
||||||
|
|
||||||
eth_gpio = LDP_SMC911X_GPIO;
|
eth_gpio = LDP_SMC911X_GPIO;
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
#include <linux/serial_8250.h>
|
#include <linux/serial_8250.h>
|
||||||
#include <linux/ata_platform.h>
|
#include <linux/ata_platform.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
|
||||||
#include <asm/elf.h>
|
#include <asm/elf.h>
|
||||||
#include <asm/mach-types.h>
|
#include <asm/mach-types.h>
|
||||||
|
@ -201,8 +202,13 @@ static struct platform_device *devs[] __initdata = {
|
||||||
&pata_device,
|
&pata_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info i2c_rtc = {
|
||||||
|
I2C_BOARD_INFO("pcf8583", 0x50)
|
||||||
|
};
|
||||||
|
|
||||||
static int __init rpc_init(void)
|
static int __init rpc_init(void)
|
||||||
{
|
{
|
||||||
|
i2c_register_board_info(0, &i2c_rtc, 1);
|
||||||
return platform_add_devices(devs, ARRAY_SIZE(devs));
|
return platform_add_devices(devs, ARRAY_SIZE(devs));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -23,7 +23,8 @@ ENTRY(v6_early_abort)
|
||||||
#ifdef CONFIG_CPU_32v6K
|
#ifdef CONFIG_CPU_32v6K
|
||||||
clrex
|
clrex
|
||||||
#else
|
#else
|
||||||
strex r0, r1, [sp] @ Clear the exclusive monitor
|
sub r1, sp, #4 @ Get unused stack location
|
||||||
|
strex r0, r1, [r1] @ Clear the exclusive monitor
|
||||||
#endif
|
#endif
|
||||||
mrc p15, 0, r1, c5, c0, 0 @ get FSR
|
mrc p15, 0, r1, c5, c0, 0 @ get FSR
|
||||||
mrc p15, 0, r0, c6, c0, 0 @ get FAR
|
mrc p15, 0, r0, c6, c0, 0 @ get FAR
|
||||||
|
|
|
@ -55,7 +55,7 @@ static void s3c_irq_eint_unmask(unsigned int irq)
|
||||||
u32 mask;
|
u32 mask;
|
||||||
|
|
||||||
mask = __raw_readl(S3C64XX_EINT0MASK);
|
mask = __raw_readl(S3C64XX_EINT0MASK);
|
||||||
mask |= eint_irq_to_bit(irq);
|
mask &= ~eint_irq_to_bit(irq);
|
||||||
__raw_writel(mask, S3C64XX_EINT0MASK);
|
__raw_writel(mask, S3C64XX_EINT0MASK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1129,6 +1129,7 @@ endchoice
|
||||||
|
|
||||||
config PM_WAKEUP_BY_GPIO
|
config PM_WAKEUP_BY_GPIO
|
||||||
bool "Allow Wakeup from Standby by GPIO"
|
bool "Allow Wakeup from Standby by GPIO"
|
||||||
|
depends on PM && !BF54x
|
||||||
|
|
||||||
config PM_WAKEUP_GPIO_NUMBER
|
config PM_WAKEUP_GPIO_NUMBER
|
||||||
int "GPIO number"
|
int "GPIO number"
|
||||||
|
@ -1168,6 +1169,12 @@ config PM_BFIN_WAKE_GP
|
||||||
default n
|
default n
|
||||||
help
|
help
|
||||||
Enable General-Purpose Wake-Up (Voltage Regulator Power-Up)
|
Enable General-Purpose Wake-Up (Voltage Regulator Power-Up)
|
||||||
|
(all processors, except ADSP-BF549). This option sets
|
||||||
|
the general-purpose wake-up enable (GPWE) control bit to enable
|
||||||
|
wake-up upon detection of an active low signal on the /GPW (PH7) pin.
|
||||||
|
On ADSP-BF549 this option enables the the same functionality on the
|
||||||
|
/MRXON pin also PH7.
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
|
||||||
menu "CPU Frequency scaling"
|
menu "CPU Frequency scaling"
|
||||||
|
|
|
@ -21,12 +21,6 @@ config DEBUG_STACK_USAGE
|
||||||
config HAVE_ARCH_KGDB
|
config HAVE_ARCH_KGDB
|
||||||
def_bool y
|
def_bool y
|
||||||
|
|
||||||
config KGDB_TESTCASE
|
|
||||||
tristate "KGDB: for test case in expect"
|
|
||||||
default n
|
|
||||||
help
|
|
||||||
This is a kgdb test case for automated testing.
|
|
||||||
|
|
||||||
config DEBUG_VERBOSE
|
config DEBUG_VERBOSE
|
||||||
bool "Verbose fault messages"
|
bool "Verbose fault messages"
|
||||||
default y
|
default y
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#
|
#
|
||||||
# Automatically generated make config: don't edit
|
# Automatically generated make config: don't edit
|
||||||
# Linux kernel version: 2.6.28-rc2
|
# Linux kernel version: 2.6.28
|
||||||
# Fri Jan 9 17:58:41 2009
|
# Fri Feb 20 10:01:44 2009
|
||||||
#
|
#
|
||||||
# CONFIG_MMU is not set
|
# CONFIG_MMU is not set
|
||||||
# CONFIG_FPU is not set
|
# CONFIG_FPU is not set
|
||||||
|
@ -133,10 +133,15 @@ CONFIG_BF518=y
|
||||||
# CONFIG_BF538 is not set
|
# CONFIG_BF538 is not set
|
||||||
# CONFIG_BF539 is not set
|
# CONFIG_BF539 is not set
|
||||||
# CONFIG_BF542 is not set
|
# CONFIG_BF542 is not set
|
||||||
|
# CONFIG_BF542M is not set
|
||||||
# CONFIG_BF544 is not set
|
# CONFIG_BF544 is not set
|
||||||
|
# CONFIG_BF544M is not set
|
||||||
# CONFIG_BF547 is not set
|
# CONFIG_BF547 is not set
|
||||||
|
# CONFIG_BF547M is not set
|
||||||
# CONFIG_BF548 is not set
|
# CONFIG_BF548 is not set
|
||||||
|
# CONFIG_BF548M is not set
|
||||||
# CONFIG_BF549 is not set
|
# CONFIG_BF549 is not set
|
||||||
|
# CONFIG_BF549M is not set
|
||||||
# CONFIG_BF561 is not set
|
# CONFIG_BF561 is not set
|
||||||
CONFIG_BF_REV_MIN=0
|
CONFIG_BF_REV_MIN=0
|
||||||
CONFIG_BF_REV_MAX=2
|
CONFIG_BF_REV_MAX=2
|
||||||
|
@ -426,7 +431,17 @@ CONFIG_DEFAULT_TCP_CONG="cubic"
|
||||||
# CONFIG_TIPC is not set
|
# CONFIG_TIPC is not set
|
||||||
# CONFIG_ATM is not set
|
# CONFIG_ATM is not set
|
||||||
# CONFIG_BRIDGE is not set
|
# CONFIG_BRIDGE is not set
|
||||||
# CONFIG_NET_DSA is not set
|
CONFIG_NET_DSA=y
|
||||||
|
# CONFIG_NET_DSA_TAG_DSA is not set
|
||||||
|
# CONFIG_NET_DSA_TAG_EDSA is not set
|
||||||
|
# CONFIG_NET_DSA_TAG_TRAILER is not set
|
||||||
|
CONFIG_NET_DSA_TAG_STPID=y
|
||||||
|
# CONFIG_NET_DSA_MV88E6XXX is not set
|
||||||
|
# CONFIG_NET_DSA_MV88E6060 is not set
|
||||||
|
# CONFIG_NET_DSA_MV88E6XXX_NEED_PPU is not set
|
||||||
|
# CONFIG_NET_DSA_MV88E6131 is not set
|
||||||
|
# CONFIG_NET_DSA_MV88E6123_61_65 is not set
|
||||||
|
CONFIG_NET_DSA_KSZ8893M=y
|
||||||
# CONFIG_VLAN_8021Q is not set
|
# CONFIG_VLAN_8021Q is not set
|
||||||
# CONFIG_DECNET is not set
|
# CONFIG_DECNET is not set
|
||||||
# CONFIG_LLC2 is not set
|
# CONFIG_LLC2 is not set
|
||||||
|
@ -529,6 +544,8 @@ CONFIG_MTD_COMPLEX_MAPPINGS=y
|
||||||
#
|
#
|
||||||
# Self-contained MTD device drivers
|
# Self-contained MTD device drivers
|
||||||
#
|
#
|
||||||
|
# CONFIG_MTD_DATAFLASH is not set
|
||||||
|
# CONFIG_MTD_M25P80 is not set
|
||||||
# CONFIG_MTD_SLRAM is not set
|
# CONFIG_MTD_SLRAM is not set
|
||||||
# CONFIG_MTD_PHRAM is not set
|
# CONFIG_MTD_PHRAM is not set
|
||||||
# CONFIG_MTD_MTDRAM is not set
|
# CONFIG_MTD_MTDRAM is not set
|
||||||
|
@ -561,7 +578,9 @@ CONFIG_BLK_DEV_RAM_SIZE=4096
|
||||||
# CONFIG_BLK_DEV_HD is not set
|
# CONFIG_BLK_DEV_HD is not set
|
||||||
CONFIG_MISC_DEVICES=y
|
CONFIG_MISC_DEVICES=y
|
||||||
# CONFIG_EEPROM_93CX6 is not set
|
# CONFIG_EEPROM_93CX6 is not set
|
||||||
|
# CONFIG_ICS932S401 is not set
|
||||||
# CONFIG_ENCLOSURE_SERVICES is not set
|
# CONFIG_ENCLOSURE_SERVICES is not set
|
||||||
|
# CONFIG_C2PORT is not set
|
||||||
CONFIG_HAVE_IDE=y
|
CONFIG_HAVE_IDE=y
|
||||||
# CONFIG_IDE is not set
|
# CONFIG_IDE is not set
|
||||||
|
|
||||||
|
@ -607,6 +626,7 @@ CONFIG_BFIN_RX_DESC_NUM=20
|
||||||
# CONFIG_SMC91X is not set
|
# CONFIG_SMC91X is not set
|
||||||
# CONFIG_SMSC911X is not set
|
# CONFIG_SMSC911X is not set
|
||||||
# CONFIG_DM9000 is not set
|
# CONFIG_DM9000 is not set
|
||||||
|
# CONFIG_ENC28J60 is not set
|
||||||
# CONFIG_IBM_NEW_EMAC_ZMII is not set
|
# CONFIG_IBM_NEW_EMAC_ZMII is not set
|
||||||
# CONFIG_IBM_NEW_EMAC_RGMII is not set
|
# CONFIG_IBM_NEW_EMAC_RGMII is not set
|
||||||
# CONFIG_IBM_NEW_EMAC_TAH is not set
|
# CONFIG_IBM_NEW_EMAC_TAH is not set
|
||||||
|
@ -764,7 +784,23 @@ CONFIG_I2C_BLACKFIN_TWI_CLK_KHZ=100
|
||||||
# CONFIG_I2C_DEBUG_ALGO is not set
|
# CONFIG_I2C_DEBUG_ALGO is not set
|
||||||
# CONFIG_I2C_DEBUG_BUS is not set
|
# CONFIG_I2C_DEBUG_BUS is not set
|
||||||
# CONFIG_I2C_DEBUG_CHIP is not set
|
# CONFIG_I2C_DEBUG_CHIP is not set
|
||||||
# CONFIG_SPI is not set
|
CONFIG_SPI=y
|
||||||
|
# CONFIG_SPI_DEBUG is not set
|
||||||
|
CONFIG_SPI_MASTER=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# SPI Master Controller Drivers
|
||||||
|
#
|
||||||
|
CONFIG_SPI_BFIN=y
|
||||||
|
# CONFIG_SPI_BFIN_LOCK is not set
|
||||||
|
# CONFIG_SPI_BITBANG is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# SPI Protocol Masters
|
||||||
|
#
|
||||||
|
# CONFIG_SPI_AT25 is not set
|
||||||
|
# CONFIG_SPI_SPIDEV is not set
|
||||||
|
# CONFIG_SPI_TLE62X0 is not set
|
||||||
CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y
|
CONFIG_ARCH_WANT_OPTIONAL_GPIOLIB=y
|
||||||
# CONFIG_GPIOLIB is not set
|
# CONFIG_GPIOLIB is not set
|
||||||
# CONFIG_W1 is not set
|
# CONFIG_W1 is not set
|
||||||
|
@ -788,8 +824,10 @@ CONFIG_BFIN_WDT=y
|
||||||
# CONFIG_MFD_SM501 is not set
|
# CONFIG_MFD_SM501 is not set
|
||||||
# CONFIG_HTC_PASIC3 is not set
|
# CONFIG_HTC_PASIC3 is not set
|
||||||
# CONFIG_MFD_TMIO is not set
|
# CONFIG_MFD_TMIO is not set
|
||||||
|
# CONFIG_PMIC_DA903X is not set
|
||||||
# CONFIG_MFD_WM8400 is not set
|
# CONFIG_MFD_WM8400 is not set
|
||||||
# CONFIG_MFD_WM8350_I2C is not set
|
# CONFIG_MFD_WM8350_I2C is not set
|
||||||
|
# CONFIG_REGULATOR is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# Multimedia devices
|
# Multimedia devices
|
||||||
|
@ -861,10 +899,18 @@ CONFIG_RTC_INTF_DEV=y
|
||||||
# CONFIG_RTC_DRV_M41T80 is not set
|
# CONFIG_RTC_DRV_M41T80 is not set
|
||||||
# CONFIG_RTC_DRV_S35390A is not set
|
# CONFIG_RTC_DRV_S35390A is not set
|
||||||
# CONFIG_RTC_DRV_FM3130 is not set
|
# CONFIG_RTC_DRV_FM3130 is not set
|
||||||
|
# CONFIG_RTC_DRV_RX8581 is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# SPI RTC drivers
|
# SPI RTC drivers
|
||||||
#
|
#
|
||||||
|
# CONFIG_RTC_DRV_M41T94 is not set
|
||||||
|
# CONFIG_RTC_DRV_DS1305 is not set
|
||||||
|
# CONFIG_RTC_DRV_DS1390 is not set
|
||||||
|
# CONFIG_RTC_DRV_MAX6902 is not set
|
||||||
|
# CONFIG_RTC_DRV_R9701 is not set
|
||||||
|
# CONFIG_RTC_DRV_RS5C348 is not set
|
||||||
|
# CONFIG_RTC_DRV_DS3234 is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# Platform RTC drivers
|
# Platform RTC drivers
|
||||||
|
@ -1062,12 +1108,20 @@ CONFIG_DEBUG_INFO=y
|
||||||
# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
|
# CONFIG_DEBUG_BLOCK_EXT_DEVT is not set
|
||||||
# CONFIG_FAULT_INJECTION is not set
|
# CONFIG_FAULT_INJECTION is not set
|
||||||
CONFIG_SYSCTL_SYSCALL_CHECK=y
|
CONFIG_SYSCTL_SYSCALL_CHECK=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Tracers
|
||||||
|
#
|
||||||
|
# CONFIG_SCHED_TRACER is not set
|
||||||
|
# CONFIG_CONTEXT_SWITCH_TRACER is not set
|
||||||
|
# CONFIG_BOOT_TRACER is not set
|
||||||
# CONFIG_DYNAMIC_PRINTK_DEBUG is not set
|
# CONFIG_DYNAMIC_PRINTK_DEBUG is not set
|
||||||
# CONFIG_SAMPLES is not set
|
# CONFIG_SAMPLES is not set
|
||||||
CONFIG_HAVE_ARCH_KGDB=y
|
CONFIG_HAVE_ARCH_KGDB=y
|
||||||
# CONFIG_KGDB is not set
|
# CONFIG_KGDB is not set
|
||||||
# CONFIG_DEBUG_STACKOVERFLOW is not set
|
# CONFIG_DEBUG_STACKOVERFLOW is not set
|
||||||
# CONFIG_DEBUG_STACK_USAGE is not set
|
# CONFIG_DEBUG_STACK_USAGE is not set
|
||||||
|
# CONFIG_KGDB_TESTCASE is not set
|
||||||
CONFIG_DEBUG_VERBOSE=y
|
CONFIG_DEBUG_VERBOSE=y
|
||||||
CONFIG_DEBUG_MMRS=y
|
CONFIG_DEBUG_MMRS=y
|
||||||
# CONFIG_DEBUG_HWERR is not set
|
# CONFIG_DEBUG_HWERR is not set
|
||||||
|
@ -1100,6 +1154,7 @@ CONFIG_CRYPTO=y
|
||||||
#
|
#
|
||||||
# CONFIG_CRYPTO_FIPS is not set
|
# CONFIG_CRYPTO_FIPS is not set
|
||||||
# CONFIG_CRYPTO_MANAGER is not set
|
# CONFIG_CRYPTO_MANAGER is not set
|
||||||
|
# CONFIG_CRYPTO_MANAGER2 is not set
|
||||||
# CONFIG_CRYPTO_GF128MUL is not set
|
# CONFIG_CRYPTO_GF128MUL is not set
|
||||||
# CONFIG_CRYPTO_NULL is not set
|
# CONFIG_CRYPTO_NULL is not set
|
||||||
# CONFIG_CRYPTO_CRYPTD is not set
|
# CONFIG_CRYPTO_CRYPTD is not set
|
||||||
|
|
|
@ -327,8 +327,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -290,8 +290,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -290,8 +290,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -298,8 +298,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
@ -568,15 +568,7 @@ CONFIG_MTD_PHYSMAP_BANKWIDTH=2
|
||||||
# CONFIG_MTD_DOC2000 is not set
|
# CONFIG_MTD_DOC2000 is not set
|
||||||
# CONFIG_MTD_DOC2001 is not set
|
# CONFIG_MTD_DOC2001 is not set
|
||||||
# CONFIG_MTD_DOC2001PLUS is not set
|
# CONFIG_MTD_DOC2001PLUS is not set
|
||||||
CONFIG_MTD_NAND=m
|
# CONFIG_MTD_NAND is not set
|
||||||
# CONFIG_MTD_NAND_VERIFY_WRITE is not set
|
|
||||||
# CONFIG_MTD_NAND_ECC_SMC is not set
|
|
||||||
# CONFIG_MTD_NAND_MUSEUM_IDS is not set
|
|
||||||
# CONFIG_MTD_NAND_BFIN is not set
|
|
||||||
CONFIG_MTD_NAND_IDS=m
|
|
||||||
# CONFIG_MTD_NAND_DISKONCHIP is not set
|
|
||||||
# CONFIG_MTD_NAND_NANDSIM is not set
|
|
||||||
CONFIG_MTD_NAND_PLATFORM=m
|
|
||||||
# CONFIG_MTD_ONENAND is not set
|
# CONFIG_MTD_ONENAND is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -306,8 +306,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -361,8 +361,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_BFIN_L2_CACHEABLE is not set
|
# CONFIG_BFIN_L2_CACHEABLE is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
|
@ -680,7 +680,7 @@ CONFIG_SCSI=y
|
||||||
CONFIG_SCSI_DMA=y
|
CONFIG_SCSI_DMA=y
|
||||||
# CONFIG_SCSI_TGT is not set
|
# CONFIG_SCSI_TGT is not set
|
||||||
# CONFIG_SCSI_NETLINK is not set
|
# CONFIG_SCSI_NETLINK is not set
|
||||||
CONFIG_SCSI_PROC_FS=y
|
# CONFIG_SCSI_PROC_FS is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# SCSI support type (disk, tape, CD-ROM)
|
# SCSI support type (disk, tape, CD-ROM)
|
||||||
|
|
|
@ -329,8 +329,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_BFIN_L2_CACHEABLE is not set
|
# CONFIG_BFIN_L2_CACHEABLE is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
|
|
|
@ -288,8 +288,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -332,8 +332,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -336,8 +336,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
CONFIG_L1_MAX_PIECE=16
|
CONFIG_L1_MAX_PIECE=16
|
||||||
# CONFIG_MPU is not set
|
# CONFIG_MPU is not set
|
||||||
|
|
||||||
|
@ -595,7 +595,7 @@ CONFIG_SCSI=y
|
||||||
CONFIG_SCSI_DMA=y
|
CONFIG_SCSI_DMA=y
|
||||||
# CONFIG_SCSI_TGT is not set
|
# CONFIG_SCSI_TGT is not set
|
||||||
# CONFIG_SCSI_NETLINK is not set
|
# CONFIG_SCSI_NETLINK is not set
|
||||||
CONFIG_SCSI_PROC_FS=y
|
# CONFIG_SCSI_PROC_FS is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# SCSI support type (disk, tape, CD-ROM)
|
# SCSI support type (disk, tape, CD-ROM)
|
||||||
|
|
|
@ -612,7 +612,7 @@ CONFIG_BLK_DEV_RAM_BLOCKSIZE=1024
|
||||||
CONFIG_SCSI=y
|
CONFIG_SCSI=y
|
||||||
# CONFIG_SCSI_TGT is not set
|
# CONFIG_SCSI_TGT is not set
|
||||||
# CONFIG_SCSI_NETLINK is not set
|
# CONFIG_SCSI_NETLINK is not set
|
||||||
CONFIG_SCSI_PROC_FS=y
|
# CONFIG_SCSI_PROC_FS is not set
|
||||||
|
|
||||||
#
|
#
|
||||||
# SCSI support type (disk, tape, CD-ROM)
|
# SCSI support type (disk, tape, CD-ROM)
|
||||||
|
|
|
@ -282,8 +282,8 @@ CONFIG_BFIN_ICACHE=y
|
||||||
CONFIG_BFIN_DCACHE=y
|
CONFIG_BFIN_DCACHE=y
|
||||||
# CONFIG_BFIN_DCACHE_BANKA is not set
|
# CONFIG_BFIN_DCACHE_BANKA is not set
|
||||||
# CONFIG_BFIN_ICACHE_LOCK is not set
|
# CONFIG_BFIN_ICACHE_LOCK is not set
|
||||||
# CONFIG_BFIN_WB is not set
|
CONFIG_BFIN_WB=y
|
||||||
CONFIG_BFIN_WT=y
|
# CONFIG_BFIN_WT is not set
|
||||||
CONFIG_L1_MAX_PIECE=16
|
CONFIG_L1_MAX_PIECE=16
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
include include/asm-generic/Kbuild.asm
|
include include/asm-generic/Kbuild.asm
|
||||||
|
|
||||||
|
unifdef-y += bfin_sport.h
|
||||||
unifdef-y += fixed_code.h
|
unifdef-y += fixed_code.h
|
||||||
|
|
|
@ -1,30 +1,9 @@
|
||||||
/*
|
/*
|
||||||
* File: include/asm-blackfin/bfin_sport.h
|
* bfin_sport.h - userspace header for bfin sport driver
|
||||||
* Based on:
|
|
||||||
* Author: Roy Huang (roy.huang@analog.com)
|
|
||||||
*
|
*
|
||||||
* Created: Thu Aug. 24 2006
|
* Copyright 2004-2008 Analog Devices Inc.
|
||||||
* Description:
|
|
||||||
*
|
*
|
||||||
* Modified:
|
* Licensed under the GPL-2 or later.
|
||||||
* Copyright 2004-2006 Analog Devices Inc.
|
|
||||||
*
|
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, see the file COPYING, or write
|
|
||||||
* to the Free Software Foundation, Inc.,
|
|
||||||
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef __BFIN_SPORT_H__
|
#ifndef __BFIN_SPORT_H__
|
||||||
|
@ -42,11 +21,10 @@
|
||||||
#define NORM_FORMAT 0x0
|
#define NORM_FORMAT 0x0
|
||||||
#define ALAW_FORMAT 0x2
|
#define ALAW_FORMAT 0x2
|
||||||
#define ULAW_FORMAT 0x3
|
#define ULAW_FORMAT 0x3
|
||||||
struct sport_register;
|
|
||||||
|
|
||||||
/* Function driver which use sport must initialize the structure */
|
/* Function driver which use sport must initialize the structure */
|
||||||
struct sport_config {
|
struct sport_config {
|
||||||
/*TDM (multichannels), I2S or other mode */
|
/* TDM (multichannels), I2S or other mode */
|
||||||
unsigned int mode:3;
|
unsigned int mode:3;
|
||||||
|
|
||||||
/* if TDM mode is selected, channels must be set */
|
/* if TDM mode is selected, channels must be set */
|
||||||
|
@ -72,12 +50,18 @@ struct sport_config {
|
||||||
int serial_clk;
|
int serial_clk;
|
||||||
int fsync_clk;
|
int fsync_clk;
|
||||||
|
|
||||||
unsigned int data_format:2; /*Normal, u-law or a-law */
|
unsigned int data_format:2; /* Normal, u-law or a-law */
|
||||||
|
|
||||||
int word_len; /* How length of the word in bits, 3-32 bits */
|
int word_len; /* How length of the word in bits, 3-32 bits */
|
||||||
int dma_enabled;
|
int dma_enabled;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* Userspace interface */
|
||||||
|
#define SPORT_IOC_MAGIC 'P'
|
||||||
|
#define SPORT_IOC_CONFIG _IOWR('P', 0x01, struct sport_config)
|
||||||
|
|
||||||
|
#ifdef __KERNEL__
|
||||||
|
|
||||||
struct sport_register {
|
struct sport_register {
|
||||||
unsigned short tcr1;
|
unsigned short tcr1;
|
||||||
unsigned short reserved0;
|
unsigned short reserved0;
|
||||||
|
@ -117,9 +101,6 @@ struct sport_register {
|
||||||
unsigned long mrcs3;
|
unsigned long mrcs3;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define SPORT_IOC_MAGIC 'P'
|
|
||||||
#define SPORT_IOC_CONFIG _IOWR('P', 0x01, struct sport_config)
|
|
||||||
|
|
||||||
struct sport_dev {
|
struct sport_dev {
|
||||||
struct cdev cdev; /* Char device structure */
|
struct cdev cdev; /* Char device structure */
|
||||||
|
|
||||||
|
@ -149,6 +130,8 @@ struct sport_dev {
|
||||||
struct sport_config config;
|
struct sport_config config;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
#define SPORT_TCR1 0
|
#define SPORT_TCR1 0
|
||||||
#define SPORT_TCR2 1
|
#define SPORT_TCR2 1
|
||||||
#define SPORT_TCLKDIV 2
|
#define SPORT_TCLKDIV 2
|
||||||
|
@ -169,4 +152,4 @@ struct sport_dev {
|
||||||
#define SPORT_MRCS2 22
|
#define SPORT_MRCS2 22
|
||||||
#define SPORT_MRCS3 23
|
#define SPORT_MRCS3 23
|
||||||
|
|
||||||
#endif /*__BFIN_SPORT_H__*/
|
#endif
|
||||||
|
|
|
@ -35,9 +35,9 @@
|
||||||
#include <asm/atomic.h>
|
#include <asm/atomic.h>
|
||||||
#include <asm/traps.h>
|
#include <asm/traps.h>
|
||||||
|
|
||||||
#define IPIPE_ARCH_STRING "1.8-00"
|
#define IPIPE_ARCH_STRING "1.9-00"
|
||||||
#define IPIPE_MAJOR_NUMBER 1
|
#define IPIPE_MAJOR_NUMBER 1
|
||||||
#define IPIPE_MINOR_NUMBER 8
|
#define IPIPE_MINOR_NUMBER 9
|
||||||
#define IPIPE_PATCH_NUMBER 0
|
#define IPIPE_PATCH_NUMBER 0
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
|
@ -83,9 +83,9 @@ struct ipipe_sysinfo {
|
||||||
"%2 = CYCLES2\n" \
|
"%2 = CYCLES2\n" \
|
||||||
"CC = %2 == %0\n" \
|
"CC = %2 == %0\n" \
|
||||||
"if ! CC jump 1b\n" \
|
"if ! CC jump 1b\n" \
|
||||||
: "=r" (((unsigned long *)&t)[1]), \
|
: "=d,a" (((unsigned long *)&t)[1]), \
|
||||||
"=r" (((unsigned long *)&t)[0]), \
|
"=d,a" (((unsigned long *)&t)[0]), \
|
||||||
"=r" (__cy2) \
|
"=d,a" (__cy2) \
|
||||||
: /*no input*/ : "CC"); \
|
: /*no input*/ : "CC"); \
|
||||||
t; \
|
t; \
|
||||||
})
|
})
|
||||||
|
@ -118,35 +118,40 @@ void __ipipe_disable_irqdesc(struct ipipe_domain *ipd,
|
||||||
|
|
||||||
#define __ipipe_disable_irq(irq) (irq_desc[irq].chip->mask(irq))
|
#define __ipipe_disable_irq(irq) (irq_desc[irq].chip->mask(irq))
|
||||||
|
|
||||||
#define __ipipe_lock_root() \
|
static inline int __ipipe_check_tickdev(const char *devname)
|
||||||
set_bit(IPIPE_ROOTLOCK_FLAG, &ipipe_root_domain->flags)
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
#define __ipipe_unlock_root() \
|
static inline void __ipipe_lock_root(void)
|
||||||
clear_bit(IPIPE_ROOTLOCK_FLAG, &ipipe_root_domain->flags)
|
{
|
||||||
|
set_bit(IPIPE_SYNCDEFER_FLAG, &ipipe_root_cpudom_var(status));
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void __ipipe_unlock_root(void)
|
||||||
|
{
|
||||||
|
clear_bit(IPIPE_SYNCDEFER_FLAG, &ipipe_root_cpudom_var(status));
|
||||||
|
}
|
||||||
|
|
||||||
void __ipipe_enable_pipeline(void);
|
void __ipipe_enable_pipeline(void);
|
||||||
|
|
||||||
#define __ipipe_hook_critical_ipi(ipd) do { } while (0)
|
#define __ipipe_hook_critical_ipi(ipd) do { } while (0)
|
||||||
|
|
||||||
#define __ipipe_sync_pipeline(syncmask) \
|
#define __ipipe_sync_pipeline ___ipipe_sync_pipeline
|
||||||
do { \
|
void ___ipipe_sync_pipeline(unsigned long syncmask);
|
||||||
struct ipipe_domain *ipd = ipipe_current_domain; \
|
|
||||||
if (likely(ipd != ipipe_root_domain || !test_bit(IPIPE_ROOTLOCK_FLAG, &ipd->flags))) \
|
|
||||||
__ipipe_sync_stage(syncmask); \
|
|
||||||
} while (0)
|
|
||||||
|
|
||||||
void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs);
|
void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs);
|
||||||
|
|
||||||
int __ipipe_get_irq_priority(unsigned irq);
|
int __ipipe_get_irq_priority(unsigned irq);
|
||||||
|
|
||||||
int __ipipe_get_irqthread_priority(unsigned irq);
|
|
||||||
|
|
||||||
void __ipipe_stall_root_raw(void);
|
void __ipipe_stall_root_raw(void);
|
||||||
|
|
||||||
void __ipipe_unstall_root_raw(void);
|
void __ipipe_unstall_root_raw(void);
|
||||||
|
|
||||||
void __ipipe_serial_debug(const char *fmt, ...);
|
void __ipipe_serial_debug(const char *fmt, ...);
|
||||||
|
|
||||||
|
asmlinkage void __ipipe_call_irqtail(unsigned long addr);
|
||||||
|
|
||||||
DECLARE_PER_CPU(struct pt_regs, __ipipe_tick_regs);
|
DECLARE_PER_CPU(struct pt_regs, __ipipe_tick_regs);
|
||||||
|
|
||||||
extern unsigned long __ipipe_core_clock;
|
extern unsigned long __ipipe_core_clock;
|
||||||
|
@ -162,42 +167,25 @@ static inline unsigned long __ipipe_ffnz(unsigned long ul)
|
||||||
|
|
||||||
#define __ipipe_run_irqtail() /* Must be a macro */ \
|
#define __ipipe_run_irqtail() /* Must be a macro */ \
|
||||||
do { \
|
do { \
|
||||||
asmlinkage void __ipipe_call_irqtail(void); \
|
|
||||||
unsigned long __pending; \
|
unsigned long __pending; \
|
||||||
CSYNC(); \
|
CSYNC(); \
|
||||||
__pending = bfin_read_IPEND(); \
|
__pending = bfin_read_IPEND(); \
|
||||||
if (__pending & 0x8000) { \
|
if (__pending & 0x8000) { \
|
||||||
__pending &= ~0x8010; \
|
__pending &= ~0x8010; \
|
||||||
if (__pending && (__pending & (__pending - 1)) == 0) \
|
if (__pending && (__pending & (__pending - 1)) == 0) \
|
||||||
__ipipe_call_irqtail(); \
|
__ipipe_call_irqtail(__ipipe_irq_tail_hook); \
|
||||||
} \
|
} \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define __ipipe_run_isr(ipd, irq) \
|
#define __ipipe_run_isr(ipd, irq) \
|
||||||
do { \
|
do { \
|
||||||
if (ipd == ipipe_root_domain) { \
|
if (ipd == ipipe_root_domain) { \
|
||||||
/* \
|
local_irq_enable_hw(); \
|
||||||
* Note: the I-pipe implements a threaded interrupt model on \
|
if (ipipe_virtual_irq_p(irq)) \
|
||||||
* this arch for Linux external IRQs. The interrupt handler we \
|
|
||||||
* call here only wakes up the associated IRQ thread. \
|
|
||||||
*/ \
|
|
||||||
if (ipipe_virtual_irq_p(irq)) { \
|
|
||||||
/* No irqtail here; virtual interrupts have no effect \
|
|
||||||
on IPEND so there is no need for processing \
|
|
||||||
deferral. */ \
|
|
||||||
local_irq_enable_nohead(ipd); \
|
|
||||||
ipd->irqs[irq].handler(irq, ipd->irqs[irq].cookie); \
|
ipd->irqs[irq].handler(irq, ipd->irqs[irq].cookie); \
|
||||||
local_irq_disable_nohead(ipd); \
|
else \
|
||||||
} else \
|
|
||||||
/* \
|
|
||||||
* No need to run the irqtail here either; \
|
|
||||||
* we can't be preempted by hw IRQs, so \
|
|
||||||
* non-Linux IRQs cannot stack over the short \
|
|
||||||
* thread wakeup code. Which in turn means \
|
|
||||||
* that no irqtail condition could be pending \
|
|
||||||
* for domains above Linux in the pipeline. \
|
|
||||||
*/ \
|
|
||||||
ipd->irqs[irq].handler(irq, &__raw_get_cpu_var(__ipipe_tick_regs)); \
|
ipd->irqs[irq].handler(irq, &__raw_get_cpu_var(__ipipe_tick_regs)); \
|
||||||
|
local_irq_disable_hw(); \
|
||||||
} else { \
|
} else { \
|
||||||
__clear_bit(IPIPE_SYNC_FLAG, &ipipe_cpudom_var(ipd, status)); \
|
__clear_bit(IPIPE_SYNC_FLAG, &ipipe_cpudom_var(ipd, status)); \
|
||||||
local_irq_enable_nohead(ipd); \
|
local_irq_enable_nohead(ipd); \
|
||||||
|
@ -217,42 +205,24 @@ void ipipe_init_irq_threads(void);
|
||||||
|
|
||||||
int ipipe_start_irq_thread(unsigned irq, struct irq_desc *desc);
|
int ipipe_start_irq_thread(unsigned irq, struct irq_desc *desc);
|
||||||
|
|
||||||
#define IS_SYSIRQ(irq) ((irq) > IRQ_CORETMR && (irq) <= SYS_IRQS)
|
#ifdef CONFIG_GENERIC_CLOCKEVENTS
|
||||||
#define IS_GPIOIRQ(irq) ((irq) >= GPIO_IRQ_BASE && (irq) < NR_IRQS)
|
#define IRQ_SYSTMR IRQ_CORETMR
|
||||||
|
#define IRQ_PRIOTMR IRQ_CORETMR
|
||||||
|
#else
|
||||||
#define IRQ_SYSTMR IRQ_TIMER0
|
#define IRQ_SYSTMR IRQ_TIMER0
|
||||||
#define IRQ_PRIOTMR CONFIG_IRQ_TIMER0
|
#define IRQ_PRIOTMR CONFIG_IRQ_TIMER0
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_BF531) || defined(CONFIG_BF532) || defined(CONFIG_BF533)
|
#ifdef CONFIG_BF561
|
||||||
#define PRIO_GPIODEMUX(irq) CONFIG_PFA
|
|
||||||
#elif defined(CONFIG_BF534) || defined(CONFIG_BF536) || defined(CONFIG_BF537)
|
|
||||||
#define PRIO_GPIODEMUX(irq) CONFIG_IRQ_PROG_INTA
|
|
||||||
#elif defined(CONFIG_BF52x)
|
|
||||||
#define PRIO_GPIODEMUX(irq) ((irq) == IRQ_PORTF_INTA ? CONFIG_IRQ_PORTF_INTA : \
|
|
||||||
(irq) == IRQ_PORTG_INTA ? CONFIG_IRQ_PORTG_INTA : \
|
|
||||||
(irq) == IRQ_PORTH_INTA ? CONFIG_IRQ_PORTH_INTA : \
|
|
||||||
-1)
|
|
||||||
#elif defined(CONFIG_BF561)
|
|
||||||
#define PRIO_GPIODEMUX(irq) ((irq) == IRQ_PROG0_INTA ? CONFIG_IRQ_PROG0_INTA : \
|
|
||||||
(irq) == IRQ_PROG1_INTA ? CONFIG_IRQ_PROG1_INTA : \
|
|
||||||
(irq) == IRQ_PROG2_INTA ? CONFIG_IRQ_PROG2_INTA : \
|
|
||||||
-1)
|
|
||||||
#define bfin_write_TIMER_DISABLE(val) bfin_write_TMRS8_DISABLE(val)
|
#define bfin_write_TIMER_DISABLE(val) bfin_write_TMRS8_DISABLE(val)
|
||||||
#define bfin_write_TIMER_ENABLE(val) bfin_write_TMRS8_ENABLE(val)
|
#define bfin_write_TIMER_ENABLE(val) bfin_write_TMRS8_ENABLE(val)
|
||||||
#define bfin_write_TIMER_STATUS(val) bfin_write_TMRS8_STATUS(val)
|
#define bfin_write_TIMER_STATUS(val) bfin_write_TMRS8_STATUS(val)
|
||||||
#define bfin_read_TIMER_STATUS() bfin_read_TMRS8_STATUS()
|
#define bfin_read_TIMER_STATUS() bfin_read_TMRS8_STATUS()
|
||||||
#elif defined(CONFIG_BF54x)
|
#elif defined(CONFIG_BF54x)
|
||||||
#define PRIO_GPIODEMUX(irq) ((irq) == IRQ_PINT0 ? CONFIG_IRQ_PINT0 : \
|
|
||||||
(irq) == IRQ_PINT1 ? CONFIG_IRQ_PINT1 : \
|
|
||||||
(irq) == IRQ_PINT2 ? CONFIG_IRQ_PINT2 : \
|
|
||||||
(irq) == IRQ_PINT3 ? CONFIG_IRQ_PINT3 : \
|
|
||||||
-1)
|
|
||||||
#define bfin_write_TIMER_DISABLE(val) bfin_write_TIMER_DISABLE0(val)
|
#define bfin_write_TIMER_DISABLE(val) bfin_write_TIMER_DISABLE0(val)
|
||||||
#define bfin_write_TIMER_ENABLE(val) bfin_write_TIMER_ENABLE0(val)
|
#define bfin_write_TIMER_ENABLE(val) bfin_write_TIMER_ENABLE0(val)
|
||||||
#define bfin_write_TIMER_STATUS(val) bfin_write_TIMER_STATUS0(val)
|
#define bfin_write_TIMER_STATUS(val) bfin_write_TIMER_STATUS0(val)
|
||||||
#define bfin_read_TIMER_STATUS(val) bfin_read_TIMER_STATUS0(val)
|
#define bfin_read_TIMER_STATUS(val) bfin_read_TIMER_STATUS0(val)
|
||||||
#else
|
|
||||||
# error "no PRIO_GPIODEMUX() for this part"
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define __ipipe_root_tick_p(regs) ((regs->ipend & 0x10) != 0)
|
#define __ipipe_root_tick_p(regs) ((regs->ipend & 0x10) != 0)
|
||||||
|
@ -275,4 +245,6 @@ int ipipe_start_irq_thread(unsigned irq, struct irq_desc *desc);
|
||||||
|
|
||||||
#endif /* !CONFIG_IPIPE */
|
#endif /* !CONFIG_IPIPE */
|
||||||
|
|
||||||
|
#define ipipe_update_tick_evtdev(evtdev) do { } while (0)
|
||||||
|
|
||||||
#endif /* !__ASM_BLACKFIN_IPIPE_H */
|
#endif /* !__ASM_BLACKFIN_IPIPE_H */
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
/* -*- linux-c -*-
|
/* -*- linux-c -*-
|
||||||
* include/asm-blackfin/_baseipipe.h
|
* include/asm-blackfin/ipipe_base.h
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007 Philippe Gerum.
|
* Copyright (C) 2007 Philippe Gerum.
|
||||||
*
|
*
|
||||||
|
@ -27,8 +27,9 @@
|
||||||
#define IPIPE_NR_XIRQS NR_IRQS
|
#define IPIPE_NR_XIRQS NR_IRQS
|
||||||
#define IPIPE_IRQ_ISHIFT 5 /* 2^5 for 32bits arch. */
|
#define IPIPE_IRQ_ISHIFT 5 /* 2^5 for 32bits arch. */
|
||||||
|
|
||||||
/* Blackfin-specific, global domain flags */
|
/* Blackfin-specific, per-cpu pipeline status */
|
||||||
#define IPIPE_ROOTLOCK_FLAG 1 /* Lock pipeline for root */
|
#define IPIPE_SYNCDEFER_FLAG 15
|
||||||
|
#define IPIPE_SYNCDEFER_MASK (1L << IPIPE_SYNCDEFER_MASK)
|
||||||
|
|
||||||
/* Blackfin traps -- i.e. exception vector numbers */
|
/* Blackfin traps -- i.e. exception vector numbers */
|
||||||
#define IPIPE_NR_FAULTS 52 /* We leave a gap after VEC_ILL_RES. */
|
#define IPIPE_NR_FAULTS 52 /* We leave a gap after VEC_ILL_RES. */
|
||||||
|
@ -48,11 +49,6 @@
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
#include <linux/bitops.h>
|
|
||||||
|
|
||||||
extern int test_bit(int nr, const void *addr);
|
|
||||||
|
|
||||||
|
|
||||||
extern unsigned long __ipipe_root_status; /* Alias to ipipe_root_cpudom_var(status) */
|
extern unsigned long __ipipe_root_status; /* Alias to ipipe_root_cpudom_var(status) */
|
||||||
|
|
||||||
static inline void __ipipe_stall_root(void)
|
static inline void __ipipe_stall_root(void)
|
||||||
|
|
|
@ -61,20 +61,38 @@ void __ipipe_restore_root(unsigned long flags);
|
||||||
#define raw_irqs_disabled_flags(flags) (!irqs_enabled_from_flags_hw(flags))
|
#define raw_irqs_disabled_flags(flags) (!irqs_enabled_from_flags_hw(flags))
|
||||||
#define local_test_iflag_hw(x) irqs_enabled_from_flags_hw(x)
|
#define local_test_iflag_hw(x) irqs_enabled_from_flags_hw(x)
|
||||||
|
|
||||||
#define local_save_flags(x) \
|
#define local_save_flags(x) \
|
||||||
do { \
|
do { \
|
||||||
(x) = __ipipe_test_root() ? \
|
(x) = __ipipe_test_root() ? \
|
||||||
__all_masked_irq_flags : bfin_irq_flags; \
|
__all_masked_irq_flags : bfin_irq_flags; \
|
||||||
|
barrier(); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define local_irq_save(x) \
|
#define local_irq_save(x) \
|
||||||
do { \
|
do { \
|
||||||
(x) = __ipipe_test_and_stall_root(); \
|
(x) = __ipipe_test_and_stall_root() ? \
|
||||||
|
__all_masked_irq_flags : bfin_irq_flags; \
|
||||||
|
barrier(); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define local_irq_restore(x) __ipipe_restore_root(x)
|
static inline void local_irq_restore(unsigned long x)
|
||||||
#define local_irq_disable() __ipipe_stall_root()
|
{
|
||||||
#define local_irq_enable() __ipipe_unstall_root()
|
barrier();
|
||||||
|
__ipipe_restore_root(x == __all_masked_irq_flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
#define local_irq_disable() \
|
||||||
|
do { \
|
||||||
|
__ipipe_stall_root(); \
|
||||||
|
barrier(); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
|
static inline void local_irq_enable(void)
|
||||||
|
{
|
||||||
|
barrier();
|
||||||
|
__ipipe_unstall_root();
|
||||||
|
}
|
||||||
|
|
||||||
#define irqs_disabled() __ipipe_test_root()
|
#define irqs_disabled() __ipipe_test_root()
|
||||||
|
|
||||||
#define local_save_flags_hw(x) \
|
#define local_save_flags_hw(x) \
|
||||||
|
|
|
@ -122,6 +122,7 @@ static inline struct thread_info *current_thread_info(void)
|
||||||
#define TIF_MEMDIE 4
|
#define TIF_MEMDIE 4
|
||||||
#define TIF_RESTORE_SIGMASK 5 /* restore signal mask in do_signal() */
|
#define TIF_RESTORE_SIGMASK 5 /* restore signal mask in do_signal() */
|
||||||
#define TIF_FREEZE 6 /* is freezing for suspend */
|
#define TIF_FREEZE 6 /* is freezing for suspend */
|
||||||
|
#define TIF_IRQ_SYNC 7 /* sync pipeline stage */
|
||||||
|
|
||||||
/* as above, but as bit values */
|
/* as above, but as bit values */
|
||||||
#define _TIF_SYSCALL_TRACE (1<<TIF_SYSCALL_TRACE)
|
#define _TIF_SYSCALL_TRACE (1<<TIF_SYSCALL_TRACE)
|
||||||
|
@ -130,6 +131,7 @@ static inline struct thread_info *current_thread_info(void)
|
||||||
#define _TIF_POLLING_NRFLAG (1<<TIF_POLLING_NRFLAG)
|
#define _TIF_POLLING_NRFLAG (1<<TIF_POLLING_NRFLAG)
|
||||||
#define _TIF_RESTORE_SIGMASK (1<<TIF_RESTORE_SIGMASK)
|
#define _TIF_RESTORE_SIGMASK (1<<TIF_RESTORE_SIGMASK)
|
||||||
#define _TIF_FREEZE (1<<TIF_FREEZE)
|
#define _TIF_FREEZE (1<<TIF_FREEZE)
|
||||||
|
#define _TIF_IRQ_SYNC (1<<TIF_IRQ_SYNC)
|
||||||
|
|
||||||
#define _TIF_WORK_MASK 0x0000FFFE /* work to do on interrupt/exception return */
|
#define _TIF_WORK_MASK 0x0000FFFE /* work to do on interrupt/exception return */
|
||||||
|
|
||||||
|
|
|
@ -15,13 +15,15 @@ else
|
||||||
obj-y += time.o
|
obj-y += time.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
CFLAGS_kgdb_test.o := -mlong-calls -O0
|
|
||||||
|
|
||||||
obj-$(CONFIG_IPIPE) += ipipe.o
|
obj-$(CONFIG_IPIPE) += ipipe.o
|
||||||
obj-$(CONFIG_IPIPE_TRACE_MCOUNT) += mcount.o
|
obj-$(CONFIG_IPIPE_TRACE_MCOUNT) += mcount.o
|
||||||
obj-$(CONFIG_BFIN_GPTIMERS) += gptimers.o
|
obj-$(CONFIG_BFIN_GPTIMERS) += gptimers.o
|
||||||
obj-$(CONFIG_CPLB_INFO) += cplbinfo.o
|
obj-$(CONFIG_CPLB_INFO) += cplbinfo.o
|
||||||
obj-$(CONFIG_MODULES) += module.o
|
obj-$(CONFIG_MODULES) += module.o
|
||||||
obj-$(CONFIG_KGDB) += kgdb.o
|
obj-$(CONFIG_KGDB) += kgdb.o
|
||||||
obj-$(CONFIG_KGDB_TESTCASE) += kgdb_test.o
|
obj-$(CONFIG_KGDB_TESTS) += kgdb_test.o
|
||||||
obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
|
obj-$(CONFIG_EARLY_PRINTK) += early_printk.o
|
||||||
|
|
||||||
|
# the kgdb test puts code into L2 and without linker
|
||||||
|
# relaxation, we need to force long calls to/from it
|
||||||
|
CFLAGS_kgdb_test.o := -mlong-calls -O0
|
||||||
|
|
|
@ -53,9 +53,13 @@ void __init generate_cplb_tables_cpu(unsigned int cpu)
|
||||||
|
|
||||||
i_d = i_i = 0;
|
i_d = i_i = 0;
|
||||||
|
|
||||||
|
#ifdef CONFIG_DEBUG_HUNT_FOR_ZERO
|
||||||
/* Set up the zero page. */
|
/* Set up the zero page. */
|
||||||
d_tbl[i_d].addr = 0;
|
d_tbl[i_d].addr = 0;
|
||||||
d_tbl[i_d++].data = SDRAM_OOPS | PAGE_SIZE_1KB;
|
d_tbl[i_d++].data = SDRAM_OOPS | PAGE_SIZE_1KB;
|
||||||
|
i_tbl[i_i].addr = 0;
|
||||||
|
i_tbl[i_i++].data = SDRAM_OOPS | PAGE_SIZE_1KB;
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Cover kernel memory with 4M pages. */
|
/* Cover kernel memory with 4M pages. */
|
||||||
addr = 0;
|
addr = 0;
|
||||||
|
|
|
@ -35,14 +35,8 @@
|
||||||
#include <asm/atomic.h>
|
#include <asm/atomic.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
|
||||||
static int create_irq_threads;
|
|
||||||
|
|
||||||
DEFINE_PER_CPU(struct pt_regs, __ipipe_tick_regs);
|
DEFINE_PER_CPU(struct pt_regs, __ipipe_tick_regs);
|
||||||
|
|
||||||
static DEFINE_PER_CPU(unsigned long, pending_irqthread_mask);
|
|
||||||
|
|
||||||
static DEFINE_PER_CPU(int [IVG13 + 1], pending_irq_count);
|
|
||||||
|
|
||||||
asmlinkage void asm_do_IRQ(unsigned int irq, struct pt_regs *regs);
|
asmlinkage void asm_do_IRQ(unsigned int irq, struct pt_regs *regs);
|
||||||
|
|
||||||
static void __ipipe_no_irqtail(void);
|
static void __ipipe_no_irqtail(void);
|
||||||
|
@ -93,6 +87,7 @@ void __ipipe_enable_pipeline(void)
|
||||||
*/
|
*/
|
||||||
void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs)
|
void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
|
struct ipipe_percpu_domain_data *p = ipipe_root_cpudom_ptr();
|
||||||
struct ipipe_domain *this_domain, *next_domain;
|
struct ipipe_domain *this_domain, *next_domain;
|
||||||
struct list_head *head, *pos;
|
struct list_head *head, *pos;
|
||||||
int m_ack, s = -1;
|
int m_ack, s = -1;
|
||||||
|
@ -104,7 +99,6 @@ void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs)
|
||||||
* interrupt.
|
* interrupt.
|
||||||
*/
|
*/
|
||||||
m_ack = (regs == NULL || irq == IRQ_SYSTMR || irq == IRQ_CORETMR);
|
m_ack = (regs == NULL || irq == IRQ_SYSTMR || irq == IRQ_CORETMR);
|
||||||
|
|
||||||
this_domain = ipipe_current_domain;
|
this_domain = ipipe_current_domain;
|
||||||
|
|
||||||
if (unlikely(test_bit(IPIPE_STICKY_FLAG, &this_domain->irqs[irq].control)))
|
if (unlikely(test_bit(IPIPE_STICKY_FLAG, &this_domain->irqs[irq].control)))
|
||||||
|
@ -114,49 +108,28 @@ void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs)
|
||||||
next_domain = list_entry(head, struct ipipe_domain, p_link);
|
next_domain = list_entry(head, struct ipipe_domain, p_link);
|
||||||
if (likely(test_bit(IPIPE_WIRED_FLAG, &next_domain->irqs[irq].control))) {
|
if (likely(test_bit(IPIPE_WIRED_FLAG, &next_domain->irqs[irq].control))) {
|
||||||
if (!m_ack && next_domain->irqs[irq].acknowledge != NULL)
|
if (!m_ack && next_domain->irqs[irq].acknowledge != NULL)
|
||||||
next_domain->irqs[irq].acknowledge(irq, irq_desc + irq);
|
next_domain->irqs[irq].acknowledge(irq, irq_to_desc(irq));
|
||||||
if (test_bit(IPIPE_ROOTLOCK_FLAG, &ipipe_root_domain->flags))
|
if (test_bit(IPIPE_SYNCDEFER_FLAG, &p->status))
|
||||||
s = __test_and_set_bit(IPIPE_STALL_FLAG,
|
s = __test_and_set_bit(IPIPE_STALL_FLAG, &p->status);
|
||||||
&ipipe_root_cpudom_var(status));
|
|
||||||
__ipipe_dispatch_wired(next_domain, irq);
|
__ipipe_dispatch_wired(next_domain, irq);
|
||||||
goto finalize;
|
goto out;
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Ack the interrupt. */
|
/* Ack the interrupt. */
|
||||||
|
|
||||||
pos = head;
|
pos = head;
|
||||||
|
|
||||||
while (pos != &__ipipe_pipeline) {
|
while (pos != &__ipipe_pipeline) {
|
||||||
next_domain = list_entry(pos, struct ipipe_domain, p_link);
|
next_domain = list_entry(pos, struct ipipe_domain, p_link);
|
||||||
/*
|
|
||||||
* For each domain handling the incoming IRQ, mark it
|
|
||||||
* as pending in its log.
|
|
||||||
*/
|
|
||||||
if (test_bit(IPIPE_HANDLE_FLAG, &next_domain->irqs[irq].control)) {
|
if (test_bit(IPIPE_HANDLE_FLAG, &next_domain->irqs[irq].control)) {
|
||||||
/*
|
|
||||||
* Domains that handle this IRQ are polled for
|
|
||||||
* acknowledging it by decreasing priority
|
|
||||||
* order. The interrupt must be made pending
|
|
||||||
* _first_ in the domain's status flags before
|
|
||||||
* the PIC is unlocked.
|
|
||||||
*/
|
|
||||||
__ipipe_set_irq_pending(next_domain, irq);
|
__ipipe_set_irq_pending(next_domain, irq);
|
||||||
|
|
||||||
if (!m_ack && next_domain->irqs[irq].acknowledge != NULL) {
|
if (!m_ack && next_domain->irqs[irq].acknowledge != NULL) {
|
||||||
next_domain->irqs[irq].acknowledge(irq, irq_desc + irq);
|
next_domain->irqs[irq].acknowledge(irq, irq_to_desc(irq));
|
||||||
m_ack = 1;
|
m_ack = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* If the domain does not want the IRQ to be passed
|
|
||||||
* down the interrupt pipe, exit the loop now.
|
|
||||||
*/
|
|
||||||
if (!test_bit(IPIPE_PASS_FLAG, &next_domain->irqs[irq].control))
|
if (!test_bit(IPIPE_PASS_FLAG, &next_domain->irqs[irq].control))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
pos = next_domain->p_link.next;
|
pos = next_domain->p_link.next;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -166,18 +139,24 @@ void __ipipe_handle_irq(unsigned irq, struct pt_regs *regs)
|
||||||
* immediately to the current domain if the interrupt has been
|
* immediately to the current domain if the interrupt has been
|
||||||
* marked as 'sticky'. This search does not go beyond the
|
* marked as 'sticky'. This search does not go beyond the
|
||||||
* current domain in the pipeline. We also enforce the
|
* current domain in the pipeline. We also enforce the
|
||||||
* additional root stage lock (blackfin-specific). */
|
* additional root stage lock (blackfin-specific).
|
||||||
|
*/
|
||||||
|
if (test_bit(IPIPE_SYNCDEFER_FLAG, &p->status))
|
||||||
|
s = __test_and_set_bit(IPIPE_STALL_FLAG, &p->status);
|
||||||
|
|
||||||
if (test_bit(IPIPE_ROOTLOCK_FLAG, &ipipe_root_domain->flags))
|
/*
|
||||||
s = __test_and_set_bit(IPIPE_STALL_FLAG,
|
* If the interrupt preempted the head domain, then do not
|
||||||
&ipipe_root_cpudom_var(status));
|
* even try to walk the pipeline, unless an interrupt is
|
||||||
finalize:
|
* pending for it.
|
||||||
|
*/
|
||||||
|
if (test_bit(IPIPE_AHEAD_FLAG, &this_domain->flags) &&
|
||||||
|
ipipe_head_cpudom_var(irqpend_himask) == 0)
|
||||||
|
goto out;
|
||||||
|
|
||||||
__ipipe_walk_pipeline(head);
|
__ipipe_walk_pipeline(head);
|
||||||
|
out:
|
||||||
if (!s)
|
if (!s)
|
||||||
__clear_bit(IPIPE_STALL_FLAG,
|
__clear_bit(IPIPE_STALL_FLAG, &p->status);
|
||||||
&ipipe_root_cpudom_var(status));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int __ipipe_check_root(void)
|
int __ipipe_check_root(void)
|
||||||
|
@ -187,7 +166,7 @@ int __ipipe_check_root(void)
|
||||||
|
|
||||||
void __ipipe_enable_irqdesc(struct ipipe_domain *ipd, unsigned irq)
|
void __ipipe_enable_irqdesc(struct ipipe_domain *ipd, unsigned irq)
|
||||||
{
|
{
|
||||||
struct irq_desc *desc = irq_desc + irq;
|
struct irq_desc *desc = irq_to_desc(irq);
|
||||||
int prio = desc->ic_prio;
|
int prio = desc->ic_prio;
|
||||||
|
|
||||||
desc->depth = 0;
|
desc->depth = 0;
|
||||||
|
@ -199,7 +178,7 @@ EXPORT_SYMBOL(__ipipe_enable_irqdesc);
|
||||||
|
|
||||||
void __ipipe_disable_irqdesc(struct ipipe_domain *ipd, unsigned irq)
|
void __ipipe_disable_irqdesc(struct ipipe_domain *ipd, unsigned irq)
|
||||||
{
|
{
|
||||||
struct irq_desc *desc = irq_desc + irq;
|
struct irq_desc *desc = irq_to_desc(irq);
|
||||||
int prio = desc->ic_prio;
|
int prio = desc->ic_prio;
|
||||||
|
|
||||||
if (ipd != &ipipe_root &&
|
if (ipd != &ipipe_root &&
|
||||||
|
@ -236,15 +215,18 @@ int __ipipe_syscall_root(struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
/* We need to run the IRQ tail hook whenever we don't
|
/*
|
||||||
|
* We need to run the IRQ tail hook whenever we don't
|
||||||
* propagate a syscall to higher domains, because we know that
|
* propagate a syscall to higher domains, because we know that
|
||||||
* important operations might be pending there (e.g. Xenomai
|
* important operations might be pending there (e.g. Xenomai
|
||||||
* deferred rescheduling). */
|
* deferred rescheduling).
|
||||||
|
*/
|
||||||
|
|
||||||
if (!__ipipe_syscall_watched_p(current, regs->orig_p0)) {
|
if (regs->orig_p0 < NR_syscalls) {
|
||||||
void (*hook)(void) = (void (*)(void))__ipipe_irq_tail_hook;
|
void (*hook)(void) = (void (*)(void))__ipipe_irq_tail_hook;
|
||||||
hook();
|
hook();
|
||||||
return 0;
|
if ((current->flags & PF_EVNOTIFY) == 0)
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -312,112 +294,46 @@ int ipipe_trigger_irq(unsigned irq)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
|
#ifdef CONFIG_IPIPE_DEBUG
|
||||||
if (irq >= IPIPE_NR_IRQS ||
|
if (irq >= IPIPE_NR_IRQS ||
|
||||||
(ipipe_virtual_irq_p(irq)
|
(ipipe_virtual_irq_p(irq)
|
||||||
&& !test_bit(irq - IPIPE_VIRQ_BASE, &__ipipe_virtual_irq_map)))
|
&& !test_bit(irq - IPIPE_VIRQ_BASE, &__ipipe_virtual_irq_map)))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
#endif
|
||||||
|
|
||||||
local_irq_save_hw(flags);
|
local_irq_save_hw(flags);
|
||||||
|
|
||||||
__ipipe_handle_irq(irq, NULL);
|
__ipipe_handle_irq(irq, NULL);
|
||||||
|
|
||||||
local_irq_restore_hw(flags);
|
local_irq_restore_hw(flags);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Move Linux IRQ to threads. */
|
asmlinkage void __ipipe_sync_root(void)
|
||||||
|
|
||||||
static int do_irqd(void *__desc)
|
|
||||||
{
|
{
|
||||||
struct irq_desc *desc = __desc;
|
unsigned long flags;
|
||||||
unsigned irq = desc - irq_desc;
|
|
||||||
int thrprio = desc->thr_prio;
|
|
||||||
int thrmask = 1 << thrprio;
|
|
||||||
int cpu = smp_processor_id();
|
|
||||||
cpumask_t cpumask;
|
|
||||||
|
|
||||||
sigfillset(¤t->blocked);
|
BUG_ON(irqs_disabled());
|
||||||
current->flags |= PF_NOFREEZE;
|
|
||||||
cpumask = cpumask_of_cpu(cpu);
|
|
||||||
set_cpus_allowed(current, cpumask);
|
|
||||||
ipipe_setscheduler_root(current, SCHED_FIFO, 50 + thrprio);
|
|
||||||
|
|
||||||
while (!kthread_should_stop()) {
|
local_irq_save_hw(flags);
|
||||||
local_irq_disable();
|
|
||||||
if (!(desc->status & IRQ_SCHEDULED)) {
|
clear_thread_flag(TIF_IRQ_SYNC);
|
||||||
set_current_state(TASK_INTERRUPTIBLE);
|
|
||||||
resched:
|
if (ipipe_root_cpudom_var(irqpend_himask) != 0)
|
||||||
local_irq_enable();
|
__ipipe_sync_pipeline(IPIPE_IRQMASK_ANY);
|
||||||
schedule();
|
|
||||||
local_irq_disable();
|
local_irq_restore_hw(flags);
|
||||||
}
|
|
||||||
__set_current_state(TASK_RUNNING);
|
|
||||||
/*
|
|
||||||
* If higher priority interrupt servers are ready to
|
|
||||||
* run, reschedule immediately. We need this for the
|
|
||||||
* GPIO demux IRQ handler to unmask the interrupt line
|
|
||||||
* _last_, after all GPIO IRQs have run.
|
|
||||||
*/
|
|
||||||
if (per_cpu(pending_irqthread_mask, cpu) & ~(thrmask|(thrmask-1)))
|
|
||||||
goto resched;
|
|
||||||
if (--per_cpu(pending_irq_count[thrprio], cpu) == 0)
|
|
||||||
per_cpu(pending_irqthread_mask, cpu) &= ~thrmask;
|
|
||||||
desc->status &= ~IRQ_SCHEDULED;
|
|
||||||
desc->thr_handler(irq, &__raw_get_cpu_var(__ipipe_tick_regs));
|
|
||||||
local_irq_enable();
|
|
||||||
}
|
|
||||||
__set_current_state(TASK_RUNNING);
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void kick_irqd(unsigned irq, void *cookie)
|
void ___ipipe_sync_pipeline(unsigned long syncmask)
|
||||||
{
|
{
|
||||||
struct irq_desc *desc = irq_desc + irq;
|
struct ipipe_domain *ipd = ipipe_current_domain;
|
||||||
int thrprio = desc->thr_prio;
|
|
||||||
int thrmask = 1 << thrprio;
|
|
||||||
int cpu = smp_processor_id();
|
|
||||||
|
|
||||||
if (!(desc->status & IRQ_SCHEDULED)) {
|
if (ipd == ipipe_root_domain) {
|
||||||
desc->status |= IRQ_SCHEDULED;
|
if (test_bit(IPIPE_SYNCDEFER_FLAG, &ipipe_root_cpudom_var(status)))
|
||||||
per_cpu(pending_irqthread_mask, cpu) |= thrmask;
|
return;
|
||||||
++per_cpu(pending_irq_count[thrprio], cpu);
|
|
||||||
wake_up_process(desc->thread);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int ipipe_start_irq_thread(unsigned irq, struct irq_desc *desc)
|
|
||||||
{
|
|
||||||
if (desc->thread || !create_irq_threads)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
desc->thread = kthread_create(do_irqd, desc, "IRQ %d", irq);
|
|
||||||
if (desc->thread == NULL) {
|
|
||||||
printk(KERN_ERR "irqd: could not create IRQ thread %d!\n", irq);
|
|
||||||
return -ENOMEM;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
wake_up_process(desc->thread);
|
__ipipe_sync_stage(syncmask);
|
||||||
|
|
||||||
desc->thr_handler = ipipe_root_domain->irqs[irq].handler;
|
|
||||||
ipipe_root_domain->irqs[irq].handler = &kick_irqd;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void __init ipipe_init_irq_threads(void)
|
|
||||||
{
|
|
||||||
unsigned irq;
|
|
||||||
struct irq_desc *desc;
|
|
||||||
|
|
||||||
create_irq_threads = 1;
|
|
||||||
|
|
||||||
for (irq = 0; irq < NR_IRQS; irq++) {
|
|
||||||
desc = irq_desc + irq;
|
|
||||||
if (desc->action != NULL ||
|
|
||||||
(desc->status & IRQ_NOREQUEST) != 0)
|
|
||||||
ipipe_start_irq_thread(irq, desc);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
EXPORT_SYMBOL(show_stack);
|
EXPORT_SYMBOL(show_stack);
|
||||||
|
|
|
@ -144,11 +144,15 @@ asmlinkage void asm_do_IRQ(unsigned int irq, struct pt_regs *regs)
|
||||||
#endif
|
#endif
|
||||||
generic_handle_irq(irq);
|
generic_handle_irq(irq);
|
||||||
|
|
||||||
#ifndef CONFIG_IPIPE /* Useless and bugous over the I-pipe: IRQs are threaded. */
|
#ifndef CONFIG_IPIPE
|
||||||
/* If we're the only interrupt running (ignoring IRQ15 which is for
|
/*
|
||||||
syscalls), lower our priority to IRQ14 so that softirqs run at
|
* If we're the only interrupt running (ignoring IRQ15 which
|
||||||
that level. If there's another, lower-level interrupt, irq_exit
|
* is for syscalls), lower our priority to IRQ14 so that
|
||||||
will defer softirqs to that. */
|
* softirqs run at that level. If there's another,
|
||||||
|
* lower-level interrupt, irq_exit will defer softirqs to
|
||||||
|
* that. If the interrupt pipeline is enabled, we are already
|
||||||
|
* running at IRQ14 priority, so we don't need this code.
|
||||||
|
*/
|
||||||
CSYNC();
|
CSYNC();
|
||||||
pending = bfin_read_IPEND() & ~0x8000;
|
pending = bfin_read_IPEND() & ~0x8000;
|
||||||
other_ints = pending & (pending - 1);
|
other_ints = pending & (pending - 1);
|
||||||
|
|
|
@ -20,6 +20,7 @@
|
||||||
static char cmdline[256];
|
static char cmdline[256];
|
||||||
static unsigned long len;
|
static unsigned long len;
|
||||||
|
|
||||||
|
#ifndef CONFIG_SMP
|
||||||
static int num1 __attribute__((l1_data));
|
static int num1 __attribute__((l1_data));
|
||||||
|
|
||||||
void kgdb_l1_test(void) __attribute__((l1_text));
|
void kgdb_l1_test(void) __attribute__((l1_text));
|
||||||
|
@ -32,6 +33,8 @@ void kgdb_l1_test(void)
|
||||||
printk(KERN_ALERT "L1(after change) : data variable addr = 0x%p, data value is %d\n", &num1, num1);
|
printk(KERN_ALERT "L1(after change) : data variable addr = 0x%p, data value is %d\n", &num1, num1);
|
||||||
return ;
|
return ;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if L2_LENGTH
|
#if L2_LENGTH
|
||||||
|
|
||||||
static int num2 __attribute__((l2));
|
static int num2 __attribute__((l2));
|
||||||
|
@ -59,10 +62,12 @@ int kgdb_test(char *name, int len, int count, int z)
|
||||||
static int test_proc_output(char *buf)
|
static int test_proc_output(char *buf)
|
||||||
{
|
{
|
||||||
kgdb_test("hello world!", 12, 0x55, 0x10);
|
kgdb_test("hello world!", 12, 0x55, 0x10);
|
||||||
|
#ifndef CONFIG_SMP
|
||||||
kgdb_l1_test();
|
kgdb_l1_test();
|
||||||
#if L2_LENGTH
|
#endif
|
||||||
|
#if L2_LENGTH
|
||||||
kgdb_l2_test();
|
kgdb_l2_test();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,7 @@
|
||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
#include <asm/dma.h>
|
#include <asm/dma.h>
|
||||||
#include <asm/fixed_code.h>
|
#include <asm/fixed_code.h>
|
||||||
|
#include <asm/cacheflush.h>
|
||||||
#include <asm/mem_map.h>
|
#include <asm/mem_map.h>
|
||||||
|
|
||||||
#define TEXT_OFFSET 0
|
#define TEXT_OFFSET 0
|
||||||
|
@ -240,7 +241,7 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data)
|
||||||
|
|
||||||
} else if (addr >= FIXED_CODE_START
|
} else if (addr >= FIXED_CODE_START
|
||||||
&& addr + sizeof(tmp) <= FIXED_CODE_END) {
|
&& addr + sizeof(tmp) <= FIXED_CODE_END) {
|
||||||
memcpy(&tmp, (const void *)(addr), sizeof(tmp));
|
copy_from_user_page(0, 0, 0, &tmp, (const void *)(addr), sizeof(tmp));
|
||||||
copied = sizeof(tmp);
|
copied = sizeof(tmp);
|
||||||
|
|
||||||
} else
|
} else
|
||||||
|
@ -320,7 +321,7 @@ long arch_ptrace(struct task_struct *child, long request, long addr, long data)
|
||||||
|
|
||||||
} else if (addr >= FIXED_CODE_START
|
} else if (addr >= FIXED_CODE_START
|
||||||
&& addr + sizeof(data) <= FIXED_CODE_END) {
|
&& addr + sizeof(data) <= FIXED_CODE_END) {
|
||||||
memcpy((void *)(addr), &data, sizeof(data));
|
copy_to_user_page(0, 0, 0, (void *)(addr), &data, sizeof(data));
|
||||||
copied = sizeof(data);
|
copied = sizeof(data);
|
||||||
|
|
||||||
} else
|
} else
|
||||||
|
|
|
@ -889,6 +889,10 @@ void __init setup_arch(char **cmdline_p)
|
||||||
CPU, bfin_revid());
|
CPU, bfin_revid());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* We can't run on BF548-0.1 due to ANOMALY 05000448 */
|
||||||
|
if (bfin_cpuid() == 0x27de && bfin_revid() == 1)
|
||||||
|
panic("You can't run on this processor due to 05000448\n");
|
||||||
|
|
||||||
printk(KERN_INFO "Blackfin Linux support by http://blackfin.uclinux.org/\n");
|
printk(KERN_INFO "Blackfin Linux support by http://blackfin.uclinux.org/\n");
|
||||||
|
|
||||||
printk(KERN_INFO "Processor Speed: %lu MHz core clock and %lu MHz System Clock\n",
|
printk(KERN_INFO "Processor Speed: %lu MHz core clock and %lu MHz System Clock\n",
|
||||||
|
@ -1141,12 +1145,12 @@ static int show_cpuinfo(struct seq_file *m, void *v)
|
||||||
icache_size = 0;
|
icache_size = 0;
|
||||||
|
|
||||||
seq_printf(m, "cache size\t: %d KB(L1 icache) "
|
seq_printf(m, "cache size\t: %d KB(L1 icache) "
|
||||||
"%d KB(L1 dcache-%s) %d KB(L2 cache)\n",
|
"%d KB(L1 dcache%s) %d KB(L2 cache)\n",
|
||||||
icache_size, dcache_size,
|
icache_size, dcache_size,
|
||||||
#if defined CONFIG_BFIN_WB
|
#if defined CONFIG_BFIN_WB
|
||||||
"wb"
|
"-wb"
|
||||||
#elif defined CONFIG_BFIN_WT
|
#elif defined CONFIG_BFIN_WT
|
||||||
"wt"
|
"-wt"
|
||||||
#endif
|
#endif
|
||||||
"", 0);
|
"", 0);
|
||||||
|
|
||||||
|
|
|
@ -134,7 +134,10 @@ irqreturn_t timer_interrupt(int irq, void *dummy)
|
||||||
|
|
||||||
write_seqlock(&xtime_lock);
|
write_seqlock(&xtime_lock);
|
||||||
#if defined(CONFIG_TICK_SOURCE_SYSTMR0) && !defined(CONFIG_IPIPE)
|
#if defined(CONFIG_TICK_SOURCE_SYSTMR0) && !defined(CONFIG_IPIPE)
|
||||||
/* FIXME: Here TIMIL0 is not set when IPIPE enabled, why? */
|
/*
|
||||||
|
* TIMIL0 is latched in __ipipe_grab_irq() when the I-Pipe is
|
||||||
|
* enabled.
|
||||||
|
*/
|
||||||
if (get_gptimer_status(0) & TIMER_STATUS_TIMIL0) {
|
if (get_gptimer_status(0) & TIMER_STATUS_TIMIL0) {
|
||||||
#endif
|
#endif
|
||||||
do_timer(1);
|
do_timer(1);
|
||||||
|
|
|
@ -113,7 +113,6 @@ static struct platform_device bfin_mac_device = {
|
||||||
.name = "bfin_mac",
|
.name = "bfin_mac",
|
||||||
.dev.platform_data = &bfin_mii_bus,
|
.dev.platform_data = &bfin_mii_bus,
|
||||||
};
|
};
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_NET_DSA_KSZ8893M) || defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
#if defined(CONFIG_NET_DSA_KSZ8893M) || defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
||||||
static struct dsa_platform_data ksz8893m_switch_data = {
|
static struct dsa_platform_data ksz8893m_switch_data = {
|
||||||
|
@ -132,6 +131,7 @@ static struct platform_device ksz8893m_switch_device = {
|
||||||
.dev.platform_data = &ksz8893m_switch_data,
|
.dev.platform_data = &ksz8893m_switch_data,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_MTD_M25P80) \
|
#if defined(CONFIG_MTD_M25P80) \
|
||||||
|| defined(CONFIG_MTD_M25P80_MODULE)
|
|| defined(CONFIG_MTD_M25P80_MODULE)
|
||||||
|
@ -171,6 +171,7 @@ static struct bfin5xx_spi_chip spi_adc_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
||||||
#if defined(CONFIG_NET_DSA_KSZ8893M) \
|
#if defined(CONFIG_NET_DSA_KSZ8893M) \
|
||||||
|| defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
|| defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
||||||
/* SPI SWITCH CHIP */
|
/* SPI SWITCH CHIP */
|
||||||
|
@ -179,10 +180,11 @@ static struct bfin5xx_spi_chip spi_switch_info = {
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -259,6 +261,7 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
||||||
#if defined(CONFIG_NET_DSA_KSZ8893M) \
|
#if defined(CONFIG_NET_DSA_KSZ8893M) \
|
||||||
|| defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
|| defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
||||||
{
|
{
|
||||||
|
@ -271,24 +274,15 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
@ -630,11 +624,10 @@ static struct platform_device *stamp_devices[] __initdata = {
|
||||||
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
||||||
&bfin_mii_bus,
|
&bfin_mii_bus,
|
||||||
&bfin_mac_device,
|
&bfin_mac_device,
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_NET_DSA_KSZ8893M) || defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
#if defined(CONFIG_NET_DSA_KSZ8893M) || defined(CONFIG_NET_DSA_KSZ8893M_MODULE)
|
||||||
&ksz8893m_switch_device,
|
&ksz8893m_switch_device,
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
||||||
&bfin_spi0_device,
|
&bfin_spi0_device,
|
||||||
|
|
|
@ -2,12 +2,12 @@
|
||||||
* File: include/asm-blackfin/mach-bf518/anomaly.h
|
* File: include/asm-blackfin/mach-bf518/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* This file shoule be up to date with:
|
/* This file shoule be up to date with:
|
||||||
* - ????
|
* - Revision B, 02/03/2009; ADSP-BF512/BF514/BF516/BF518 Blackfin Processor Anomaly List
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _MACH_ANOMALY_H_
|
#ifndef _MACH_ANOMALY_H_
|
||||||
|
@ -19,6 +19,8 @@
|
||||||
#define ANOMALY_05000122 (1)
|
#define ANOMALY_05000122 (1)
|
||||||
/* False Hardware Error from an Access in the Shadow of a Conditional Branch */
|
/* False Hardware Error from an Access in the Shadow of a Conditional Branch */
|
||||||
#define ANOMALY_05000245 (1)
|
#define ANOMALY_05000245 (1)
|
||||||
|
/* Incorrect Timer Pulse Width in Single-Shot PWM_OUT Mode with External Clock */
|
||||||
|
#define ANOMALY_05000254 (1)
|
||||||
/* Sensitivity To Noise with Slow Input Edge Rates on External SPORT TX and RX Clocks */
|
/* Sensitivity To Noise with Slow Input Edge Rates on External SPORT TX and RX Clocks */
|
||||||
#define ANOMALY_05000265 (1)
|
#define ANOMALY_05000265 (1)
|
||||||
/* False Hardware Errors Caused by Fetches at the Boundary of Reserved Memory */
|
/* False Hardware Errors Caused by Fetches at the Boundary of Reserved Memory */
|
||||||
|
@ -53,6 +55,12 @@
|
||||||
#define ANOMALY_05000443 (1)
|
#define ANOMALY_05000443 (1)
|
||||||
/* Incorrect L1 Instruction Bank B Memory Map Location */
|
/* Incorrect L1 Instruction Bank B Memory Map Location */
|
||||||
#define ANOMALY_05000444 (1)
|
#define ANOMALY_05000444 (1)
|
||||||
|
/* Incorrect Default Hysteresis Setting for RESET, NMI, and BMODE Signals */
|
||||||
|
#define ANOMALY_05000452 (1)
|
||||||
|
/* PWM_TRIPB Signal Not Available on PG10 */
|
||||||
|
#define ANOMALY_05000453 (1)
|
||||||
|
/* PPI_FS3 is Driven One Half Cycle Later Than PPI Data */
|
||||||
|
#define ANOMALY_05000455 (1)
|
||||||
|
|
||||||
/* Anomalies that don't exist on this proc */
|
/* Anomalies that don't exist on this proc */
|
||||||
#define ANOMALY_05000125 (0)
|
#define ANOMALY_05000125 (0)
|
||||||
|
@ -65,15 +73,20 @@
|
||||||
#define ANOMALY_05000263 (0)
|
#define ANOMALY_05000263 (0)
|
||||||
#define ANOMALY_05000266 (0)
|
#define ANOMALY_05000266 (0)
|
||||||
#define ANOMALY_05000273 (0)
|
#define ANOMALY_05000273 (0)
|
||||||
|
#define ANOMALY_05000278 (0)
|
||||||
#define ANOMALY_05000285 (0)
|
#define ANOMALY_05000285 (0)
|
||||||
|
#define ANOMALY_05000305 (0)
|
||||||
#define ANOMALY_05000307 (0)
|
#define ANOMALY_05000307 (0)
|
||||||
#define ANOMALY_05000311 (0)
|
#define ANOMALY_05000311 (0)
|
||||||
#define ANOMALY_05000312 (0)
|
#define ANOMALY_05000312 (0)
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
#define ANOMALY_05000353 (0)
|
#define ANOMALY_05000353 (0)
|
||||||
#define ANOMALY_05000363 (0)
|
#define ANOMALY_05000363 (0)
|
||||||
|
#define ANOMALY_05000380 (0)
|
||||||
#define ANOMALY_05000386 (0)
|
#define ANOMALY_05000386 (0)
|
||||||
#define ANOMALY_05000412 (0)
|
#define ANOMALY_05000412 (0)
|
||||||
#define ANOMALY_05000432 (0)
|
#define ANOMALY_05000432 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -144,7 +144,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART0_TX,
|
CH_UART0_TX,
|
||||||
CH_UART0_RX,
|
CH_UART0_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -158,7 +158,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART1_TX,
|
CH_UART1_TX,
|
||||||
CH_UART1_RX,
|
CH_UART1_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART1_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART1_CTS_PIN,
|
CONFIG_UART1_CTS_PIN,
|
||||||
CONFIG_UART1_RTS_PIN,
|
CONFIG_UART1_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -487,9 +487,9 @@ static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -585,23 +585,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
.controller_data = &ad9960_spi_chip_info,
|
.controller_data = &ad9960_spi_chip_info,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -256,9 +256,9 @@ static struct bfin5xx_spi_chip spi_adc_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -366,23 +366,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* File: include/asm-blackfin/mach-bf527/anomaly.h
|
* File: include/asm-blackfin/mach-bf527/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -167,12 +167,16 @@
|
||||||
#define ANOMALY_05000263 (0)
|
#define ANOMALY_05000263 (0)
|
||||||
#define ANOMALY_05000266 (0)
|
#define ANOMALY_05000266 (0)
|
||||||
#define ANOMALY_05000273 (0)
|
#define ANOMALY_05000273 (0)
|
||||||
|
#define ANOMALY_05000278 (0)
|
||||||
#define ANOMALY_05000285 (0)
|
#define ANOMALY_05000285 (0)
|
||||||
|
#define ANOMALY_05000305 (0)
|
||||||
#define ANOMALY_05000307 (0)
|
#define ANOMALY_05000307 (0)
|
||||||
#define ANOMALY_05000311 (0)
|
#define ANOMALY_05000311 (0)
|
||||||
#define ANOMALY_05000312 (0)
|
#define ANOMALY_05000312 (0)
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
#define ANOMALY_05000363 (0)
|
#define ANOMALY_05000363 (0)
|
||||||
#define ANOMALY_05000412 (0)
|
#define ANOMALY_05000412 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -144,7 +144,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART0_TX,
|
CH_UART0_TX,
|
||||||
CH_UART0_RX,
|
CH_UART0_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -158,7 +158,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART1_TX,
|
CH_UART1_TX,
|
||||||
CH_UART1_RX,
|
CH_UART1_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART1_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART1_CTS_PIN,
|
CONFIG_UART1_CTS_PIN,
|
||||||
CONFIG_UART1_RTS_PIN,
|
CONFIG_UART1_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -38,9 +38,4 @@ config BFIN532_IP0X
|
||||||
help
|
help
|
||||||
Core support for IP04/IP04 open hardware IP-PBX.
|
Core support for IP04/IP04 open hardware IP-PBX.
|
||||||
|
|
||||||
config GENERIC_BF533_BOARD
|
|
||||||
bool "Generic"
|
|
||||||
help
|
|
||||||
Generic or Custom board support.
|
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
# arch/blackfin/mach-bf533/boards/Makefile
|
# arch/blackfin/mach-bf533/boards/Makefile
|
||||||
#
|
#
|
||||||
|
|
||||||
obj-$(CONFIG_GENERIC_BF533_BOARD) += generic_board.o
|
|
||||||
obj-$(CONFIG_BFIN533_STAMP) += stamp.o
|
obj-$(CONFIG_BFIN533_STAMP) += stamp.o
|
||||||
obj-$(CONFIG_BFIN532_IP0X) += ip0x.o
|
obj-$(CONFIG_BFIN532_IP0X) += ip0x.o
|
||||||
obj-$(CONFIG_BFIN533_EZKIT) += ezkit.o
|
obj-$(CONFIG_BFIN533_EZKIT) += ezkit.o
|
||||||
|
|
|
@ -101,9 +101,9 @@ static struct bfin5xx_spi_chip spi_flash_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -129,23 +129,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -96,9 +96,9 @@ static struct bfin5xx_spi_chip ad1836_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -138,23 +138,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,126 +0,0 @@
|
||||||
/*
|
|
||||||
* File: arch/blackfin/mach-bf533/generic_board.c
|
|
||||||
* Based on: arch/blackfin/mach-bf533/ezkit.c
|
|
||||||
* Author: Aidan Williams <aidan@nicta.com.au>
|
|
||||||
*
|
|
||||||
* Created: 2005
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Modified:
|
|
||||||
* Copyright 2005 National ICT Australia (NICTA)
|
|
||||||
* Copyright 2004-2006 Analog Devices Inc.
|
|
||||||
*
|
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, see the file COPYING, or write
|
|
||||||
* to the Free Software Foundation, Inc.,
|
|
||||||
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/device.h>
|
|
||||||
#include <linux/platform_device.h>
|
|
||||||
#include <linux/irq.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Name the Board for the /proc/cpuinfo
|
|
||||||
*/
|
|
||||||
const char bfin_board_name[] = "UNKNOWN BOARD";
|
|
||||||
|
|
||||||
#if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_DRV_BFIN_MODULE)
|
|
||||||
static struct platform_device rtc_device = {
|
|
||||||
.name = "rtc-bfin",
|
|
||||||
.id = -1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Driver needs to know address, irq and flag pin.
|
|
||||||
*/
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
static struct resource smc91x_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x20300300,
|
|
||||||
.end = 0x20300300 + 16,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PROG_INTB,
|
|
||||||
.end = IRQ_PROG_INTB,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PF7,
|
|
||||||
.end = IRQ_PF7,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device smc91x_device = {
|
|
||||||
.name = "smc91x",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(smc91x_resources),
|
|
||||||
.resource = smc91x_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
static struct resource bfin_sir0_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0xFFC00400,
|
|
||||||
.end = 0xFFC004FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = IRQ_UART0_RX,
|
|
||||||
.end = IRQ_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = CH_UART0_RX,
|
|
||||||
.end = CH_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_DMA,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_sir0_device = {
|
|
||||||
.name = "bfin_sir",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_sir0_resources),
|
|
||||||
.resource = bfin_sir0_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static struct platform_device *generic_board_devices[] __initdata = {
|
|
||||||
#if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_DRV_BFIN_MODULE)
|
|
||||||
&rtc_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
&smc91x_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
&bfin_sir0_device,
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
static int __init generic_board_init(void)
|
|
||||||
{
|
|
||||||
printk(KERN_INFO "%s(): registering device resources\n", __func__);
|
|
||||||
return platform_add_devices(generic_board_devices, ARRAY_SIZE(generic_board_devices));
|
|
||||||
}
|
|
||||||
|
|
||||||
arch_initcall(generic_board_init);
|
|
|
@ -127,8 +127,8 @@ static struct platform_device dm9000_device2 = {
|
||||||
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
||||||
/* all SPI peripherals info goes here */
|
/* all SPI peripherals info goes here */
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
/*
|
/*
|
||||||
* CPOL (Clock Polarity)
|
* CPOL (Clock Polarity)
|
||||||
* 0 - Active high SCK
|
* 0 - Active high SCK
|
||||||
|
@ -152,14 +152,13 @@ static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
||||||
/* Notice: for blackfin, the speed_hz is the value of register
|
/* Notice: for blackfin, the speed_hz is the value of register
|
||||||
* SPI_BAUD, not the real baudrate */
|
* SPI_BAUD, not the real baudrate */
|
||||||
static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 2,
|
.max_speed_hz = 2,
|
||||||
.bus_num = 1,
|
.bus_num = 1,
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* File: include/asm-blackfin/mach-bf533/anomaly.h
|
* File: include/asm-blackfin/mach-bf533/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -160,7 +160,7 @@
|
||||||
#define ANOMALY_05000301 (__SILICON_REVISION__ < 6)
|
#define ANOMALY_05000301 (__SILICON_REVISION__ < 6)
|
||||||
/* SSYNCs After Writes To DMA MMR Registers May Not Be Handled Correctly */
|
/* SSYNCs After Writes To DMA MMR Registers May Not Be Handled Correctly */
|
||||||
#define ANOMALY_05000302 (__SILICON_REVISION__ < 5)
|
#define ANOMALY_05000302 (__SILICON_REVISION__ < 5)
|
||||||
/* New Feature: Additional Hysteresis on SPORT Input Pins (Not Available On Older Silicon) */
|
/* SPORT_HYS Bit in PLL_CTL Register Is Not Functional */
|
||||||
#define ANOMALY_05000305 (__SILICON_REVISION__ < 5)
|
#define ANOMALY_05000305 (__SILICON_REVISION__ < 5)
|
||||||
/* New Feature: Additional PPI Frame Sync Sampling Options (Not Available On Older Silicon) */
|
/* New Feature: Additional PPI Frame Sync Sampling Options (Not Available On Older Silicon) */
|
||||||
#define ANOMALY_05000306 (__SILICON_REVISION__ < 5)
|
#define ANOMALY_05000306 (__SILICON_REVISION__ < 5)
|
||||||
|
@ -278,9 +278,12 @@
|
||||||
#define ANOMALY_05000266 (0)
|
#define ANOMALY_05000266 (0)
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
#define ANOMALY_05000353 (1)
|
#define ANOMALY_05000353 (1)
|
||||||
|
#define ANOMALY_05000380 (0)
|
||||||
#define ANOMALY_05000386 (1)
|
#define ANOMALY_05000386 (1)
|
||||||
#define ANOMALY_05000412 (0)
|
#define ANOMALY_05000412 (0)
|
||||||
#define ANOMALY_05000432 (0)
|
#define ANOMALY_05000432 (0)
|
||||||
#define ANOMALY_05000435 (0)
|
#define ANOMALY_05000435 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -134,7 +134,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART_TX,
|
CH_UART_TX,
|
||||||
CH_UART_RX,
|
CH_UART_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -33,9 +33,4 @@ config CAMSIG_MINOTAUR
|
||||||
help
|
help
|
||||||
Board supply package for CSP Minotaur
|
Board supply package for CSP Minotaur
|
||||||
|
|
||||||
config GENERIC_BF537_BOARD
|
|
||||||
bool "Generic"
|
|
||||||
help
|
|
||||||
Generic or Custom board support.
|
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
# arch/blackfin/mach-bf537/boards/Makefile
|
# arch/blackfin/mach-bf537/boards/Makefile
|
||||||
#
|
#
|
||||||
|
|
||||||
obj-$(CONFIG_GENERIC_BF537_BOARD) += generic_board.o
|
|
||||||
obj-$(CONFIG_BFIN537_STAMP) += stamp.o
|
obj-$(CONFIG_BFIN537_STAMP) += stamp.o
|
||||||
obj-$(CONFIG_BFIN537_BLUETECHNIX_CM) += cm_bf537.o
|
obj-$(CONFIG_BFIN537_BLUETECHNIX_CM) += cm_bf537.o
|
||||||
obj-$(CONFIG_BFIN537_BLUETECHNIX_TCM) += tcm_bf537.o
|
obj-$(CONFIG_BFIN537_BLUETECHNIX_TCM) += tcm_bf537.o
|
||||||
|
|
|
@ -108,9 +108,9 @@ static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -160,23 +160,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 20000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 7,
|
.chip_select = 1,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,745 +0,0 @@
|
||||||
/*
|
|
||||||
* File: arch/blackfin/mach-bf537/boards/generic_board.c
|
|
||||||
* Based on: arch/blackfin/mach-bf533/boards/ezkit.c
|
|
||||||
* Author: Aidan Williams <aidan@nicta.com.au>
|
|
||||||
*
|
|
||||||
* Created:
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Modified:
|
|
||||||
* Copyright 2005 National ICT Australia (NICTA)
|
|
||||||
* Copyright 2004-2008 Analog Devices Inc.
|
|
||||||
*
|
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, see the file COPYING, or write
|
|
||||||
* to the Free Software Foundation, Inc.,
|
|
||||||
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/device.h>
|
|
||||||
#include <linux/etherdevice.h>
|
|
||||||
#include <linux/platform_device.h>
|
|
||||||
#include <linux/mtd/mtd.h>
|
|
||||||
#include <linux/mtd/partitions.h>
|
|
||||||
#include <linux/spi/spi.h>
|
|
||||||
#include <linux/spi/flash.h>
|
|
||||||
#if defined(CONFIG_USB_ISP1362_HCD) || defined(CONFIG_USB_ISP1362_HCD_MODULE)
|
|
||||||
#include <linux/usb/isp1362.h>
|
|
||||||
#endif
|
|
||||||
#include <linux/irq.h>
|
|
||||||
#include <linux/interrupt.h>
|
|
||||||
#include <linux/usb/sl811.h>
|
|
||||||
#include <asm/dma.h>
|
|
||||||
#include <asm/bfin5xx_spi.h>
|
|
||||||
#include <asm/reboot.h>
|
|
||||||
#include <asm/portmux.h>
|
|
||||||
#include <linux/spi/ad7877.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Name the Board for the /proc/cpuinfo
|
|
||||||
*/
|
|
||||||
const char bfin_board_name[] = "UNKNOWN BOARD";
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Driver needs to know address, irq and flag pin.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_ISP1760_HCD) || defined(CONFIG_USB_ISP1760_HCD_MODULE)
|
|
||||||
#include <linux/usb/isp1760.h>
|
|
||||||
static struct resource bfin_isp1760_resources[] = {
|
|
||||||
[0] = {
|
|
||||||
.start = 0x203C0000,
|
|
||||||
.end = 0x203C0000 + 0x000fffff,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
[1] = {
|
|
||||||
.start = IRQ_PF7,
|
|
||||||
.end = IRQ_PF7,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct isp1760_platform_data isp1760_priv = {
|
|
||||||
.is_isp1761 = 0,
|
|
||||||
.port1_disable = 0,
|
|
||||||
.bus_width_16 = 1,
|
|
||||||
.port1_otg = 0,
|
|
||||||
.analog_oc = 0,
|
|
||||||
.dack_polarity_high = 0,
|
|
||||||
.dreq_polarity_high = 0,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_isp1760_device = {
|
|
||||||
.name = "isp1760-hcd",
|
|
||||||
.id = 0,
|
|
||||||
.dev = {
|
|
||||||
.platform_data = &isp1760_priv,
|
|
||||||
},
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_isp1760_resources),
|
|
||||||
.resource = bfin_isp1760_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE)
|
|
||||||
static struct resource bfin_pcmcia_cf_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x20310000, /* IO PORT */
|
|
||||||
.end = 0x20312000,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = 0x20311000, /* Attribute Memory */
|
|
||||||
.end = 0x20311FFF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PF4,
|
|
||||||
.end = IRQ_PF4,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_LOWLEVEL,
|
|
||||||
}, {
|
|
||||||
.start = 6, /* Card Detect PF6 */
|
|
||||||
.end = 6,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_pcmcia_cf_device = {
|
|
||||||
.name = "bfin_cf_pcmcia",
|
|
||||||
.id = -1,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_pcmcia_cf_resources),
|
|
||||||
.resource = bfin_pcmcia_cf_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_DRV_BFIN_MODULE)
|
|
||||||
static struct platform_device rtc_device = {
|
|
||||||
.name = "rtc-bfin",
|
|
||||||
.id = -1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
static struct resource smc91x_resources[] = {
|
|
||||||
{
|
|
||||||
.name = "smc91x-regs",
|
|
||||||
.start = 0x20300300,
|
|
||||||
.end = 0x20300300 + 16,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
|
|
||||||
.start = IRQ_PF7,
|
|
||||||
.end = IRQ_PF7,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
static struct platform_device smc91x_device = {
|
|
||||||
.name = "smc91x",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(smc91x_resources),
|
|
||||||
.resource = smc91x_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE)
|
|
||||||
static struct resource dm9000_resources[] = {
|
|
||||||
[0] = {
|
|
||||||
.start = 0x203FB800,
|
|
||||||
.end = 0x203FB800 + 1,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
[1] = {
|
|
||||||
.start = 0x203FB800 + 4,
|
|
||||||
.end = 0x203FB800 + 5,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
[2] = {
|
|
||||||
.start = IRQ_PF9,
|
|
||||||
.end = IRQ_PF9,
|
|
||||||
.flags = (IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHEDGE),
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device dm9000_device = {
|
|
||||||
.name = "dm9000",
|
|
||||||
.id = -1,
|
|
||||||
.num_resources = ARRAY_SIZE(dm9000_resources),
|
|
||||||
.resource = dm9000_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_SL811_HCD) || defined(CONFIG_USB_SL811_HCD_MODULE)
|
|
||||||
static struct resource sl811_hcd_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x20340000,
|
|
||||||
.end = 0x20340000,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = 0x20340004,
|
|
||||||
.end = 0x20340004,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = CONFIG_USB_SL811_BFIN_IRQ,
|
|
||||||
.end = CONFIG_USB_SL811_BFIN_IRQ,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_SL811_BFIN_USE_VBUS)
|
|
||||||
void sl811_port_power(struct device *dev, int is_on)
|
|
||||||
{
|
|
||||||
gpio_request(CONFIG_USB_SL811_BFIN_GPIO_VBUS, "usb:SL811_VBUS");
|
|
||||||
gpio_direction_output(CONFIG_USB_SL811_BFIN_GPIO_VBUS, is_on);
|
|
||||||
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static struct sl811_platform_data sl811_priv = {
|
|
||||||
.potpg = 10,
|
|
||||||
.power = 250, /* == 500mA */
|
|
||||||
#if defined(CONFIG_USB_SL811_BFIN_USE_VBUS)
|
|
||||||
.port_power = &sl811_port_power,
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device sl811_hcd_device = {
|
|
||||||
.name = "sl811-hcd",
|
|
||||||
.id = 0,
|
|
||||||
.dev = {
|
|
||||||
.platform_data = &sl811_priv,
|
|
||||||
},
|
|
||||||
.num_resources = ARRAY_SIZE(sl811_hcd_resources),
|
|
||||||
.resource = sl811_hcd_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_ISP1362_HCD) || defined(CONFIG_USB_ISP1362_HCD_MODULE)
|
|
||||||
static struct resource isp1362_hcd_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x20360000,
|
|
||||||
.end = 0x20360000,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = 0x20360004,
|
|
||||||
.end = 0x20360004,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = CONFIG_USB_ISP1362_BFIN_GPIO_IRQ,
|
|
||||||
.end = CONFIG_USB_ISP1362_BFIN_GPIO_IRQ,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct isp1362_platform_data isp1362_priv = {
|
|
||||||
.sel15Kres = 1,
|
|
||||||
.clknotstop = 0,
|
|
||||||
.oc_enable = 0,
|
|
||||||
.int_act_high = 0,
|
|
||||||
.int_edge_triggered = 0,
|
|
||||||
.remote_wakeup_connected = 0,
|
|
||||||
.no_power_switching = 1,
|
|
||||||
.power_switching_mode = 0,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device isp1362_hcd_device = {
|
|
||||||
.name = "isp1362-hcd",
|
|
||||||
.id = 0,
|
|
||||||
.dev = {
|
|
||||||
.platform_data = &isp1362_priv,
|
|
||||||
},
|
|
||||||
.num_resources = ARRAY_SIZE(isp1362_hcd_resources),
|
|
||||||
.resource = isp1362_hcd_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
|
||||||
static struct platform_device bfin_mii_bus = {
|
|
||||||
.name = "bfin_mii_bus",
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_mac_device = {
|
|
||||||
.name = "bfin_mac",
|
|
||||||
.dev.platform_data = &bfin_mii_bus,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_NET2272) || defined(CONFIG_USB_NET2272_MODULE)
|
|
||||||
static struct resource net2272_bfin_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x20300000,
|
|
||||||
.end = 0x20300000 + 0x100,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PF7,
|
|
||||||
.end = IRQ_PF7,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device net2272_bfin_device = {
|
|
||||||
.name = "net2272",
|
|
||||||
.id = -1,
|
|
||||||
.num_resources = ARRAY_SIZE(net2272_bfin_resources),
|
|
||||||
.resource = net2272_bfin_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
|
||||||
/* all SPI peripherals info goes here */
|
|
||||||
|
|
||||||
#if defined(CONFIG_MTD_M25P80) \
|
|
||||||
|| defined(CONFIG_MTD_M25P80_MODULE)
|
|
||||||
static struct mtd_partition bfin_spi_flash_partitions[] = {
|
|
||||||
{
|
|
||||||
.name = "bootloader(spi)",
|
|
||||||
.size = 0x00020000,
|
|
||||||
.offset = 0,
|
|
||||||
.mask_flags = MTD_CAP_ROM
|
|
||||||
}, {
|
|
||||||
.name = "linux kernel(spi)",
|
|
||||||
.size = 0xe0000,
|
|
||||||
.offset = 0x20000
|
|
||||||
}, {
|
|
||||||
.name = "file system(spi)",
|
|
||||||
.size = 0x700000,
|
|
||||||
.offset = 0x00100000,
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct flash_platform_data bfin_spi_flash_data = {
|
|
||||||
.name = "m25p80",
|
|
||||||
.parts = bfin_spi_flash_partitions,
|
|
||||||
.nr_parts = ARRAY_SIZE(bfin_spi_flash_partitions),
|
|
||||||
.type = "m25p64",
|
|
||||||
};
|
|
||||||
|
|
||||||
/* SPI flash chip (m25p64) */
|
|
||||||
static struct bfin5xx_spi_chip spi_flash_chip_info = {
|
|
||||||
.enable_dma = 0, /* use dma transfer with this chip*/
|
|
||||||
.bits_per_word = 8,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_ADC_BF533) \
|
|
||||||
|| defined(CONFIG_SPI_ADC_BF533_MODULE)
|
|
||||||
/* SPI ADC chip */
|
|
||||||
static struct bfin5xx_spi_chip spi_adc_chip_info = {
|
|
||||||
.enable_dma = 1, /* use dma transfer with this chip*/
|
|
||||||
.bits_per_word = 16,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SND_BLACKFIN_AD1836) \
|
|
||||||
|| defined(CONFIG_SND_BLACKFIN_AD1836_MODULE)
|
|
||||||
static struct bfin5xx_spi_chip ad1836_spi_chip_info = {
|
|
||||||
.enable_dma = 0,
|
|
||||||
.bits_per_word = 16,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_AD9960) || defined(CONFIG_AD9960_MODULE)
|
|
||||||
static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
|
||||||
.enable_dma = 0,
|
|
||||||
.bits_per_word = 16,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
|
||||||
.enable_dma = 1,
|
|
||||||
.bits_per_word = 8,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_PBX)
|
|
||||||
static struct bfin5xx_spi_chip spi_si3xxx_chip_info = {
|
|
||||||
.ctl_reg = 0x4, /* send zero */
|
|
||||||
.enable_dma = 0,
|
|
||||||
.bits_per_word = 8,
|
|
||||||
.cs_change_per_word = 1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_TOUCHSCREEN_AD7877) || defined(CONFIG_TOUCHSCREEN_AD7877_MODULE)
|
|
||||||
static struct bfin5xx_spi_chip spi_ad7877_chip_info = {
|
|
||||||
.enable_dma = 0,
|
|
||||||
.bits_per_word = 16,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct ad7877_platform_data bfin_ad7877_ts_info = {
|
|
||||||
.model = 7877,
|
|
||||||
.vref_delay_usecs = 50, /* internal, no capacitor */
|
|
||||||
.x_plate_ohms = 419,
|
|
||||||
.y_plate_ohms = 486,
|
|
||||||
.pressure_max = 1000,
|
|
||||||
.pressure_min = 0,
|
|
||||||
.stopacq_polarity = 1,
|
|
||||||
.first_conversion_delay = 3,
|
|
||||||
.acquisition_time = 1,
|
|
||||||
.averaging = 1,
|
|
||||||
.pen_down_acc_interval = 1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
|
||||||
#if defined(CONFIG_MTD_M25P80) \
|
|
||||||
|| defined(CONFIG_MTD_M25P80_MODULE)
|
|
||||||
{
|
|
||||||
/* the modalias must be the same as spi device driver name */
|
|
||||||
.modalias = "m25p80", /* Name of spi_driver for this device */
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0, /* Framework bus number */
|
|
||||||
.chip_select = 1, /* Framework chip select. On STAMP537 it is SPISSEL1*/
|
|
||||||
.platform_data = &bfin_spi_flash_data,
|
|
||||||
.controller_data = &spi_flash_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_ADC_BF533) \
|
|
||||||
|| defined(CONFIG_SPI_ADC_BF533_MODULE)
|
|
||||||
{
|
|
||||||
.modalias = "bfin_spi_adc", /* Name of spi_driver for this device */
|
|
||||||
.max_speed_hz = 6250000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0, /* Framework bus number */
|
|
||||||
.chip_select = 1, /* Framework chip select. */
|
|
||||||
.platform_data = NULL, /* No spi_driver specific config */
|
|
||||||
.controller_data = &spi_adc_chip_info,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SND_BLACKFIN_AD1836) \
|
|
||||||
|| defined(CONFIG_SND_BLACKFIN_AD1836_MODULE)
|
|
||||||
{
|
|
||||||
.modalias = "ad1836-spi",
|
|
||||||
.max_speed_hz = 3125000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SND_BLACKFIN_SPI_PFBIT,
|
|
||||||
.controller_data = &ad1836_spi_chip_info,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
#if defined(CONFIG_AD9960) || defined(CONFIG_AD9960_MODULE)
|
|
||||||
{
|
|
||||||
.modalias = "ad9960-spi",
|
|
||||||
.max_speed_hz = 10000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = 1,
|
|
||||||
.controller_data = &ad9960_spi_chip_info,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc_dummy",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = 0,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
#if defined(CONFIG_PBX)
|
|
||||||
{
|
|
||||||
.modalias = "fxs-spi",
|
|
||||||
.max_speed_hz = 12500000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = 8 - CONFIG_J11_JUMPER,
|
|
||||||
.controller_data = &spi_si3xxx_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "fxo-spi",
|
|
||||||
.max_speed_hz = 12500000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = 8 - CONFIG_J19_JUMPER,
|
|
||||||
.controller_data = &spi_si3xxx_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
#if defined(CONFIG_TOUCHSCREEN_AD7877) || defined(CONFIG_TOUCHSCREEN_AD7877_MODULE)
|
|
||||||
{
|
|
||||||
.modalias = "ad7877",
|
|
||||||
.platform_data = &bfin_ad7877_ts_info,
|
|
||||||
.irq = IRQ_PF6,
|
|
||||||
.max_speed_hz = 12500000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = 1,
|
|
||||||
.controller_data = &spi_ad7877_chip_info,
|
|
||||||
},
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
/* SPI controller data */
|
|
||||||
static struct bfin5xx_spi_master bfin_spi0_info = {
|
|
||||||
.num_chipselect = 8,
|
|
||||||
.enable_dma = 1, /* master has the ability to do dma transfer */
|
|
||||||
.pin_req = {P_SPI0_SCK, P_SPI0_MISO, P_SPI0_MOSI, 0},
|
|
||||||
};
|
|
||||||
|
|
||||||
/* SPI (0) */
|
|
||||||
static struct resource bfin_spi0_resource[] = {
|
|
||||||
[0] = {
|
|
||||||
.start = SPI0_REGBASE,
|
|
||||||
.end = SPI0_REGBASE + 0xFF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
[1] = {
|
|
||||||
.start = CH_SPI,
|
|
||||||
.end = CH_SPI,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_spi0_device = {
|
|
||||||
.name = "bfin-spi",
|
|
||||||
.id = 0, /* Bus number */
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_spi0_resource),
|
|
||||||
.resource = bfin_spi0_resource,
|
|
||||||
.dev = {
|
|
||||||
.platform_data = &bfin_spi0_info, /* Passed to driver */
|
|
||||||
},
|
|
||||||
};
|
|
||||||
#endif /* spi master and devices */
|
|
||||||
|
|
||||||
#if defined(CONFIG_FB_BF537_LQ035) || defined(CONFIG_FB_BF537_LQ035_MODULE)
|
|
||||||
static struct platform_device bfin_fb_device = {
|
|
||||||
.name = "bf537-lq035",
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_FB_BFIN_7393) || defined(CONFIG_FB_BFIN_7393_MODULE)
|
|
||||||
static struct platform_device bfin_fb_adv7393_device = {
|
|
||||||
.name = "bfin-adv7393",
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE)
|
|
||||||
static struct resource bfin_uart_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0xFFC00400,
|
|
||||||
.end = 0xFFC004FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = 0xFFC02000,
|
|
||||||
.end = 0xFFC020FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_uart_device = {
|
|
||||||
.name = "bfin-uart",
|
|
||||||
.id = 1,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_uart_resources),
|
|
||||||
.resource = bfin_uart_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
static struct resource bfin_sir0_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0xFFC00400,
|
|
||||||
.end = 0xFFC004FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = IRQ_UART0_RX,
|
|
||||||
.end = IRQ_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = CH_UART0_RX,
|
|
||||||
.end = CH_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_DMA,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_sir0_device = {
|
|
||||||
.name = "bfin_sir",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_sir0_resources),
|
|
||||||
.resource = bfin_sir0_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_BFIN_SIR1
|
|
||||||
static struct resource bfin_sir1_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0xFFC02000,
|
|
||||||
.end = 0xFFC020FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = IRQ_UART1_RX,
|
|
||||||
.end = IRQ_UART1_RX+1,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = CH_UART1_RX,
|
|
||||||
.end = CH_UART1_RX+1,
|
|
||||||
.flags = IORESOURCE_DMA,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_sir1_device = {
|
|
||||||
.name = "bfin_sir",
|
|
||||||
.id = 1,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_sir1_resources),
|
|
||||||
.resource = bfin_sir1_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_I2C_BLACKFIN_TWI) || defined(CONFIG_I2C_BLACKFIN_TWI_MODULE)
|
|
||||||
static struct resource bfin_twi0_resource[] = {
|
|
||||||
[0] = {
|
|
||||||
.start = TWI0_REGBASE,
|
|
||||||
.end = TWI0_REGBASE + 0xFF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
[1] = {
|
|
||||||
.start = IRQ_TWI,
|
|
||||||
.end = IRQ_TWI,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device i2c_bfin_twi_device = {
|
|
||||||
.name = "i2c-bfin-twi",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_twi0_resource),
|
|
||||||
.resource = bfin_twi0_resource,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SERIAL_BFIN_SPORT) || defined(CONFIG_SERIAL_BFIN_SPORT_MODULE)
|
|
||||||
static struct platform_device bfin_sport0_uart_device = {
|
|
||||||
.name = "bfin-sport-uart",
|
|
||||||
.id = 0,
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_sport1_uart_device = {
|
|
||||||
.name = "bfin-sport-uart",
|
|
||||||
.id = 1,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static struct platform_device *stamp_devices[] __initdata = {
|
|
||||||
#if defined(CONFIG_BFIN_CFPCMCIA) || defined(CONFIG_BFIN_CFPCMCIA_MODULE)
|
|
||||||
&bfin_pcmcia_cf_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_RTC_DRV_BFIN) || defined(CONFIG_RTC_DRV_BFIN_MODULE)
|
|
||||||
&rtc_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_SL811_HCD) || defined(CONFIG_USB_SL811_HCD_MODULE)
|
|
||||||
&sl811_hcd_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_ISP1362_HCD) || defined(CONFIG_USB_ISP1362_HCD_MODULE)
|
|
||||||
&isp1362_hcd_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
&smc91x_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_DM9000) || defined(CONFIG_DM9000_MODULE)
|
|
||||||
&dm9000_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
|
||||||
&bfin_mii_bus,
|
|
||||||
&bfin_mac_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_NET2272) || defined(CONFIG_USB_NET2272_MODULE)
|
|
||||||
&net2272_bfin_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_USB_ISP1760_HCD) || defined(CONFIG_USB_ISP1760_HCD_MODULE)
|
|
||||||
&bfin_isp1760_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
|
||||||
&bfin_spi0_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_FB_BF537_LQ035) || defined(CONFIG_FB_BF537_LQ035_MODULE)
|
|
||||||
&bfin_fb_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_FB_BFIN_7393) || defined(CONFIG_FB_BFIN_7393_MODULE)
|
|
||||||
&bfin_fb_adv7393_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SERIAL_BFIN) || defined(CONFIG_SERIAL_BFIN_MODULE)
|
|
||||||
&bfin_uart_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
&bfin_sir0_device,
|
|
||||||
#endif
|
|
||||||
#ifdef CONFIG_BFIN_SIR1
|
|
||||||
&bfin_sir1_device,
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_I2C_BLACKFIN_TWI) || defined(CONFIG_I2C_BLACKFIN_TWI_MODULE)
|
|
||||||
&i2c_bfin_twi_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_SERIAL_BFIN_SPORT) || defined(CONFIG_SERIAL_BFIN_SPORT_MODULE)
|
|
||||||
&bfin_sport0_uart_device,
|
|
||||||
&bfin_sport1_uart_device,
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
static int __init generic_init(void)
|
|
||||||
{
|
|
||||||
printk(KERN_INFO "%s(): registering device resources\n", __func__);
|
|
||||||
platform_add_devices(stamp_devices, ARRAY_SIZE(stamp_devices));
|
|
||||||
#if defined(CONFIG_SPI_BFIN) || defined(CONFIG_SPI_BFIN_MODULE)
|
|
||||||
spi_register_board_info(bfin_spi_board_info,
|
|
||||||
ARRAY_SIZE(bfin_spi_board_info));
|
|
||||||
#endif
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
arch_initcall(generic_init);
|
|
||||||
|
|
||||||
void native_machine_restart(char *cmd)
|
|
||||||
{
|
|
||||||
/* workaround reboot hang when booting from SPI */
|
|
||||||
if ((bfin_read_SYSCR() & 0x7) == 0x3)
|
|
||||||
bfin_reset_boot_spi_cs(P_DEFAULT_BOOT_SPI_CS);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_MAC) || defined(CONFIG_BFIN_MAC_MODULE)
|
|
||||||
void bfin_get_ether_addr(char *addr)
|
|
||||||
{
|
|
||||||
random_ether_addr(addr);
|
|
||||||
printk(KERN_WARNING "%s:%s: Setting Ethernet MAC to a random one\n", __FILE__, __func__);
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(bfin_get_ether_addr);
|
|
||||||
#endif
|
|
|
@ -134,9 +134,9 @@ static struct bfin5xx_spi_chip spi_flash_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -156,23 +156,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 5000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 5000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 0,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 5000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -289,9 +289,9 @@ static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -364,23 +364,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
.controller_data = &ad9960_spi_chip_info,
|
.controller_data = &ad9960_spi_chip_info,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 7,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -108,9 +108,9 @@ static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -160,23 +160,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc_dummy",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = 7,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.modalias = "spi_mmc",
|
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
|
||||||
.bus_num = 0,
|
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
|
||||||
.platform_data = NULL,
|
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* File: include/asm-blackfin/mach-bf537/anomaly.h
|
* File: include/asm-blackfin/mach-bf537/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -110,7 +110,7 @@
|
||||||
#define ANOMALY_05000301 (1)
|
#define ANOMALY_05000301 (1)
|
||||||
/* SSYNCs After Writes To CAN/DMA MMR Registers Are Not Always Handled Correctly */
|
/* SSYNCs After Writes To CAN/DMA MMR Registers Are Not Always Handled Correctly */
|
||||||
#define ANOMALY_05000304 (__SILICON_REVISION__ < 3)
|
#define ANOMALY_05000304 (__SILICON_REVISION__ < 3)
|
||||||
/* New Feature: Additional Hysteresis on SPORT Input Pins (Not Available On Older Silicon) */
|
/* SPORT_HYS Bit in PLL_CTL Register Is Not Functional */
|
||||||
#define ANOMALY_05000305 (__SILICON_REVISION__ < 3)
|
#define ANOMALY_05000305 (__SILICON_REVISION__ < 3)
|
||||||
/* SCKELOW Bit Does Not Maintain State Through Hibernate */
|
/* SCKELOW Bit Does Not Maintain State Through Hibernate */
|
||||||
#define ANOMALY_05000307 (__SILICON_REVISION__ < 3)
|
#define ANOMALY_05000307 (__SILICON_REVISION__ < 3)
|
||||||
|
@ -168,9 +168,12 @@
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
#define ANOMALY_05000353 (1)
|
#define ANOMALY_05000353 (1)
|
||||||
#define ANOMALY_05000363 (0)
|
#define ANOMALY_05000363 (0)
|
||||||
|
#define ANOMALY_05000380 (0)
|
||||||
#define ANOMALY_05000386 (1)
|
#define ANOMALY_05000386 (1)
|
||||||
#define ANOMALY_05000412 (0)
|
#define ANOMALY_05000412 (0)
|
||||||
#define ANOMALY_05000432 (0)
|
#define ANOMALY_05000432 (0)
|
||||||
#define ANOMALY_05000435 (0)
|
#define ANOMALY_05000435 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -144,7 +144,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART0_TX,
|
CH_UART0_TX,
|
||||||
CH_UART0_RX,
|
CH_UART0_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -158,7 +158,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART1_TX,
|
CH_UART1_TX,
|
||||||
CH_UART1_RX,
|
CH_UART1_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART1_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART1_CTS_PIN,
|
CONFIG_UART1_CTS_PIN,
|
||||||
CONFIG_UART1_RTS_PIN,
|
CONFIG_UART1_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
* File: include/asm-blackfin/mach-bf538/anomaly.h
|
* File: include/asm-blackfin/mach-bf538/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -120,13 +120,17 @@
|
||||||
#define ANOMALY_05000198 (0)
|
#define ANOMALY_05000198 (0)
|
||||||
#define ANOMALY_05000230 (0)
|
#define ANOMALY_05000230 (0)
|
||||||
#define ANOMALY_05000263 (0)
|
#define ANOMALY_05000263 (0)
|
||||||
|
#define ANOMALY_05000305 (0)
|
||||||
#define ANOMALY_05000311 (0)
|
#define ANOMALY_05000311 (0)
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
#define ANOMALY_05000353 (1)
|
#define ANOMALY_05000353 (1)
|
||||||
#define ANOMALY_05000363 (0)
|
#define ANOMALY_05000363 (0)
|
||||||
|
#define ANOMALY_05000380 (0)
|
||||||
#define ANOMALY_05000386 (1)
|
#define ANOMALY_05000386 (1)
|
||||||
#define ANOMALY_05000412 (0)
|
#define ANOMALY_05000412 (0)
|
||||||
#define ANOMALY_05000432 (0)
|
#define ANOMALY_05000432 (0)
|
||||||
#define ANOMALY_05000435 (0)
|
#define ANOMALY_05000435 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -144,7 +144,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART0_TX,
|
CH_UART0_TX,
|
||||||
CH_UART0_RX,
|
CH_UART0_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -158,7 +158,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART1_TX,
|
CH_UART1_TX,
|
||||||
CH_UART1_RX,
|
CH_UART1_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART1_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART1_CTS_PIN,
|
CONFIG_UART1_CTS_PIN,
|
||||||
CONFIG_UART1_RTS_PIN,
|
CONFIG_UART1_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2,12 +2,12 @@
|
||||||
* File: include/asm-blackfin/mach-bf548/anomaly.h
|
* File: include/asm-blackfin/mach-bf548/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* This file shoule be up to date with:
|
/* This file shoule be up to date with:
|
||||||
* - Revision G, 08/07/2008; ADSP-BF542/BF544/BF547/BF548/BF549 Blackfin Processor Anomaly List
|
* - Revision H, 01/16/2009; ADSP-BF542/BF544/BF547/BF548/BF549 Blackfin Processor Anomaly List
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef _MACH_ANOMALY_H_
|
#ifndef _MACH_ANOMALY_H_
|
||||||
|
@ -91,8 +91,6 @@
|
||||||
#define ANOMALY_05000371 (__SILICON_REVISION__ < 2)
|
#define ANOMALY_05000371 (__SILICON_REVISION__ < 2)
|
||||||
/* USB DP/DM Data Pins May Lose State When Entering Hibernate */
|
/* USB DP/DM Data Pins May Lose State When Entering Hibernate */
|
||||||
#define ANOMALY_05000372 (__SILICON_REVISION__ < 1)
|
#define ANOMALY_05000372 (__SILICON_REVISION__ < 1)
|
||||||
/* Mobile DDR Operation Not Functional */
|
|
||||||
#define ANOMALY_05000377 (1)
|
|
||||||
/* Security/Authentication Speedpath Causes Authentication To Fail To Initiate */
|
/* Security/Authentication Speedpath Causes Authentication To Fail To Initiate */
|
||||||
#define ANOMALY_05000378 (__SILICON_REVISION__ < 2)
|
#define ANOMALY_05000378 (__SILICON_REVISION__ < 2)
|
||||||
/* 16-Bit NAND FLASH Boot Mode Is Not Functional */
|
/* 16-Bit NAND FLASH Boot Mode Is Not Functional */
|
||||||
|
@ -157,8 +155,22 @@
|
||||||
#define ANOMALY_05000429 (__SILICON_REVISION__ < 2)
|
#define ANOMALY_05000429 (__SILICON_REVISION__ < 2)
|
||||||
/* Software System Reset Corrupts PLL_LOCKCNT Register */
|
/* Software System Reset Corrupts PLL_LOCKCNT Register */
|
||||||
#define ANOMALY_05000430 (__SILICON_REVISION__ >= 2)
|
#define ANOMALY_05000430 (__SILICON_REVISION__ >= 2)
|
||||||
|
/* Incorrect Use of Stack in Lockbox Firmware During Authentication */
|
||||||
|
#define ANOMALY_05000431 (__SILICON_REVISION__ < 3)
|
||||||
|
/* OTP Write Accesses Not Supported */
|
||||||
|
#define ANOMALY_05000442 (__SILICON_REVISION__ < 1)
|
||||||
/* IFLUSH Instruction at End of Hardware Loop Causes Infinite Stall */
|
/* IFLUSH Instruction at End of Hardware Loop Causes Infinite Stall */
|
||||||
#define ANOMALY_05000443 (1)
|
#define ANOMALY_05000443 (1)
|
||||||
|
/* CDMAPRIO and L2DMAPRIO Bits in the SYSCR Register Are Not Functional */
|
||||||
|
#define ANOMALY_05000446 (1)
|
||||||
|
/* UART IrDA Receiver Fails on Extended Bit Pulses */
|
||||||
|
#define ANOMALY_05000447 (1)
|
||||||
|
/* DDR Clock Duty Cycle Spec Violation (tCH, tCL) */
|
||||||
|
#define ANOMALY_05000448 (__SILICON_REVISION__ == 1)
|
||||||
|
/* Reduced Timing Margins on DDR Output Setup and Hold (tDS and tDH) */
|
||||||
|
#define ANOMALY_05000449 (__SILICON_REVISION__ == 1)
|
||||||
|
/* USB DMA Mode 1 Short Packet Data Corruption */
|
||||||
|
#define ANOMALY_05000450 (1
|
||||||
|
|
||||||
/* Anomalies that don't exist on this proc */
|
/* Anomalies that don't exist on this proc */
|
||||||
#define ANOMALY_05000125 (0)
|
#define ANOMALY_05000125 (0)
|
||||||
|
@ -171,6 +183,8 @@
|
||||||
#define ANOMALY_05000263 (0)
|
#define ANOMALY_05000263 (0)
|
||||||
#define ANOMALY_05000266 (0)
|
#define ANOMALY_05000266 (0)
|
||||||
#define ANOMALY_05000273 (0)
|
#define ANOMALY_05000273 (0)
|
||||||
|
#define ANOMALY_05000278 (0)
|
||||||
|
#define ANOMALY_05000305 (0)
|
||||||
#define ANOMALY_05000307 (0)
|
#define ANOMALY_05000307 (0)
|
||||||
#define ANOMALY_05000311 (0)
|
#define ANOMALY_05000311 (0)
|
||||||
#define ANOMALY_05000323 (0)
|
#define ANOMALY_05000323 (0)
|
||||||
|
|
|
@ -63,7 +63,7 @@
|
||||||
#define UART_ENABLE_INTS(x, v) UART_SET_IER(x, v)
|
#define UART_ENABLE_INTS(x, v) UART_SET_IER(x, v)
|
||||||
#define UART_DISABLE_INTS(x) UART_CLEAR_IER(x, 0xF)
|
#define UART_DISABLE_INTS(x) UART_CLEAR_IER(x, 0xF)
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_UART0_CTSRTS) || defined(CONFIG_BFIN_UART1_CTSRTS)
|
#if defined(CONFIG_BFIN_UART0_CTSRTS) || defined(CONFIG_BFIN_UART2_CTSRTS)
|
||||||
# define CONFIG_SERIAL_BFIN_CTSRTS
|
# define CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
|
|
||||||
# ifndef CONFIG_UART0_CTS_PIN
|
# ifndef CONFIG_UART0_CTS_PIN
|
||||||
|
@ -74,12 +74,12 @@
|
||||||
# define CONFIG_UART0_RTS_PIN -1
|
# define CONFIG_UART0_RTS_PIN -1
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifndef CONFIG_UART1_CTS_PIN
|
# ifndef CONFIG_UART2_CTS_PIN
|
||||||
# define CONFIG_UART1_CTS_PIN -1
|
# define CONFIG_UART2_CTS_PIN -1
|
||||||
# endif
|
# endif
|
||||||
|
|
||||||
# ifndef CONFIG_UART1_RTS_PIN
|
# ifndef CONFIG_UART2_RTS_PIN
|
||||||
# define CONFIG_UART1_RTS_PIN -1
|
# define CONFIG_UART2_RTS_PIN -1
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -130,7 +130,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART0_TX,
|
CH_UART0_TX,
|
||||||
CH_UART0_RX,
|
CH_UART0_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -143,6 +143,10 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
#ifdef CONFIG_SERIAL_BFIN_DMA
|
#ifdef CONFIG_SERIAL_BFIN_DMA
|
||||||
CH_UART1_TX,
|
CH_UART1_TX,
|
||||||
CH_UART1_RX,
|
CH_UART1_RX,
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
|
0,
|
||||||
|
0,
|
||||||
#endif
|
#endif
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
@ -154,7 +158,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART2_TX,
|
CH_UART2_TX,
|
||||||
CH_UART2_RX,
|
CH_UART2_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART2_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART2_CTS_PIN,
|
CONFIG_UART2_CTS_PIN,
|
||||||
CONFIG_UART2_RTS_PIN,
|
CONFIG_UART2_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
@ -167,6 +171,10 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
#ifdef CONFIG_SERIAL_BFIN_DMA
|
#ifdef CONFIG_SERIAL_BFIN_DMA
|
||||||
CH_UART3_TX,
|
CH_UART3_TX,
|
||||||
CH_UART3_RX,
|
CH_UART3_RX,
|
||||||
|
#endif
|
||||||
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
|
0,
|
||||||
|
0,
|
||||||
#endif
|
#endif
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -123,8 +123,8 @@ Events (highest priority) EMU 0
|
||||||
#define IRQ_MXVR_ERROR BFIN_IRQ(51) /* MXVR Status (Error) Interrupt */
|
#define IRQ_MXVR_ERROR BFIN_IRQ(51) /* MXVR Status (Error) Interrupt */
|
||||||
#define IRQ_MXVR_MSG BFIN_IRQ(52) /* MXVR Message Interrupt */
|
#define IRQ_MXVR_MSG BFIN_IRQ(52) /* MXVR Message Interrupt */
|
||||||
#define IRQ_MXVR_PKT BFIN_IRQ(53) /* MXVR Packet Interrupt */
|
#define IRQ_MXVR_PKT BFIN_IRQ(53) /* MXVR Packet Interrupt */
|
||||||
#define IRQ_EPP1_ERROR BFIN_IRQ(54) /* EPPI1 Error Interrupt */
|
#define IRQ_EPPI1_ERROR BFIN_IRQ(54) /* EPPI1 Error Interrupt */
|
||||||
#define IRQ_EPP2_ERROR BFIN_IRQ(55) /* EPPI2 Error Interrupt */
|
#define IRQ_EPPI2_ERROR BFIN_IRQ(55) /* EPPI2 Error Interrupt */
|
||||||
#define IRQ_UART3_ERROR BFIN_IRQ(56) /* UART3 Status (Error) Interrupt */
|
#define IRQ_UART3_ERROR BFIN_IRQ(56) /* UART3 Status (Error) Interrupt */
|
||||||
#define IRQ_HOST_ERROR BFIN_IRQ(57) /* HOST Status (Error) Interrupt */
|
#define IRQ_HOST_ERROR BFIN_IRQ(57) /* HOST Status (Error) Interrupt */
|
||||||
#define IRQ_PIXC_ERROR BFIN_IRQ(59) /* PIXC Status (Error) Interrupt */
|
#define IRQ_PIXC_ERROR BFIN_IRQ(59) /* PIXC Status (Error) Interrupt */
|
||||||
|
@ -361,8 +361,8 @@ Events (highest priority) EMU 0
|
||||||
#define IRQ_UART2_ERR IRQ_UART2_ERROR
|
#define IRQ_UART2_ERR IRQ_UART2_ERROR
|
||||||
#define IRQ_CAN0_ERR IRQ_CAN0_ERROR
|
#define IRQ_CAN0_ERR IRQ_CAN0_ERROR
|
||||||
#define IRQ_MXVR_ERR IRQ_MXVR_ERROR
|
#define IRQ_MXVR_ERR IRQ_MXVR_ERROR
|
||||||
#define IRQ_EPP1_ERR IRQ_EPP1_ERROR
|
#define IRQ_EPPI1_ERR IRQ_EPPI1_ERROR
|
||||||
#define IRQ_EPP2_ERR IRQ_EPP2_ERROR
|
#define IRQ_EPPI2_ERR IRQ_EPPI2_ERROR
|
||||||
#define IRQ_UART3_ERR IRQ_UART3_ERROR
|
#define IRQ_UART3_ERR IRQ_UART3_ERROR
|
||||||
#define IRQ_HOST_ERR IRQ_HOST_ERROR
|
#define IRQ_HOST_ERR IRQ_HOST_ERROR
|
||||||
#define IRQ_PIXC_ERR IRQ_PIXC_ERROR
|
#define IRQ_PIXC_ERR IRQ_PIXC_ERROR
|
||||||
|
|
|
@ -19,9 +19,4 @@ config BFIN561_BLUETECHNIX_CM
|
||||||
help
|
help
|
||||||
CM-BF561 support for EVAL- and DEV-Board.
|
CM-BF561 support for EVAL- and DEV-Board.
|
||||||
|
|
||||||
config GENERIC_BF561_BOARD
|
|
||||||
bool "Generic"
|
|
||||||
help
|
|
||||||
Generic or Custom board support.
|
|
||||||
|
|
||||||
endchoice
|
endchoice
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
# arch/blackfin/mach-bf561/boards/Makefile
|
# arch/blackfin/mach-bf561/boards/Makefile
|
||||||
#
|
#
|
||||||
|
|
||||||
obj-$(CONFIG_GENERIC_BF561_BOARD) += generic_board.o
|
|
||||||
obj-$(CONFIG_BFIN561_BLUETECHNIX_CM) += cm_bf561.o
|
obj-$(CONFIG_BFIN561_BLUETECHNIX_CM) += cm_bf561.o
|
||||||
obj-$(CONFIG_BFIN561_EZKIT) += ezkit.o
|
obj-$(CONFIG_BFIN561_EZKIT) += ezkit.o
|
||||||
obj-$(CONFIG_BFIN561_TEPLA) += tepla.o
|
obj-$(CONFIG_BFIN561_TEPLA) += tepla.o
|
||||||
|
|
|
@ -105,9 +105,9 @@ static struct bfin5xx_spi_chip ad9960_spi_chip_info = {
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
static struct bfin5xx_spi_chip spi_mmc_chip_info = {
|
static struct bfin5xx_spi_chip mmc_spi_chip_info = {
|
||||||
.enable_dma = 1,
|
.enable_dma = 0,
|
||||||
.bits_per_word = 8,
|
.bits_per_word = 8,
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
@ -155,14 +155,13 @@ static struct spi_board_info bfin_spi_board_info[] __initdata = {
|
||||||
.controller_data = &ad9960_spi_chip_info,
|
.controller_data = &ad9960_spi_chip_info,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
#if defined(CONFIG_SPI_MMC) || defined(CONFIG_SPI_MMC_MODULE)
|
#if defined(CONFIG_MMC_SPI) || defined(CONFIG_MMC_SPI_MODULE)
|
||||||
{
|
{
|
||||||
.modalias = "spi_mmc",
|
.modalias = "mmc_spi",
|
||||||
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
.max_speed_hz = 25000000, /* max spi clock (SCK) speed in HZ */
|
||||||
.bus_num = 0,
|
.bus_num = 0,
|
||||||
.chip_select = CONFIG_SPI_MMC_CS_CHAN,
|
.chip_select = 5,
|
||||||
.platform_data = NULL,
|
.controller_data = &mmc_spi_chip_info,
|
||||||
.controller_data = &spi_mmc_chip_info,
|
|
||||||
.mode = SPI_MODE_3,
|
.mode = SPI_MODE_3,
|
||||||
},
|
},
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1,113 +0,0 @@
|
||||||
/*
|
|
||||||
* File: arch/blackfin/mach-bf561/generic_board.c
|
|
||||||
* Based on: arch/blackfin/mach-bf533/ezkit.c
|
|
||||||
* Author: Aidan Williams <aidan@nicta.com.au>
|
|
||||||
*
|
|
||||||
* Created:
|
|
||||||
* Description:
|
|
||||||
*
|
|
||||||
* Modified:
|
|
||||||
* Copyright 2005 National ICT Australia (NICTA)
|
|
||||||
* Copyright 2004-2006 Analog Devices Inc.
|
|
||||||
*
|
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
|
||||||
*
|
|
||||||
* This program is free software; you can redistribute it and/or modify
|
|
||||||
* it under the terms of the GNU General Public License as published by
|
|
||||||
* the Free Software Foundation; either version 2 of the License, or
|
|
||||||
* (at your option) any later version.
|
|
||||||
*
|
|
||||||
* This program is distributed in the hope that it will be useful,
|
|
||||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
* GNU General Public License for more details.
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License
|
|
||||||
* along with this program; if not, see the file COPYING, or write
|
|
||||||
* to the Free Software Foundation, Inc.,
|
|
||||||
* 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include <linux/device.h>
|
|
||||||
#include <linux/platform_device.h>
|
|
||||||
#include <linux/irq.h>
|
|
||||||
|
|
||||||
const char bfin_board_name[] = "UNKNOWN BOARD";
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Driver needs to know address, irq and flag pin.
|
|
||||||
*/
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
static struct resource smc91x_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0x2C010300,
|
|
||||||
.end = 0x2C010300 + 16,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PROG_INTB,
|
|
||||||
.end = IRQ_PROG_INTB,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
}, {
|
|
||||||
.start = IRQ_PF9,
|
|
||||||
.end = IRQ_PF9,
|
|
||||||
.flags = IORESOURCE_IRQ | IORESOURCE_IRQ_HIGHLEVEL,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device smc91x_device = {
|
|
||||||
.name = "smc91x",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(smc91x_resources),
|
|
||||||
.resource = smc91x_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
static struct resource bfin_sir0_resources[] = {
|
|
||||||
{
|
|
||||||
.start = 0xFFC00400,
|
|
||||||
.end = 0xFFC004FF,
|
|
||||||
.flags = IORESOURCE_MEM,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = IRQ_UART0_RX,
|
|
||||||
.end = IRQ_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_IRQ,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
.start = CH_UART0_RX,
|
|
||||||
.end = CH_UART0_RX+1,
|
|
||||||
.flags = IORESOURCE_DMA,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct platform_device bfin_sir0_device = {
|
|
||||||
.name = "bfin_sir",
|
|
||||||
.id = 0,
|
|
||||||
.num_resources = ARRAY_SIZE(bfin_sir0_resources),
|
|
||||||
.resource = bfin_sir0_resources,
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static struct platform_device *generic_board_devices[] __initdata = {
|
|
||||||
#if defined(CONFIG_SMC91X) || defined(CONFIG_SMC91X_MODULE)
|
|
||||||
&smc91x_device,
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_BFIN_SIR) || defined(CONFIG_BFIN_SIR_MODULE)
|
|
||||||
#ifdef CONFIG_BFIN_SIR0
|
|
||||||
&bfin_sir0_device,
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
|
|
||||||
static int __init generic_board_init(void)
|
|
||||||
{
|
|
||||||
printk(KERN_INFO "%s(): registering device resources\n", __func__);
|
|
||||||
return platform_add_devices(generic_board_devices,
|
|
||||||
ARRAY_SIZE(generic_board_devices));
|
|
||||||
}
|
|
||||||
|
|
||||||
arch_initcall(generic_board_init);
|
|
|
@ -2,7 +2,7 @@
|
||||||
* File: include/asm-blackfin/mach-bf561/anomaly.h
|
* File: include/asm-blackfin/mach-bf561/anomaly.h
|
||||||
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
* Bugs: Enter bugs at http://blackfin.uclinux.org/
|
||||||
*
|
*
|
||||||
* Copyright (C) 2004-2008 Analog Devices Inc.
|
* Copyright (C) 2004-2009 Analog Devices Inc.
|
||||||
* Licensed under the GPL-2 or later.
|
* Licensed under the GPL-2 or later.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -224,7 +224,7 @@
|
||||||
#define ANOMALY_05000301 (1)
|
#define ANOMALY_05000301 (1)
|
||||||
/* SSYNCs After Writes To DMA MMR Registers May Not Be Handled Correctly */
|
/* SSYNCs After Writes To DMA MMR Registers May Not Be Handled Correctly */
|
||||||
#define ANOMALY_05000302 (1)
|
#define ANOMALY_05000302 (1)
|
||||||
/* New Feature: Additional Hysteresis on SPORT Input Pins (Not Available On Older Silicon) */
|
/* SPORT_HYS Bit in PLL_CTL Register Is Not Functional */
|
||||||
#define ANOMALY_05000305 (__SILICON_REVISION__ < 5)
|
#define ANOMALY_05000305 (__SILICON_REVISION__ < 5)
|
||||||
/* SCKELOW Bit Does Not Maintain State Through Hibernate */
|
/* SCKELOW Bit Does Not Maintain State Through Hibernate */
|
||||||
#define ANOMALY_05000307 (__SILICON_REVISION__ < 5)
|
#define ANOMALY_05000307 (__SILICON_REVISION__ < 5)
|
||||||
|
@ -283,8 +283,11 @@
|
||||||
#define ANOMALY_05000273 (0)
|
#define ANOMALY_05000273 (0)
|
||||||
#define ANOMALY_05000311 (0)
|
#define ANOMALY_05000311 (0)
|
||||||
#define ANOMALY_05000353 (1)
|
#define ANOMALY_05000353 (1)
|
||||||
|
#define ANOMALY_05000380 (0)
|
||||||
#define ANOMALY_05000386 (1)
|
#define ANOMALY_05000386 (1)
|
||||||
#define ANOMALY_05000432 (0)
|
#define ANOMALY_05000432 (0)
|
||||||
#define ANOMALY_05000435 (0)
|
#define ANOMALY_05000435 (0)
|
||||||
|
#define ANOMALY_05000447 (0)
|
||||||
|
#define ANOMALY_05000448 (0)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -134,7 +134,7 @@ struct bfin_serial_res bfin_serial_resource[] = {
|
||||||
CH_UART_TX,
|
CH_UART_TX,
|
||||||
CH_UART_RX,
|
CH_UART_RX,
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BFIN_UART0_CTSRTS
|
#ifdef CONFIG_SERIAL_BFIN_CTSRTS
|
||||||
CONFIG_UART0_CTS_PIN,
|
CONFIG_UART0_CTS_PIN,
|
||||||
CONFIG_UART0_RTS_PIN,
|
CONFIG_UART0_RTS_PIN,
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -62,3 +62,12 @@
|
||||||
#if (CONFIG_BOOT_LOAD & 0x3)
|
#if (CONFIG_BOOT_LOAD & 0x3)
|
||||||
# error "The kernel load address must be 4 byte aligned"
|
# error "The kernel load address must be 4 byte aligned"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* The entire kernel must be able to make a 24bit pcrel call to start of L1 */
|
||||||
|
#if ((0xffffffff - L1_CODE_START + 1) + CONFIG_BOOT_LOAD) > 0x1000000
|
||||||
|
# error "The kernel load address is too high; keep it below 10meg for safety"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if ANOMALY_05000448
|
||||||
|
# error You are using a part with anomaly 05000448, this issue causes random memory read/write failures - that means random crashes.
|
||||||
|
#endif
|
||||||
|
|
|
@ -66,11 +66,33 @@
|
||||||
|
|
||||||
/* Invalidate all instruction cache lines assocoiated with this memory area */
|
/* Invalidate all instruction cache lines assocoiated with this memory area */
|
||||||
ENTRY(_blackfin_icache_flush_range)
|
ENTRY(_blackfin_icache_flush_range)
|
||||||
|
/*
|
||||||
|
* Walkaround to avoid loading wrong instruction after invalidating icache
|
||||||
|
* and following sequence is met.
|
||||||
|
*
|
||||||
|
* 1) One instruction address is cached in the instruction cache.
|
||||||
|
* 2) This instruction in SDRAM is changed.
|
||||||
|
* 3) IFLASH[P0] is executed only once in blackfin_icache_flush_range().
|
||||||
|
* 4) This instruction is executed again, but the old one is loaded.
|
||||||
|
*/
|
||||||
|
P0 = R0;
|
||||||
|
IFLUSH[P0];
|
||||||
do_flush IFLUSH, , nop
|
do_flush IFLUSH, , nop
|
||||||
ENDPROC(_blackfin_icache_flush_range)
|
ENDPROC(_blackfin_icache_flush_range)
|
||||||
|
|
||||||
/* Flush all cache lines assocoiated with this area of memory. */
|
/* Flush all cache lines assocoiated with this area of memory. */
|
||||||
ENTRY(_blackfin_icache_dcache_flush_range)
|
ENTRY(_blackfin_icache_dcache_flush_range)
|
||||||
|
/*
|
||||||
|
* Walkaround to avoid loading wrong instruction after invalidating icache
|
||||||
|
* and following sequence is met.
|
||||||
|
*
|
||||||
|
* 1) One instruction address is cached in the instruction cache.
|
||||||
|
* 2) This instruction in SDRAM is changed.
|
||||||
|
* 3) IFLASH[P0] is executed only once in blackfin_icache_flush_range().
|
||||||
|
* 4) This instruction is executed again, but the old one is loaded.
|
||||||
|
*/
|
||||||
|
P0 = R0;
|
||||||
|
IFLUSH[P0];
|
||||||
do_flush FLUSH, IFLUSH
|
do_flush FLUSH, IFLUSH
|
||||||
ENDPROC(_blackfin_icache_dcache_flush_range)
|
ENDPROC(_blackfin_icache_dcache_flush_range)
|
||||||
|
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
#define SDGCTL_WIDTH (1 << 31) /* SDRAM external data path width */
|
#define SDGCTL_WIDTH (1 << 31) /* SDRAM external data path width */
|
||||||
#define PLL_CTL_VAL \
|
#define PLL_CTL_VAL \
|
||||||
(((CONFIG_VCO_MULT & 63) << 9) | CLKIN_HALF | \
|
(((CONFIG_VCO_MULT & 63) << 9) | CLKIN_HALF | \
|
||||||
(PLL_BYPASS << 8) | (ANOMALY_05000265 ? 0x8000 : 0))
|
(PLL_BYPASS << 8) | (ANOMALY_05000305 ? 0 : 0x8000))
|
||||||
|
|
||||||
__attribute__((l1_text))
|
__attribute__((l1_text))
|
||||||
static void do_sync(void)
|
static void do_sync(void)
|
||||||
|
|
|
@ -376,10 +376,22 @@ ENTRY(_do_hibernate)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef PINT0_ASSIGN
|
#ifdef PINT0_ASSIGN
|
||||||
|
PM_SYS_PUSH(PINT0_MASK_SET)
|
||||||
|
PM_SYS_PUSH(PINT1_MASK_SET)
|
||||||
|
PM_SYS_PUSH(PINT2_MASK_SET)
|
||||||
|
PM_SYS_PUSH(PINT3_MASK_SET)
|
||||||
PM_SYS_PUSH(PINT0_ASSIGN)
|
PM_SYS_PUSH(PINT0_ASSIGN)
|
||||||
PM_SYS_PUSH(PINT1_ASSIGN)
|
PM_SYS_PUSH(PINT1_ASSIGN)
|
||||||
PM_SYS_PUSH(PINT2_ASSIGN)
|
PM_SYS_PUSH(PINT2_ASSIGN)
|
||||||
PM_SYS_PUSH(PINT3_ASSIGN)
|
PM_SYS_PUSH(PINT3_ASSIGN)
|
||||||
|
PM_SYS_PUSH(PINT0_INVERT_SET)
|
||||||
|
PM_SYS_PUSH(PINT1_INVERT_SET)
|
||||||
|
PM_SYS_PUSH(PINT2_INVERT_SET)
|
||||||
|
PM_SYS_PUSH(PINT3_INVERT_SET)
|
||||||
|
PM_SYS_PUSH(PINT0_EDGE_SET)
|
||||||
|
PM_SYS_PUSH(PINT1_EDGE_SET)
|
||||||
|
PM_SYS_PUSH(PINT2_EDGE_SET)
|
||||||
|
PM_SYS_PUSH(PINT3_EDGE_SET)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
PM_SYS_PUSH(EBIU_AMBCTL0)
|
PM_SYS_PUSH(EBIU_AMBCTL0)
|
||||||
|
@ -714,10 +726,22 @@ ENTRY(_do_hibernate)
|
||||||
PM_SYS_POP(EBIU_AMBCTL0)
|
PM_SYS_POP(EBIU_AMBCTL0)
|
||||||
|
|
||||||
#ifdef PINT0_ASSIGN
|
#ifdef PINT0_ASSIGN
|
||||||
|
PM_SYS_POP(PINT3_EDGE_SET)
|
||||||
|
PM_SYS_POP(PINT2_EDGE_SET)
|
||||||
|
PM_SYS_POP(PINT1_EDGE_SET)
|
||||||
|
PM_SYS_POP(PINT0_EDGE_SET)
|
||||||
|
PM_SYS_POP(PINT3_INVERT_SET)
|
||||||
|
PM_SYS_POP(PINT2_INVERT_SET)
|
||||||
|
PM_SYS_POP(PINT1_INVERT_SET)
|
||||||
|
PM_SYS_POP(PINT0_INVERT_SET)
|
||||||
PM_SYS_POP(PINT3_ASSIGN)
|
PM_SYS_POP(PINT3_ASSIGN)
|
||||||
PM_SYS_POP(PINT2_ASSIGN)
|
PM_SYS_POP(PINT2_ASSIGN)
|
||||||
PM_SYS_POP(PINT1_ASSIGN)
|
PM_SYS_POP(PINT1_ASSIGN)
|
||||||
PM_SYS_POP(PINT0_ASSIGN)
|
PM_SYS_POP(PINT0_ASSIGN)
|
||||||
|
PM_SYS_POP(PINT3_MASK_SET)
|
||||||
|
PM_SYS_POP(PINT2_MASK_SET)
|
||||||
|
PM_SYS_POP(PINT1_MASK_SET)
|
||||||
|
PM_SYS_POP(PINT0_MASK_SET)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef SICA_IWR1
|
#ifdef SICA_IWR1
|
||||||
|
|
|
@ -600,6 +600,19 @@ ENTRY(_system_call)
|
||||||
p2 = [p2];
|
p2 = [p2];
|
||||||
|
|
||||||
[p2+(TASK_THREAD+THREAD_KSP)] = sp;
|
[p2+(TASK_THREAD+THREAD_KSP)] = sp;
|
||||||
|
#ifdef CONFIG_IPIPE
|
||||||
|
r0 = sp;
|
||||||
|
SP += -12;
|
||||||
|
call ___ipipe_syscall_root;
|
||||||
|
SP += 12;
|
||||||
|
cc = r0 == 1;
|
||||||
|
if cc jump .Lsyscall_really_exit;
|
||||||
|
cc = r0 == -1;
|
||||||
|
if cc jump .Lresume_userspace;
|
||||||
|
r3 = [sp + PT_R3];
|
||||||
|
r4 = [sp + PT_R4];
|
||||||
|
p0 = [sp + PT_ORIG_P0];
|
||||||
|
#endif /* CONFIG_IPIPE */
|
||||||
|
|
||||||
/* Check the System Call */
|
/* Check the System Call */
|
||||||
r7 = __NR_syscall;
|
r7 = __NR_syscall;
|
||||||
|
@ -654,6 +667,17 @@ ENTRY(_system_call)
|
||||||
r7 = r7 & r4;
|
r7 = r7 & r4;
|
||||||
|
|
||||||
.Lsyscall_resched:
|
.Lsyscall_resched:
|
||||||
|
#ifdef CONFIG_IPIPE
|
||||||
|
cc = BITTST(r7, TIF_IRQ_SYNC);
|
||||||
|
if !cc jump .Lsyscall_no_irqsync;
|
||||||
|
[--sp] = reti;
|
||||||
|
r0 = [sp++];
|
||||||
|
SP += -12;
|
||||||
|
call ___ipipe_sync_root;
|
||||||
|
SP += 12;
|
||||||
|
jump .Lresume_userspace_1;
|
||||||
|
.Lsyscall_no_irqsync:
|
||||||
|
#endif
|
||||||
cc = BITTST(r7, TIF_NEED_RESCHED);
|
cc = BITTST(r7, TIF_NEED_RESCHED);
|
||||||
if !cc jump .Lsyscall_sigpending;
|
if !cc jump .Lsyscall_sigpending;
|
||||||
|
|
||||||
|
@ -685,6 +709,10 @@ ENTRY(_system_call)
|
||||||
.Lsyscall_really_exit:
|
.Lsyscall_really_exit:
|
||||||
r5 = [sp + PT_RESERVED];
|
r5 = [sp + PT_RESERVED];
|
||||||
rets = r5;
|
rets = r5;
|
||||||
|
#ifdef CONFIG_IPIPE
|
||||||
|
[--sp] = reti;
|
||||||
|
r5 = [sp++];
|
||||||
|
#endif /* CONFIG_IPIPE */
|
||||||
rts;
|
rts;
|
||||||
ENDPROC(_system_call)
|
ENDPROC(_system_call)
|
||||||
|
|
||||||
|
@ -771,6 +799,15 @@ _new_old_task:
|
||||||
ENDPROC(_resume)
|
ENDPROC(_resume)
|
||||||
|
|
||||||
ENTRY(_ret_from_exception)
|
ENTRY(_ret_from_exception)
|
||||||
|
#ifdef CONFIG_IPIPE
|
||||||
|
[--sp] = rets;
|
||||||
|
SP += -12;
|
||||||
|
call ___ipipe_check_root
|
||||||
|
SP += 12
|
||||||
|
rets = [sp++];
|
||||||
|
cc = r0 == 0;
|
||||||
|
if cc jump 4f; /* not on behalf of Linux, get out */
|
||||||
|
#endif /* CONFIG_IPIPE */
|
||||||
p2.l = lo(IPEND);
|
p2.l = lo(IPEND);
|
||||||
p2.h = hi(IPEND);
|
p2.h = hi(IPEND);
|
||||||
|
|
||||||
|
@ -827,6 +864,28 @@ ENTRY(_ret_from_exception)
|
||||||
rts;
|
rts;
|
||||||
ENDPROC(_ret_from_exception)
|
ENDPROC(_ret_from_exception)
|
||||||
|
|
||||||
|
#ifdef CONFIG_IPIPE
|
||||||
|
|
||||||
|
_sync_root_irqs:
|
||||||
|
[--sp] = reti; /* Reenable interrupts */
|
||||||
|
r0 = [sp++];
|
||||||
|
jump.l ___ipipe_sync_root
|
||||||
|
|
||||||
|
_resume_kernel_from_int:
|
||||||
|
r0.l = _sync_root_irqs
|
||||||
|
r0.h = _sync_root_irqs
|
||||||
|
[--sp] = rets;
|
||||||
|
[--sp] = ( r7:4, p5:3 );
|
||||||
|
SP += -12;
|
||||||
|
call ___ipipe_call_irqtail
|
||||||
|
SP += 12;
|
||||||
|
( r7:4, p5:3 ) = [sp++];
|
||||||
|
rets = [sp++];
|
||||||
|
rts
|
||||||
|
#else
|
||||||
|
#define _resume_kernel_from_int 2f
|
||||||
|
#endif
|
||||||
|
|
||||||
ENTRY(_return_from_int)
|
ENTRY(_return_from_int)
|
||||||
/* If someone else already raised IRQ 15, do nothing. */
|
/* If someone else already raised IRQ 15, do nothing. */
|
||||||
csync;
|
csync;
|
||||||
|
@ -848,7 +907,7 @@ ENTRY(_return_from_int)
|
||||||
r1 = r0 - r1;
|
r1 = r0 - r1;
|
||||||
r2 = r0 & r1;
|
r2 = r0 & r1;
|
||||||
cc = r2 == 0;
|
cc = r2 == 0;
|
||||||
if !cc jump 2f;
|
if !cc jump _resume_kernel_from_int;
|
||||||
|
|
||||||
/* Lower the interrupt level to 15. */
|
/* Lower the interrupt level to 15. */
|
||||||
p0.l = lo(EVT15);
|
p0.l = lo(EVT15);
|
||||||
|
|
|
@ -235,6 +235,7 @@ ENDPROC(_evt_system_call)
|
||||||
|
|
||||||
#ifdef CONFIG_IPIPE
|
#ifdef CONFIG_IPIPE
|
||||||
ENTRY(___ipipe_call_irqtail)
|
ENTRY(___ipipe_call_irqtail)
|
||||||
|
p0 = r0;
|
||||||
r0.l = 1f;
|
r0.l = 1f;
|
||||||
r0.h = 1f;
|
r0.h = 1f;
|
||||||
reti = r0;
|
reti = r0;
|
||||||
|
@ -242,9 +243,6 @@ ENTRY(___ipipe_call_irqtail)
|
||||||
1:
|
1:
|
||||||
[--sp] = rets;
|
[--sp] = rets;
|
||||||
[--sp] = ( r7:4, p5:3 );
|
[--sp] = ( r7:4, p5:3 );
|
||||||
p0.l = ___ipipe_irq_tail_hook;
|
|
||||||
p0.h = ___ipipe_irq_tail_hook;
|
|
||||||
p0 = [p0];
|
|
||||||
sp += -12;
|
sp += -12;
|
||||||
call (p0);
|
call (p0);
|
||||||
sp += 12;
|
sp += 12;
|
||||||
|
@ -259,7 +257,7 @@ ENTRY(___ipipe_call_irqtail)
|
||||||
p0.h = hi(EVT14);
|
p0.h = hi(EVT14);
|
||||||
[p0] = r0;
|
[p0] = r0;
|
||||||
csync;
|
csync;
|
||||||
r0 = 0x401f;
|
r0 = 0x401f (z);
|
||||||
sti r0;
|
sti r0;
|
||||||
raise 14;
|
raise 14;
|
||||||
[--sp] = reti; /* IRQs on. */
|
[--sp] = reti; /* IRQs on. */
|
||||||
|
@ -277,11 +275,7 @@ ENTRY(___ipipe_call_irqtail)
|
||||||
p0.h = _bfin_irq_flags;
|
p0.h = _bfin_irq_flags;
|
||||||
r0 = [p0];
|
r0 = [p0];
|
||||||
sti r0;
|
sti r0;
|
||||||
#if 0 /* FIXME: this actually raises scheduling latencies */
|
|
||||||
/* Reenable interrupts */
|
|
||||||
[--sp] = reti;
|
|
||||||
r0 = [sp++];
|
|
||||||
#endif
|
|
||||||
rts;
|
rts;
|
||||||
ENDPROC(___ipipe_call_irqtail)
|
ENDPROC(___ipipe_call_irqtail)
|
||||||
|
|
||||||
#endif /* CONFIG_IPIPE */
|
#endif /* CONFIG_IPIPE */
|
||||||
|
|
|
@ -161,11 +161,15 @@ static void bfin_core_unmask_irq(unsigned int irq)
|
||||||
|
|
||||||
static void bfin_internal_mask_irq(unsigned int irq)
|
static void bfin_internal_mask_irq(unsigned int irq)
|
||||||
{
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
#ifdef CONFIG_BF53x
|
#ifdef CONFIG_BF53x
|
||||||
|
local_irq_save_hw(flags);
|
||||||
bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() &
|
bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() &
|
||||||
~(1 << SIC_SYSIRQ(irq)));
|
~(1 << SIC_SYSIRQ(irq)));
|
||||||
#else
|
#else
|
||||||
unsigned mask_bank, mask_bit;
|
unsigned mask_bank, mask_bit;
|
||||||
|
local_irq_save_hw(flags);
|
||||||
mask_bank = SIC_SYSIRQ(irq) / 32;
|
mask_bank = SIC_SYSIRQ(irq) / 32;
|
||||||
mask_bit = SIC_SYSIRQ(irq) % 32;
|
mask_bit = SIC_SYSIRQ(irq) % 32;
|
||||||
bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) &
|
bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) &
|
||||||
|
@ -175,15 +179,20 @@ static void bfin_internal_mask_irq(unsigned int irq)
|
||||||
~(1 << mask_bit));
|
~(1 << mask_bit));
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
local_irq_restore_hw(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bfin_internal_unmask_irq(unsigned int irq)
|
static void bfin_internal_unmask_irq(unsigned int irq)
|
||||||
{
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
#ifdef CONFIG_BF53x
|
#ifdef CONFIG_BF53x
|
||||||
|
local_irq_save_hw(flags);
|
||||||
bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() |
|
bfin_write_SIC_IMASK(bfin_read_SIC_IMASK() |
|
||||||
(1 << SIC_SYSIRQ(irq)));
|
(1 << SIC_SYSIRQ(irq)));
|
||||||
#else
|
#else
|
||||||
unsigned mask_bank, mask_bit;
|
unsigned mask_bank, mask_bit;
|
||||||
|
local_irq_save_hw(flags);
|
||||||
mask_bank = SIC_SYSIRQ(irq) / 32;
|
mask_bank = SIC_SYSIRQ(irq) / 32;
|
||||||
mask_bit = SIC_SYSIRQ(irq) % 32;
|
mask_bit = SIC_SYSIRQ(irq) % 32;
|
||||||
bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) |
|
bfin_write_SIC_IMASK(mask_bank, bfin_read_SIC_IMASK(mask_bank) |
|
||||||
|
@ -193,6 +202,7 @@ static void bfin_internal_unmask_irq(unsigned int irq)
|
||||||
(1 << mask_bit));
|
(1 << mask_bit));
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
local_irq_restore_hw(flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
|
@ -390,7 +400,7 @@ static void bfin_demux_error_irq(unsigned int int_err_irq,
|
||||||
static inline void bfin_set_irq_handler(unsigned irq, irq_flow_handler_t handle)
|
static inline void bfin_set_irq_handler(unsigned irq, irq_flow_handler_t handle)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_IPIPE
|
#ifdef CONFIG_IPIPE
|
||||||
_set_irq_handler(irq, handle_edge_irq);
|
_set_irq_handler(irq, handle_level_irq);
|
||||||
#else
|
#else
|
||||||
struct irq_desc *desc = irq_desc + irq;
|
struct irq_desc *desc = irq_desc + irq;
|
||||||
/* May not call generic set_irq_handler() due to spinlock
|
/* May not call generic set_irq_handler() due to spinlock
|
||||||
|
@ -1055,13 +1065,18 @@ int __init init_arch_irq(void)
|
||||||
#endif
|
#endif
|
||||||
default:
|
default:
|
||||||
#ifdef CONFIG_IPIPE
|
#ifdef CONFIG_IPIPE
|
||||||
/*
|
/*
|
||||||
* We want internal interrupt sources to be masked, because
|
* We want internal interrupt sources to be
|
||||||
* ISRs may trigger interrupts recursively (e.g. DMA), but
|
* masked, because ISRs may trigger interrupts
|
||||||
* interrupts are _not_ masked at CPU level. So let's handle
|
* recursively (e.g. DMA), but interrupts are
|
||||||
* them as level interrupts.
|
* _not_ masked at CPU level. So let's handle
|
||||||
*/
|
* most of them as level interrupts, except
|
||||||
set_irq_handler(irq, handle_level_irq);
|
* the timer interrupt which is special.
|
||||||
|
*/
|
||||||
|
if (irq == IRQ_SYSTMR || irq == IRQ_CORETMR)
|
||||||
|
set_irq_handler(irq, handle_simple_irq);
|
||||||
|
else
|
||||||
|
set_irq_handler(irq, handle_level_irq);
|
||||||
#else /* !CONFIG_IPIPE */
|
#else /* !CONFIG_IPIPE */
|
||||||
set_irq_handler(irq, handle_simple_irq);
|
set_irq_handler(irq, handle_simple_irq);
|
||||||
#endif /* !CONFIG_IPIPE */
|
#endif /* !CONFIG_IPIPE */
|
||||||
|
@ -1123,9 +1138,8 @@ int __init init_arch_irq(void)
|
||||||
|
|
||||||
#ifdef CONFIG_IPIPE
|
#ifdef CONFIG_IPIPE
|
||||||
for (irq = 0; irq < NR_IRQS; irq++) {
|
for (irq = 0; irq < NR_IRQS; irq++) {
|
||||||
struct irq_desc *desc = irq_desc + irq;
|
struct irq_desc *desc = irq_to_desc(irq);
|
||||||
desc->ic_prio = __ipipe_get_irq_priority(irq);
|
desc->ic_prio = __ipipe_get_irq_priority(irq);
|
||||||
desc->thr_prio = __ipipe_get_irqthread_priority(irq);
|
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_IPIPE */
|
#endif /* CONFIG_IPIPE */
|
||||||
|
|
||||||
|
@ -1208,76 +1222,21 @@ int __ipipe_get_irq_priority(unsigned irq)
|
||||||
return IVG15;
|
return IVG15;
|
||||||
}
|
}
|
||||||
|
|
||||||
int __ipipe_get_irqthread_priority(unsigned irq)
|
|
||||||
{
|
|
||||||
int ient, prio;
|
|
||||||
int demux_irq;
|
|
||||||
|
|
||||||
/* The returned priority value is rescaled to [0..IVG13+1]
|
|
||||||
* with 0 being the lowest effective priority level. */
|
|
||||||
|
|
||||||
if (irq <= IRQ_CORETMR)
|
|
||||||
return IVG13 - irq + 1;
|
|
||||||
|
|
||||||
/* GPIO IRQs are given the priority of the demux
|
|
||||||
* interrupt. */
|
|
||||||
if (IS_GPIOIRQ(irq)) {
|
|
||||||
#if defined(CONFIG_BF54x)
|
|
||||||
u32 bank = PINT_2_BANK(irq2pint_lut[irq - SYS_IRQS]);
|
|
||||||
demux_irq = (bank == 0 ? IRQ_PINT0 :
|
|
||||||
bank == 1 ? IRQ_PINT1 :
|
|
||||||
bank == 2 ? IRQ_PINT2 :
|
|
||||||
IRQ_PINT3);
|
|
||||||
#elif defined(CONFIG_BF561)
|
|
||||||
demux_irq = (irq >= IRQ_PF32 ? IRQ_PROG2_INTA :
|
|
||||||
irq >= IRQ_PF16 ? IRQ_PROG1_INTA :
|
|
||||||
IRQ_PROG0_INTA);
|
|
||||||
#elif defined(CONFIG_BF52x)
|
|
||||||
demux_irq = (irq >= IRQ_PH0 ? IRQ_PORTH_INTA :
|
|
||||||
irq >= IRQ_PG0 ? IRQ_PORTG_INTA :
|
|
||||||
IRQ_PORTF_INTA);
|
|
||||||
#else
|
|
||||||
demux_irq = irq;
|
|
||||||
#endif
|
|
||||||
return IVG13 - PRIO_GPIODEMUX(demux_irq) + 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The GPIO demux interrupt is given a lower priority
|
|
||||||
* than the GPIO IRQs, so that its threaded handler
|
|
||||||
* unmasks the interrupt line after the decoded IRQs
|
|
||||||
* have been processed. */
|
|
||||||
prio = PRIO_GPIODEMUX(irq);
|
|
||||||
/* demux irq? */
|
|
||||||
if (prio != -1)
|
|
||||||
return IVG13 - prio;
|
|
||||||
|
|
||||||
for (ient = 0; ient < NR_PERI_INTS; ient++) {
|
|
||||||
struct ivgx *ivg = ivg_table + ient;
|
|
||||||
if (ivg->irqno == irq) {
|
|
||||||
for (prio = 0; prio <= IVG13-IVG7; prio++) {
|
|
||||||
if (ivg7_13[prio].ifirst <= ivg &&
|
|
||||||
ivg7_13[prio].istop > ivg)
|
|
||||||
return IVG7 - prio;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Hw interrupts are disabled on entry (check SAVE_CONTEXT). */
|
/* Hw interrupts are disabled on entry (check SAVE_CONTEXT). */
|
||||||
#ifdef CONFIG_DO_IRQ_L1
|
#ifdef CONFIG_DO_IRQ_L1
|
||||||
__attribute__((l1_text))
|
__attribute__((l1_text))
|
||||||
#endif
|
#endif
|
||||||
asmlinkage int __ipipe_grab_irq(int vec, struct pt_regs *regs)
|
asmlinkage int __ipipe_grab_irq(int vec, struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
|
struct ipipe_percpu_domain_data *p = ipipe_root_cpudom_ptr();
|
||||||
|
struct ipipe_domain *this_domain = ipipe_current_domain;
|
||||||
struct ivgx *ivg_stop = ivg7_13[vec-IVG7].istop;
|
struct ivgx *ivg_stop = ivg7_13[vec-IVG7].istop;
|
||||||
struct ivgx *ivg = ivg7_13[vec-IVG7].ifirst;
|
struct ivgx *ivg = ivg7_13[vec-IVG7].ifirst;
|
||||||
int irq;
|
int irq, s;
|
||||||
|
|
||||||
if (likely(vec == EVT_IVTMR_P)) {
|
if (likely(vec == EVT_IVTMR_P)) {
|
||||||
irq = IRQ_CORETMR;
|
irq = IRQ_CORETMR;
|
||||||
goto handle_irq;
|
goto core_tick;
|
||||||
}
|
}
|
||||||
|
|
||||||
SSYNC();
|
SSYNC();
|
||||||
|
@ -1319,24 +1278,39 @@ asmlinkage int __ipipe_grab_irq(int vec, struct pt_regs *regs)
|
||||||
irq = ivg->irqno;
|
irq = ivg->irqno;
|
||||||
|
|
||||||
if (irq == IRQ_SYSTMR) {
|
if (irq == IRQ_SYSTMR) {
|
||||||
|
#ifdef CONFIG_GENERIC_CLOCKEVENTS
|
||||||
|
core_tick:
|
||||||
|
#else
|
||||||
bfin_write_TIMER_STATUS(1); /* Latch TIMIL0 */
|
bfin_write_TIMER_STATUS(1); /* Latch TIMIL0 */
|
||||||
|
#endif
|
||||||
/* This is basically what we need from the register frame. */
|
/* This is basically what we need from the register frame. */
|
||||||
__raw_get_cpu_var(__ipipe_tick_regs).ipend = regs->ipend;
|
__raw_get_cpu_var(__ipipe_tick_regs).ipend = regs->ipend;
|
||||||
__raw_get_cpu_var(__ipipe_tick_regs).pc = regs->pc;
|
__raw_get_cpu_var(__ipipe_tick_regs).pc = regs->pc;
|
||||||
if (!ipipe_root_domain_p)
|
if (this_domain != ipipe_root_domain)
|
||||||
__raw_get_cpu_var(__ipipe_tick_regs).ipend |= 0x10;
|
|
||||||
else
|
|
||||||
__raw_get_cpu_var(__ipipe_tick_regs).ipend &= ~0x10;
|
__raw_get_cpu_var(__ipipe_tick_regs).ipend &= ~0x10;
|
||||||
|
else
|
||||||
|
__raw_get_cpu_var(__ipipe_tick_regs).ipend |= 0x10;
|
||||||
}
|
}
|
||||||
|
|
||||||
handle_irq:
|
#ifndef CONFIG_GENERIC_CLOCKEVENTS
|
||||||
|
core_tick:
|
||||||
|
#endif
|
||||||
|
if (this_domain == ipipe_root_domain) {
|
||||||
|
s = __test_and_set_bit(IPIPE_SYNCDEFER_FLAG, &p->status);
|
||||||
|
barrier();
|
||||||
|
}
|
||||||
|
|
||||||
ipipe_trace_irq_entry(irq);
|
ipipe_trace_irq_entry(irq);
|
||||||
__ipipe_handle_irq(irq, regs);
|
__ipipe_handle_irq(irq, regs);
|
||||||
ipipe_trace_irq_exit(irq);
|
ipipe_trace_irq_exit(irq);
|
||||||
|
|
||||||
if (ipipe_root_domain_p)
|
if (this_domain == ipipe_root_domain) {
|
||||||
return !test_bit(IPIPE_STALL_FLAG, &ipipe_root_cpudom_var(status));
|
set_thread_flag(TIF_IRQ_SYNC);
|
||||||
|
if (!s) {
|
||||||
|
__clear_bit(IPIPE_SYNCDEFER_FLAG, &p->status);
|
||||||
|
return !test_bit(IPIPE_STALL_FLAG, &p->status);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -158,10 +158,14 @@ static irqreturn_t ipi_handler(int irq, void *dev_instance)
|
||||||
kfree(msg);
|
kfree(msg);
|
||||||
break;
|
break;
|
||||||
case BFIN_IPI_CALL_FUNC:
|
case BFIN_IPI_CALL_FUNC:
|
||||||
|
spin_unlock(&msg_queue->lock);
|
||||||
ipi_call_function(cpu, msg);
|
ipi_call_function(cpu, msg);
|
||||||
|
spin_lock(&msg_queue->lock);
|
||||||
break;
|
break;
|
||||||
case BFIN_IPI_CPU_STOP:
|
case BFIN_IPI_CPU_STOP:
|
||||||
|
spin_unlock(&msg_queue->lock);
|
||||||
ipi_cpu_stop(cpu);
|
ipi_cpu_stop(cpu);
|
||||||
|
spin_lock(&msg_queue->lock);
|
||||||
kfree(msg);
|
kfree(msg);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -457,7 +461,7 @@ void smp_icache_flush_range_others(unsigned long start, unsigned long end)
|
||||||
smp_flush_data.start = start;
|
smp_flush_data.start = start;
|
||||||
smp_flush_data.end = end;
|
smp_flush_data.end = end;
|
||||||
|
|
||||||
if (smp_call_function(&ipi_flush_icache, &smp_flush_data, 1))
|
if (smp_call_function(&ipi_flush_icache, &smp_flush_data, 0))
|
||||||
printk(KERN_WARNING "SMP: failed to run I-cache flush request on other CPUs\n");
|
printk(KERN_WARNING "SMP: failed to run I-cache flush request on other CPUs\n");
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(smp_icache_flush_range_others);
|
EXPORT_SYMBOL_GPL(smp_icache_flush_range_others);
|
||||||
|
|
|
@ -104,7 +104,7 @@ void __init paging_init(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage void init_pda(void)
|
asmlinkage void __init init_pda(void)
|
||||||
{
|
{
|
||||||
unsigned int cpu = raw_smp_processor_id();
|
unsigned int cpu = raw_smp_processor_id();
|
||||||
|
|
||||||
|
|
|
@ -638,6 +638,17 @@ config DMAR
|
||||||
and include PCI device scope covered by these DMA
|
and include PCI device scope covered by these DMA
|
||||||
remapping devices.
|
remapping devices.
|
||||||
|
|
||||||
|
config DMAR_DEFAULT_ON
|
||||||
|
def_bool y
|
||||||
|
prompt "Enable DMA Remapping Devices by default"
|
||||||
|
depends on DMAR
|
||||||
|
help
|
||||||
|
Selecting this option will enable a DMAR device at boot time if
|
||||||
|
one is found. If this option is not selected, DMAR support can
|
||||||
|
be enabled by passing intel_iommu=on to the kernel. It is
|
||||||
|
recommended you say N here while the DMAR code remains
|
||||||
|
experimental.
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -507,7 +507,7 @@ static int iosapic_find_sharable_irq(unsigned long trigger, unsigned long pol)
|
||||||
if (trigger == IOSAPIC_EDGE)
|
if (trigger == IOSAPIC_EDGE)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
for (i = 0; i <= NR_IRQS; i++) {
|
for (i = 0; i < NR_IRQS; i++) {
|
||||||
info = &iosapic_intr_info[i];
|
info = &iosapic_intr_info[i];
|
||||||
if (info->trigger == trigger && info->polarity == pol &&
|
if (info->trigger == trigger && info->polarity == pol &&
|
||||||
(info->dmode == IOSAPIC_FIXED ||
|
(info->dmode == IOSAPIC_FIXED ||
|
||||||
|
|
Некоторые файлы не были показаны из-за слишком большого количества измененных файлов Показать больше
Загрузка…
Ссылка в новой задаче