mirror of https://gitee.com/openkylin/linux.git
Merge branch 'upstream'
This commit is contained in:
commit
fce45c1c8a
6
CREDITS
6
CREDITS
|
@ -2247,6 +2247,12 @@ S: 249 Nichols Avenue
|
||||||
S: Syracuse, New York 13206
|
S: Syracuse, New York 13206
|
||||||
S: USA
|
S: USA
|
||||||
|
|
||||||
|
N: Kyle McMartin
|
||||||
|
E: kyle@parisc-linux.org
|
||||||
|
D: Linux/PARISC hacker
|
||||||
|
D: AD1889 sound driver
|
||||||
|
S: Ottawa, Canada
|
||||||
|
|
||||||
N: Dirk Melchers
|
N: Dirk Melchers
|
||||||
E: dirk@merlin.nbg.sub.org
|
E: dirk@merlin.nbg.sub.org
|
||||||
D: 8 bit XT hard disk driver for OMTI5520
|
D: 8 bit XT hard disk driver for OMTI5520
|
||||||
|
|
|
@ -65,7 +65,7 @@ o isdn4k-utils 3.1pre1 # isdnctrl 2>&1|grep version
|
||||||
o nfs-utils 1.0.5 # showmount --version
|
o nfs-utils 1.0.5 # showmount --version
|
||||||
o procps 3.2.0 # ps --version
|
o procps 3.2.0 # ps --version
|
||||||
o oprofile 0.9 # oprofiled --version
|
o oprofile 0.9 # oprofiled --version
|
||||||
o udev 058 # udevinfo -V
|
o udev 071 # udevinfo -V
|
||||||
|
|
||||||
Kernel compilation
|
Kernel compilation
|
||||||
==================
|
==================
|
||||||
|
|
|
@ -286,7 +286,9 @@ X!Edrivers/pci/search.c
|
||||||
-->
|
-->
|
||||||
!Edrivers/pci/msi.c
|
!Edrivers/pci/msi.c
|
||||||
!Edrivers/pci/bus.c
|
!Edrivers/pci/bus.c
|
||||||
!Edrivers/pci/hotplug.c
|
<!-- FIXME: Removed for now since no structured comments in source
|
||||||
|
X!Edrivers/pci/hotplug.c
|
||||||
|
-->
|
||||||
!Edrivers/pci/probe.c
|
!Edrivers/pci/probe.c
|
||||||
!Edrivers/pci/rom.c
|
!Edrivers/pci/rom.c
|
||||||
</sect1>
|
</sect1>
|
||||||
|
|
|
@ -291,7 +291,7 @@
|
||||||
|
|
||||||
!Edrivers/usb/core/hcd.c
|
!Edrivers/usb/core/hcd.c
|
||||||
!Edrivers/usb/core/hcd-pci.c
|
!Edrivers/usb/core/hcd-pci.c
|
||||||
!Edrivers/usb/core/buffer.c
|
!Idrivers/usb/core/buffer.c
|
||||||
</chapter>
|
</chapter>
|
||||||
|
|
||||||
<chapter>
|
<chapter>
|
||||||
|
|
|
@ -345,7 +345,6 @@ if (!retval) {
|
||||||
<programlisting>
|
<programlisting>
|
||||||
static inline void skel_delete (struct usb_skel *dev)
|
static inline void skel_delete (struct usb_skel *dev)
|
||||||
{
|
{
|
||||||
if (dev->bulk_in_buffer != NULL)
|
|
||||||
kfree (dev->bulk_in_buffer);
|
kfree (dev->bulk_in_buffer);
|
||||||
if (dev->bulk_out_buffer != NULL)
|
if (dev->bulk_out_buffer != NULL)
|
||||||
usb_buffer_free (dev->udev, dev->bulk_out_size,
|
usb_buffer_free (dev->udev, dev->bulk_out_size,
|
||||||
|
|
|
@ -49,9 +49,6 @@ changes occur:
|
||||||
page table operations such as what happens during
|
page table operations such as what happens during
|
||||||
fork, and exec.
|
fork, and exec.
|
||||||
|
|
||||||
Platform developers note that generic code will always
|
|
||||||
invoke this interface without mm->page_table_lock held.
|
|
||||||
|
|
||||||
3) void flush_tlb_range(struct vm_area_struct *vma,
|
3) void flush_tlb_range(struct vm_area_struct *vma,
|
||||||
unsigned long start, unsigned long end)
|
unsigned long start, unsigned long end)
|
||||||
|
|
||||||
|
@ -72,9 +69,6 @@ changes occur:
|
||||||
call flush_tlb_page (see below) for each entry which may be
|
call flush_tlb_page (see below) for each entry which may be
|
||||||
modified.
|
modified.
|
||||||
|
|
||||||
Platform developers note that generic code will always
|
|
||||||
invoke this interface with mm->page_table_lock held.
|
|
||||||
|
|
||||||
4) void flush_tlb_page(struct vm_area_struct *vma, unsigned long addr)
|
4) void flush_tlb_page(struct vm_area_struct *vma, unsigned long addr)
|
||||||
|
|
||||||
This time we need to remove the PAGE_SIZE sized translation
|
This time we need to remove the PAGE_SIZE sized translation
|
||||||
|
@ -93,9 +87,6 @@ changes occur:
|
||||||
|
|
||||||
This is used primarily during fault processing.
|
This is used primarily during fault processing.
|
||||||
|
|
||||||
Platform developers note that generic code will always
|
|
||||||
invoke this interface with mm->page_table_lock held.
|
|
||||||
|
|
||||||
5) void flush_tlb_pgtables(struct mm_struct *mm,
|
5) void flush_tlb_pgtables(struct mm_struct *mm,
|
||||||
unsigned long start, unsigned long end)
|
unsigned long start, unsigned long end)
|
||||||
|
|
||||||
|
|
|
@ -14,8 +14,8 @@ struct device_driver {
|
||||||
int (*probe) (struct device * dev);
|
int (*probe) (struct device * dev);
|
||||||
int (*remove) (struct device * dev);
|
int (*remove) (struct device * dev);
|
||||||
|
|
||||||
int (*suspend) (struct device * dev, pm_message_t state, u32 level);
|
int (*suspend) (struct device * dev, pm_message_t state);
|
||||||
int (*resume) (struct device * dev, u32 level);
|
int (*resume) (struct device * dev);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -194,69 +194,13 @@ device; i.e. anything in the device's driver_data field.
|
||||||
If the device is still present, it should quiesce the device and place
|
If the device is still present, it should quiesce the device and place
|
||||||
it into a supported low-power state.
|
it into a supported low-power state.
|
||||||
|
|
||||||
int (*suspend) (struct device * dev, pm_message_t state, u32 level);
|
int (*suspend) (struct device * dev, pm_message_t state);
|
||||||
|
|
||||||
suspend is called to put the device in a low power state. There are
|
suspend is called to put the device in a low power state.
|
||||||
several stages to successfully suspending a device, which is denoted in
|
|
||||||
the @level parameter. Breaking the suspend transition into several
|
|
||||||
stages affords the platform flexibility in performing device power
|
|
||||||
management based on the requirements of the system and the
|
|
||||||
user-defined policy.
|
|
||||||
|
|
||||||
SUSPEND_NOTIFY notifies the device that a suspend transition is about
|
int (*resume) (struct device * dev);
|
||||||
to happen. This happens on system power state transitions to verify
|
|
||||||
that all devices can successfully suspend.
|
|
||||||
|
|
||||||
A driver may choose to fail on this call, which should cause the
|
Resume is used to bring a device back from a low power state.
|
||||||
entire suspend transition to fail. A driver should fail only if it
|
|
||||||
knows that the device will not be able to be resumed properly when the
|
|
||||||
system wakes up again. It could also fail if it somehow determines it
|
|
||||||
is in the middle of an operation too important to stop.
|
|
||||||
|
|
||||||
SUSPEND_DISABLE tells the device to stop I/O transactions. When it
|
|
||||||
stops transactions, or what it should do with unfinished transactions
|
|
||||||
is a policy of the driver. After this call, the driver should not
|
|
||||||
accept any other I/O requests.
|
|
||||||
|
|
||||||
SUSPEND_SAVE_STATE tells the device to save the context of the
|
|
||||||
hardware. This includes any bus-specific hardware state and
|
|
||||||
device-specific hardware state. A pointer to this saved state can be
|
|
||||||
stored in the device's saved_state field.
|
|
||||||
|
|
||||||
SUSPEND_POWER_DOWN tells the driver to place the device in the low
|
|
||||||
power state requested.
|
|
||||||
|
|
||||||
Whether suspend is called with a given level is a policy of the
|
|
||||||
platform. Some levels may be omitted; drivers must not assume the
|
|
||||||
reception of any level. However, all levels must be called in the
|
|
||||||
order above; i.e. notification will always come before disabling;
|
|
||||||
disabling the device will come before suspending the device.
|
|
||||||
|
|
||||||
All calls are made with interrupts enabled, except for the
|
|
||||||
SUSPEND_POWER_DOWN level.
|
|
||||||
|
|
||||||
int (*resume) (struct device * dev, u32 level);
|
|
||||||
|
|
||||||
Resume is used to bring a device back from a low power state. Like the
|
|
||||||
suspend transition, it happens in several stages.
|
|
||||||
|
|
||||||
RESUME_POWER_ON tells the driver to set the power state to the state
|
|
||||||
before the suspend call (The device could have already been in a low
|
|
||||||
power state before the suspend call to put in a lower power state).
|
|
||||||
|
|
||||||
RESUME_RESTORE_STATE tells the driver to restore the state saved by
|
|
||||||
the SUSPEND_SAVE_STATE suspend call.
|
|
||||||
|
|
||||||
RESUME_ENABLE tells the driver to start accepting I/O transactions
|
|
||||||
again. Depending on driver policy, the device may already have pending
|
|
||||||
I/O requests.
|
|
||||||
|
|
||||||
RESUME_POWER_ON is called with interrupts disabled. The other resume
|
|
||||||
levels are called with interrupts enabled.
|
|
||||||
|
|
||||||
As with the various suspend stages, the driver must not assume that
|
|
||||||
any other resume calls have been or will be made. Each call should be
|
|
||||||
self-contained and not dependent on any external state.
|
|
||||||
|
|
||||||
|
|
||||||
Attributes
|
Attributes
|
||||||
|
|
|
@ -350,7 +350,7 @@ When a driver is registered, the bus's list of devices is iterated
|
||||||
over. bus->match() is called for each device that is not already
|
over. bus->match() is called for each device that is not already
|
||||||
claimed by a driver.
|
claimed by a driver.
|
||||||
|
|
||||||
When a device is successfully bound to a device, device->driver is
|
When a device is successfully bound to a driver, device->driver is
|
||||||
set, the device is added to a per-driver list of devices, and a
|
set, the device is added to a per-driver list of devices, and a
|
||||||
symlink is created in the driver's sysfs directory that points to the
|
symlink is created in the driver's sysfs directory that points to the
|
||||||
device's physical directory:
|
device's physical directory:
|
||||||
|
|
|
@ -4,18 +4,18 @@ Kernel driver it87
|
||||||
Supported chips:
|
Supported chips:
|
||||||
* IT8705F
|
* IT8705F
|
||||||
Prefix: 'it87'
|
Prefix: 'it87'
|
||||||
Addresses scanned: from Super I/O config space, or default ISA 0x290 (8 I/O ports)
|
Addresses scanned: from Super I/O config space (8 I/O ports)
|
||||||
Datasheet: Publicly available at the ITE website
|
Datasheet: Publicly available at the ITE website
|
||||||
http://www.ite.com.tw/
|
http://www.ite.com.tw/
|
||||||
* IT8712F
|
* IT8712F
|
||||||
Prefix: 'it8712'
|
Prefix: 'it8712'
|
||||||
Addresses scanned: I2C 0x28 - 0x2f
|
Addresses scanned: I2C 0x28 - 0x2f
|
||||||
from Super I/O config space, or default ISA 0x290 (8 I/O ports)
|
from Super I/O config space (8 I/O ports)
|
||||||
Datasheet: Publicly available at the ITE website
|
Datasheet: Publicly available at the ITE website
|
||||||
http://www.ite.com.tw/
|
http://www.ite.com.tw/
|
||||||
* SiS950 [clone of IT8705F]
|
* SiS950 [clone of IT8705F]
|
||||||
Prefix: 'sis950'
|
Prefix: 'it87'
|
||||||
Addresses scanned: from Super I/O config space, or default ISA 0x290 (8 I/O ports)
|
Addresses scanned: from Super I/O config space (8 I/O ports)
|
||||||
Datasheet: No longer be available
|
Datasheet: No longer be available
|
||||||
|
|
||||||
Author: Christophe Gauthron <chrisg@0-in.com>
|
Author: Christophe Gauthron <chrisg@0-in.com>
|
||||||
|
|
|
@ -24,14 +24,14 @@ Supported chips:
|
||||||
http://www.national.com/pf/LM/LM86.html
|
http://www.national.com/pf/LM/LM86.html
|
||||||
* Analog Devices ADM1032
|
* Analog Devices ADM1032
|
||||||
Prefix: 'adm1032'
|
Prefix: 'adm1032'
|
||||||
Addresses scanned: I2C 0x4c
|
Addresses scanned: I2C 0x4c and 0x4d
|
||||||
Datasheet: Publicly available at the Analog Devices website
|
Datasheet: Publicly available at the Analog Devices website
|
||||||
http://products.analog.com/products/info.asp?product=ADM1032
|
http://www.analog.com/en/prod/0,2877,ADM1032,00.html
|
||||||
* Analog Devices ADT7461
|
* Analog Devices ADT7461
|
||||||
Prefix: 'adt7461'
|
Prefix: 'adt7461'
|
||||||
Addresses scanned: I2C 0x4c
|
Addresses scanned: I2C 0x4c and 0x4d
|
||||||
Datasheet: Publicly available at the Analog Devices website
|
Datasheet: Publicly available at the Analog Devices website
|
||||||
http://products.analog.com/products/info.asp?product=ADT7461
|
http://www.analog.com/en/prod/0,2877,ADT7461,00.html
|
||||||
Note: Only if in ADM1032 compatibility mode
|
Note: Only if in ADM1032 compatibility mode
|
||||||
* Maxim MAX6657
|
* Maxim MAX6657
|
||||||
Prefix: 'max6657'
|
Prefix: 'max6657'
|
||||||
|
@ -71,8 +71,8 @@ increased resolution of the remote temperature measurement.
|
||||||
|
|
||||||
The different chipsets of the family are not strictly identical, although
|
The different chipsets of the family are not strictly identical, although
|
||||||
very similar. This driver doesn't handle any specific feature for now,
|
very similar. This driver doesn't handle any specific feature for now,
|
||||||
but could if there ever was a need for it. For reference, here comes a
|
with the exception of SMBus PEC. For reference, here comes a non-exhaustive
|
||||||
non-exhaustive list of specific features:
|
list of specific features:
|
||||||
|
|
||||||
LM90:
|
LM90:
|
||||||
* Filter and alert configuration register at 0xBF.
|
* Filter and alert configuration register at 0xBF.
|
||||||
|
@ -91,6 +91,7 @@ ADM1032:
|
||||||
* Conversion averaging.
|
* Conversion averaging.
|
||||||
* Up to 64 conversions/s.
|
* Up to 64 conversions/s.
|
||||||
* ALERT is triggered by open remote sensor.
|
* ALERT is triggered by open remote sensor.
|
||||||
|
* SMBus PEC support for Write Byte and Receive Byte transactions.
|
||||||
|
|
||||||
ADT7461
|
ADT7461
|
||||||
* Extended temperature range (breaks compatibility)
|
* Extended temperature range (breaks compatibility)
|
||||||
|
@ -119,3 +120,37 @@ The lm90 driver will not update its values more frequently than every
|
||||||
other second; reading them more often will do no harm, but will return
|
other second; reading them more often will do no harm, but will return
|
||||||
'old' values.
|
'old' values.
|
||||||
|
|
||||||
|
PEC Support
|
||||||
|
-----------
|
||||||
|
|
||||||
|
The ADM1032 is the only chip of the family which supports PEC. It does
|
||||||
|
not support PEC on all transactions though, so some care must be taken.
|
||||||
|
|
||||||
|
When reading a register value, the PEC byte is computed and sent by the
|
||||||
|
ADM1032 chip. However, in the case of a combined transaction (SMBus Read
|
||||||
|
Byte), the ADM1032 computes the CRC value over only the second half of
|
||||||
|
the message rather than its entirety, because it thinks the first half
|
||||||
|
of the message belongs to a different transaction. As a result, the CRC
|
||||||
|
value differs from what the SMBus master expects, and all reads fail.
|
||||||
|
|
||||||
|
For this reason, the lm90 driver will enable PEC for the ADM1032 only if
|
||||||
|
the bus supports the SMBus Send Byte and Receive Byte transaction types.
|
||||||
|
These transactions will be used to read register values, instead of
|
||||||
|
SMBus Read Byte, and PEC will work properly.
|
||||||
|
|
||||||
|
Additionally, the ADM1032 doesn't support SMBus Send Byte with PEC.
|
||||||
|
Instead, it will try to write the PEC value to the register (because the
|
||||||
|
SMBus Send Byte transaction with PEC is similar to a Write Byte transaction
|
||||||
|
without PEC), which is not what we want. Thus, PEC is explicitely disabled
|
||||||
|
on SMBus Send Byte transactions in the lm90 driver.
|
||||||
|
|
||||||
|
PEC on byte data transactions represents a significant increase in bandwidth
|
||||||
|
usage (+33% for writes, +25% for reads) in normal conditions. With the need
|
||||||
|
to use two SMBus transaction for reads, this overhead jumps to +50%. Worse,
|
||||||
|
two transactions will typically mean twice as much delay waiting for
|
||||||
|
transaction completion, effectively doubling the register cache refresh time.
|
||||||
|
I guess reliability comes at a price, but it's quite expensive this time.
|
||||||
|
|
||||||
|
So, as not everyone might enjoy the slowdown, PEC can be disabled through
|
||||||
|
sysfs. Just write 0 to the "pec" file and PEC will be disabled. Write 1
|
||||||
|
to that file to enable PEC again.
|
||||||
|
|
|
@ -3,6 +3,7 @@ Kernel driver smsc47b397
|
||||||
|
|
||||||
Supported chips:
|
Supported chips:
|
||||||
* SMSC LPC47B397-NC
|
* SMSC LPC47B397-NC
|
||||||
|
* SMSC SCH5307-NS
|
||||||
Prefix: 'smsc47b397'
|
Prefix: 'smsc47b397'
|
||||||
Addresses scanned: none, address read from Super I/O config space
|
Addresses scanned: none, address read from Super I/O config space
|
||||||
Datasheet: In this file
|
Datasheet: In this file
|
||||||
|
@ -12,11 +13,14 @@ Authors: Mark M. Hoffman <mhoffman@lightlink.com>
|
||||||
|
|
||||||
November 23, 2004
|
November 23, 2004
|
||||||
|
|
||||||
The following specification describes the SMSC LPC47B397-NC sensor chip
|
The following specification describes the SMSC LPC47B397-NC[1] sensor chip
|
||||||
(for which there is no public datasheet available). This document was
|
(for which there is no public datasheet available). This document was
|
||||||
provided by Craig Kelly (In-Store Broadcast Network) and edited/corrected
|
provided by Craig Kelly (In-Store Broadcast Network) and edited/corrected
|
||||||
by Mark M. Hoffman <mhoffman@lightlink.com>.
|
by Mark M. Hoffman <mhoffman@lightlink.com>.
|
||||||
|
|
||||||
|
[1] And SMSC SCH5307-NS, which has a different device ID but is otherwise
|
||||||
|
compatible.
|
||||||
|
|
||||||
* * * * *
|
* * * * *
|
||||||
|
|
||||||
Methods for detecting the HP SIO and reading the thermal data on a dc7100.
|
Methods for detecting the HP SIO and reading the thermal data on a dc7100.
|
||||||
|
@ -127,7 +131,7 @@ OUT DX,AL
|
||||||
The registers of interest for identifying the SIO on the dc7100 are Device ID
|
The registers of interest for identifying the SIO on the dc7100 are Device ID
|
||||||
(0x20) and Device Rev (0x21).
|
(0x20) and Device Rev (0x21).
|
||||||
|
|
||||||
The Device ID will read 0X6F
|
The Device ID will read 0x6F (for SCH5307-NS, 0x81)
|
||||||
The Device Rev currently reads 0x01
|
The Device Rev currently reads 0x01
|
||||||
|
|
||||||
Obtaining the HWM Base Address.
|
Obtaining the HWM Base Address.
|
||||||
|
|
|
@ -12,6 +12,10 @@ Supported chips:
|
||||||
http://www.smsc.com/main/datasheets/47m14x.pdf
|
http://www.smsc.com/main/datasheets/47m14x.pdf
|
||||||
http://www.smsc.com/main/tools/discontinued/47m15x.pdf
|
http://www.smsc.com/main/tools/discontinued/47m15x.pdf
|
||||||
http://www.smsc.com/main/datasheets/47m192.pdf
|
http://www.smsc.com/main/datasheets/47m192.pdf
|
||||||
|
* SMSC LPC47M997
|
||||||
|
Addresses scanned: none, address read from Super I/O config space
|
||||||
|
Prefix: 'smsc47m1'
|
||||||
|
Datasheet: none
|
||||||
|
|
||||||
Authors:
|
Authors:
|
||||||
Mark D. Studebaker <mdsxyz123@yahoo.com>,
|
Mark D. Studebaker <mdsxyz123@yahoo.com>,
|
||||||
|
@ -30,6 +34,9 @@ The 47M15x and 47M192 chips contain a full 'hardware monitoring block'
|
||||||
in addition to the fan monitoring and control. The hardware monitoring
|
in addition to the fan monitoring and control. The hardware monitoring
|
||||||
block is not supported by the driver.
|
block is not supported by the driver.
|
||||||
|
|
||||||
|
No documentation is available for the 47M997, but it has the same device
|
||||||
|
ID as the 47M15x and 47M192 chips and seems to be compatible.
|
||||||
|
|
||||||
Fan rotation speeds are reported in RPM (rotations per minute). An alarm is
|
Fan rotation speeds are reported in RPM (rotations per minute). An alarm is
|
||||||
triggered if the rotation speed has dropped below a programmable limit. Fan
|
triggered if the rotation speed has dropped below a programmable limit. Fan
|
||||||
readings can be divided by a programmable divider (1, 2, 4 or 8) to give
|
readings can be divided by a programmable divider (1, 2, 4 or 8) to give
|
||||||
|
|
|
@ -272,3 +272,6 @@ beep_mask Bitmask for beep.
|
||||||
|
|
||||||
eeprom Raw EEPROM data in binary form.
|
eeprom Raw EEPROM data in binary form.
|
||||||
Read only.
|
Read only.
|
||||||
|
|
||||||
|
pec Enable or disable PEC (SMBus only)
|
||||||
|
Read/Write
|
||||||
|
|
|
@ -18,8 +18,9 @@ Authors:
|
||||||
Module Parameters
|
Module Parameters
|
||||||
-----------------
|
-----------------
|
||||||
|
|
||||||
force_addr=0xaddr Set the I/O base address. Useful for Asus A7V boards
|
force_addr=0xaddr Set the I/O base address. Useful for boards that
|
||||||
that don't set the address in the BIOS. Does not do a
|
don't set the address in the BIOS. Look for a BIOS
|
||||||
|
upgrade before resorting to this. Does not do a
|
||||||
PCI force; the via686a must still be present in lspci.
|
PCI force; the via686a must still be present in lspci.
|
||||||
Don't use this unless the driver complains that the
|
Don't use this unless the driver complains that the
|
||||||
base address is not set.
|
base address is not set.
|
||||||
|
@ -63,3 +64,15 @@ miss once-only alarms.
|
||||||
|
|
||||||
The driver only updates its values each 1.5 seconds; reading it more often
|
The driver only updates its values each 1.5 seconds; reading it more often
|
||||||
will do no harm, but will return 'old' values.
|
will do no harm, but will return 'old' values.
|
||||||
|
|
||||||
|
Known Issues
|
||||||
|
------------
|
||||||
|
|
||||||
|
This driver handles sensors integrated in some VIA south bridges. It is
|
||||||
|
possible that a motherboard maker used a VT82C686A/B chip as part of a
|
||||||
|
product design but was not interested in its hardware monitoring features,
|
||||||
|
in which case the sensor inputs will not be wired. This is the case of
|
||||||
|
the Asus K7V, A7V and A7V133 motherboards, to name only a few of them.
|
||||||
|
So, if you need the force_addr parameter, and end up with values which
|
||||||
|
don't seem to make any sense, don't look any further: your chip is simply
|
||||||
|
not wired for hardware monitoring.
|
||||||
|
|
|
@ -2,6 +2,7 @@ Kernel driver i2c-i810
|
||||||
|
|
||||||
Supported adapters:
|
Supported adapters:
|
||||||
* Intel 82810, 82810-DC100, 82810E, and 82815 (GMCH)
|
* Intel 82810, 82810-DC100, 82810E, and 82815 (GMCH)
|
||||||
|
* Intel 82845G (GMCH)
|
||||||
|
|
||||||
Authors:
|
Authors:
|
||||||
Frodo Looijaard <frodol@dds.nl>,
|
Frodo Looijaard <frodol@dds.nl>,
|
||||||
|
|
|
@ -14,7 +14,8 @@ Authors:
|
||||||
Frodo Looijaard <frodol@dds.nl>,
|
Frodo Looijaard <frodol@dds.nl>,
|
||||||
Philip Edelbrock <phil@netroedge.com>,
|
Philip Edelbrock <phil@netroedge.com>,
|
||||||
Kyösti Mälkki <kmalkki@cc.hut.fi>,
|
Kyösti Mälkki <kmalkki@cc.hut.fi>,
|
||||||
Mark D. Studebaker <mdsxyz123@yahoo.com>
|
Mark D. Studebaker <mdsxyz123@yahoo.com>,
|
||||||
|
Jean Delvare <khali@linux-fr.org>
|
||||||
|
|
||||||
Module Parameters
|
Module Parameters
|
||||||
-----------------
|
-----------------
|
||||||
|
@ -28,20 +29,22 @@ Description
|
||||||
-----------
|
-----------
|
||||||
|
|
||||||
i2c-viapro is a true SMBus host driver for motherboards with one of the
|
i2c-viapro is a true SMBus host driver for motherboards with one of the
|
||||||
supported VIA southbridges.
|
supported VIA south bridges.
|
||||||
|
|
||||||
Your lspci -n listing must show one of these :
|
Your lspci -n listing must show one of these :
|
||||||
|
|
||||||
device 1106:3050 (VT82C596 function 3)
|
device 1106:3050 (VT82C596A function 3)
|
||||||
device 1106:3051 (VT82C596 function 3)
|
device 1106:3051 (VT82C596B function 3)
|
||||||
device 1106:3057 (VT82C686 function 4)
|
device 1106:3057 (VT82C686 function 4)
|
||||||
device 1106:3074 (VT8233)
|
device 1106:3074 (VT8233)
|
||||||
device 1106:3147 (VT8233A)
|
device 1106:3147 (VT8233A)
|
||||||
device 1106:8235 (VT8231)
|
device 1106:8235 (VT8231 function 4)
|
||||||
devide 1106:3177 (VT8235)
|
device 1106:3177 (VT8235)
|
||||||
devide 1106:3227 (VT8237)
|
device 1106:3227 (VT8237R)
|
||||||
|
|
||||||
If none of these show up, you should look in the BIOS for settings like
|
If none of these show up, you should look in the BIOS for settings like
|
||||||
enable ACPI / SMBus or even USB.
|
enable ACPI / SMBus or even USB.
|
||||||
|
|
||||||
|
Except for the oldest chips (VT82C596A/B, VT82C686A and most probably
|
||||||
|
VT8231), this driver supports I2C block transactions. Such transactions
|
||||||
|
are mainly useful to read from and write to EEPROMs.
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
Kernel driver x1205
|
||||||
|
===================
|
||||||
|
|
||||||
|
Supported chips:
|
||||||
|
* Xicor X1205 RTC
|
||||||
|
Prefix: 'x1205'
|
||||||
|
Addresses scanned: none
|
||||||
|
Datasheet: http://www.intersil.com/cda/deviceinfo/0,1477,X1205,00.html
|
||||||
|
|
||||||
|
Authors:
|
||||||
|
Karen Spearel <kas11@tampabay.rr.com>,
|
||||||
|
Alessandro Zummo <a.zummo@towertech.it>
|
||||||
|
|
||||||
|
Description
|
||||||
|
-----------
|
||||||
|
|
||||||
|
This module aims to provide complete access to the Xicor X1205 RTC.
|
||||||
|
Recently Xicor has merged with Intersil, but the chip is
|
||||||
|
still sold under the Xicor brand.
|
||||||
|
|
||||||
|
This chip is located at address 0x6f and uses a 2-byte register addressing.
|
||||||
|
Two bytes need to be written to read a single register, while most
|
||||||
|
other chips just require one and take the second one as the data
|
||||||
|
to be written. To prevent corrupting unknown chips, the user must
|
||||||
|
explicitely set the probe parameter.
|
||||||
|
|
||||||
|
example:
|
||||||
|
|
||||||
|
modprobe x1205 probe=0,0x6f
|
||||||
|
|
||||||
|
The module supports one more option, hctosys, which is used to set the
|
||||||
|
software clock from the x1205. On systems where the x1205 is the
|
||||||
|
only hardware rtc, this parameter could be used to achieve a correct
|
||||||
|
date/time earlier in the system boot sequence.
|
||||||
|
|
||||||
|
example:
|
||||||
|
|
||||||
|
modprobe x1205 probe=0,0x6f hctosys=1
|
|
@ -17,9 +17,10 @@ For the most up-to-date list of functionality constants, please check
|
||||||
I2C_FUNC_I2C Plain i2c-level commands (Pure SMBus
|
I2C_FUNC_I2C Plain i2c-level commands (Pure SMBus
|
||||||
adapters typically can not do these)
|
adapters typically can not do these)
|
||||||
I2C_FUNC_10BIT_ADDR Handles the 10-bit address extensions
|
I2C_FUNC_10BIT_ADDR Handles the 10-bit address extensions
|
||||||
I2C_FUNC_PROTOCOL_MANGLING Knows about the I2C_M_REV_DIR_ADDR,
|
I2C_FUNC_PROTOCOL_MANGLING Knows about the I2C_M_IGNORE_NAK,
|
||||||
I2C_M_REV_DIR_ADDR and I2C_M_REV_DIR_NOSTART
|
I2C_M_REV_DIR_ADDR, I2C_M_NOSTART and
|
||||||
flags (which modify the i2c protocol!)
|
I2C_M_NO_RD_ACK flags (which modify the
|
||||||
|
I2C protocol!)
|
||||||
I2C_FUNC_SMBUS_QUICK Handles the SMBus write_quick command
|
I2C_FUNC_SMBUS_QUICK Handles the SMBus write_quick command
|
||||||
I2C_FUNC_SMBUS_READ_BYTE Handles the SMBus read_byte command
|
I2C_FUNC_SMBUS_READ_BYTE Handles the SMBus read_byte command
|
||||||
I2C_FUNC_SMBUS_WRITE_BYTE Handles the SMBus write_byte command
|
I2C_FUNC_SMBUS_WRITE_BYTE Handles the SMBus write_byte command
|
||||||
|
|
|
@ -82,7 +82,7 @@ Technical changes:
|
||||||
exit and exit_free. For i2c+isa drivers, labels should be named
|
exit and exit_free. For i2c+isa drivers, labels should be named
|
||||||
ERROR0, ERROR1 and ERROR2. Don't forget to properly set err before
|
ERROR0, ERROR1 and ERROR2. Don't forget to properly set err before
|
||||||
jumping to error labels. By the way, labels should be left-aligned.
|
jumping to error labels. By the way, labels should be left-aligned.
|
||||||
Use memset to fill the client and data area with 0x00.
|
Use kzalloc instead of kmalloc.
|
||||||
Use i2c_set_clientdata to set the client data (as opposed to
|
Use i2c_set_clientdata to set the client data (as opposed to
|
||||||
a direct access to client->data).
|
a direct access to client->data).
|
||||||
Use strlcpy instead of strcpy to copy the client name.
|
Use strlcpy instead of strcpy to copy the client name.
|
||||||
|
|
|
@ -33,8 +33,8 @@ static struct i2c_driver foo_driver = {
|
||||||
.command = &foo_command /* may be NULL */
|
.command = &foo_command /* may be NULL */
|
||||||
}
|
}
|
||||||
|
|
||||||
The name can be chosen freely, and may be upto 40 characters long. Please
|
The name field must match the driver name, including the case. It must not
|
||||||
use something descriptive here.
|
contain spaces, and may be up to 31 characters long.
|
||||||
|
|
||||||
Don't worry about the flags field; just put I2C_DF_NOTIFY into it. This
|
Don't worry about the flags field; just put I2C_DF_NOTIFY into it. This
|
||||||
means that your driver will be notified when new adapters are found.
|
means that your driver will be notified when new adapters are found.
|
||||||
|
@ -43,9 +43,6 @@ This is almost always what you want.
|
||||||
All other fields are for call-back functions which will be explained
|
All other fields are for call-back functions which will be explained
|
||||||
below.
|
below.
|
||||||
|
|
||||||
There use to be two additional fields in this structure, inc_use et dec_use,
|
|
||||||
for module usage count, but these fields were obsoleted and removed.
|
|
||||||
|
|
||||||
|
|
||||||
Extra client data
|
Extra client data
|
||||||
=================
|
=================
|
||||||
|
@ -58,6 +55,7 @@ be very useful.
|
||||||
An example structure is below.
|
An example structure is below.
|
||||||
|
|
||||||
struct foo_data {
|
struct foo_data {
|
||||||
|
struct i2c_client client;
|
||||||
struct semaphore lock; /* For ISA access in `sensors' drivers. */
|
struct semaphore lock; /* For ISA access in `sensors' drivers. */
|
||||||
int sysctl_id; /* To keep the /proc directory entry for
|
int sysctl_id; /* To keep the /proc directory entry for
|
||||||
`sensors' drivers. */
|
`sensors' drivers. */
|
||||||
|
@ -310,22 +308,15 @@ For now, you can ignore the `flags' parameter. It is there for future use.
|
||||||
client structure, even though we cannot fill it completely yet.
|
client structure, even though we cannot fill it completely yet.
|
||||||
But it allows us to access several i2c functions safely */
|
But it allows us to access several i2c functions safely */
|
||||||
|
|
||||||
/* Note that we reserve some space for foo_data too. If you don't
|
if (!(data = kzalloc(sizeof(struct foo_data), GFP_KERNEL))) {
|
||||||
need it, remove it. We do it here to help to lessen memory
|
|
||||||
fragmentation. */
|
|
||||||
if (! (new_client = kmalloc(sizeof(struct i2c_client) +
|
|
||||||
sizeof(struct foo_data),
|
|
||||||
GFP_KERNEL))) {
|
|
||||||
err = -ENOMEM;
|
err = -ENOMEM;
|
||||||
goto ERROR0;
|
goto ERROR0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* This is tricky, but it will set the data to the right value. */
|
new_client = &data->client;
|
||||||
client->data = new_client + 1;
|
i2c_set_clientdata(new_client, data);
|
||||||
data = (struct foo_data *) (client->data);
|
|
||||||
|
|
||||||
new_client->addr = address;
|
new_client->addr = address;
|
||||||
new_client->data = data;
|
|
||||||
new_client->adapter = adapter;
|
new_client->adapter = adapter;
|
||||||
new_client->driver = &foo_driver;
|
new_client->driver = &foo_driver;
|
||||||
new_client->flags = 0;
|
new_client->flags = 0;
|
||||||
|
@ -451,7 +442,7 @@ much simpler than the attachment code, fortunately!
|
||||||
release_region(client->addr,LM78_EXTENT);
|
release_region(client->addr,LM78_EXTENT);
|
||||||
/* HYBRID SENSORS CHIP ONLY END */
|
/* HYBRID SENSORS CHIP ONLY END */
|
||||||
|
|
||||||
kfree(client); /* Frees client data too, if allocated at the same time */
|
kfree(data);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -576,12 +567,12 @@ SMBus communication
|
||||||
extern s32 i2c_smbus_write_block_data(struct i2c_client * client,
|
extern s32 i2c_smbus_write_block_data(struct i2c_client * client,
|
||||||
u8 command, u8 length,
|
u8 command, u8 length,
|
||||||
u8 *values);
|
u8 *values);
|
||||||
|
extern s32 i2c_smbus_read_i2c_block_data(struct i2c_client * client,
|
||||||
|
u8 command, u8 *values);
|
||||||
|
|
||||||
These ones were removed in Linux 2.6.10 because they had no users, but could
|
These ones were removed in Linux 2.6.10 because they had no users, but could
|
||||||
be added back later if needed:
|
be added back later if needed:
|
||||||
|
|
||||||
extern s32 i2c_smbus_read_i2c_block_data(struct i2c_client * client,
|
|
||||||
u8 command, u8 *values);
|
|
||||||
extern s32 i2c_smbus_read_block_data(struct i2c_client * client,
|
extern s32 i2c_smbus_read_block_data(struct i2c_client * client,
|
||||||
u8 command, u8 *values);
|
u8 command, u8 *values);
|
||||||
extern s32 i2c_smbus_write_i2c_block_data(struct i2c_client * client,
|
extern s32 i2c_smbus_write_i2c_block_data(struct i2c_client * client,
|
||||||
|
|
|
@ -2,7 +2,6 @@ Driver documentation for yealink usb-p1k phones
|
||||||
|
|
||||||
0. Status
|
0. Status
|
||||||
~~~~~~~~~
|
~~~~~~~~~
|
||||||
|
|
||||||
The p1k is a relatively cheap usb 1.1 phone with:
|
The p1k is a relatively cheap usb 1.1 phone with:
|
||||||
- keyboard full support, yealink.ko / input event API
|
- keyboard full support, yealink.ko / input event API
|
||||||
- LCD full support, yealink.ko / sysfs API
|
- LCD full support, yealink.ko / sysfs API
|
||||||
|
@ -17,9 +16,8 @@ For vendor documentation see http://www.yealink.com
|
||||||
|
|
||||||
1. Compilation (stand alone version)
|
1. Compilation (stand alone version)
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
Currently only kernel 2.6.x.y versions are supported.
|
Currently only kernel 2.6.x.y versions are supported.
|
||||||
In order to build the yealink.ko module do:
|
In order to build the yealink.ko module do
|
||||||
|
|
||||||
make
|
make
|
||||||
|
|
||||||
|
@ -28,6 +26,21 @@ the Makefile is pointing to the location where your kernel sources
|
||||||
are located, default /usr/src/linux.
|
are located, default /usr/src/linux.
|
||||||
|
|
||||||
|
|
||||||
|
1.1 Troubleshooting
|
||||||
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
Q: Module yealink compiled and installed without any problem but phone
|
||||||
|
is not initialized and does not react to any actions.
|
||||||
|
A: If you see something like:
|
||||||
|
hiddev0: USB HID v1.00 Device [Yealink Network Technology Ltd. VOIP USB Phone
|
||||||
|
in dmesg, it means that the hid driver has grabbed the device first. Try to
|
||||||
|
load module yealink before any other usb hid driver. Please see the
|
||||||
|
instructions provided by your distribution on module configuration.
|
||||||
|
|
||||||
|
Q: Phone is working now (displays version and accepts keypad input) but I can't
|
||||||
|
find the sysfs files.
|
||||||
|
A: The sysfs files are located on the particular usb endpoint. On most
|
||||||
|
distributions you can do: "find /sys/ -name get_icons" for a hint.
|
||||||
|
|
||||||
|
|
||||||
2. keyboard features
|
2. keyboard features
|
||||||
~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
|
@ -1460,8 +1460,6 @@ running once the system is up.
|
||||||
stifb= [HW]
|
stifb= [HW]
|
||||||
Format: bpp:<bpp1>[:<bpp2>[:<bpp3>...]]
|
Format: bpp:<bpp1>[:<bpp2>[:<bpp3>...]]
|
||||||
|
|
||||||
stram_swap= [HW,M68k]
|
|
||||||
|
|
||||||
swiotlb= [IA-64] Number of I/O TLB slabs
|
swiotlb= [IA-64] Number of I/O TLB slabs
|
||||||
|
|
||||||
switches= [HW,M68k]
|
switches= [HW,M68k]
|
||||||
|
@ -1517,8 +1515,6 @@ running once the system is up.
|
||||||
uart6850= [HW,OSS]
|
uart6850= [HW,OSS]
|
||||||
Format: <io>,<irq>
|
Format: <io>,<irq>
|
||||||
|
|
||||||
usb-handoff [HW] Enable early USB BIOS -> OS handoff
|
|
||||||
|
|
||||||
usbhid.mousepoll=
|
usbhid.mousepoll=
|
||||||
[USBHID] The interval which mice are to be polled at.
|
[USBHID] The interval which mice are to be polled at.
|
||||||
|
|
||||||
|
|
|
@ -626,7 +626,7 @@ ignored (others aren't affected).
|
||||||
can be performed in optimal order. Not all SCSI devices support
|
can be performed in optimal order. Not all SCSI devices support
|
||||||
tagged queuing (:-().
|
tagged queuing (:-().
|
||||||
|
|
||||||
4.6 switches=
|
4.5 switches=
|
||||||
-------------
|
-------------
|
||||||
|
|
||||||
Syntax: switches=<list of switches>
|
Syntax: switches=<list of switches>
|
||||||
|
@ -661,28 +661,6 @@ correctly.
|
||||||
earlier initialization ("ov_"-less) takes precedence. But the
|
earlier initialization ("ov_"-less) takes precedence. But the
|
||||||
switching-off on reset still happens in this case.
|
switching-off on reset still happens in this case.
|
||||||
|
|
||||||
4.5) stram_swap=
|
|
||||||
----------------
|
|
||||||
|
|
||||||
Syntax: stram_swap=<do_swap>[,<max_swap>]
|
|
||||||
|
|
||||||
This option is available only if the kernel has been compiled with
|
|
||||||
CONFIG_STRAM_SWAP enabled. Normally, the kernel then determines
|
|
||||||
dynamically whether to actually use ST-RAM as swap space. (Currently,
|
|
||||||
the fraction of ST-RAM must be less or equal 1/3 of total memory to
|
|
||||||
enable this swapping.) You can override the kernel's decision by
|
|
||||||
specifying this option. 1 for <do_swap> means always enable the swap,
|
|
||||||
even if you have less alternate RAM. 0 stands for never swap to
|
|
||||||
ST-RAM, even if it's small enough compared to the rest of memory.
|
|
||||||
|
|
||||||
If ST-RAM swapping is enabled, the kernel usually uses all free
|
|
||||||
ST-RAM as swap "device". If the kernel resides in ST-RAM, the region
|
|
||||||
allocated by it is obviously never used for swapping :-) You can also
|
|
||||||
limit this amount by specifying the second parameter, <max_swap>, if
|
|
||||||
you want to use parts of ST-RAM as normal system memory. <max_swap> is
|
|
||||||
in kBytes and the number should be a multiple of 4 (otherwise: rounded
|
|
||||||
down).
|
|
||||||
|
|
||||||
5) Options for Amiga Only:
|
5) Options for Amiga Only:
|
||||||
==========================
|
==========================
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,168 @@
|
||||||
|
README for MIPS AU1XXX IDE driver - Released 2005-07-15
|
||||||
|
|
||||||
|
ABOUT
|
||||||
|
-----
|
||||||
|
This file describes the 'drivers/ide/mips/au1xxx-ide.c', related files and the
|
||||||
|
services they provide.
|
||||||
|
|
||||||
|
If you are short in patience and just want to know how to add your hard disc to
|
||||||
|
the white or black list, go to the 'ADD NEW HARD DISC TO WHITE OR BLACK LIST'
|
||||||
|
section.
|
||||||
|
|
||||||
|
|
||||||
|
LICENSE
|
||||||
|
-------
|
||||||
|
|
||||||
|
Copyright (c) 2003-2005 AMD, Personal Connectivity Solutions
|
||||||
|
|
||||||
|
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 SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR
|
||||||
|
BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License along with
|
||||||
|
this program; if not, write to the Free Software Foundation, Inc.,
|
||||||
|
675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
|
||||||
|
Note: for more information, please refer "AMD Alchemy Au1200/Au1550 IDE
|
||||||
|
Interface and Linux Device Driver" Application Note.
|
||||||
|
|
||||||
|
|
||||||
|
FILES, CONFIGS AND COMPATABILITY
|
||||||
|
--------------------------------
|
||||||
|
|
||||||
|
Two files are introduced:
|
||||||
|
|
||||||
|
a) 'include/asm-mips/mach-au1x00/au1xxx_ide.h'
|
||||||
|
containes : struct _auide_hwif
|
||||||
|
struct drive_list_entry dma_white_list
|
||||||
|
struct drive_list_entry dma_black_list
|
||||||
|
timing parameters for PIO mode 0/1/2/3/4
|
||||||
|
timing parameters for MWDMA 0/1/2
|
||||||
|
|
||||||
|
b) 'drivers/ide/mips/au1xxx-ide.c'
|
||||||
|
contains the functionality of the AU1XXX IDE driver
|
||||||
|
|
||||||
|
Four configs variables are introduced:
|
||||||
|
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_PIO_DBDMA - enable the PIO+DBDMA mode
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA - enable the MWDMA mode
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_BURSTABLE_ON - set Burstable FIFO in DBDMA
|
||||||
|
controler
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_SEQTS_PER_RQ - maximum transfer size
|
||||||
|
per descriptor
|
||||||
|
|
||||||
|
If MWDMA is enabled and the connected hard disc is not on the white list, the
|
||||||
|
kernel switches to a "safe mwdma mode" at boot time. In this mode the IDE
|
||||||
|
performance is substantial slower then in full speed mwdma. In this case
|
||||||
|
please add your hard disc to the white list (follow instruction from 'ADD NEW
|
||||||
|
HARD DISC TO WHITE OR BLACK LIST' section).
|
||||||
|
|
||||||
|
|
||||||
|
SUPPORTED IDE MODES
|
||||||
|
-------------------
|
||||||
|
|
||||||
|
The AU1XXX IDE driver supported all PIO modes - PIO mode 0/1/2/3/4 - and all
|
||||||
|
MWDMA modes - MWDMA 0/1/2 -. There is no support for SWDMA and UDMA mode.
|
||||||
|
|
||||||
|
To change the PIO mode use the program hdparm with option -p, e.g.
|
||||||
|
'hdparm -p0 [device]' for PIO mode 0. To enable the MWDMA mode use the option
|
||||||
|
-X, e.g. 'hdparm -X32 [device]' for MWDMA mode 0.
|
||||||
|
|
||||||
|
|
||||||
|
PERFORMANCE CONFIGURATIONS
|
||||||
|
--------------------------
|
||||||
|
|
||||||
|
If the used system doesn't need USB support enable the following kernel configs:
|
||||||
|
|
||||||
|
CONFIG_IDE=y
|
||||||
|
CONFIG_BLK_DEV_IDE=y
|
||||||
|
CONFIG_IDE_GENERIC=y
|
||||||
|
CONFIG_BLK_DEV_IDEPCI=y
|
||||||
|
CONFIG_BLK_DEV_GENERIC=y
|
||||||
|
CONFIG_BLK_DEV_IDEDMA_PCI=y
|
||||||
|
CONFIG_IDEDMA_PCI_AUTO=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_BURSTABLE_ON=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_SEQTS_PER_RQ=128
|
||||||
|
CONFIG_BLK_DEV_IDEDMA=y
|
||||||
|
CONFIG_IDEDMA_AUTO=y
|
||||||
|
|
||||||
|
If the used system need the USB support enable the following kernel configs for
|
||||||
|
high IDE to USB throughput.
|
||||||
|
|
||||||
|
CONFIG_BLK_DEV_IDEDISK=y
|
||||||
|
CONFIG_IDE_GENERIC=y
|
||||||
|
CONFIG_BLK_DEV_IDEPCI=y
|
||||||
|
CONFIG_BLK_DEV_GENERIC=y
|
||||||
|
CONFIG_BLK_DEV_IDEDMA_PCI=y
|
||||||
|
CONFIG_IDEDMA_PCI_AUTO=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_MDMA2_DBDMA=y
|
||||||
|
CONFIG_BLK_DEV_IDE_AU1XXX_SEQTS_PER_RQ=128
|
||||||
|
CONFIG_BLK_DEV_IDEDMA=y
|
||||||
|
CONFIG_IDEDMA_AUTO=y
|
||||||
|
|
||||||
|
|
||||||
|
ADD NEW HARD DISC TO WHITE OR BLACK LIST
|
||||||
|
----------------------------------------
|
||||||
|
|
||||||
|
Step 1 : detect the model name of your hard disc
|
||||||
|
|
||||||
|
a) connect your hard disc to the AU1XXX
|
||||||
|
|
||||||
|
b) boot your kernel and get the hard disc model.
|
||||||
|
|
||||||
|
Example boot log:
|
||||||
|
|
||||||
|
--snipped--
|
||||||
|
Uniform Multi-Platform E-IDE driver Revision: 7.00alpha2
|
||||||
|
ide: Assuming 50MHz system bus speed for PIO modes; override with idebus=xx
|
||||||
|
Au1xxx IDE(builtin) configured for MWDMA2
|
||||||
|
Probing IDE interface ide0...
|
||||||
|
hda: Maxtor 6E040L0, ATA DISK drive
|
||||||
|
ide0 at 0xac800000-0xac800007,0xac8001c0 on irq 64
|
||||||
|
hda: max request size: 64KiB
|
||||||
|
hda: 80293248 sectors (41110 MB) w/2048KiB Cache, CHS=65535/16/63, (U)DMA
|
||||||
|
--snipped--
|
||||||
|
|
||||||
|
In this example 'Maxtor 6E040L0'.
|
||||||
|
|
||||||
|
Step 2 : edit 'include/asm-mips/mach-au1x00/au1xxx_ide.h'
|
||||||
|
|
||||||
|
Add your hard disc to the dma_white_list or dma_black_list structur.
|
||||||
|
|
||||||
|
Step 3 : Recompile the kernel
|
||||||
|
|
||||||
|
Enable MWDMA support in the kernel configuration. Recompile the kernel and
|
||||||
|
reboot.
|
||||||
|
|
||||||
|
Step 4 : Tests
|
||||||
|
|
||||||
|
If you have add a hard disc to the white list, please run some stress tests
|
||||||
|
for verification.
|
||||||
|
|
||||||
|
|
||||||
|
ACKNOWLEDGMENTS
|
||||||
|
---------------
|
||||||
|
|
||||||
|
These drivers wouldn't have been done without the base of kernel 2.4.x AU1XXX
|
||||||
|
IDE driver from AMD.
|
||||||
|
|
||||||
|
Additional input also from:
|
||||||
|
Matthias Lenk <matthias.lenk@amd.com>
|
||||||
|
|
||||||
|
Happy hacking!
|
||||||
|
Enrico Walther <enrico.walther@amd.com>
|
|
@ -309,7 +309,7 @@ tcp_tso_win_divisor - INTEGER
|
||||||
can be consumed by a single TSO frame.
|
can be consumed by a single TSO frame.
|
||||||
The setting of this parameter is a choice between burstiness and
|
The setting of this parameter is a choice between burstiness and
|
||||||
building larger TSO frames.
|
building larger TSO frames.
|
||||||
Default: 8
|
Default: 3
|
||||||
|
|
||||||
tcp_frto - BOOLEAN
|
tcp_frto - BOOLEAN
|
||||||
Enables F-RTO, an enhanced recovery algorithm for TCP retransmission
|
Enables F-RTO, an enhanced recovery algorithm for TCP retransmission
|
||||||
|
|
45
MAINTAINERS
45
MAINTAINERS
|
@ -116,12 +116,6 @@ M: ajk@iehk.rwth-aachen.de
|
||||||
L: linux-hams@vger.kernel.org
|
L: linux-hams@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
YEALINK PHONE DRIVER
|
|
||||||
P: Henk Vergonet
|
|
||||||
M: Henk.Vergonet@gmail.com
|
|
||||||
L: usbb2k-api-dev@nongnu.org
|
|
||||||
S: Maintained
|
|
||||||
|
|
||||||
8139CP 10/100 FAST ETHERNET DRIVER
|
8139CP 10/100 FAST ETHERNET DRIVER
|
||||||
P: Jeff Garzik
|
P: Jeff Garzik
|
||||||
M: jgarzik@pobox.com
|
M: jgarzik@pobox.com
|
||||||
|
@ -197,6 +191,15 @@ M: Thorsten Knabe <linux@thorsten-knabe.de>
|
||||||
W: http://linux.thorsten-knabe.de
|
W: http://linux.thorsten-knabe.de
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
|
AD1889 SOUND DRIVER
|
||||||
|
P: Kyle McMartin
|
||||||
|
M: kyle@parisc-linux.org
|
||||||
|
P: Thibaut Varene
|
||||||
|
M: T-Bone@parisc-linux.org
|
||||||
|
W: http://wiki.parisc-linux.org/AD1889
|
||||||
|
L: parisc-linux@lists.parisc-linux.org
|
||||||
|
S: Maintained
|
||||||
|
|
||||||
ADM1025 HARDWARE MONITOR DRIVER
|
ADM1025 HARDWARE MONITOR DRIVER
|
||||||
P: Jean Delvare
|
P: Jean Delvare
|
||||||
M: khali@linux-fr.org
|
M: khali@linux-fr.org
|
||||||
|
@ -1640,7 +1643,7 @@ S: Maintained
|
||||||
MIPS
|
MIPS
|
||||||
P: Ralf Baechle
|
P: Ralf Baechle
|
||||||
M: ralf@linux-mips.org
|
M: ralf@linux-mips.org
|
||||||
W: http://oss.sgi.com/mips/mips-howto.html
|
W: http://www.linux-mips.org/
|
||||||
L: linux-mips@linux-mips.org
|
L: linux-mips@linux-mips.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
|
@ -1942,6 +1945,14 @@ M: george@mvista.com
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
|
|
||||||
|
POWERPC 4xx EMAC DRIVER
|
||||||
|
P: Eugene Surovegin
|
||||||
|
M: ebs@ebshome.net
|
||||||
|
W: http://kernel.ebshome.net/emac/
|
||||||
|
L: linuxppc-embedded@ozlabs.org
|
||||||
|
L: netdev@vger.kernel.org
|
||||||
|
S: Maintained
|
||||||
|
|
||||||
PNP SUPPORT
|
PNP SUPPORT
|
||||||
P: Adam Belay
|
P: Adam Belay
|
||||||
M: ambx1@neo.rr.com
|
M: ambx1@neo.rr.com
|
||||||
|
@ -2486,14 +2497,6 @@ L: linux-kernel@vger.kernel.org
|
||||||
L: linux-usb-devel@lists.sourceforge.net
|
L: linux-usb-devel@lists.sourceforge.net
|
||||||
S: Supported
|
S: Supported
|
||||||
|
|
||||||
USB BLUETOOTH TTY CONVERTER DRIVER
|
|
||||||
P: Greg Kroah-Hartman
|
|
||||||
M: greg@kroah.com
|
|
||||||
L: linux-usb-users@lists.sourceforge.net
|
|
||||||
L: linux-usb-devel@lists.sourceforge.net
|
|
||||||
S: Maintained
|
|
||||||
W: http://www.kroah.com/linux-usb/
|
|
||||||
|
|
||||||
USB CDC ETHERNET DRIVER
|
USB CDC ETHERNET DRIVER
|
||||||
P: Greg Kroah-Hartman
|
P: Greg Kroah-Hartman
|
||||||
M: greg@kroah.com
|
M: greg@kroah.com
|
||||||
|
@ -2727,6 +2730,12 @@ P: Roger Luethi
|
||||||
M: rl@hellgate.ch
|
M: rl@hellgate.ch
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
|
VIAPRO SMBUS DRIVER
|
||||||
|
P: Jean Delvare
|
||||||
|
M: khali@linux-fr.org
|
||||||
|
L: lm-sensors@lm-sensors.org
|
||||||
|
S: Maintained
|
||||||
|
|
||||||
UCLINUX (AND M68KNOMMU)
|
UCLINUX (AND M68KNOMMU)
|
||||||
P: Greg Ungerer
|
P: Greg Ungerer
|
||||||
M: gerg@uclinux.org
|
M: gerg@uclinux.org
|
||||||
|
@ -2848,6 +2857,12 @@ M: jpr@f6fbb.org
|
||||||
L: linux-hams@vger.kernel.org
|
L: linux-hams@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
|
YEALINK PHONE DRIVER
|
||||||
|
P: Henk Vergonet
|
||||||
|
M: Henk.Vergonet@gmail.com
|
||||||
|
L: usbb2k-api-dev@nongnu.org
|
||||||
|
S: Maintained
|
||||||
|
|
||||||
YMFPCI YAMAHA PCI SOUND (Use ALSA instead)
|
YMFPCI YAMAHA PCI SOUND (Use ALSA instead)
|
||||||
P: Pete Zaitcev
|
P: Pete Zaitcev
|
||||||
M: zaitcev@yahoo.com
|
M: zaitcev@yahoo.com
|
||||||
|
|
4
Makefile
4
Makefile
|
@ -371,8 +371,8 @@ export MODVERDIR := $(if $(KBUILD_EXTMOD),$(firstword $(KBUILD_EXTMOD))/).tmp_ve
|
||||||
|
|
||||||
# Files to ignore in find ... statements
|
# Files to ignore in find ... statements
|
||||||
|
|
||||||
RCS_FIND_IGNORE := \( -name SCCS -o -name BitKeeper -o -name .svn -o -name CVS -o -name .pc -o -name .hg \) -prune -o
|
RCS_FIND_IGNORE := \( -name SCCS -o -name BitKeeper -o -name .svn -o -name CVS -o -name .pc -o -name .hg -o -name .git \) -prune -o
|
||||||
export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn --exclude CVS --exclude .pc --exclude .hg
|
export RCS_TAR_IGNORE := --exclude SCCS --exclude BitKeeper --exclude .svn --exclude CVS --exclude .pc --exclude .hg --exclude .git
|
||||||
|
|
||||||
# ===========================================================================
|
# ===========================================================================
|
||||||
# Rules shared between *config targets and build targets
|
# Rules shared between *config targets and build targets
|
||||||
|
|
|
@ -371,6 +371,8 @@ show_mem(void)
|
||||||
show_free_areas();
|
show_free_areas();
|
||||||
printk("Free swap: %6ldkB\n", nr_swap_pages<<(PAGE_SHIFT-10));
|
printk("Free swap: %6ldkB\n", nr_swap_pages<<(PAGE_SHIFT-10));
|
||||||
for_each_online_node(nid) {
|
for_each_online_node(nid) {
|
||||||
|
unsigned long flags;
|
||||||
|
pgdat_resize_lock(NODE_DATA(nid), &flags);
|
||||||
i = node_spanned_pages(nid);
|
i = node_spanned_pages(nid);
|
||||||
while (i-- > 0) {
|
while (i-- > 0) {
|
||||||
struct page *page = nid_page_nr(nid, i);
|
struct page *page = nid_page_nr(nid, i);
|
||||||
|
@ -384,6 +386,7 @@ show_mem(void)
|
||||||
else
|
else
|
||||||
shared += page_count(page) - 1;
|
shared += page_count(page) - 1;
|
||||||
}
|
}
|
||||||
|
pgdat_resize_unlock(NODE_DATA(nid), &flags);
|
||||||
}
|
}
|
||||||
printk("%ld pages of RAM\n",total);
|
printk("%ld pages of RAM\n",total);
|
||||||
printk("%ld free pages\n",free);
|
printk("%ld free pages\n",free);
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
#include <asm/pgalloc.h>
|
#include <asm/pgalloc.h>
|
||||||
#include <asm/cacheflush.h>
|
#include <asm/cacheflush.h>
|
||||||
|
|
||||||
/* called with the page_table_lock held */
|
|
||||||
static inline void
|
static inline void
|
||||||
remap_area_pte(pte_t * pte, unsigned long address, unsigned long size,
|
remap_area_pte(pte_t * pte, unsigned long address, unsigned long size,
|
||||||
unsigned long phys_addr, unsigned long flags)
|
unsigned long phys_addr, unsigned long flags)
|
||||||
|
@ -31,7 +30,6 @@ remap_area_pte(pte_t * pte, unsigned long address, unsigned long size,
|
||||||
} while (address && (address < end));
|
} while (address && (address < end));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* called with the page_table_lock held */
|
|
||||||
static inline int
|
static inline int
|
||||||
remap_area_pmd(pmd_t * pmd, unsigned long address, unsigned long size,
|
remap_area_pmd(pmd_t * pmd, unsigned long address, unsigned long size,
|
||||||
unsigned long phys_addr, unsigned long flags)
|
unsigned long phys_addr, unsigned long flags)
|
||||||
|
@ -46,7 +44,7 @@ remap_area_pmd(pmd_t * pmd, unsigned long address, unsigned long size,
|
||||||
if (address >= end)
|
if (address >= end)
|
||||||
BUG();
|
BUG();
|
||||||
do {
|
do {
|
||||||
pte_t * pte = pte_alloc_kernel(&init_mm, pmd, address);
|
pte_t * pte = pte_alloc_kernel(pmd, address);
|
||||||
if (!pte)
|
if (!pte)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
remap_area_pte(pte, address, end - address,
|
remap_area_pte(pte, address, end - address,
|
||||||
|
@ -70,7 +68,6 @@ __alpha_remap_area_pages(unsigned long address, unsigned long phys_addr,
|
||||||
flush_cache_all();
|
flush_cache_all();
|
||||||
if (address >= end)
|
if (address >= end)
|
||||||
BUG();
|
BUG();
|
||||||
spin_lock(&init_mm.page_table_lock);
|
|
||||||
do {
|
do {
|
||||||
pmd_t *pmd;
|
pmd_t *pmd;
|
||||||
pmd = pmd_alloc(&init_mm, dir, address);
|
pmd = pmd_alloc(&init_mm, dir, address);
|
||||||
|
@ -84,7 +81,6 @@ __alpha_remap_area_pages(unsigned long address, unsigned long phys_addr,
|
||||||
address = (address + PGDIR_SIZE) & PGDIR_MASK;
|
address = (address + PGDIR_SIZE) & PGDIR_MASK;
|
||||||
dir++;
|
dir++;
|
||||||
} while (address && (address < end));
|
} while (address && (address < end));
|
||||||
spin_unlock(&init_mm.page_table_lock);
|
|
||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -204,6 +204,7 @@ config ARCH_H720X
|
||||||
|
|
||||||
config ARCH_AAEC2000
|
config ARCH_AAEC2000
|
||||||
bool "Agilent AAEC-2000 based"
|
bool "Agilent AAEC-2000 based"
|
||||||
|
select ARM_AMBA
|
||||||
help
|
help
|
||||||
This enables support for systems based on the Agilent AAEC-2000
|
This enables support for systems based on the Agilent AAEC-2000
|
||||||
|
|
||||||
|
@ -687,7 +688,8 @@ source "drivers/acorn/block/Kconfig"
|
||||||
|
|
||||||
if PCMCIA || ARCH_CLPS7500 || ARCH_IOP3XX || ARCH_IXP4XX \
|
if PCMCIA || ARCH_CLPS7500 || ARCH_IOP3XX || ARCH_IXP4XX \
|
||||||
|| ARCH_L7200 || ARCH_LH7A40X || ARCH_PXA || ARCH_RPC \
|
|| ARCH_L7200 || ARCH_LH7A40X || ARCH_PXA || ARCH_RPC \
|
||||||
|| ARCH_S3C2410 || ARCH_SA1100 || ARCH_SHARK || FOOTBRIDGE
|
|| ARCH_S3C2410 || ARCH_SA1100 || ARCH_SHARK || FOOTBRIDGE \
|
||||||
|
|| MACH_MP1000
|
||||||
source "drivers/ide/Kconfig"
|
source "drivers/ide/Kconfig"
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
# Copyright (C) 1995-2001 by Russell King
|
# Copyright (C) 1995-2001 by Russell King
|
||||||
|
|
||||||
LDFLAGS_vmlinux :=-p --no-undefined -X
|
LDFLAGS_vmlinux :=-p --no-undefined -X
|
||||||
CPPFLAGS_vmlinux.lds = -DTEXTADDR=$(TEXTADDR) -DDATAADDR=$(DATAADDR)
|
CPPFLAGS_vmlinux.lds = -DKERNEL_RAM_ADDR=$(TEXTADDR)
|
||||||
OBJCOPYFLAGS :=-O binary -R .note -R .comment -S
|
OBJCOPYFLAGS :=-O binary -R .note -R .comment -S
|
||||||
GZFLAGS :=-9
|
GZFLAGS :=-9
|
||||||
#CFLAGS +=-pipe
|
#CFLAGS +=-pipe
|
||||||
|
@ -108,27 +108,19 @@ export CFLAGS_3c589_cs.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
TEXTADDR := $(textaddr-y)
|
TEXTADDR := $(textaddr-y)
|
||||||
ifeq ($(CONFIG_XIP_KERNEL),y)
|
|
||||||
DATAADDR := $(TEXTADDR)
|
|
||||||
xipaddr-$(CONFIG_ARCH_CO285) := 0x5f000000
|
|
||||||
xipaddr-y ?= 0xbf000000
|
|
||||||
# Replace phys addr with virt addr while keeping offset from base.
|
|
||||||
TEXTADDR := $(shell echo $(CONFIG_XIP_PHYS_ADDR) $(xipaddr-y) | \
|
|
||||||
awk --non-decimal-data '/[:xdigit:]/ \
|
|
||||||
{ printf("0x%x\n", and($$1, 0x000fffff) + $$2) }' )
|
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(incdir-y),)
|
ifeq ($(incdir-y),)
|
||||||
incdir-y := $(machine-y)
|
incdir-y := $(machine-y)
|
||||||
endif
|
endif
|
||||||
INCDIR := arch-$(incdir-y)
|
INCDIR := arch-$(incdir-y)
|
||||||
|
|
||||||
ifneq ($(machine-y),)
|
ifneq ($(machine-y),)
|
||||||
MACHINE := arch/arm/mach-$(machine-y)/
|
MACHINE := arch/arm/mach-$(machine-y)/
|
||||||
else
|
else
|
||||||
MACHINE :=
|
MACHINE :=
|
||||||
endif
|
endif
|
||||||
|
|
||||||
export TEXTADDR DATAADDR GZFLAGS
|
export TEXTADDR GZFLAGS
|
||||||
|
|
||||||
# Do we have FASTFPE?
|
# Do we have FASTFPE?
|
||||||
FASTFPE :=arch/arm/fastfpe
|
FASTFPE :=arch/arm/fastfpe
|
||||||
|
|
|
@ -39,7 +39,8 @@
|
||||||
defined(CONFIG_ARCH_IXP4XX) || \
|
defined(CONFIG_ARCH_IXP4XX) || \
|
||||||
defined(CONFIG_ARCH_IXP2000) || \
|
defined(CONFIG_ARCH_IXP2000) || \
|
||||||
defined(CONFIG_ARCH_LH7A40X) || \
|
defined(CONFIG_ARCH_LH7A40X) || \
|
||||||
defined(CONFIG_ARCH_OMAP)
|
defined(CONFIG_ARCH_OMAP) || \
|
||||||
|
defined(CONFIG_MACH_MP1000)
|
||||||
.macro loadsp, rb
|
.macro loadsp, rb
|
||||||
addruart \rb
|
addruart \rb
|
||||||
.endm
|
.endm
|
||||||
|
|
|
@ -30,7 +30,7 @@ unsigned int __machine_arch_type;
|
||||||
#define putstr icedcc_putstr
|
#define putstr icedcc_putstr
|
||||||
#define putc icedcc_putc
|
#define putc icedcc_putc
|
||||||
|
|
||||||
extern void idedcc_putc(int ch);
|
extern void icedcc_putc(int ch);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
icedcc_putstr(const char *ptr)
|
icedcc_putstr(const char *ptr)
|
||||||
|
|
|
@ -550,15 +550,12 @@ struct locomo_save_data {
|
||||||
u16 LCM_SPIMD;
|
u16 LCM_SPIMD;
|
||||||
};
|
};
|
||||||
|
|
||||||
static int locomo_suspend(struct device *dev, pm_message_t state, u32 level)
|
static int locomo_suspend(struct device *dev, pm_message_t state)
|
||||||
{
|
{
|
||||||
struct locomo *lchip = dev_get_drvdata(dev);
|
struct locomo *lchip = dev_get_drvdata(dev);
|
||||||
struct locomo_save_data *save;
|
struct locomo_save_data *save;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
if (level != SUSPEND_DISABLE)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
save = kmalloc(sizeof(struct locomo_save_data), GFP_KERNEL);
|
save = kmalloc(sizeof(struct locomo_save_data), GFP_KERNEL);
|
||||||
if (!save)
|
if (!save)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
@ -597,16 +594,13 @@ static int locomo_suspend(struct device *dev, pm_message_t state, u32 level)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int locomo_resume(struct device *dev, u32 level)
|
static int locomo_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
struct locomo *lchip = dev_get_drvdata(dev);
|
struct locomo *lchip = dev_get_drvdata(dev);
|
||||||
struct locomo_save_data *save;
|
struct locomo_save_data *save;
|
||||||
unsigned long r;
|
unsigned long r;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
if (level != RESUME_ENABLE)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
save = (struct locomo_save_data *) dev->power.saved_state;
|
save = (struct locomo_save_data *) dev->power.saved_state;
|
||||||
if (!save)
|
if (!save)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -801,7 +801,7 @@ struct sa1111_save_data {
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
|
|
||||||
static int sa1111_suspend(struct device *dev, pm_message_t state, u32 level)
|
static int sa1111_suspend(struct device *dev, pm_message_t state)
|
||||||
{
|
{
|
||||||
struct sa1111 *sachip = dev_get_drvdata(dev);
|
struct sa1111 *sachip = dev_get_drvdata(dev);
|
||||||
struct sa1111_save_data *save;
|
struct sa1111_save_data *save;
|
||||||
|
@ -809,9 +809,6 @@ static int sa1111_suspend(struct device *dev, pm_message_t state, u32 level)
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
void __iomem *base;
|
void __iomem *base;
|
||||||
|
|
||||||
if (level != SUSPEND_DISABLE)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
save = kmalloc(sizeof(struct sa1111_save_data), GFP_KERNEL);
|
save = kmalloc(sizeof(struct sa1111_save_data), GFP_KERNEL);
|
||||||
if (!save)
|
if (!save)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
@ -856,23 +853,19 @@ static int sa1111_suspend(struct device *dev, pm_message_t state, u32 level)
|
||||||
/*
|
/*
|
||||||
* sa1111_resume - Restore the SA1111 device state.
|
* sa1111_resume - Restore the SA1111 device state.
|
||||||
* @dev: device to restore
|
* @dev: device to restore
|
||||||
* @level: resume level
|
|
||||||
*
|
*
|
||||||
* Restore the general state of the SA1111; clock control and
|
* Restore the general state of the SA1111; clock control and
|
||||||
* interrupt controller. Other parts of the SA1111 must be
|
* interrupt controller. Other parts of the SA1111 must be
|
||||||
* restored by their respective drivers, and must be called
|
* restored by their respective drivers, and must be called
|
||||||
* via LDM after this function.
|
* via LDM after this function.
|
||||||
*/
|
*/
|
||||||
static int sa1111_resume(struct device *dev, u32 level)
|
static int sa1111_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
struct sa1111 *sachip = dev_get_drvdata(dev);
|
struct sa1111 *sachip = dev_get_drvdata(dev);
|
||||||
struct sa1111_save_data *save;
|
struct sa1111_save_data *save;
|
||||||
unsigned long flags, id;
|
unsigned long flags, id;
|
||||||
void __iomem *base;
|
void __iomem *base;
|
||||||
|
|
||||||
if (level != RESUME_ENABLE)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
save = (struct sa1111_save_data *)dev->power.saved_state;
|
save = (struct sa1111_save_data *)dev->power.saved_state;
|
||||||
if (!save)
|
if (!save)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -102,26 +102,24 @@ static void check_scoop_reg(struct scoop_dev *sdev)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
static int scoop_suspend(struct device *dev, pm_message_t state, uint32_t level)
|
static int scoop_suspend(struct device *dev, pm_message_t state)
|
||||||
{
|
{
|
||||||
if (level == SUSPEND_POWER_DOWN) {
|
|
||||||
struct scoop_dev *sdev = dev_get_drvdata(dev);
|
struct scoop_dev *sdev = dev_get_drvdata(dev);
|
||||||
|
|
||||||
check_scoop_reg(sdev);
|
check_scoop_reg(sdev);
|
||||||
sdev->scoop_gpwr = SCOOP_REG(sdev->base, SCOOP_GPWR);
|
sdev->scoop_gpwr = SCOOP_REG(sdev->base, SCOOP_GPWR);
|
||||||
SCOOP_REG(sdev->base, SCOOP_GPWR) = (sdev->scoop_gpwr & ~sdev->suspend_clr) | sdev->suspend_set;
|
SCOOP_REG(sdev->base, SCOOP_GPWR) = (sdev->scoop_gpwr & ~sdev->suspend_clr) | sdev->suspend_set;
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int scoop_resume(struct device *dev, uint32_t level)
|
static int scoop_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
if (level == RESUME_POWER_ON) {
|
|
||||||
struct scoop_dev *sdev = dev_get_drvdata(dev);
|
struct scoop_dev *sdev = dev_get_drvdata(dev);
|
||||||
|
|
||||||
check_scoop_reg(sdev);
|
check_scoop_reg(sdev);
|
||||||
SCOOP_REG(sdev->base,SCOOP_GPWR) = sdev->scoop_gpwr;
|
SCOOP_REG(sdev->base,SCOOP_GPWR) = sdev->scoop_gpwr;
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -0,0 +1,897 @@
|
||||||
|
#
|
||||||
|
# Automatically generated make config: don't edit
|
||||||
|
# Linux kernel version: 2.6.14-rc1
|
||||||
|
# Fri Sep 16 15:48:13 2005
|
||||||
|
#
|
||||||
|
CONFIG_ARM=y
|
||||||
|
CONFIG_MMU=y
|
||||||
|
CONFIG_UID16=y
|
||||||
|
CONFIG_RWSEM_GENERIC_SPINLOCK=y
|
||||||
|
CONFIG_GENERIC_CALIBRATE_DELAY=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Code maturity level options
|
||||||
|
#
|
||||||
|
CONFIG_EXPERIMENTAL=y
|
||||||
|
# CONFIG_CLEAN_COMPILE is not set
|
||||||
|
CONFIG_BROKEN=y
|
||||||
|
CONFIG_BROKEN_ON_SMP=y
|
||||||
|
CONFIG_LOCK_KERNEL=y
|
||||||
|
CONFIG_INIT_ENV_ARG_LIMIT=32
|
||||||
|
|
||||||
|
#
|
||||||
|
# General setup
|
||||||
|
#
|
||||||
|
CONFIG_LOCALVERSION=""
|
||||||
|
CONFIG_LOCALVERSION_AUTO=y
|
||||||
|
CONFIG_SWAP=y
|
||||||
|
CONFIG_SYSVIPC=y
|
||||||
|
# CONFIG_POSIX_MQUEUE is not set
|
||||||
|
# CONFIG_BSD_PROCESS_ACCT is not set
|
||||||
|
CONFIG_SYSCTL=y
|
||||||
|
# CONFIG_AUDIT is not set
|
||||||
|
# CONFIG_HOTPLUG is not set
|
||||||
|
CONFIG_KOBJECT_UEVENT=y
|
||||||
|
CONFIG_IKCONFIG=y
|
||||||
|
CONFIG_IKCONFIG_PROC=y
|
||||||
|
CONFIG_INITRAMFS_SOURCE=""
|
||||||
|
CONFIG_EMBEDDED=y
|
||||||
|
CONFIG_KALLSYMS=y
|
||||||
|
# CONFIG_KALLSYMS_ALL is not set
|
||||||
|
# CONFIG_KALLSYMS_EXTRA_PASS is not set
|
||||||
|
CONFIG_PRINTK=y
|
||||||
|
CONFIG_BUG=y
|
||||||
|
CONFIG_BASE_FULL=y
|
||||||
|
CONFIG_FUTEX=y
|
||||||
|
CONFIG_EPOLL=y
|
||||||
|
CONFIG_CC_OPTIMIZE_FOR_SIZE=y
|
||||||
|
CONFIG_SHMEM=y
|
||||||
|
CONFIG_CC_ALIGN_FUNCTIONS=0
|
||||||
|
CONFIG_CC_ALIGN_LABELS=0
|
||||||
|
CONFIG_CC_ALIGN_LOOPS=0
|
||||||
|
CONFIG_CC_ALIGN_JUMPS=0
|
||||||
|
# CONFIG_TINY_SHMEM is not set
|
||||||
|
CONFIG_BASE_SMALL=0
|
||||||
|
|
||||||
|
#
|
||||||
|
# Loadable module support
|
||||||
|
#
|
||||||
|
CONFIG_MODULES=y
|
||||||
|
CONFIG_MODULE_UNLOAD=y
|
||||||
|
# CONFIG_MODULE_FORCE_UNLOAD is not set
|
||||||
|
CONFIG_OBSOLETE_MODPARM=y
|
||||||
|
# CONFIG_MODVERSIONS is not set
|
||||||
|
# CONFIG_MODULE_SRCVERSION_ALL is not set
|
||||||
|
CONFIG_KMOD=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# System Type
|
||||||
|
#
|
||||||
|
# CONFIG_ARCH_CLPS7500 is not set
|
||||||
|
CONFIG_ARCH_CLPS711X=y
|
||||||
|
# CONFIG_ARCH_CO285 is not set
|
||||||
|
# CONFIG_ARCH_EBSA110 is not set
|
||||||
|
# CONFIG_ARCH_CAMELOT is not set
|
||||||
|
# CONFIG_ARCH_FOOTBRIDGE is not set
|
||||||
|
# CONFIG_ARCH_INTEGRATOR is not set
|
||||||
|
# CONFIG_ARCH_IOP3XX is not set
|
||||||
|
# CONFIG_ARCH_IXP4XX is not set
|
||||||
|
# CONFIG_ARCH_IXP2000 is not set
|
||||||
|
# CONFIG_ARCH_L7200 is not set
|
||||||
|
# CONFIG_ARCH_PXA is not set
|
||||||
|
# CONFIG_ARCH_RPC is not set
|
||||||
|
# CONFIG_ARCH_SA1100 is not set
|
||||||
|
# CONFIG_ARCH_S3C2410 is not set
|
||||||
|
# CONFIG_ARCH_SHARK is not set
|
||||||
|
# CONFIG_ARCH_LH7A40X is not set
|
||||||
|
# CONFIG_ARCH_OMAP is not set
|
||||||
|
# CONFIG_ARCH_VERSATILE is not set
|
||||||
|
# CONFIG_ARCH_IMX is not set
|
||||||
|
# CONFIG_ARCH_H720X is not set
|
||||||
|
# CONFIG_ARCH_AAEC2000 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# CLPS711X/EP721X Implementations
|
||||||
|
#
|
||||||
|
# CONFIG_ARCH_AUTCPU12 is not set
|
||||||
|
# CONFIG_ARCH_CDB89712 is not set
|
||||||
|
# CONFIG_ARCH_CEIVA is not set
|
||||||
|
# CONFIG_ARCH_CLEP7312 is not set
|
||||||
|
# CONFIG_ARCH_EDB7211 is not set
|
||||||
|
# CONFIG_ARCH_P720T is not set
|
||||||
|
# CONFIG_ARCH_FORTUNET is not set
|
||||||
|
CONFIG_MACH_MP1000=y
|
||||||
|
CONFIG_MP1000_90MHZ=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Processor Type
|
||||||
|
#
|
||||||
|
CONFIG_CPU_32=y
|
||||||
|
CONFIG_CPU_ARM720T=y
|
||||||
|
CONFIG_CPU_32v4=y
|
||||||
|
CONFIG_CPU_ABRT_LV4T=y
|
||||||
|
CONFIG_CPU_CACHE_V4=y
|
||||||
|
CONFIG_CPU_CACHE_VIVT=y
|
||||||
|
CONFIG_CPU_COPY_V4WT=y
|
||||||
|
CONFIG_CPU_TLB_V4WT=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Processor Features
|
||||||
|
#
|
||||||
|
CONFIG_ARM_THUMB=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Bus support
|
||||||
|
#
|
||||||
|
CONFIG_ISA_DMA_API=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# PCCARD (PCMCIA/CardBus) support
|
||||||
|
#
|
||||||
|
# CONFIG_PCCARD is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Kernel Features
|
||||||
|
#
|
||||||
|
# CONFIG_SMP is not set
|
||||||
|
CONFIG_PREEMPT=y
|
||||||
|
# CONFIG_NO_IDLE_HZ is not set
|
||||||
|
# CONFIG_ARCH_DISCONTIGMEM_ENABLE is not set
|
||||||
|
CONFIG_SELECT_MEMORY_MODEL=y
|
||||||
|
CONFIG_FLATMEM_MANUAL=y
|
||||||
|
# CONFIG_DISCONTIGMEM_MANUAL is not set
|
||||||
|
# CONFIG_SPARSEMEM_MANUAL is not set
|
||||||
|
CONFIG_FLATMEM=y
|
||||||
|
CONFIG_FLAT_NODE_MEM_MAP=y
|
||||||
|
# CONFIG_SPARSEMEM_STATIC is not set
|
||||||
|
CONFIG_ALIGNMENT_TRAP=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Boot options
|
||||||
|
#
|
||||||
|
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||||
|
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||||
|
CONFIG_CMDLINE="console=ttyCL,38400 root=/dev/discs/disc0/part1 ip=any cs89x0_media=rj45"
|
||||||
|
# CONFIG_XIP_KERNEL is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Floating point emulation
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# At least one emulation must be selected
|
||||||
|
#
|
||||||
|
CONFIG_FPE_NWFPE=y
|
||||||
|
# CONFIG_FPE_NWFPE_XP is not set
|
||||||
|
# CONFIG_FPE_FASTFPE is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Userspace binary formats
|
||||||
|
#
|
||||||
|
CONFIG_BINFMT_ELF=y
|
||||||
|
# CONFIG_BINFMT_AOUT is not set
|
||||||
|
CONFIG_BINFMT_MISC=y
|
||||||
|
# CONFIG_ARTHUR is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Power management options
|
||||||
|
#
|
||||||
|
# CONFIG_PM is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Networking
|
||||||
|
#
|
||||||
|
CONFIG_NET=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Networking options
|
||||||
|
#
|
||||||
|
CONFIG_PACKET=y
|
||||||
|
# CONFIG_PACKET_MMAP is not set
|
||||||
|
CONFIG_UNIX=y
|
||||||
|
# CONFIG_NET_KEY is not set
|
||||||
|
CONFIG_INET=y
|
||||||
|
# CONFIG_IP_MULTICAST is not set
|
||||||
|
# CONFIG_IP_ADVANCED_ROUTER is not set
|
||||||
|
CONFIG_IP_FIB_HASH=y
|
||||||
|
CONFIG_IP_PNP=y
|
||||||
|
CONFIG_IP_PNP_DHCP=y
|
||||||
|
CONFIG_IP_PNP_BOOTP=y
|
||||||
|
CONFIG_IP_PNP_RARP=y
|
||||||
|
# CONFIG_NET_IPIP is not set
|
||||||
|
# CONFIG_NET_IPGRE is not set
|
||||||
|
# CONFIG_ARPD is not set
|
||||||
|
# CONFIG_SYN_COOKIES is not set
|
||||||
|
# CONFIG_INET_AH is not set
|
||||||
|
# CONFIG_INET_ESP is not set
|
||||||
|
# CONFIG_INET_IPCOMP is not set
|
||||||
|
# CONFIG_INET_TUNNEL is not set
|
||||||
|
CONFIG_INET_DIAG=y
|
||||||
|
CONFIG_INET_TCP_DIAG=y
|
||||||
|
# CONFIG_TCP_CONG_ADVANCED is not set
|
||||||
|
CONFIG_TCP_CONG_BIC=y
|
||||||
|
CONFIG_IPV6=y
|
||||||
|
# CONFIG_IPV6_PRIVACY is not set
|
||||||
|
# CONFIG_INET6_AH is not set
|
||||||
|
# CONFIG_INET6_ESP is not set
|
||||||
|
# CONFIG_INET6_IPCOMP is not set
|
||||||
|
# CONFIG_INET6_TUNNEL is not set
|
||||||
|
# CONFIG_IPV6_TUNNEL is not set
|
||||||
|
# CONFIG_NETFILTER is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# DCCP Configuration (EXPERIMENTAL)
|
||||||
|
#
|
||||||
|
# CONFIG_IP_DCCP is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# SCTP Configuration (EXPERIMENTAL)
|
||||||
|
#
|
||||||
|
# CONFIG_IP_SCTP is not set
|
||||||
|
# CONFIG_ATM is not set
|
||||||
|
# CONFIG_BRIDGE is not set
|
||||||
|
# CONFIG_VLAN_8021Q is not set
|
||||||
|
# CONFIG_DECNET is not set
|
||||||
|
# CONFIG_LLC2 is not set
|
||||||
|
# CONFIG_IPX is not set
|
||||||
|
# CONFIG_ATALK is not set
|
||||||
|
# CONFIG_X25 is not set
|
||||||
|
# CONFIG_LAPB is not set
|
||||||
|
# CONFIG_NET_DIVERT is not set
|
||||||
|
# CONFIG_ECONET is not set
|
||||||
|
# CONFIG_WAN_ROUTER is not set
|
||||||
|
# CONFIG_NET_SCHED is not set
|
||||||
|
# CONFIG_NET_CLS_ROUTE is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Network testing
|
||||||
|
#
|
||||||
|
# CONFIG_NET_PKTGEN is not set
|
||||||
|
# CONFIG_NETFILTER_NETLINK is not set
|
||||||
|
# CONFIG_HAMRADIO is not set
|
||||||
|
# CONFIG_IRDA is not set
|
||||||
|
# CONFIG_BT is not set
|
||||||
|
# CONFIG_IEEE80211 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Device Drivers
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Generic Driver Options
|
||||||
|
#
|
||||||
|
CONFIG_STANDALONE=y
|
||||||
|
CONFIG_PREVENT_FIRMWARE_BUILD=y
|
||||||
|
# CONFIG_FW_LOADER is not set
|
||||||
|
# CONFIG_DEBUG_DRIVER is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Memory Technology Devices (MTD)
|
||||||
|
#
|
||||||
|
CONFIG_MTD=y
|
||||||
|
CONFIG_MTD_DEBUG=y
|
||||||
|
CONFIG_MTD_DEBUG_VERBOSE=3
|
||||||
|
# CONFIG_MTD_CONCAT is not set
|
||||||
|
CONFIG_MTD_PARTITIONS=y
|
||||||
|
CONFIG_MTD_REDBOOT_PARTS=m
|
||||||
|
CONFIG_MTD_REDBOOT_DIRECTORY_BLOCK=-2
|
||||||
|
CONFIG_MTD_REDBOOT_PARTS_UNALLOCATED=y
|
||||||
|
# CONFIG_MTD_REDBOOT_PARTS_READONLY is not set
|
||||||
|
CONFIG_MTD_CMDLINE_PARTS=y
|
||||||
|
# CONFIG_MTD_AFS_PARTS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# User Modules And Translation Layers
|
||||||
|
#
|
||||||
|
CONFIG_MTD_CHAR=y
|
||||||
|
CONFIG_MTD_BLOCK=y
|
||||||
|
# CONFIG_FTL is not set
|
||||||
|
# CONFIG_NFTL is not set
|
||||||
|
# CONFIG_INFTL is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# RAM/ROM/Flash chip drivers
|
||||||
|
#
|
||||||
|
CONFIG_MTD_CFI=m
|
||||||
|
# CONFIG_MTD_JEDECPROBE is not set
|
||||||
|
CONFIG_MTD_GEN_PROBE=m
|
||||||
|
CONFIG_MTD_CFI_ADV_OPTIONS=y
|
||||||
|
CONFIG_MTD_CFI_NOSWAP=y
|
||||||
|
# CONFIG_MTD_CFI_BE_BYTE_SWAP is not set
|
||||||
|
# CONFIG_MTD_CFI_LE_BYTE_SWAP is not set
|
||||||
|
CONFIG_MTD_CFI_GEOMETRY=y
|
||||||
|
# CONFIG_MTD_MAP_BANK_WIDTH_1 is not set
|
||||||
|
# CONFIG_MTD_MAP_BANK_WIDTH_2 is not set
|
||||||
|
CONFIG_MTD_MAP_BANK_WIDTH_4=y
|
||||||
|
# CONFIG_MTD_MAP_BANK_WIDTH_8 is not set
|
||||||
|
# CONFIG_MTD_MAP_BANK_WIDTH_16 is not set
|
||||||
|
# CONFIG_MTD_MAP_BANK_WIDTH_32 is not set
|
||||||
|
# CONFIG_MTD_CFI_I1 is not set
|
||||||
|
CONFIG_MTD_CFI_I2=y
|
||||||
|
# CONFIG_MTD_CFI_I4 is not set
|
||||||
|
# CONFIG_MTD_CFI_I8 is not set
|
||||||
|
# CONFIG_MTD_OTP is not set
|
||||||
|
CONFIG_MTD_CFI_INTELEXT=m
|
||||||
|
# CONFIG_MTD_CFI_AMDSTD is not set
|
||||||
|
# CONFIG_MTD_CFI_STAA is not set
|
||||||
|
CONFIG_MTD_CFI_UTIL=m
|
||||||
|
# CONFIG_MTD_RAM is not set
|
||||||
|
# CONFIG_MTD_ROM is not set
|
||||||
|
# CONFIG_MTD_ABSENT is not set
|
||||||
|
# CONFIG_MTD_OBSOLETE_CHIPS is not set
|
||||||
|
# CONFIG_MTD_XIP is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Mapping drivers for chip access
|
||||||
|
#
|
||||||
|
# CONFIG_MTD_COMPLEX_MAPPINGS is not set
|
||||||
|
CONFIG_MTD_PHYSMAP=m
|
||||||
|
CONFIG_MTD_PHYSMAP_START=0x0000000
|
||||||
|
CONFIG_MTD_PHYSMAP_LEN=0x4000000
|
||||||
|
CONFIG_MTD_PHYSMAP_BANKWIDTH=2
|
||||||
|
# CONFIG_MTD_ARM_INTEGRATOR is not set
|
||||||
|
CONFIG_MTD_EDB7312=m
|
||||||
|
# CONFIG_MTD_PLATRAM is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Self-contained MTD device drivers
|
||||||
|
#
|
||||||
|
# CONFIG_MTD_SLRAM is not set
|
||||||
|
# CONFIG_MTD_PHRAM is not set
|
||||||
|
# CONFIG_MTD_MTDRAM is not set
|
||||||
|
# CONFIG_MTD_BLKMTD is not set
|
||||||
|
# CONFIG_MTD_BLOCK2MTD is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Disk-On-Chip Device Drivers
|
||||||
|
#
|
||||||
|
# CONFIG_MTD_DOC2000 is not set
|
||||||
|
# CONFIG_MTD_DOC2001 is not set
|
||||||
|
# CONFIG_MTD_DOC2001PLUS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# NAND Flash Device Drivers
|
||||||
|
#
|
||||||
|
CONFIG_MTD_NAND=y
|
||||||
|
# CONFIG_MTD_NAND_VERIFY_WRITE is not set
|
||||||
|
CONFIG_MTD_NAND_MP1000=y
|
||||||
|
CONFIG_MTD_NAND_IDS=y
|
||||||
|
# CONFIG_MTD_NAND_DISKONCHIP is not set
|
||||||
|
# CONFIG_MTD_NAND_NANDSIM is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Parallel port support
|
||||||
|
#
|
||||||
|
# CONFIG_PARPORT is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Plug and Play support
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Block devices
|
||||||
|
#
|
||||||
|
# CONFIG_BLK_DEV_COW_COMMON is not set
|
||||||
|
CONFIG_BLK_DEV_LOOP=m
|
||||||
|
# CONFIG_BLK_DEV_CRYPTOLOOP is not set
|
||||||
|
# CONFIG_BLK_DEV_NBD is not set
|
||||||
|
CONFIG_BLK_DEV_RAM=y
|
||||||
|
CONFIG_BLK_DEV_RAM_COUNT=2
|
||||||
|
CONFIG_BLK_DEV_RAM_SIZE=16384
|
||||||
|
CONFIG_BLK_DEV_INITRD=y
|
||||||
|
# CONFIG_CDROM_PKTCDVD is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# IO Schedulers
|
||||||
|
#
|
||||||
|
CONFIG_IOSCHED_NOOP=y
|
||||||
|
CONFIG_IOSCHED_AS=y
|
||||||
|
CONFIG_IOSCHED_DEADLINE=y
|
||||||
|
CONFIG_IOSCHED_CFQ=y
|
||||||
|
# CONFIG_ATA_OVER_ETH is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# ATA/ATAPI/MFM/RLL support
|
||||||
|
#
|
||||||
|
CONFIG_IDE=y
|
||||||
|
CONFIG_BLK_DEV_IDE=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Please see Documentation/ide.txt for help/info on IDE drives
|
||||||
|
#
|
||||||
|
# CONFIG_BLK_DEV_IDE_SATA is not set
|
||||||
|
# CONFIG_BLK_DEV_HD_IDE is not set
|
||||||
|
CONFIG_BLK_DEV_IDEDISK=y
|
||||||
|
# CONFIG_IDEDISK_MULTI_MODE is not set
|
||||||
|
# CONFIG_BLK_DEV_IDECD is not set
|
||||||
|
# CONFIG_BLK_DEV_IDETAPE is not set
|
||||||
|
# CONFIG_BLK_DEV_IDEFLOPPY is not set
|
||||||
|
# CONFIG_IDE_TASK_IOCTL is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# IDE chipset support/bugfixes
|
||||||
|
#
|
||||||
|
# CONFIG_IDE_GENERIC is not set
|
||||||
|
CONFIG_IDE_ARM=y
|
||||||
|
CONFIG_BLK_DEV_IDE_MP1000=y
|
||||||
|
# CONFIG_BLK_DEV_IDEDMA is not set
|
||||||
|
# CONFIG_IDEDMA_AUTO is not set
|
||||||
|
# CONFIG_BLK_DEV_HD is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# SCSI device support
|
||||||
|
#
|
||||||
|
# CONFIG_RAID_ATTRS is not set
|
||||||
|
# CONFIG_SCSI is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Multi-device support (RAID and LVM)
|
||||||
|
#
|
||||||
|
CONFIG_MD=y
|
||||||
|
# CONFIG_BLK_DEV_MD is not set
|
||||||
|
CONFIG_BLK_DEV_DM=y
|
||||||
|
# CONFIG_DM_CRYPT is not set
|
||||||
|
# CONFIG_DM_SNAPSHOT is not set
|
||||||
|
# CONFIG_DM_MIRROR is not set
|
||||||
|
# CONFIG_DM_ZERO is not set
|
||||||
|
# CONFIG_DM_MULTIPATH is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Fusion MPT device support
|
||||||
|
#
|
||||||
|
# CONFIG_FUSION is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# IEEE 1394 (FireWire) support
|
||||||
|
#
|
||||||
|
# CONFIG_IEEE1394 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# I2O device support
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Network device support
|
||||||
|
#
|
||||||
|
CONFIG_NETDEVICES=y
|
||||||
|
# CONFIG_DUMMY is not set
|
||||||
|
# CONFIG_BONDING is not set
|
||||||
|
# CONFIG_EQUALIZER is not set
|
||||||
|
# CONFIG_TUN is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# PHY device support
|
||||||
|
#
|
||||||
|
# CONFIG_PHYLIB is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Ethernet (10 or 100Mbit)
|
||||||
|
#
|
||||||
|
CONFIG_NET_ETHERNET=y
|
||||||
|
# CONFIG_MII is not set
|
||||||
|
# CONFIG_SMC91X is not set
|
||||||
|
# CONFIG_DM9000 is not set
|
||||||
|
CONFIG_CS89x0=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Ethernet (1000 Mbit)
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Ethernet (10000 Mbit)
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Token Ring devices
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Wireless LAN (non-hamradio)
|
||||||
|
#
|
||||||
|
# CONFIG_NET_RADIO is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Wan interfaces
|
||||||
|
#
|
||||||
|
# CONFIG_WAN is not set
|
||||||
|
# CONFIG_PPP is not set
|
||||||
|
# CONFIG_SLIP is not set
|
||||||
|
# CONFIG_SHAPER is not set
|
||||||
|
# CONFIG_NETCONSOLE is not set
|
||||||
|
# CONFIG_NETPOLL is not set
|
||||||
|
# CONFIG_NET_POLL_CONTROLLER is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# ISDN subsystem
|
||||||
|
#
|
||||||
|
# CONFIG_ISDN is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Input device support
|
||||||
|
#
|
||||||
|
CONFIG_INPUT=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Userland interfaces
|
||||||
|
#
|
||||||
|
# CONFIG_INPUT_MOUSEDEV is not set
|
||||||
|
# CONFIG_INPUT_JOYDEV is not set
|
||||||
|
# CONFIG_INPUT_TSDEV is not set
|
||||||
|
# CONFIG_INPUT_EVDEV is not set
|
||||||
|
CONFIG_INPUT_EVBUG=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Input Device Drivers
|
||||||
|
#
|
||||||
|
# CONFIG_INPUT_KEYBOARD is not set
|
||||||
|
# CONFIG_INPUT_MOUSE is not set
|
||||||
|
# CONFIG_INPUT_JOYSTICK is not set
|
||||||
|
# CONFIG_INPUT_TOUCHSCREEN is not set
|
||||||
|
# CONFIG_INPUT_MISC is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Hardware I/O ports
|
||||||
|
#
|
||||||
|
CONFIG_SERIO=y
|
||||||
|
CONFIG_SERIO_SERPORT=y
|
||||||
|
# CONFIG_SERIO_LIBPS2 is not set
|
||||||
|
# CONFIG_SERIO_RAW is not set
|
||||||
|
# CONFIG_GAMEPORT is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Character devices
|
||||||
|
#
|
||||||
|
CONFIG_VT=y
|
||||||
|
CONFIG_VT_CONSOLE=y
|
||||||
|
CONFIG_HW_CONSOLE=y
|
||||||
|
# CONFIG_SERIAL_NONSTANDARD is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Serial drivers
|
||||||
|
#
|
||||||
|
CONFIG_SERIAL_8250=y
|
||||||
|
CONFIG_SERIAL_8250_CONSOLE=y
|
||||||
|
CONFIG_SERIAL_8250_NR_UARTS=2
|
||||||
|
# CONFIG_SERIAL_8250_EXTENDED is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Non-8250 serial port support
|
||||||
|
#
|
||||||
|
CONFIG_SERIAL_CLPS711X=y
|
||||||
|
CONFIG_SERIAL_CLPS711X_CONSOLE=y
|
||||||
|
CONFIG_SERIAL_CORE=y
|
||||||
|
CONFIG_SERIAL_CORE_CONSOLE=y
|
||||||
|
CONFIG_UNIX98_PTYS=y
|
||||||
|
CONFIG_LEGACY_PTYS=y
|
||||||
|
CONFIG_LEGACY_PTY_COUNT=256
|
||||||
|
|
||||||
|
#
|
||||||
|
# IPMI
|
||||||
|
#
|
||||||
|
# CONFIG_IPMI_HANDLER is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Watchdog Cards
|
||||||
|
#
|
||||||
|
# CONFIG_WATCHDOG is not set
|
||||||
|
CONFIG_NVRAM=y
|
||||||
|
CONFIG_RTC=y
|
||||||
|
# CONFIG_DTLK is not set
|
||||||
|
# CONFIG_R3964 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Ftape, the floppy tape device driver
|
||||||
|
#
|
||||||
|
# CONFIG_RAW_DRIVER is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# TPM devices
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# I2C support
|
||||||
|
#
|
||||||
|
# CONFIG_I2C is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Hardware Monitoring support
|
||||||
|
#
|
||||||
|
CONFIG_HWMON=y
|
||||||
|
# CONFIG_HWMON_VID is not set
|
||||||
|
# CONFIG_HWMON_DEBUG_CHIP is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Misc devices
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Multimedia Capabilities Port drivers
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Multimedia devices
|
||||||
|
#
|
||||||
|
# CONFIG_VIDEO_DEV is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Digital Video Broadcasting Devices
|
||||||
|
#
|
||||||
|
# CONFIG_DVB is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Graphics support
|
||||||
|
#
|
||||||
|
# CONFIG_FB is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Console display driver support
|
||||||
|
#
|
||||||
|
# CONFIG_VGA_CONSOLE is not set
|
||||||
|
CONFIG_DUMMY_CONSOLE=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Sound
|
||||||
|
#
|
||||||
|
# CONFIG_SOUND is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# USB support
|
||||||
|
#
|
||||||
|
CONFIG_USB_ARCH_HAS_HCD=y
|
||||||
|
# CONFIG_USB_ARCH_HAS_OHCI is not set
|
||||||
|
# CONFIG_USB is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# USB Gadget Support
|
||||||
|
#
|
||||||
|
# CONFIG_USB_GADGET is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# MMC/SD Card support
|
||||||
|
#
|
||||||
|
# CONFIG_MMC is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# File systems
|
||||||
|
#
|
||||||
|
CONFIG_EXT2_FS=y
|
||||||
|
CONFIG_EXT2_FS_XATTR=y
|
||||||
|
# CONFIG_EXT2_FS_POSIX_ACL is not set
|
||||||
|
# CONFIG_EXT2_FS_SECURITY is not set
|
||||||
|
# CONFIG_EXT2_FS_XIP is not set
|
||||||
|
CONFIG_EXT3_FS=y
|
||||||
|
CONFIG_EXT3_FS_XATTR=y
|
||||||
|
# CONFIG_EXT3_FS_POSIX_ACL is not set
|
||||||
|
# CONFIG_EXT3_FS_SECURITY is not set
|
||||||
|
CONFIG_JBD=y
|
||||||
|
# CONFIG_JBD_DEBUG is not set
|
||||||
|
CONFIG_FS_MBCACHE=y
|
||||||
|
CONFIG_REISERFS_FS=m
|
||||||
|
# CONFIG_REISERFS_CHECK is not set
|
||||||
|
# CONFIG_REISERFS_PROC_INFO is not set
|
||||||
|
# CONFIG_REISERFS_FS_XATTR is not set
|
||||||
|
# CONFIG_JFS_FS is not set
|
||||||
|
CONFIG_FS_POSIX_ACL=y
|
||||||
|
# CONFIG_XFS_FS is not set
|
||||||
|
# CONFIG_MINIX_FS is not set
|
||||||
|
# CONFIG_ROMFS_FS is not set
|
||||||
|
CONFIG_INOTIFY=y
|
||||||
|
CONFIG_QUOTA=y
|
||||||
|
# CONFIG_QFMT_V1 is not set
|
||||||
|
# CONFIG_QFMT_V2 is not set
|
||||||
|
CONFIG_QUOTACTL=y
|
||||||
|
CONFIG_DNOTIFY=y
|
||||||
|
# CONFIG_AUTOFS_FS is not set
|
||||||
|
# CONFIG_AUTOFS4_FS is not set
|
||||||
|
# CONFIG_FUSE_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# CD-ROM/DVD Filesystems
|
||||||
|
#
|
||||||
|
# CONFIG_ISO9660_FS is not set
|
||||||
|
# CONFIG_UDF_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# DOS/FAT/NT Filesystems
|
||||||
|
#
|
||||||
|
# CONFIG_MSDOS_FS is not set
|
||||||
|
# CONFIG_VFAT_FS is not set
|
||||||
|
# CONFIG_NTFS_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Pseudo filesystems
|
||||||
|
#
|
||||||
|
CONFIG_PROC_FS=y
|
||||||
|
CONFIG_SYSFS=y
|
||||||
|
CONFIG_TMPFS=y
|
||||||
|
# CONFIG_HUGETLBFS is not set
|
||||||
|
# CONFIG_HUGETLB_PAGE is not set
|
||||||
|
CONFIG_RAMFS=y
|
||||||
|
# CONFIG_RELAYFS_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Miscellaneous filesystems
|
||||||
|
#
|
||||||
|
# CONFIG_ADFS_FS is not set
|
||||||
|
# CONFIG_AFFS_FS is not set
|
||||||
|
# CONFIG_HFS_FS is not set
|
||||||
|
# CONFIG_HFSPLUS_FS is not set
|
||||||
|
# CONFIG_BEFS_FS is not set
|
||||||
|
# CONFIG_BFS_FS is not set
|
||||||
|
# CONFIG_EFS_FS is not set
|
||||||
|
# CONFIG_JFFS_FS is not set
|
||||||
|
CONFIG_JFFS2_FS=m
|
||||||
|
CONFIG_JFFS2_FS_DEBUG=0
|
||||||
|
CONFIG_JFFS2_FS_WRITEBUFFER=y
|
||||||
|
# CONFIG_JFFS2_COMPRESSION_OPTIONS is not set
|
||||||
|
CONFIG_JFFS2_ZLIB=y
|
||||||
|
CONFIG_JFFS2_RTIME=y
|
||||||
|
# CONFIG_JFFS2_RUBIN is not set
|
||||||
|
CONFIG_CRAMFS=m
|
||||||
|
# CONFIG_VXFS_FS is not set
|
||||||
|
# CONFIG_HPFS_FS is not set
|
||||||
|
# CONFIG_QNX4FS_FS is not set
|
||||||
|
# CONFIG_SYSV_FS is not set
|
||||||
|
# CONFIG_UFS_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Network File Systems
|
||||||
|
#
|
||||||
|
CONFIG_NFS_FS=y
|
||||||
|
CONFIG_NFS_V3=y
|
||||||
|
# CONFIG_NFS_V3_ACL is not set
|
||||||
|
CONFIG_NFS_V4=y
|
||||||
|
# CONFIG_NFS_DIRECTIO is not set
|
||||||
|
CONFIG_NFSD=y
|
||||||
|
CONFIG_NFSD_V3=y
|
||||||
|
# CONFIG_NFSD_V3_ACL is not set
|
||||||
|
CONFIG_NFSD_V4=y
|
||||||
|
CONFIG_NFSD_TCP=y
|
||||||
|
CONFIG_ROOT_NFS=y
|
||||||
|
CONFIG_LOCKD=y
|
||||||
|
CONFIG_LOCKD_V4=y
|
||||||
|
CONFIG_EXPORTFS=y
|
||||||
|
CONFIG_NFS_COMMON=y
|
||||||
|
CONFIG_SUNRPC=y
|
||||||
|
CONFIG_SUNRPC_GSS=y
|
||||||
|
CONFIG_RPCSEC_GSS_KRB5=y
|
||||||
|
# CONFIG_RPCSEC_GSS_SPKM3 is not set
|
||||||
|
CONFIG_SMB_FS=m
|
||||||
|
# CONFIG_SMB_NLS_DEFAULT is not set
|
||||||
|
CONFIG_CIFS=m
|
||||||
|
# CONFIG_CIFS_STATS is not set
|
||||||
|
# CONFIG_CIFS_XATTR is not set
|
||||||
|
# CONFIG_CIFS_EXPERIMENTAL is not set
|
||||||
|
# CONFIG_NCP_FS is not set
|
||||||
|
# CONFIG_CODA_FS is not set
|
||||||
|
# CONFIG_AFS_FS is not set
|
||||||
|
# CONFIG_9P_FS is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Partition Types
|
||||||
|
#
|
||||||
|
# CONFIG_PARTITION_ADVANCED is not set
|
||||||
|
CONFIG_MSDOS_PARTITION=y
|
||||||
|
|
||||||
|
#
|
||||||
|
# Native Language Support
|
||||||
|
#
|
||||||
|
CONFIG_NLS=y
|
||||||
|
CONFIG_NLS_DEFAULT="iso8859-1"
|
||||||
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
|
# CONFIG_NLS_CODEPAGE_737 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_775 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_850 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_852 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_855 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_857 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_860 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_861 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_862 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_863 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_864 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_865 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_866 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_869 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_936 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_950 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_932 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_949 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_874 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_8 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_1250 is not set
|
||||||
|
# CONFIG_NLS_CODEPAGE_1251 is not set
|
||||||
|
# CONFIG_NLS_ASCII is not set
|
||||||
|
# CONFIG_NLS_ISO8859_1 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_2 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_3 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_4 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_5 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_6 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_7 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_9 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_13 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_14 is not set
|
||||||
|
# CONFIG_NLS_ISO8859_15 is not set
|
||||||
|
# CONFIG_NLS_KOI8_R is not set
|
||||||
|
# CONFIG_NLS_KOI8_U is not set
|
||||||
|
# CONFIG_NLS_UTF8 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Profiling support
|
||||||
|
#
|
||||||
|
# CONFIG_PROFILING is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Kernel hacking
|
||||||
|
#
|
||||||
|
CONFIG_PRINTK_TIME=y
|
||||||
|
CONFIG_DEBUG_KERNEL=y
|
||||||
|
# CONFIG_MAGIC_SYSRQ is not set
|
||||||
|
CONFIG_LOG_BUF_SHIFT=14
|
||||||
|
CONFIG_DETECT_SOFTLOCKUP=y
|
||||||
|
# CONFIG_SCHEDSTATS is not set
|
||||||
|
# CONFIG_DEBUG_SLAB is not set
|
||||||
|
CONFIG_DEBUG_PREEMPT=y
|
||||||
|
# CONFIG_DEBUG_SPINLOCK is not set
|
||||||
|
# CONFIG_DEBUG_SPINLOCK_SLEEP is not set
|
||||||
|
# CONFIG_DEBUG_KOBJECT is not set
|
||||||
|
# CONFIG_DEBUG_BUGVERBOSE is not set
|
||||||
|
CONFIG_DEBUG_INFO=y
|
||||||
|
# CONFIG_DEBUG_FS is not set
|
||||||
|
CONFIG_FRAME_POINTER=y
|
||||||
|
CONFIG_DEBUG_USER=y
|
||||||
|
CONFIG_DEBUG_WAITQ=y
|
||||||
|
CONFIG_DEBUG_ERRORS=y
|
||||||
|
CONFIG_DEBUG_LL=y
|
||||||
|
# CONFIG_DEBUG_ICEDCC is not set
|
||||||
|
# CONFIG_DEBUG_CLPS711X_UART2 is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Security options
|
||||||
|
#
|
||||||
|
# CONFIG_KEYS is not set
|
||||||
|
# CONFIG_SECURITY is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Cryptographic options
|
||||||
|
#
|
||||||
|
CONFIG_CRYPTO=y
|
||||||
|
# CONFIG_CRYPTO_HMAC is not set
|
||||||
|
# CONFIG_CRYPTO_NULL is not set
|
||||||
|
# CONFIG_CRYPTO_MD4 is not set
|
||||||
|
CONFIG_CRYPTO_MD5=y
|
||||||
|
# CONFIG_CRYPTO_SHA1 is not set
|
||||||
|
# CONFIG_CRYPTO_SHA256 is not set
|
||||||
|
# CONFIG_CRYPTO_SHA512 is not set
|
||||||
|
# CONFIG_CRYPTO_WP512 is not set
|
||||||
|
# CONFIG_CRYPTO_TGR192 is not set
|
||||||
|
CONFIG_CRYPTO_DES=y
|
||||||
|
# CONFIG_CRYPTO_BLOWFISH is not set
|
||||||
|
# CONFIG_CRYPTO_TWOFISH is not set
|
||||||
|
# CONFIG_CRYPTO_SERPENT is not set
|
||||||
|
# CONFIG_CRYPTO_AES is not set
|
||||||
|
# CONFIG_CRYPTO_CAST5 is not set
|
||||||
|
# CONFIG_CRYPTO_CAST6 is not set
|
||||||
|
# CONFIG_CRYPTO_TEA is not set
|
||||||
|
# CONFIG_CRYPTO_ARC4 is not set
|
||||||
|
# CONFIG_CRYPTO_KHAZAD is not set
|
||||||
|
# CONFIG_CRYPTO_ANUBIS is not set
|
||||||
|
# CONFIG_CRYPTO_DEFLATE is not set
|
||||||
|
# CONFIG_CRYPTO_MICHAEL_MIC is not set
|
||||||
|
# CONFIG_CRYPTO_CRC32C is not set
|
||||||
|
# CONFIG_CRYPTO_TEST is not set
|
||||||
|
|
||||||
|
#
|
||||||
|
# Hardware crypto devices
|
||||||
|
#
|
||||||
|
|
||||||
|
#
|
||||||
|
# Library routines
|
||||||
|
#
|
||||||
|
# CONFIG_CRC_CCITT is not set
|
||||||
|
# CONFIG_CRC16 is not set
|
||||||
|
CONFIG_CRC32=y
|
||||||
|
# CONFIG_LIBCRC32C is not set
|
||||||
|
CONFIG_ZLIB_INFLATE=m
|
||||||
|
CONFIG_ZLIB_DEFLATE=m
|
|
@ -2,7 +2,7 @@
|
||||||
# Makefile for the linux kernel.
|
# Makefile for the linux kernel.
|
||||||
#
|
#
|
||||||
|
|
||||||
AFLAGS_head.o := -DTEXTADDR=$(TEXTADDR) -DDATAADDR=$(DATAADDR)
|
AFLAGS_head.o := -DKERNEL_RAM_ADDR=$(TEXTADDR)
|
||||||
|
|
||||||
# Object file lists.
|
# Object file lists.
|
||||||
|
|
||||||
|
|
|
@ -94,7 +94,6 @@ int main(void)
|
||||||
DEFINE(VM_EXEC, VM_EXEC);
|
DEFINE(VM_EXEC, VM_EXEC);
|
||||||
BLANK();
|
BLANK();
|
||||||
DEFINE(PAGE_SZ, PAGE_SIZE);
|
DEFINE(PAGE_SZ, PAGE_SIZE);
|
||||||
DEFINE(VIRT_OFFSET, PAGE_OFFSET);
|
|
||||||
BLANK();
|
BLANK();
|
||||||
DEFINE(SYS_ERROR0, 0x9f0000);
|
DEFINE(SYS_ERROR0, 0x9f0000);
|
||||||
BLANK();
|
BLANK();
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
*/
|
*/
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
|
|
||||||
|
#include <asm/memory.h>
|
||||||
#include <asm/glue.h>
|
#include <asm/glue.h>
|
||||||
#include <asm/vfpmacros.h>
|
#include <asm/vfpmacros.h>
|
||||||
#include <asm/hardware.h> /* should be moved into entry-macro.S */
|
#include <asm/hardware.h> /* should be moved into entry-macro.S */
|
||||||
|
@ -310,7 +311,7 @@ __pabt_svc:
|
||||||
|
|
||||||
#if __LINUX_ARM_ARCH__ < 6 && !defined(CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG)
|
#if __LINUX_ARM_ARCH__ < 6 && !defined(CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG)
|
||||||
@ make sure our user space atomic helper is aborted
|
@ make sure our user space atomic helper is aborted
|
||||||
cmp r2, #VIRT_OFFSET
|
cmp r2, #TASK_SIZE
|
||||||
bichs r3, r3, #PSR_Z_BIT
|
bichs r3, r3, #PSR_Z_BIT
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,7 @@
|
||||||
#include <asm/procinfo.h>
|
#include <asm/procinfo.h>
|
||||||
#include <asm/ptrace.h>
|
#include <asm/ptrace.h>
|
||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
|
#include <asm/memory.h>
|
||||||
#include <asm/thread_info.h>
|
#include <asm/thread_info.h>
|
||||||
#include <asm/system.h>
|
#include <asm/system.h>
|
||||||
|
|
||||||
|
@ -33,52 +34,28 @@
|
||||||
#define MACHINFO_PGOFFIO 12
|
#define MACHINFO_PGOFFIO 12
|
||||||
#define MACHINFO_NAME 16
|
#define MACHINFO_NAME 16
|
||||||
|
|
||||||
#ifndef CONFIG_XIP_KERNEL
|
|
||||||
/*
|
/*
|
||||||
* We place the page tables 16K below TEXTADDR. Therefore, we must make sure
|
* swapper_pg_dir is the virtual address of the initial page table.
|
||||||
* that TEXTADDR is correctly set. Currently, we expect the least significant
|
* We place the page tables 16K below KERNEL_RAM_ADDR. Therefore, we must
|
||||||
* 16 bits to be 0x8000, but we could probably relax this restriction to
|
* make sure that KERNEL_RAM_ADDR is correctly set. Currently, we expect
|
||||||
* TEXTADDR >= PAGE_OFFSET + 0x4000
|
* the least significant 16 bits to be 0x8000, but we could probably
|
||||||
*
|
* relax this restriction to KERNEL_RAM_ADDR >= PAGE_OFFSET + 0x4000.
|
||||||
* Note that swapper_pg_dir is the virtual address of the page tables, and
|
|
||||||
* pgtbl gives us a position-independent reference to these tables. We can
|
|
||||||
* do this because stext == TEXTADDR
|
|
||||||
*/
|
*/
|
||||||
#if (TEXTADDR & 0xffff) != 0x8000
|
#if (KERNEL_RAM_ADDR & 0xffff) != 0x8000
|
||||||
#error TEXTADDR must start at 0xXXXX8000
|
#error KERNEL_RAM_ADDR must start at 0xXXXX8000
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
.globl swapper_pg_dir
|
.globl swapper_pg_dir
|
||||||
.equ swapper_pg_dir, TEXTADDR - 0x4000
|
.equ swapper_pg_dir, KERNEL_RAM_ADDR - 0x4000
|
||||||
|
|
||||||
.macro pgtbl, rd, phys
|
.macro pgtbl, rd
|
||||||
adr \rd, stext
|
ldr \rd, =(__virt_to_phys(KERNEL_RAM_ADDR - 0x4000))
|
||||||
sub \rd, \rd, #0x4000
|
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
#ifdef CONFIG_XIP_KERNEL
|
||||||
|
#define TEXTADDR XIP_VIRT_ADDR(CONFIG_XIP_PHYS_ADDR)
|
||||||
#else
|
#else
|
||||||
/*
|
#define TEXTADDR KERNEL_RAM_ADDR
|
||||||
* XIP Kernel:
|
|
||||||
*
|
|
||||||
* We place the page tables 16K below DATAADDR. Therefore, we must make sure
|
|
||||||
* that DATAADDR is correctly set. Currently, we expect the least significant
|
|
||||||
* 16 bits to be 0x8000, but we could probably relax this restriction to
|
|
||||||
* DATAADDR >= PAGE_OFFSET + 0x4000
|
|
||||||
*
|
|
||||||
* Note that pgtbl is meant to return the physical address of swapper_pg_dir.
|
|
||||||
* We can't make it relative to the kernel position in this case since
|
|
||||||
* the kernel can physically be anywhere.
|
|
||||||
*/
|
|
||||||
#if (DATAADDR & 0xffff) != 0x8000
|
|
||||||
#error DATAADDR must start at 0xXXXX8000
|
|
||||||
#endif
|
|
||||||
|
|
||||||
.globl swapper_pg_dir
|
|
||||||
.equ swapper_pg_dir, DATAADDR - 0x4000
|
|
||||||
|
|
||||||
.macro pgtbl, rd, phys
|
|
||||||
ldr \rd, =((DATAADDR - 0x4000) - VIRT_OFFSET)
|
|
||||||
add \rd, \rd, \phys
|
|
||||||
.endm
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -279,7 +256,7 @@ __turn_mmu_on:
|
||||||
.type __create_page_tables, %function
|
.type __create_page_tables, %function
|
||||||
__create_page_tables:
|
__create_page_tables:
|
||||||
ldr r5, [r8, #MACHINFO_PHYSRAM] @ physram
|
ldr r5, [r8, #MACHINFO_PHYSRAM] @ physram
|
||||||
pgtbl r4, r5 @ page table address
|
pgtbl r4 @ page table address
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Clear the 16K level 1 swapper page table
|
* Clear the 16K level 1 swapper page table
|
||||||
|
@ -324,7 +301,7 @@ __create_page_tables:
|
||||||
/*
|
/*
|
||||||
* Then map first 1MB of ram in case it contains our boot params.
|
* Then map first 1MB of ram in case it contains our boot params.
|
||||||
*/
|
*/
|
||||||
add r0, r4, #VIRT_OFFSET >> 18
|
add r0, r4, #PAGE_OFFSET >> 18
|
||||||
orr r6, r5, r7
|
orr r6, r5, r7
|
||||||
str r6, [r0]
|
str r6, [r0]
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,7 @@
|
||||||
*/
|
*/
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
#include <linux/moduleloader.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/elf.h>
|
#include <linux/elf.h>
|
||||||
#include <linux/vmalloc.h>
|
#include <linux/vmalloc.h>
|
||||||
|
|
|
@ -139,93 +139,33 @@ struct iwmmxt_sigframe {
|
||||||
unsigned long storage[0x98/4];
|
unsigned long storage[0x98/4];
|
||||||
};
|
};
|
||||||
|
|
||||||
static int page_present(struct mm_struct *mm, void __user *uptr, int wr)
|
|
||||||
{
|
|
||||||
unsigned long addr = (unsigned long)uptr;
|
|
||||||
pgd_t *pgd = pgd_offset(mm, addr);
|
|
||||||
if (pgd_present(*pgd)) {
|
|
||||||
pmd_t *pmd = pmd_offset(pgd, addr);
|
|
||||||
if (pmd_present(*pmd)) {
|
|
||||||
pte_t *pte = pte_offset_map(pmd, addr);
|
|
||||||
return (pte_present(*pte) && (!wr || pte_write(*pte)));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int copy_locked(void __user *uptr, void *kptr, size_t size, int write,
|
|
||||||
void (*copyfn)(void *, void __user *))
|
|
||||||
{
|
|
||||||
unsigned char v, __user *userptr = uptr;
|
|
||||||
int err = 0;
|
|
||||||
|
|
||||||
do {
|
|
||||||
struct mm_struct *mm;
|
|
||||||
|
|
||||||
if (write) {
|
|
||||||
__put_user_error(0, userptr, err);
|
|
||||||
__put_user_error(0, userptr + size - 1, err);
|
|
||||||
} else {
|
|
||||||
__get_user_error(v, userptr, err);
|
|
||||||
__get_user_error(v, userptr + size - 1, err);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err)
|
|
||||||
break;
|
|
||||||
|
|
||||||
mm = current->mm;
|
|
||||||
spin_lock(&mm->page_table_lock);
|
|
||||||
if (page_present(mm, userptr, write) &&
|
|
||||||
page_present(mm, userptr + size - 1, write)) {
|
|
||||||
copyfn(kptr, uptr);
|
|
||||||
} else
|
|
||||||
err = 1;
|
|
||||||
spin_unlock(&mm->page_table_lock);
|
|
||||||
} while (err);
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int preserve_iwmmxt_context(struct iwmmxt_sigframe *frame)
|
static int preserve_iwmmxt_context(struct iwmmxt_sigframe *frame)
|
||||||
{
|
{
|
||||||
int err = 0;
|
char kbuf[sizeof(*frame) + 8];
|
||||||
|
struct iwmmxt_sigframe *kframe;
|
||||||
|
|
||||||
/* the iWMMXt context must be 64 bit aligned */
|
/* the iWMMXt context must be 64 bit aligned */
|
||||||
WARN_ON((unsigned long)frame & 7);
|
kframe = (struct iwmmxt_sigframe *)((unsigned long)(kbuf + 8) & ~7);
|
||||||
|
kframe->magic0 = IWMMXT_MAGIC0;
|
||||||
__put_user_error(IWMMXT_MAGIC0, &frame->magic0, err);
|
kframe->magic1 = IWMMXT_MAGIC1;
|
||||||
__put_user_error(IWMMXT_MAGIC1, &frame->magic1, err);
|
iwmmxt_task_copy(current_thread_info(), &kframe->storage);
|
||||||
|
return __copy_to_user(frame, kframe, sizeof(*frame));
|
||||||
/*
|
|
||||||
* iwmmxt_task_copy() doesn't check user permissions.
|
|
||||||
* Let's do a dummy write on the upper boundary to ensure
|
|
||||||
* access to user mem is OK all way up.
|
|
||||||
*/
|
|
||||||
err |= copy_locked(&frame->storage, current_thread_info(),
|
|
||||||
sizeof(frame->storage), 1, iwmmxt_task_copy);
|
|
||||||
return err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int restore_iwmmxt_context(struct iwmmxt_sigframe *frame)
|
static int restore_iwmmxt_context(struct iwmmxt_sigframe *frame)
|
||||||
{
|
{
|
||||||
unsigned long magic0, magic1;
|
char kbuf[sizeof(*frame) + 8];
|
||||||
int err = 0;
|
struct iwmmxt_sigframe *kframe;
|
||||||
|
|
||||||
/* the iWMMXt context is 64 bit aligned */
|
/* the iWMMXt context must be 64 bit aligned */
|
||||||
WARN_ON((unsigned long)frame & 7);
|
kframe = (struct iwmmxt_sigframe *)((unsigned long)(kbuf + 8) & ~7);
|
||||||
|
if (__copy_from_user(kframe, frame, sizeof(*frame)))
|
||||||
/*
|
return -1;
|
||||||
* Validate iWMMXt context signature.
|
if (kframe->magic0 != IWMMXT_MAGIC0 ||
|
||||||
* Also, iwmmxt_task_restore() doesn't check user permissions.
|
kframe->magic1 != IWMMXT_MAGIC1)
|
||||||
* Let's do a dummy write on the upper boundary to ensure
|
return -1;
|
||||||
* access to user mem is OK all way up.
|
iwmmxt_task_restore(current_thread_info(), &kframe->storage);
|
||||||
*/
|
return 0;
|
||||||
__get_user_error(magic0, &frame->magic0, err);
|
|
||||||
__get_user_error(magic1, &frame->magic1, err);
|
|
||||||
if (!err && magic0 == IWMMXT_MAGIC0 && magic1 == IWMMXT_MAGIC1)
|
|
||||||
err = copy_locked(&frame->storage, current_thread_info(),
|
|
||||||
sizeof(frame->storage), 0, iwmmxt_task_restore);
|
|
||||||
return err;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -345,7 +345,9 @@ static int bad_syscall(int n, struct pt_regs *regs)
|
||||||
struct thread_info *thread = current_thread_info();
|
struct thread_info *thread = current_thread_info();
|
||||||
siginfo_t info;
|
siginfo_t info;
|
||||||
|
|
||||||
if (current->personality != PER_LINUX && thread->exec_domain->handler) {
|
if (current->personality != PER_LINUX &&
|
||||||
|
current->personality != PER_LINUX_32BIT &&
|
||||||
|
thread->exec_domain->handler) {
|
||||||
thread->exec_domain->handler(n, regs);
|
thread->exec_domain->handler(n, regs);
|
||||||
return regs->ARM_r0;
|
return regs->ARM_r0;
|
||||||
}
|
}
|
||||||
|
@ -481,29 +483,33 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs)
|
||||||
unsigned long addr = regs->ARM_r2;
|
unsigned long addr = regs->ARM_r2;
|
||||||
struct mm_struct *mm = current->mm;
|
struct mm_struct *mm = current->mm;
|
||||||
pgd_t *pgd; pmd_t *pmd; pte_t *pte;
|
pgd_t *pgd; pmd_t *pmd; pte_t *pte;
|
||||||
|
spinlock_t *ptl;
|
||||||
|
|
||||||
regs->ARM_cpsr &= ~PSR_C_BIT;
|
regs->ARM_cpsr &= ~PSR_C_BIT;
|
||||||
spin_lock(&mm->page_table_lock);
|
down_read(&mm->mmap_sem);
|
||||||
pgd = pgd_offset(mm, addr);
|
pgd = pgd_offset(mm, addr);
|
||||||
if (!pgd_present(*pgd))
|
if (!pgd_present(*pgd))
|
||||||
goto bad_access;
|
goto bad_access;
|
||||||
pmd = pmd_offset(pgd, addr);
|
pmd = pmd_offset(pgd, addr);
|
||||||
if (!pmd_present(*pmd))
|
if (!pmd_present(*pmd))
|
||||||
goto bad_access;
|
goto bad_access;
|
||||||
pte = pte_offset_map(pmd, addr);
|
pte = pte_offset_map_lock(mm, pmd, addr, &ptl);
|
||||||
if (!pte_present(*pte) || !pte_write(*pte))
|
if (!pte_present(*pte) || !pte_write(*pte)) {
|
||||||
|
pte_unmap_unlock(pte, ptl);
|
||||||
goto bad_access;
|
goto bad_access;
|
||||||
|
}
|
||||||
val = *(unsigned long *)addr;
|
val = *(unsigned long *)addr;
|
||||||
val -= regs->ARM_r0;
|
val -= regs->ARM_r0;
|
||||||
if (val == 0) {
|
if (val == 0) {
|
||||||
*(unsigned long *)addr = regs->ARM_r1;
|
*(unsigned long *)addr = regs->ARM_r1;
|
||||||
regs->ARM_cpsr |= PSR_C_BIT;
|
regs->ARM_cpsr |= PSR_C_BIT;
|
||||||
}
|
}
|
||||||
spin_unlock(&mm->page_table_lock);
|
pte_unmap_unlock(pte, ptl);
|
||||||
|
up_read(&mm->mmap_sem);
|
||||||
return val;
|
return val;
|
||||||
|
|
||||||
bad_access:
|
bad_access:
|
||||||
spin_unlock(&mm->page_table_lock);
|
up_read(&mm->mmap_sem);
|
||||||
/* simulate a write access fault */
|
/* simulate a write access fault */
|
||||||
do_DataAbort(addr, 15 + (1 << 11), regs);
|
do_DataAbort(addr, 15 + (1 << 11), regs);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
|
@ -6,14 +6,23 @@
|
||||||
#include <asm-generic/vmlinux.lds.h>
|
#include <asm-generic/vmlinux.lds.h>
|
||||||
#include <linux/config.h>
|
#include <linux/config.h>
|
||||||
#include <asm/thread_info.h>
|
#include <asm/thread_info.h>
|
||||||
|
#include <asm/memory.h>
|
||||||
|
|
||||||
OUTPUT_ARCH(arm)
|
OUTPUT_ARCH(arm)
|
||||||
ENTRY(stext)
|
ENTRY(stext)
|
||||||
|
|
||||||
#ifndef __ARMEB__
|
#ifndef __ARMEB__
|
||||||
jiffies = jiffies_64;
|
jiffies = jiffies_64;
|
||||||
#else
|
#else
|
||||||
jiffies = jiffies_64 + 4;
|
jiffies = jiffies_64 + 4;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_XIP_KERNEL
|
||||||
|
#define TEXTADDR XIP_VIRT_ADDR(CONFIG_XIP_PHYS_ADDR)
|
||||||
|
#else
|
||||||
|
#define TEXTADDR KERNEL_RAM_ADDR
|
||||||
|
#endif
|
||||||
|
|
||||||
SECTIONS
|
SECTIONS
|
||||||
{
|
{
|
||||||
. = TEXTADDR;
|
. = TEXTADDR;
|
||||||
|
@ -95,7 +104,7 @@ SECTIONS
|
||||||
|
|
||||||
#ifdef CONFIG_XIP_KERNEL
|
#ifdef CONFIG_XIP_KERNEL
|
||||||
__data_loc = ALIGN(4); /* location in binary */
|
__data_loc = ALIGN(4); /* location in binary */
|
||||||
. = DATAADDR;
|
. = KERNEL_RAM_ADDR;
|
||||||
#else
|
#else
|
||||||
. = ALIGN(THREAD_SIZE);
|
. = ALIGN(THREAD_SIZE);
|
||||||
__data_loc = .;
|
__data_loc = .;
|
||||||
|
|
|
@ -11,7 +11,7 @@ lib-y := backtrace.o changebit.o csumipv6.o csumpartial.o \
|
||||||
strnlen_user.o strchr.o strrchr.o testchangebit.o \
|
strnlen_user.o strchr.o strrchr.o testchangebit.o \
|
||||||
testclearbit.o testsetbit.o uaccess.o getuser.o \
|
testclearbit.o testsetbit.o uaccess.o getuser.o \
|
||||||
putuser.o ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \
|
putuser.o ashldi3.o ashrdi3.o lshrdi3.o muldi3.o \
|
||||||
ucmpdi2.o lib1funcs.o div64.o \
|
ucmpdi2.o lib1funcs.o div64.o sha1.o \
|
||||||
io-readsb.o io-writesb.o io-readsl.o io-writesl.o
|
io-readsb.o io-writesb.o io-readsl.o io-writesl.o
|
||||||
|
|
||||||
ifeq ($(CONFIG_CPU_32v3),y)
|
ifeq ($(CONFIG_CPU_32v3),y)
|
||||||
|
|
|
@ -0,0 +1,206 @@
|
||||||
|
/*
|
||||||
|
* linux/arch/arm/lib/sha1.S
|
||||||
|
*
|
||||||
|
* SHA transform optimized for ARM
|
||||||
|
*
|
||||||
|
* Copyright: (C) 2005 by Nicolas Pitre <nico@cam.org>
|
||||||
|
* Created: September 17, 2005
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* The reference implementation for this code is linux/lib/sha1.c
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/linkage.h>
|
||||||
|
|
||||||
|
.text
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* void sha_transform(__u32 *digest, const char *in, __u32 *W)
|
||||||
|
*
|
||||||
|
* Note: the "in" ptr may be unaligned.
|
||||||
|
*/
|
||||||
|
|
||||||
|
ENTRY(sha_transform)
|
||||||
|
|
||||||
|
stmfd sp!, {r4 - r8, lr}
|
||||||
|
|
||||||
|
@ for (i = 0; i < 16; i++)
|
||||||
|
@ W[i] = be32_to_cpu(in[i]); */
|
||||||
|
|
||||||
|
#ifdef __ARMEB__
|
||||||
|
mov r4, r0
|
||||||
|
mov r0, r2
|
||||||
|
mov r2, #64
|
||||||
|
bl memcpy
|
||||||
|
mov r2, r0
|
||||||
|
mov r0, r4
|
||||||
|
#else
|
||||||
|
mov r3, r2
|
||||||
|
mov lr, #16
|
||||||
|
1: ldrb r4, [r1], #1
|
||||||
|
ldrb r5, [r1], #1
|
||||||
|
ldrb r6, [r1], #1
|
||||||
|
ldrb r7, [r1], #1
|
||||||
|
subs lr, lr, #1
|
||||||
|
orr r5, r5, r4, lsl #8
|
||||||
|
orr r6, r6, r5, lsl #8
|
||||||
|
orr r7, r7, r6, lsl #8
|
||||||
|
str r7, [r3], #4
|
||||||
|
bne 1b
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ for (i = 0; i < 64; i++)
|
||||||
|
@ W[i+16] = ror(W[i+13] ^ W[i+8] ^ W[i+2] ^ W[i], 31);
|
||||||
|
|
||||||
|
sub r3, r2, #4
|
||||||
|
mov lr, #64
|
||||||
|
2: ldr r4, [r3, #4]!
|
||||||
|
subs lr, lr, #1
|
||||||
|
ldr r5, [r3, #8]
|
||||||
|
ldr r6, [r3, #32]
|
||||||
|
ldr r7, [r3, #52]
|
||||||
|
eor r4, r4, r5
|
||||||
|
eor r4, r4, r6
|
||||||
|
eor r4, r4, r7
|
||||||
|
mov r4, r4, ror #31
|
||||||
|
str r4, [r3, #64]
|
||||||
|
bne 2b
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The SHA functions are:
|
||||||
|
*
|
||||||
|
* f1(B,C,D) = (D ^ (B & (C ^ D)))
|
||||||
|
* f2(B,C,D) = (B ^ C ^ D)
|
||||||
|
* f3(B,C,D) = ((B & C) | (D & (B | C)))
|
||||||
|
*
|
||||||
|
* Then the sub-blocks are processed as follows:
|
||||||
|
*
|
||||||
|
* A' = ror(A, 27) + f(B,C,D) + E + K + *W++
|
||||||
|
* B' = A
|
||||||
|
* C' = ror(B, 2)
|
||||||
|
* D' = C
|
||||||
|
* E' = D
|
||||||
|
*
|
||||||
|
* We therefore unroll each loop 5 times to avoid register shuffling.
|
||||||
|
* Also the ror for C (and also D and E which are successivelyderived
|
||||||
|
* from it) is applied in place to cut on an additional mov insn for
|
||||||
|
* each round.
|
||||||
|
*/
|
||||||
|
|
||||||
|
.macro sha_f1, A, B, C, D, E
|
||||||
|
ldr r3, [r2], #4
|
||||||
|
eor ip, \C, \D
|
||||||
|
add \E, r1, \E, ror #2
|
||||||
|
and ip, \B, ip, ror #2
|
||||||
|
add \E, \E, \A, ror #27
|
||||||
|
eor ip, ip, \D, ror #2
|
||||||
|
add \E, \E, r3
|
||||||
|
add \E, \E, ip
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro sha_f2, A, B, C, D, E
|
||||||
|
ldr r3, [r2], #4
|
||||||
|
add \E, r1, \E, ror #2
|
||||||
|
eor ip, \B, \C, ror #2
|
||||||
|
add \E, \E, \A, ror #27
|
||||||
|
eor ip, ip, \D, ror #2
|
||||||
|
add \E, \E, r3
|
||||||
|
add \E, \E, ip
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro sha_f3, A, B, C, D, E
|
||||||
|
ldr r3, [r2], #4
|
||||||
|
add \E, r1, \E, ror #2
|
||||||
|
orr ip, \B, \C, ror #2
|
||||||
|
add \E, \E, \A, ror #27
|
||||||
|
and ip, ip, \D, ror #2
|
||||||
|
add \E, \E, r3
|
||||||
|
and r3, \B, \C, ror #2
|
||||||
|
orr ip, ip, r3
|
||||||
|
add \E, \E, ip
|
||||||
|
.endm
|
||||||
|
|
||||||
|
ldmia r0, {r4 - r8}
|
||||||
|
|
||||||
|
mov lr, #4
|
||||||
|
ldr r1, .L_sha_K + 0
|
||||||
|
|
||||||
|
/* adjust initial values */
|
||||||
|
mov r6, r6, ror #30
|
||||||
|
mov r7, r7, ror #30
|
||||||
|
mov r8, r8, ror #30
|
||||||
|
|
||||||
|
3: subs lr, lr, #1
|
||||||
|
sha_f1 r4, r5, r6, r7, r8
|
||||||
|
sha_f1 r8, r4, r5, r6, r7
|
||||||
|
sha_f1 r7, r8, r4, r5, r6
|
||||||
|
sha_f1 r6, r7, r8, r4, r5
|
||||||
|
sha_f1 r5, r6, r7, r8, r4
|
||||||
|
bne 3b
|
||||||
|
|
||||||
|
ldr r1, .L_sha_K + 4
|
||||||
|
mov lr, #4
|
||||||
|
|
||||||
|
4: subs lr, lr, #1
|
||||||
|
sha_f2 r4, r5, r6, r7, r8
|
||||||
|
sha_f2 r8, r4, r5, r6, r7
|
||||||
|
sha_f2 r7, r8, r4, r5, r6
|
||||||
|
sha_f2 r6, r7, r8, r4, r5
|
||||||
|
sha_f2 r5, r6, r7, r8, r4
|
||||||
|
bne 4b
|
||||||
|
|
||||||
|
ldr r1, .L_sha_K + 8
|
||||||
|
mov lr, #4
|
||||||
|
|
||||||
|
5: subs lr, lr, #1
|
||||||
|
sha_f3 r4, r5, r6, r7, r8
|
||||||
|
sha_f3 r8, r4, r5, r6, r7
|
||||||
|
sha_f3 r7, r8, r4, r5, r6
|
||||||
|
sha_f3 r6, r7, r8, r4, r5
|
||||||
|
sha_f3 r5, r6, r7, r8, r4
|
||||||
|
bne 5b
|
||||||
|
|
||||||
|
ldr r1, .L_sha_K + 12
|
||||||
|
mov lr, #4
|
||||||
|
|
||||||
|
6: subs lr, lr, #1
|
||||||
|
sha_f2 r4, r5, r6, r7, r8
|
||||||
|
sha_f2 r8, r4, r5, r6, r7
|
||||||
|
sha_f2 r7, r8, r4, r5, r6
|
||||||
|
sha_f2 r6, r7, r8, r4, r5
|
||||||
|
sha_f2 r5, r6, r7, r8, r4
|
||||||
|
bne 6b
|
||||||
|
|
||||||
|
ldmia r0, {r1, r2, r3, ip, lr}
|
||||||
|
add r4, r1, r4
|
||||||
|
add r5, r2, r5
|
||||||
|
add r6, r3, r6, ror #2
|
||||||
|
add r7, ip, r7, ror #2
|
||||||
|
add r8, lr, r8, ror #2
|
||||||
|
stmia r0, {r4 - r8}
|
||||||
|
|
||||||
|
ldmfd sp!, {r4 - r8, pc}
|
||||||
|
|
||||||
|
.L_sha_K:
|
||||||
|
.word 0x5a827999, 0x6ed9eba1, 0x8f1bbcdc, 0xca62c1d6
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* void sha_init(__u32 *buf)
|
||||||
|
*/
|
||||||
|
|
||||||
|
.L_sha_initial_digest:
|
||||||
|
.word 0x67452301, 0xefcdab89, 0x98badcfe, 0x10325476, 0xc3d2e1f0
|
||||||
|
|
||||||
|
ENTRY(sha_init)
|
||||||
|
|
||||||
|
str lr, [sp, #-4]!
|
||||||
|
adr r1, .L_sha_initial_digest
|
||||||
|
ldmia r1, {r1, r2, r3, ip, lr}
|
||||||
|
stmia r0, {r1, r2, r3, ip, lr}
|
||||||
|
ldr pc, [sp], #4
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
# Common support (must be linked before board specific support)
|
# Common support (must be linked before board specific support)
|
||||||
obj-y += core.o
|
obj-y += core.o clock.o
|
||||||
|
|
||||||
# Specific board support
|
# Specific board support
|
||||||
obj-$(CONFIG_MACH_AAED2000) += aaed2000.o
|
obj-$(CONFIG_MACH_AAED2000) += aaed2000.o
|
||||||
|
|
|
@ -27,16 +27,65 @@
|
||||||
#include <asm/mach/map.h>
|
#include <asm/mach/map.h>
|
||||||
#include <asm/mach/irq.h>
|
#include <asm/mach/irq.h>
|
||||||
|
|
||||||
|
#include <asm/arch/aaed2000.h>
|
||||||
|
|
||||||
#include "core.h"
|
#include "core.h"
|
||||||
|
|
||||||
|
static void aaed2000_clcd_disable(struct clcd_fb *fb)
|
||||||
|
{
|
||||||
|
AAED_EXT_GPIO &= ~AAED_EGPIO_LCD_PWR_EN;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void aaed2000_clcd_enable(struct clcd_fb *fb)
|
||||||
|
{
|
||||||
|
AAED_EXT_GPIO |= AAED_EGPIO_LCD_PWR_EN;
|
||||||
|
}
|
||||||
|
|
||||||
|
struct aaec2000_clcd_info clcd_info = {
|
||||||
|
.enable = aaed2000_clcd_enable,
|
||||||
|
.disable = aaed2000_clcd_disable,
|
||||||
|
.panel = {
|
||||||
|
.mode = {
|
||||||
|
.name = "Sharp",
|
||||||
|
.refresh = 60,
|
||||||
|
.xres = 640,
|
||||||
|
.yres = 480,
|
||||||
|
.pixclock = 39721,
|
||||||
|
.left_margin = 20,
|
||||||
|
.right_margin = 44,
|
||||||
|
.upper_margin = 21,
|
||||||
|
.lower_margin = 34,
|
||||||
|
.hsync_len = 96,
|
||||||
|
.vsync_len = 2,
|
||||||
|
.sync = 0,
|
||||||
|
.vmode = FB_VMODE_NONINTERLACED,
|
||||||
|
},
|
||||||
|
.width = -1,
|
||||||
|
.height = -1,
|
||||||
|
.tim2 = TIM2_IVS | TIM2_IHS,
|
||||||
|
.cntl = CNTL_LCDTFT,
|
||||||
|
.bpp = 16,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
static void __init aaed2000_init_irq(void)
|
static void __init aaed2000_init_irq(void)
|
||||||
{
|
{
|
||||||
aaec2000_init_irq();
|
aaec2000_init_irq();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __init aaed2000_init(void)
|
||||||
|
{
|
||||||
|
aaec2000_set_clcd_plat_data(&clcd_info);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct map_desc aaed2000_io_desc[] __initdata = {
|
||||||
|
{ EXT_GPIO_VBASE, EXT_GPIO_PBASE, EXT_GPIO_LENGTH, MT_DEVICE }, /* Ext GPIO */
|
||||||
|
};
|
||||||
|
|
||||||
static void __init aaed2000_map_io(void)
|
static void __init aaed2000_map_io(void)
|
||||||
{
|
{
|
||||||
aaec2000_map_io();
|
aaec2000_map_io();
|
||||||
|
iotable_init(aaed2000_io_desc, ARRAY_SIZE(aaed2000_io_desc));
|
||||||
}
|
}
|
||||||
|
|
||||||
MACHINE_START(AAED2000, "Agilent AAED-2000 Development Platform")
|
MACHINE_START(AAED2000, "Agilent AAED-2000 Development Platform")
|
||||||
|
@ -47,4 +96,5 @@ MACHINE_START(AAED2000, "Agilent AAED-2000 Development Platform")
|
||||||
.map_io = aaed2000_map_io,
|
.map_io = aaed2000_map_io,
|
||||||
.init_irq = aaed2000_init_irq,
|
.init_irq = aaed2000_init_irq,
|
||||||
.timer = &aaec2000_timer,
|
.timer = &aaec2000_timer,
|
||||||
|
.init_machine = aaed2000_init,
|
||||||
MACHINE_END
|
MACHINE_END
|
||||||
|
|
|
@ -0,0 +1,110 @@
|
||||||
|
/*
|
||||||
|
* linux/arch/arm/mach-aaec2000/clock.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Nicolas Bellido Y Ortega
|
||||||
|
*
|
||||||
|
* Based on linux/arch/arm/mach-integrator/clock.c
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*/
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/list.h>
|
||||||
|
#include <linux/errno.h>
|
||||||
|
#include <linux/err.h>
|
||||||
|
|
||||||
|
#include <asm/semaphore.h>
|
||||||
|
#include <asm/hardware/clock.h>
|
||||||
|
|
||||||
|
#include "clock.h"
|
||||||
|
|
||||||
|
static LIST_HEAD(clocks);
|
||||||
|
static DECLARE_MUTEX(clocks_sem);
|
||||||
|
|
||||||
|
struct clk *clk_get(struct device *dev, const char *id)
|
||||||
|
{
|
||||||
|
struct clk *p, *clk = ERR_PTR(-ENOENT);
|
||||||
|
|
||||||
|
down(&clocks_sem);
|
||||||
|
list_for_each_entry(p, &clocks, node) {
|
||||||
|
if (strcmp(id, p->name) == 0 && try_module_get(p->owner)) {
|
||||||
|
clk = p;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
up(&clocks_sem);
|
||||||
|
|
||||||
|
return clk;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_get);
|
||||||
|
|
||||||
|
void clk_put(struct clk *clk)
|
||||||
|
{
|
||||||
|
module_put(clk->owner);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_put);
|
||||||
|
|
||||||
|
int clk_enable(struct clk *clk)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_enable);
|
||||||
|
|
||||||
|
void clk_disable(struct clk *clk)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_disable);
|
||||||
|
|
||||||
|
int clk_use(struct clk *clk)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_use);
|
||||||
|
|
||||||
|
void clk_unuse(struct clk *clk)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_unuse);
|
||||||
|
|
||||||
|
unsigned long clk_get_rate(struct clk *clk)
|
||||||
|
{
|
||||||
|
return clk->rate;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_get_rate);
|
||||||
|
|
||||||
|
long clk_round_rate(struct clk *clk, unsigned long rate)
|
||||||
|
{
|
||||||
|
return rate;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_round_rate);
|
||||||
|
|
||||||
|
int clk_set_rate(struct clk *clk, unsigned long rate)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_set_rate);
|
||||||
|
|
||||||
|
int clk_register(struct clk *clk)
|
||||||
|
{
|
||||||
|
down(&clocks_sem);
|
||||||
|
list_add(&clk->node, &clocks);
|
||||||
|
up(&clocks_sem);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_register);
|
||||||
|
|
||||||
|
void clk_unregister(struct clk *clk)
|
||||||
|
{
|
||||||
|
down(&clocks_sem);
|
||||||
|
list_del(&clk->node);
|
||||||
|
up(&clocks_sem);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(clk_unregister);
|
||||||
|
|
||||||
|
static int __init clk_init(void)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
arch_initcall(clk_init);
|
|
@ -0,0 +1,23 @@
|
||||||
|
/*
|
||||||
|
* linux/arch/arm/mach-aaec2000/clock.h
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Nicolas Bellido Y Ortega
|
||||||
|
*
|
||||||
|
* Based on linux/arch/arm/mach-integrator/clock.h
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*/
|
||||||
|
struct module;
|
||||||
|
|
||||||
|
struct clk {
|
||||||
|
struct list_head node;
|
||||||
|
unsigned long rate;
|
||||||
|
struct module *owner;
|
||||||
|
const char *name;
|
||||||
|
void *data;
|
||||||
|
};
|
||||||
|
|
||||||
|
int clk_register(struct clk *clk);
|
||||||
|
void clk_unregister(struct clk *clk);
|
|
@ -13,19 +13,27 @@
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
|
#include <linux/device.h>
|
||||||
#include <linux/list.h>
|
#include <linux/list.h>
|
||||||
#include <linux/errno.h>
|
#include <linux/errno.h>
|
||||||
|
#include <linux/dma-mapping.h>
|
||||||
#include <linux/interrupt.h>
|
#include <linux/interrupt.h>
|
||||||
#include <linux/timex.h>
|
#include <linux/timex.h>
|
||||||
#include <linux/signal.h>
|
#include <linux/signal.h>
|
||||||
|
|
||||||
#include <asm/hardware.h>
|
#include <asm/hardware.h>
|
||||||
#include <asm/irq.h>
|
#include <asm/irq.h>
|
||||||
|
#include <asm/sizes.h>
|
||||||
|
#include <asm/hardware/amba.h>
|
||||||
|
|
||||||
|
#include <asm/mach/flash.h>
|
||||||
#include <asm/mach/irq.h>
|
#include <asm/mach/irq.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
#include <asm/mach/map.h>
|
#include <asm/mach/map.h>
|
||||||
|
|
||||||
|
#include "core.h"
|
||||||
|
#include "clock.h"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Common I/O mapping:
|
* Common I/O mapping:
|
||||||
*
|
*
|
||||||
|
@ -40,9 +48,17 @@
|
||||||
* default mapping provided here.
|
* default mapping provided here.
|
||||||
*/
|
*/
|
||||||
static struct map_desc standard_io_desc[] __initdata = {
|
static struct map_desc standard_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{
|
||||||
{ VIO_APB_BASE, PIO_APB_BASE, IO_APB_LENGTH, MT_DEVICE },
|
.virtual = VIO_APB_BASE,
|
||||||
{ VIO_AHB_BASE, PIO_AHB_BASE, IO_AHB_LENGTH, MT_DEVICE }
|
.physical = __phys_to_pfn(PIO_APB_BASE),
|
||||||
|
.length = IO_APB_LENGTH,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = VIO_AHB_BASE,
|
||||||
|
.physical = __phys_to_pfn(PIO_AHB_BASE),
|
||||||
|
.length = IO_AHB_LENGTH,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init aaec2000_map_io(void)
|
void __init aaec2000_map_io(void)
|
||||||
|
@ -155,3 +171,116 @@ struct sys_timer aaec2000_timer = {
|
||||||
.offset = aaec2000_gettimeoffset,
|
.offset = aaec2000_gettimeoffset,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct clcd_panel mach_clcd_panel;
|
||||||
|
|
||||||
|
static int aaec2000_clcd_setup(struct clcd_fb *fb)
|
||||||
|
{
|
||||||
|
dma_addr_t dma;
|
||||||
|
|
||||||
|
fb->panel = &mach_clcd_panel;
|
||||||
|
|
||||||
|
fb->fb.screen_base = dma_alloc_writecombine(&fb->dev->dev, SZ_1M,
|
||||||
|
&dma, GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!fb->fb.screen_base) {
|
||||||
|
printk(KERN_ERR "CLCD: unable to map framebuffer\n");
|
||||||
|
return -ENOMEM;
|
||||||
|
}
|
||||||
|
|
||||||
|
fb->fb.fix.smem_start = dma;
|
||||||
|
fb->fb.fix.smem_len = SZ_1M;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int aaec2000_clcd_mmap(struct clcd_fb *fb, struct vm_area_struct *vma)
|
||||||
|
{
|
||||||
|
return dma_mmap_writecombine(&fb->dev->dev, vma,
|
||||||
|
fb->fb.screen_base,
|
||||||
|
fb->fb.fix.smem_start,
|
||||||
|
fb->fb.fix.smem_len);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void aaec2000_clcd_remove(struct clcd_fb *fb)
|
||||||
|
{
|
||||||
|
dma_free_writecombine(&fb->dev->dev, fb->fb.fix.smem_len,
|
||||||
|
fb->fb.screen_base, fb->fb.fix.smem_start);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct clcd_board clcd_plat_data = {
|
||||||
|
.name = "AAEC-2000",
|
||||||
|
.check = clcdfb_check,
|
||||||
|
.decode = clcdfb_decode,
|
||||||
|
.setup = aaec2000_clcd_setup,
|
||||||
|
.mmap = aaec2000_clcd_mmap,
|
||||||
|
.remove = aaec2000_clcd_remove,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct amba_device clcd_device = {
|
||||||
|
.dev = {
|
||||||
|
.bus_id = "mb:16",
|
||||||
|
.coherent_dma_mask = ~0,
|
||||||
|
.platform_data = &clcd_plat_data,
|
||||||
|
},
|
||||||
|
.res = {
|
||||||
|
.start = AAEC_CLCD_PHYS,
|
||||||
|
.end = AAEC_CLCD_PHYS + SZ_4K - 1,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
.irq = { INT_LCD, NO_IRQ },
|
||||||
|
.periphid = 0x41110,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct amba_device *amba_devs[] __initdata = {
|
||||||
|
&clcd_device,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct clk aaec2000_clcd_clk = {
|
||||||
|
.name = "CLCDCLK",
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init aaec2000_set_clcd_plat_data(struct aaec2000_clcd_info *clcd)
|
||||||
|
{
|
||||||
|
clcd_plat_data.enable = clcd->enable;
|
||||||
|
clcd_plat_data.disable = clcd->disable;
|
||||||
|
memcpy(&mach_clcd_panel, &clcd->panel, sizeof(struct clcd_panel));
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct flash_platform_data aaec2000_flash_data = {
|
||||||
|
.map_name = "cfi_probe",
|
||||||
|
.width = 4,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct resource aaec2000_flash_resource = {
|
||||||
|
.start = AAEC_FLASH_BASE,
|
||||||
|
.end = AAEC_FLASH_BASE + AAEC_FLASH_SIZE,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device aaec2000_flash_device = {
|
||||||
|
.name = "armflash",
|
||||||
|
.id = 0,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &aaec2000_flash_data,
|
||||||
|
},
|
||||||
|
.num_resources = 1,
|
||||||
|
.resource = &aaec2000_flash_resource,
|
||||||
|
};
|
||||||
|
|
||||||
|
static int __init aaec2000_init(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
clk_register(&aaec2000_clcd_clk);
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(amba_devs); i++) {
|
||||||
|
struct amba_device *d = amba_devs[i];
|
||||||
|
amba_device_register(d, &iomem_resource);
|
||||||
|
}
|
||||||
|
|
||||||
|
platform_device_register(&aaec2000_flash_device);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
};
|
||||||
|
arch_initcall(aaec2000_init);
|
||||||
|
|
||||||
|
|
|
@ -9,8 +9,19 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <asm/hardware/amba_clcd.h>
|
||||||
|
|
||||||
struct sys_timer;
|
struct sys_timer;
|
||||||
|
|
||||||
extern struct sys_timer aaec2000_timer;
|
extern struct sys_timer aaec2000_timer;
|
||||||
extern void __init aaec2000_map_io(void);
|
extern void __init aaec2000_map_io(void);
|
||||||
extern void __init aaec2000_init_irq(void);
|
extern void __init aaec2000_init_irq(void);
|
||||||
|
|
||||||
|
struct aaec2000_clcd_info {
|
||||||
|
struct clcd_panel panel;
|
||||||
|
void (*disable)(struct clcd_fb *);
|
||||||
|
void (*enable)(struct clcd_fb *);
|
||||||
|
};
|
||||||
|
|
||||||
|
extern void __init aaec2000_set_clcd_plat_data(struct aaec2000_clcd_info *);
|
||||||
|
|
||||||
|
|
|
@ -69,6 +69,17 @@ config EP72XX_ROM_BOOT
|
||||||
|
|
||||||
You almost surely want to say N here.
|
You almost surely want to say N here.
|
||||||
|
|
||||||
|
config MACH_MP1000
|
||||||
|
bool "MACH_MP1000"
|
||||||
|
help
|
||||||
|
Say Y if you intend to run the kernel on the Comdial MP1000 platform.
|
||||||
|
|
||||||
|
config MP1000_90MHZ
|
||||||
|
bool "MP1000_90MHZ"
|
||||||
|
depends on MACH_MP1000
|
||||||
|
help
|
||||||
|
Say Y if you have the MP1000 configured to be set at 90MHZ rather than 74MHZ
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -15,6 +15,7 @@ obj-$(CONFIG_ARCH_CDB89712) += cdb89712.o
|
||||||
obj-$(CONFIG_ARCH_CLEP7312) += clep7312.o
|
obj-$(CONFIG_ARCH_CLEP7312) += clep7312.o
|
||||||
obj-$(CONFIG_ARCH_EDB7211) += edb7211-arch.o edb7211-mm.o
|
obj-$(CONFIG_ARCH_EDB7211) += edb7211-arch.o edb7211-mm.o
|
||||||
obj-$(CONFIG_ARCH_FORTUNET) += fortunet.o
|
obj-$(CONFIG_ARCH_FORTUNET) += fortunet.o
|
||||||
|
obj-$(CONFIG_MACH_MP1000) += mp1000-mach.o mp1000-mm.o mp1000-seprom.o
|
||||||
obj-$(CONFIG_ARCH_P720T) += p720t.o
|
obj-$(CONFIG_ARCH_P720T) += p720t.o
|
||||||
leds-$(CONFIG_ARCH_P720T) += p720t-leds.o
|
leds-$(CONFIG_ARCH_P720T) += p720t-leds.o
|
||||||
obj-$(CONFIG_LEDS) += $(leds-y)
|
obj-$(CONFIG_LEDS) += $(leds-y)
|
||||||
|
|
|
@ -46,10 +46,14 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct map_desc autcpu12_io_desc[] __initdata = {
|
static struct map_desc autcpu12_io_desc[] __initdata = {
|
||||||
/* virtual, physical, length, type */
|
|
||||||
/* memory-mapped extra io and CS8900A Ethernet chip */
|
/* memory-mapped extra io and CS8900A Ethernet chip */
|
||||||
/* ethernet chip */
|
/* ethernet chip */
|
||||||
{ AUTCPU12_VIRT_CS8900A, AUTCPU12_PHYS_CS8900A, SZ_1M, MT_DEVICE }
|
{
|
||||||
|
.virtual = AUTCPU12_VIRT_CS8900A,
|
||||||
|
.pfn = __phys_to_pfn(AUTCPU12_PHYS_CS8900A),
|
||||||
|
.length = SZ_1M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init autcpu12_map_io(void)
|
void __init autcpu12_map_io(void)
|
||||||
|
|
|
@ -39,7 +39,12 @@
|
||||||
* ethernet driver, perhaps.
|
* ethernet driver, perhaps.
|
||||||
*/
|
*/
|
||||||
static struct map_desc cdb89712_io_desc[] __initdata = {
|
static struct map_desc cdb89712_io_desc[] __initdata = {
|
||||||
{ ETHER_BASE, ETHER_START, ETHER_SIZE, MT_DEVICE }
|
{
|
||||||
|
.virtual = ETHER_BASE,
|
||||||
|
.pfn =__phys_to_pfn(ETHER_START),
|
||||||
|
.length = ETHER_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init cdb89712_map_io(void)
|
static void __init cdb89712_map_io(void)
|
||||||
|
|
|
@ -37,11 +37,13 @@
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
|
||||||
static struct map_desc ceiva_io_desc[] __initdata = {
|
static struct map_desc ceiva_io_desc[] __initdata = {
|
||||||
/* virtual, physical, length, type */
|
|
||||||
|
|
||||||
/* SED1355 controlled video RAM & registers */
|
/* SED1355 controlled video RAM & registers */
|
||||||
{ CEIVA_VIRT_SED1355, CEIVA_PHYS_SED1355, SZ_2M, MT_DEVICE }
|
{
|
||||||
|
.virtual = CEIVA_VIRT_SED1355,
|
||||||
|
.pfn = __phys_to_pfn(CEIVA_PHYS_SED1355),
|
||||||
|
.length = SZ_2M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -51,15 +51,27 @@ extern void clps711x_map_io(void);
|
||||||
* happens).
|
* happens).
|
||||||
*/
|
*/
|
||||||
static struct map_desc edb7211_io_desc[] __initdata = {
|
static struct map_desc edb7211_io_desc[] __initdata = {
|
||||||
/* virtual, physical, length, type */
|
{ /* memory-mapped extra keyboard row */
|
||||||
|
.virtual = EP7211_VIRT_EXTKBD,
|
||||||
/* memory-mapped extra keyboard row and CS8900A Ethernet chip */
|
.pfn = __phys_to_pfn(EP7211_PHYS_EXTKBD),
|
||||||
{ EP7211_VIRT_EXTKBD, EP7211_PHYS_EXTKBD, SZ_1M, MT_DEVICE },
|
.length = SZ_1M,
|
||||||
{ EP7211_VIRT_CS8900A, EP7211_PHYS_CS8900A, SZ_1M, MT_DEVICE },
|
.type - MT_DEVICE
|
||||||
|
}, { /* and CS8900A Ethernet chip */
|
||||||
/* flash banks */
|
.virtual = EP7211_VIRT_CS8900A,
|
||||||
{ EP7211_VIRT_FLASH1, EP7211_PHYS_FLASH1, SZ_8M, MT_DEVICE },
|
.pfn = __phys_to_pfn(EP7211_PHYS_CS8900A),
|
||||||
{ EP7211_VIRT_FLASH2, EP7211_PHYS_FLASH2, SZ_8M, MT_DEVICE }
|
.length = SZ_1M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* flash banks */
|
||||||
|
.virtual = EP7211_VIRT_FLASH1,
|
||||||
|
.pfn = __phys_to_pfn(EP7211_PHYS_FLASH1),
|
||||||
|
.length = SZ_8M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = EP7211_VIRT_FLASH2,
|
||||||
|
.pfn = __phys_to_pfn(EP7211_PHYS_FLASH2),
|
||||||
|
.length = SZ_8M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init edb7211_map_io(void)
|
void __init edb7211_map_io(void)
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/bootmem.h>
|
#include <linux/bootmem.h>
|
||||||
|
|
||||||
|
#include <asm/sizes.h>
|
||||||
#include <asm/hardware.h>
|
#include <asm/hardware.h>
|
||||||
#include <asm/pgtable.h>
|
#include <asm/pgtable.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
|
@ -34,7 +35,12 @@
|
||||||
* This maps the generic CLPS711x registers
|
* This maps the generic CLPS711x registers
|
||||||
*/
|
*/
|
||||||
static struct map_desc clps711x_io_desc[] __initdata = {
|
static struct map_desc clps711x_io_desc[] __initdata = {
|
||||||
{ CLPS7111_VIRT_BASE, CLPS7111_PHYS_BASE, 1048576, MT_DEVICE }
|
{
|
||||||
|
.virtual = CLPS7111_VIRT_BASE,
|
||||||
|
.pfn = __phys_to_pfn(CLPS7111_PHYS_BASE),
|
||||||
|
.length = SZ_1M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init clps711x_map_io(void)
|
void __init clps711x_map_io(void)
|
||||||
|
|
|
@ -0,0 +1,49 @@
|
||||||
|
/*
|
||||||
|
* linux/arch/arm/mach-mp1000/mp1000.c
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Comdial Corporation
|
||||||
|
*
|
||||||
|
* 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, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/string.h>
|
||||||
|
|
||||||
|
#include <asm/setup.h>
|
||||||
|
#include <asm/mach-types.h>
|
||||||
|
#include <asm/mach/arch.h>
|
||||||
|
#include <asm/arch/mp1000-seprom.h>
|
||||||
|
|
||||||
|
#include "common.h"
|
||||||
|
|
||||||
|
extern void mp1000_map_io(void);
|
||||||
|
|
||||||
|
static void __init mp1000_init(void)
|
||||||
|
{
|
||||||
|
seprom_init();
|
||||||
|
}
|
||||||
|
|
||||||
|
MACHINE_START(MP1000, "Comdial MP1000")
|
||||||
|
/* Maintainer: Jon Ringle */
|
||||||
|
.phys_ram = 0xc0000000,
|
||||||
|
.phys_io = 0x80000000,
|
||||||
|
.io_pg_offst = ((0xff000000) >> 18) & 0xfffc,
|
||||||
|
.boot_params = 0xc0015100,
|
||||||
|
.map_io = mp1000_map_io,
|
||||||
|
.init_irq = clps711x_init_irq,
|
||||||
|
.init_machine = mp1000_init,
|
||||||
|
.timer = &clps711x_timer,
|
||||||
|
MACHINE_END
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
/*
|
||||||
|
* linux/arch/arm/mach-mp1000/mm.c
|
||||||
|
*
|
||||||
|
* Extra MM routines for the MP1000
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Comdial Corporation
|
||||||
|
*
|
||||||
|
* 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, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/init.h>
|
||||||
|
|
||||||
|
#include <asm/hardware.h>
|
||||||
|
#include <asm/page.h>
|
||||||
|
#include <asm/pgtable.h>
|
||||||
|
#include <asm/sizes.h>
|
||||||
|
|
||||||
|
#include <asm/mach/map.h>
|
||||||
|
|
||||||
|
extern void clps711x_map_io(void);
|
||||||
|
|
||||||
|
static struct map_desc mp1000_io_desc[] __initdata = {
|
||||||
|
{ MP1000_EIO_BASE, MP1000_EIO_START, MP1000_EIO_SIZE, MT_DEVICE },
|
||||||
|
{ MP1000_FIO_BASE, MP1000_FIO_START, MP1000_FIO_SIZE, MT_DEVICE },
|
||||||
|
{ MP1000_LIO_BASE, MP1000_LIO_START, MP1000_LIO_SIZE, MT_DEVICE },
|
||||||
|
{ MP1000_NIO_BASE, MP1000_NIO_START, MP1000_NIO_SIZE, MT_DEVICE },
|
||||||
|
{ MP1000_IDE_BASE, MP1000_IDE_START, MP1000_IDE_SIZE, MT_DEVICE },
|
||||||
|
{ MP1000_DSP_BASE, MP1000_DSP_START, MP1000_DSP_SIZE, MT_DEVICE }
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init mp1000_map_io(void)
|
||||||
|
{
|
||||||
|
clps711x_map_io();
|
||||||
|
iotable_init(mp1000_io_desc, ARRAY_SIZE(mp1000_io_desc));
|
||||||
|
}
|
|
@ -0,0 +1,195 @@
|
||||||
|
/*`
|
||||||
|
* mp1000-seprom.c
|
||||||
|
*
|
||||||
|
* This file contains the Serial EEPROM code for the MP1000 board
|
||||||
|
*
|
||||||
|
* Copyright (C) 2005 Comdial Corporation
|
||||||
|
*
|
||||||
|
* 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, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/init.h>
|
||||||
|
#include <asm/hardware.h>
|
||||||
|
#include <asm/hardware/clps7111.h>
|
||||||
|
#include <asm/arch/mp1000-seprom.h>
|
||||||
|
|
||||||
|
/* If SepromInit() can initialize and checksum the seprom successfully, */
|
||||||
|
/* then it will point seprom_data_ptr at the shadow copy. */
|
||||||
|
|
||||||
|
static eeprom_struct seprom_data; /* shadow copy of seprom content */
|
||||||
|
|
||||||
|
eeprom_struct *seprom_data_ptr = 0; /* 0 => not initialized */
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Port D Bit 5 is Chip Select for EEPROM
|
||||||
|
* Port E Bit 0 is Input, Data out from EEPROM
|
||||||
|
* Port E Bit 1 is Output, Data in to EEPROM
|
||||||
|
* Port E Bit 2 is Output, CLK to EEPROM
|
||||||
|
*/
|
||||||
|
|
||||||
|
static char *port_d_ptr = (char *)(CLPS7111_VIRT_BASE + PDDR);
|
||||||
|
static char *port_e_ptr = (char *)(CLPS7111_VIRT_BASE + PEDR);
|
||||||
|
|
||||||
|
#define NO_OF_SHORTS 64 // Device is 64 x 16 bits
|
||||||
|
#define ENABLE_RW 0
|
||||||
|
#define DISABLE_RW 1
|
||||||
|
|
||||||
|
static inline void toggle_seprom_clock(void)
|
||||||
|
{
|
||||||
|
*port_e_ptr |= HwPortESepromCLK;
|
||||||
|
*port_e_ptr &= ~(HwPortESepromCLK);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void select_eeprom(void)
|
||||||
|
{
|
||||||
|
*port_d_ptr |= HwPortDEECS;
|
||||||
|
*port_e_ptr &= ~(HwPortESepromCLK);
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void deselect_eeprom(void)
|
||||||
|
{
|
||||||
|
*port_d_ptr &= ~(HwPortDEECS);
|
||||||
|
*port_e_ptr &= ~(HwPortESepromDIn);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* GetSepromDataPtr - returns pointer to shadow (RAM) copy of seprom
|
||||||
|
* and returns 0 if seprom is not initialized or
|
||||||
|
* has a checksum error.
|
||||||
|
*/
|
||||||
|
|
||||||
|
eeprom_struct* get_seprom_ptr(void)
|
||||||
|
{
|
||||||
|
return seprom_data_ptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
unsigned char* get_eeprom_mac_address(void)
|
||||||
|
{
|
||||||
|
return seprom_data_ptr->variant.eprom_struct.mac_Address;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ReadSProm, Physically reads data from the Serial PROM
|
||||||
|
*/
|
||||||
|
static void read_sprom(short address, int length, eeprom_struct *buffer)
|
||||||
|
{
|
||||||
|
short data = COMMAND_READ | (address & 0x3F);
|
||||||
|
short bit;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
select_eeprom();
|
||||||
|
|
||||||
|
// Clock in 9 bits of the command
|
||||||
|
for (i = 0, bit = 0x100; i < 9; i++, bit >>= 1) {
|
||||||
|
if (data & bit)
|
||||||
|
*port_e_ptr |= HwPortESepromDIn;
|
||||||
|
else
|
||||||
|
*port_e_ptr &= ~(HwPortESepromDIn);
|
||||||
|
|
||||||
|
toggle_seprom_clock();
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Now read one or more shorts of data from the Seprom
|
||||||
|
//
|
||||||
|
while (length-- > 0) {
|
||||||
|
data = 0;
|
||||||
|
|
||||||
|
// Read 16 bits at a time
|
||||||
|
for (i = 0; i < 16; i++) {
|
||||||
|
data <<= 1;
|
||||||
|
toggle_seprom_clock();
|
||||||
|
data |= *port_e_ptr & HwPortESepromDOut;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
buffer->variant.eprom_short_data[address++] = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
deselect_eeprom();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ReadSerialPROM
|
||||||
|
*
|
||||||
|
* Input: Pointer to array of 64 x 16 Bits
|
||||||
|
*
|
||||||
|
* Output: if no problem reading data is filled in
|
||||||
|
*/
|
||||||
|
static void read_serial_prom(eeprom_struct *data)
|
||||||
|
{
|
||||||
|
read_sprom(0, 64, data);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
//
|
||||||
|
// Compute Serial EEPROM checksum
|
||||||
|
//
|
||||||
|
// Input: Pointer to struct with Eprom data
|
||||||
|
//
|
||||||
|
// Output: The computed Eprom checksum
|
||||||
|
//
|
||||||
|
static short compute_seprom_checksum(eeprom_struct *data)
|
||||||
|
{
|
||||||
|
short checksum = 0;
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; i < 126; i++) {
|
||||||
|
checksum += (short)data->variant.eprom_byte_data[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
return((short)(0x5555 - (checksum & 0xFFFF)));
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
// Make sure the data port bits for the SEPROM are correctly initialised
|
||||||
|
//
|
||||||
|
|
||||||
|
void __init seprom_init(void)
|
||||||
|
{
|
||||||
|
short checksum;
|
||||||
|
|
||||||
|
// Init Port D
|
||||||
|
*(char *)(CLPS7111_VIRT_BASE + PDDDR) = 0x0;
|
||||||
|
*(char *)(CLPS7111_VIRT_BASE + PDDR) = 0x15;
|
||||||
|
|
||||||
|
// Init Port E
|
||||||
|
*(int *)(CLPS7111_VIRT_BASE + PEDDR) = 0x06;
|
||||||
|
*(int *)(CLPS7111_VIRT_BASE + PEDR) = 0x04;
|
||||||
|
|
||||||
|
//
|
||||||
|
// Make sure that EEPROM struct size never exceeds 128 bytes
|
||||||
|
//
|
||||||
|
if (sizeof(eeprom_struct) > 128) {
|
||||||
|
panic("Serial PROM struct size > 128, aborting read\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
read_serial_prom(&seprom_data);
|
||||||
|
|
||||||
|
checksum = compute_seprom_checksum(&seprom_data);
|
||||||
|
|
||||||
|
if (checksum != seprom_data.variant.eprom_short_data[63]) {
|
||||||
|
panic("Serial EEPROM checksum failed\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
seprom_data_ptr = &seprom_data;
|
||||||
|
}
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include <asm/pgtable.h>
|
#include <asm/pgtable.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
#include <asm/setup.h>
|
#include <asm/setup.h>
|
||||||
|
#include <asm/sizes.h>
|
||||||
#include <asm/mach-types.h>
|
#include <asm/mach-types.h>
|
||||||
#include <asm/mach/arch.h>
|
#include <asm/mach/arch.h>
|
||||||
#include <asm/mach/map.h>
|
#include <asm/mach/map.h>
|
||||||
|
@ -42,8 +43,17 @@
|
||||||
* We map both here.
|
* We map both here.
|
||||||
*/
|
*/
|
||||||
static struct map_desc p720t_io_desc[] __initdata = {
|
static struct map_desc p720t_io_desc[] __initdata = {
|
||||||
{ SYSPLD_VIRT_BASE, SYSPLD_PHYS_BASE, 1048576, MT_DEVICE },
|
{
|
||||||
{ 0xfe400000, 0x10400000, 1048576, MT_DEVICE }
|
.virtual = SYSPLD_VIRT_BASE,
|
||||||
|
.pfn = __phys_to_pfn(SYSPLD_PHYS_BASE),
|
||||||
|
.length = SZ_1M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = 0xfe400000,
|
||||||
|
.pfn = __phys_to_pfn(0x10400000),
|
||||||
|
.length = SZ_1M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init
|
static void __init
|
||||||
|
|
|
@ -259,10 +259,27 @@ static void __init clps7500_init_irq(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc cl7500_io_desc[] __initdata = {
|
static struct map_desc cl7500_io_desc[] __initdata = {
|
||||||
{ IO_BASE, IO_START, IO_SIZE, MT_DEVICE }, /* IO space */
|
{ /* IO space */
|
||||||
{ ISA_BASE, ISA_START, ISA_SIZE, MT_DEVICE }, /* ISA space */
|
.virtual = IO_BASE,
|
||||||
{ FLASH_BASE, FLASH_START, FLASH_SIZE, MT_DEVICE }, /* Flash */
|
.pfn = __phys_to_pfn(IO_START),
|
||||||
{ LED_BASE, LED_START, LED_SIZE, MT_DEVICE } /* LED */
|
.length = IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* ISA space */
|
||||||
|
.virtual = ISA_BASE,
|
||||||
|
.pfn = __phys_to_pfn(ISA_START),
|
||||||
|
.length = ISA_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* Flash */
|
||||||
|
.virtual = FLASH_BASE,
|
||||||
|
.pfn = __phys_to_pfn(FLASH_START),
|
||||||
|
.length = FLASH_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* LED */
|
||||||
|
.virtual = LED_BASE,
|
||||||
|
.pfn = __phys_to_pfn(LED_START),
|
||||||
|
.length = LED_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init clps7500_map_io(void)
|
static void __init clps7500_map_io(void)
|
||||||
|
|
|
@ -76,16 +76,42 @@ static struct map_desc ebsa110_io_desc[] __initdata = {
|
||||||
/*
|
/*
|
||||||
* sparse external-decode ISAIO space
|
* sparse external-decode ISAIO space
|
||||||
*/
|
*/
|
||||||
{ IRQ_STAT, TRICK4_PHYS, PGDIR_SIZE, MT_DEVICE }, /* IRQ_STAT/IRQ_MCLR */
|
{ /* IRQ_STAT/IRQ_MCLR */
|
||||||
{ IRQ_MASK, TRICK3_PHYS, PGDIR_SIZE, MT_DEVICE }, /* IRQ_MASK/IRQ_MSET */
|
.virtual = IRQ_STAT,
|
||||||
{ SOFT_BASE, TRICK1_PHYS, PGDIR_SIZE, MT_DEVICE }, /* SOFT_BASE */
|
.pfn = __phys_to_pfn(TRICK4_PHYS),
|
||||||
{ PIT_BASE, TRICK0_PHYS, PGDIR_SIZE, MT_DEVICE }, /* PIT_BASE */
|
.length = PGDIR_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* IRQ_MASK/IRQ_MSET */
|
||||||
|
.virtual = IRQ_MASK,
|
||||||
|
.pfn = __phys_to_pfn(TRICK3_PHYS),
|
||||||
|
.length = PGDIR_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* SOFT_BASE */
|
||||||
|
.virtual = SOFT_BASE,
|
||||||
|
.pfn = __phys_to_pfn(TRICK1_PHYS),
|
||||||
|
.length = PGDIR_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* PIT_BASE */
|
||||||
|
.virtual = PIT_BASE,
|
||||||
|
.pfn = __phys_to_pfn(TRICK0_PHYS),
|
||||||
|
.length = PGDIR_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
},
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* self-decode ISAIO space
|
* self-decode ISAIO space
|
||||||
*/
|
*/
|
||||||
{ ISAIO_BASE, ISAIO_PHYS, ISAIO_SIZE, MT_DEVICE },
|
{
|
||||||
{ ISAMEM_BASE, ISAMEM_PHYS, ISAMEM_SIZE, MT_DEVICE }
|
.virtual = ISAIO_BASE,
|
||||||
|
.pfn = __phys_to_pfn(ISAIO_PHYS),
|
||||||
|
.length = ISAIO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = ISAMEM_BASE,
|
||||||
|
.pfn = __phys_to_pfn(ISAMEM_PHYS),
|
||||||
|
.length = ISAMEM_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init ebsa110_map_io(void)
|
static void __init ebsa110_map_io(void)
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
|
|
||||||
|
#include <asm/hardware.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
|
|
||||||
|
|
|
@ -31,12 +31,37 @@
|
||||||
/* Page table mapping for I/O region */
|
/* Page table mapping for I/O region */
|
||||||
|
|
||||||
static struct map_desc epxa10db_io_desc[] __initdata = {
|
static struct map_desc epxa10db_io_desc[] __initdata = {
|
||||||
{ IO_ADDRESS(EXC_REGISTERS_BASE), EXC_REGISTERS_BASE, SZ_16K, MT_DEVICE },
|
{
|
||||||
{ IO_ADDRESS(EXC_PLD_BLOCK0_BASE), EXC_PLD_BLOCK0_BASE, SZ_16K, MT_DEVICE },
|
.virtual = IO_ADDRESS(EXC_REGISTERS_BASE),
|
||||||
{ IO_ADDRESS(EXC_PLD_BLOCK1_BASE), EXC_PLD_BLOCK1_BASE, SZ_16K, MT_DEVICE },
|
.pfn = __phys_to_pfn(EXC_REGISTERS_BASE),
|
||||||
{ IO_ADDRESS(EXC_PLD_BLOCK2_BASE), EXC_PLD_BLOCK2_BASE, SZ_16K, MT_DEVICE },
|
.length = SZ_16K,
|
||||||
{ IO_ADDRESS(EXC_PLD_BLOCK3_BASE), EXC_PLD_BLOCK3_BASE, SZ_16K, MT_DEVICE },
|
.type = MT_DEVICE
|
||||||
{ FLASH_VADDR(EXC_EBI_BLOCK0_BASE), EXC_EBI_BLOCK0_BASE, SZ_16M, MT_DEVICE }
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(EXC_PLD_BLOCK0_BASE),
|
||||||
|
.pfn = __phys_to_pfn(EXC_PLD_BLOCK0_BASE),
|
||||||
|
.length = SZ_16K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(EXC_PLD_BLOCK1_BASE),
|
||||||
|
.pfn =__phys_to_pfn(EXC_PLD_BLOCK1_BASE),
|
||||||
|
.length = SZ_16K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(EXC_PLD_BLOCK2_BASE),
|
||||||
|
.physical = __phys_to_pfn(EXC_PLD_BLOCK2_BASE),
|
||||||
|
.length = SZ_16K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(EXC_PLD_BLOCK3_BASE),
|
||||||
|
.pfn = __phys_to_pfn(EXC_PLD_BLOCK3_BASE),
|
||||||
|
.length = SZ_16K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = FLASH_VADDR(EXC_EBI_BLOCK0_BASE),
|
||||||
|
.pfn = __phys_to_pfn(EXC_EBI_BLOCK0_BASE),
|
||||||
|
.length = SZ_16M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init epxa10db_map_io(void)
|
void __init epxa10db_map_io(void)
|
||||||
|
|
|
@ -130,8 +130,17 @@ void __init footbridge_init_irq(void)
|
||||||
* it means that we have extra bullet protection on our feet.
|
* it means that we have extra bullet protection on our feet.
|
||||||
*/
|
*/
|
||||||
static struct map_desc fb_common_io_desc[] __initdata = {
|
static struct map_desc fb_common_io_desc[] __initdata = {
|
||||||
{ ARMCSR_BASE, DC21285_ARMCSR_BASE, ARMCSR_SIZE, MT_DEVICE },
|
{
|
||||||
{ XBUS_BASE, 0x40000000, XBUS_SIZE, MT_DEVICE }
|
.virtual = ARMCSR_BASE,
|
||||||
|
.pfn = DC21285_ARMCSR_BASE,
|
||||||
|
.length = ARMCSR_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = XBUS_BASE,
|
||||||
|
.pfn = __phys_to_pfn(0x40000000),
|
||||||
|
.length = XBUS_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -140,11 +149,32 @@ static struct map_desc fb_common_io_desc[] __initdata = {
|
||||||
*/
|
*/
|
||||||
static struct map_desc ebsa285_host_io_desc[] __initdata = {
|
static struct map_desc ebsa285_host_io_desc[] __initdata = {
|
||||||
#if defined(CONFIG_ARCH_FOOTBRIDGE) && defined(CONFIG_FOOTBRIDGE_HOST)
|
#if defined(CONFIG_ARCH_FOOTBRIDGE) && defined(CONFIG_FOOTBRIDGE_HOST)
|
||||||
{ PCIMEM_BASE, DC21285_PCI_MEM, PCIMEM_SIZE, MT_DEVICE },
|
{
|
||||||
{ PCICFG0_BASE, DC21285_PCI_TYPE_0_CONFIG, PCICFG0_SIZE, MT_DEVICE },
|
.virtual = PCIMEM_BASE,
|
||||||
{ PCICFG1_BASE, DC21285_PCI_TYPE_1_CONFIG, PCICFG1_SIZE, MT_DEVICE },
|
.pfn = __phys_to_pfn(DC21285_PCI_MEM),
|
||||||
{ PCIIACK_BASE, DC21285_PCI_IACK, PCIIACK_SIZE, MT_DEVICE },
|
.length = PCIMEM_SIZE,
|
||||||
{ PCIO_BASE, DC21285_PCI_IO, PCIO_SIZE, MT_DEVICE }
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCICFG0_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_TYPE_0_CONFIG),
|
||||||
|
.length = PCICFG0_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCICFG1_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_TYPE_1_CONFIG),
|
||||||
|
.length = PCICFG1_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCIIACK_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_IACK),
|
||||||
|
.length = PCIIACK_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCIO_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_IO),
|
||||||
|
.length = PCIO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -153,8 +183,17 @@ static struct map_desc ebsa285_host_io_desc[] __initdata = {
|
||||||
*/
|
*/
|
||||||
static struct map_desc co285_io_desc[] __initdata = {
|
static struct map_desc co285_io_desc[] __initdata = {
|
||||||
#ifdef CONFIG_ARCH_CO285
|
#ifdef CONFIG_ARCH_CO285
|
||||||
{ PCIO_BASE, DC21285_PCI_IO, PCIO_SIZE, MT_DEVICE },
|
{
|
||||||
{ PCIMEM_BASE, DC21285_PCI_MEM, PCIMEM_SIZE, MT_DEVICE }
|
.virtual = PCIO_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_IO),
|
||||||
|
.length = PCIO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCIMEM_BASE,
|
||||||
|
.pfn = __phys_to_pfn(DC21285_PCI_MEM),
|
||||||
|
.length = PCIMEM_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -237,7 +237,12 @@ void __init h720x_init_irq (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc h720x_io_desc[] __initdata = {
|
static struct map_desc h720x_io_desc[] __initdata = {
|
||||||
{ IO_VIRT, IO_PHYS, IO_SIZE, MT_DEVICE },
|
{
|
||||||
|
.virtual = IO_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IO_PHYS),
|
||||||
|
.length = IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Initialize io tables */
|
/* Initialize io tables */
|
||||||
|
|
|
@ -273,8 +273,12 @@ static struct platform_device *devices[] __initdata = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct map_desc imx_io_desc[] __initdata = {
|
static struct map_desc imx_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{
|
||||||
{IMX_IO_BASE, IMX_IO_PHYS, IMX_IO_SIZE, MT_DEVICE},
|
.virtual = IMX_IO_BASE,
|
||||||
|
.pfn = __phys_to_pfn(IMX_IO_PHYS),
|
||||||
|
.length = IMX_IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init
|
void __init
|
||||||
|
|
|
@ -61,13 +61,37 @@ mx1ads_init(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc mx1ads_io_desc[] __initdata = {
|
static struct map_desc mx1ads_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{
|
||||||
{IMX_CS0_VIRT, IMX_CS0_PHYS, IMX_CS0_SIZE, MT_DEVICE},
|
.virtual = IMX_CS0_VIRT,
|
||||||
{IMX_CS1_VIRT, IMX_CS1_PHYS, IMX_CS1_SIZE, MT_DEVICE},
|
.pfn = __phys_to_pfn(IMX_CS0_PHYS),
|
||||||
{IMX_CS2_VIRT, IMX_CS2_PHYS, IMX_CS2_SIZE, MT_DEVICE},
|
.length = IMX_CS0_SIZE,
|
||||||
{IMX_CS3_VIRT, IMX_CS3_PHYS, IMX_CS3_SIZE, MT_DEVICE},
|
.type = MT_DEVICE
|
||||||
{IMX_CS4_VIRT, IMX_CS4_PHYS, IMX_CS4_SIZE, MT_DEVICE},
|
}, {
|
||||||
{IMX_CS5_VIRT, IMX_CS5_PHYS, IMX_CS5_SIZE, MT_DEVICE},
|
.virtual = IMX_CS1_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IMX_CS1_PHYS),
|
||||||
|
.length = IMX_CS1_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IMX_CS2_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IMX_CS2_PHYS),
|
||||||
|
.length = IMX_CS2_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IMX_CS3_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IMX_CS3_PHYS),
|
||||||
|
.length = IMX_CS3_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IMX_CS4_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IMX_CS4_PHYS),
|
||||||
|
.length = IMX_CS4_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IMX_CS5_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IMX_CS5_PHYS),
|
||||||
|
.length = IMX_CS5_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init
|
static void __init
|
||||||
|
|
|
@ -75,19 +75,72 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct map_desc ap_io_desc[] __initdata = {
|
static struct map_desc ap_io_desc[] __initdata = {
|
||||||
{ IO_ADDRESS(INTEGRATOR_HDR_BASE), INTEGRATOR_HDR_BASE, SZ_4K, MT_DEVICE },
|
{
|
||||||
{ IO_ADDRESS(INTEGRATOR_SC_BASE), INTEGRATOR_SC_BASE, SZ_4K, MT_DEVICE },
|
.virtual = IO_ADDRESS(INTEGRATOR_HDR_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_EBI_BASE), INTEGRATOR_EBI_BASE, SZ_4K, MT_DEVICE },
|
.pfn = __phys_to_pfn(INTEGRATOR_HDR_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_CT_BASE), INTEGRATOR_CT_BASE, SZ_4K, MT_DEVICE },
|
.length = SZ_4K,
|
||||||
{ IO_ADDRESS(INTEGRATOR_IC_BASE), INTEGRATOR_IC_BASE, SZ_4K, MT_DEVICE },
|
.type = MT_DEVICE
|
||||||
{ IO_ADDRESS(INTEGRATOR_UART0_BASE), INTEGRATOR_UART0_BASE, SZ_4K, MT_DEVICE },
|
}, {
|
||||||
{ IO_ADDRESS(INTEGRATOR_UART1_BASE), INTEGRATOR_UART1_BASE, SZ_4K, MT_DEVICE },
|
.virtual = IO_ADDRESS(INTEGRATOR_SC_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_DBG_BASE), INTEGRATOR_DBG_BASE, SZ_4K, MT_DEVICE },
|
.pfn = __phys_to_pfn(INTEGRATOR_SC_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_GPIO_BASE), INTEGRATOR_GPIO_BASE, SZ_4K, MT_DEVICE },
|
.length = SZ_4K,
|
||||||
{ PCI_MEMORY_VADDR, PHYS_PCI_MEM_BASE, SZ_16M, MT_DEVICE },
|
.type = MT_DEVICE
|
||||||
{ PCI_CONFIG_VADDR, PHYS_PCI_CONFIG_BASE, SZ_16M, MT_DEVICE },
|
}, {
|
||||||
{ PCI_V3_VADDR, PHYS_PCI_V3_BASE, SZ_64K, MT_DEVICE },
|
.virtual = IO_ADDRESS(INTEGRATOR_EBI_BASE),
|
||||||
{ PCI_IO_VADDR, PHYS_PCI_IO_BASE, SZ_64K, MT_DEVICE }
|
.pfn = __phys_to_pfn(INTEGRATOR_EBI_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_CT_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_CT_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_IC_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_IC_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_UART0_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_UART0_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_UART1_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_UART1_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_DBG_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_DBG_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_GPIO_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_GPIO_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCI_MEMORY_VADDR,
|
||||||
|
.pfn = __phys_to_pfn(PHYS_PCI_MEM_BASE),
|
||||||
|
.length = SZ_16M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCI_CONFIG_VADDR,
|
||||||
|
.pfn = __phys_to_pfn(PHYS_PCI_CONFIG_BASE),
|
||||||
|
.length = SZ_16M,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCI_V3_VADDR,
|
||||||
|
.pfn = __phys_to_pfn(PHYS_PCI_V3_BASE),
|
||||||
|
.length = SZ_64K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = PCI_IO_VADDR,
|
||||||
|
.pfn = __phys_to_pfn(PHYS_PCI_IO_BASE),
|
||||||
|
.length = SZ_64K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init ap_map_io(void)
|
static void __init ap_map_io(void)
|
||||||
|
|
|
@ -74,17 +74,62 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct map_desc intcp_io_desc[] __initdata = {
|
static struct map_desc intcp_io_desc[] __initdata = {
|
||||||
{ IO_ADDRESS(INTEGRATOR_HDR_BASE), INTEGRATOR_HDR_BASE, SZ_4K, MT_DEVICE },
|
{
|
||||||
{ IO_ADDRESS(INTEGRATOR_SC_BASE), INTEGRATOR_SC_BASE, SZ_4K, MT_DEVICE },
|
.virtual = IO_ADDRESS(INTEGRATOR_HDR_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_EBI_BASE), INTEGRATOR_EBI_BASE, SZ_4K, MT_DEVICE },
|
.pfn = __phys_to_pfn(INTEGRATOR_HDR_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_CT_BASE), INTEGRATOR_CT_BASE, SZ_4K, MT_DEVICE },
|
.length = SZ_4K,
|
||||||
{ IO_ADDRESS(INTEGRATOR_IC_BASE), INTEGRATOR_IC_BASE, SZ_4K, MT_DEVICE },
|
.type = MT_DEVICE
|
||||||
{ IO_ADDRESS(INTEGRATOR_UART0_BASE), INTEGRATOR_UART0_BASE, SZ_4K, MT_DEVICE },
|
}, {
|
||||||
{ IO_ADDRESS(INTEGRATOR_UART1_BASE), INTEGRATOR_UART1_BASE, SZ_4K, MT_DEVICE },
|
.virtual = IO_ADDRESS(INTEGRATOR_SC_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_DBG_BASE), INTEGRATOR_DBG_BASE, SZ_4K, MT_DEVICE },
|
.pfn = __phys_to_pfn(INTEGRATOR_SC_BASE),
|
||||||
{ IO_ADDRESS(INTEGRATOR_GPIO_BASE), INTEGRATOR_GPIO_BASE, SZ_4K, MT_DEVICE },
|
.length = SZ_4K,
|
||||||
{ 0xfca00000, 0xca000000, SZ_4K, MT_DEVICE },
|
.type = MT_DEVICE
|
||||||
{ 0xfcb00000, 0xcb000000, SZ_4K, MT_DEVICE },
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_EBI_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_EBI_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_CT_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_CT_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_IC_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_IC_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_UART0_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_UART0_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_UART1_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_UART1_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_DBG_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_DBG_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = IO_ADDRESS(INTEGRATOR_GPIO_BASE),
|
||||||
|
.pfn = __phys_to_pfn(INTEGRATOR_GPIO_BASE),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = 0xfca00000,
|
||||||
|
.pfn = __phys_to_pfn(0xca000000),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = 0xfcb00000,
|
||||||
|
.pfn = __phys_to_pfn(0xcb000000),
|
||||||
|
.length = SZ_4K,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init intcp_map_io(void)
|
static void __init intcp_map_io(void)
|
||||||
|
|
|
@ -38,13 +38,17 @@
|
||||||
* Standard IO mapping for all IOP321 based systems
|
* Standard IO mapping for all IOP321 based systems
|
||||||
*/
|
*/
|
||||||
static struct map_desc iop321_std_desc[] __initdata = {
|
static struct map_desc iop321_std_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{ /* mem mapped registers */
|
||||||
|
.virtual = IOP321_VIRT_MEM_BASE,
|
||||||
/* mem mapped registers */
|
.pfn = __phys_to_pfn(IOP321_PHYS_MEM_BASE),
|
||||||
{ IOP321_VIRT_MEM_BASE, IOP321_PHYS_MEM_BASE, 0x00002000, MT_DEVICE },
|
.length = 0x00002000,
|
||||||
|
.type = MT_DEVICE
|
||||||
/* PCI IO space */
|
}, { /* PCI IO space */
|
||||||
{ IOP321_PCI_LOWER_IO_VA, IOP321_PCI_LOWER_IO_PA, IOP321_PCI_IO_WINDOW_SIZE, MT_DEVICE }
|
.virtual = IOP321_PCI_LOWER_IO_VA,
|
||||||
|
.pfn = __phys_to_pfn(IOP321_PCI_LOWER_IO_PA),
|
||||||
|
.length = IOP321_PCI_IO_WINDOW_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_IQ80321
|
#ifdef CONFIG_ARCH_IQ80321
|
||||||
|
|
|
@ -37,13 +37,17 @@
|
||||||
* Standard IO mapping for all IOP331 based systems
|
* Standard IO mapping for all IOP331 based systems
|
||||||
*/
|
*/
|
||||||
static struct map_desc iop331_std_desc[] __initdata = {
|
static struct map_desc iop331_std_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{ /* mem mapped registers */
|
||||||
|
.virtual = IOP331_VIRT_MEM_BASE,
|
||||||
/* mem mapped registers */
|
.pfn = __phys_to_pfn(IOP331_PHYS_MEM_BASE),
|
||||||
{ IOP331_VIRT_MEM_BASE, IOP331_PHYS_MEM_BASE, 0x00002000, MT_DEVICE },
|
.length = 0x00002000,
|
||||||
|
.type = MT_DEVICE
|
||||||
/* PCI IO space */
|
}, { /* PCI IO space */
|
||||||
{ IOP331_PCI_LOWER_IO_VA, IOP331_PCI_LOWER_IO_PA, IOP331_PCI_IO_WINDOW_SIZE, MT_DEVICE }
|
.virtual = IOP331_PCI_LOWER_IO_VA,
|
||||||
|
.pfn = __phys_to_pfn(IOP331_PCI_LOWER_IO_PA),
|
||||||
|
.length = IOP331_PCI_IO_WINDOW_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct uart_port iop331_serial_ports[] = {
|
static struct uart_port iop331_serial_ports[] = {
|
||||||
|
|
|
@ -29,10 +29,12 @@
|
||||||
* We use RedBoot's setup for the onboard devices.
|
* We use RedBoot's setup for the onboard devices.
|
||||||
*/
|
*/
|
||||||
static struct map_desc iq31244_io_desc[] __initdata = {
|
static struct map_desc iq31244_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{ /* on-board devices */
|
||||||
|
.virtual = IQ31244_UART,
|
||||||
/* on-board devices */
|
.pfn = __phys_to_pfn(IQ31244_UART),
|
||||||
{ IQ31244_UART, IQ31244_UART, 0x00100000, MT_DEVICE }
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init iq31244_map_io(void)
|
void __init iq31244_map_io(void)
|
||||||
|
|
|
@ -29,10 +29,12 @@
|
||||||
* We use RedBoot's setup for the onboard devices.
|
* We use RedBoot's setup for the onboard devices.
|
||||||
*/
|
*/
|
||||||
static struct map_desc iq80321_io_desc[] __initdata = {
|
static struct map_desc iq80321_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{ /* on-board devices */
|
||||||
|
.virtual = IQ80321_UART,
|
||||||
/* on-board devices */
|
.pfn = __phys_to_pfn(IQ80321_UART),
|
||||||
{ IQ80321_UART, IQ80321_UART, 0x00100000, MT_DEVICE }
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init iq80321_map_io(void)
|
void __init iq80321_map_io(void)
|
||||||
|
|
|
@ -83,42 +83,42 @@ void ixp2000_release_slowport(struct slowport_cfg *old_cfg)
|
||||||
static struct map_desc ixp2000_io_desc[] __initdata = {
|
static struct map_desc ixp2000_io_desc[] __initdata = {
|
||||||
{
|
{
|
||||||
.virtual = IXP2000_CAP_VIRT_BASE,
|
.virtual = IXP2000_CAP_VIRT_BASE,
|
||||||
.physical = IXP2000_CAP_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_CAP_PHYS_BASE),
|
||||||
.length = IXP2000_CAP_SIZE,
|
.length = IXP2000_CAP_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_INTCTL_VIRT_BASE,
|
.virtual = IXP2000_INTCTL_VIRT_BASE,
|
||||||
.physical = IXP2000_INTCTL_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_INTCTL_PHYS_BASE),
|
||||||
.length = IXP2000_INTCTL_SIZE,
|
.length = IXP2000_INTCTL_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_PCI_CREG_VIRT_BASE,
|
.virtual = IXP2000_PCI_CREG_VIRT_BASE,
|
||||||
.physical = IXP2000_PCI_CREG_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_PCI_CREG_PHYS_BASE),
|
||||||
.length = IXP2000_PCI_CREG_SIZE,
|
.length = IXP2000_PCI_CREG_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_PCI_CSR_VIRT_BASE,
|
.virtual = IXP2000_PCI_CSR_VIRT_BASE,
|
||||||
.physical = IXP2000_PCI_CSR_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_PCI_CSR_PHYS_BASE),
|
||||||
.length = IXP2000_PCI_CSR_SIZE,
|
.length = IXP2000_PCI_CSR_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_MSF_VIRT_BASE,
|
.virtual = IXP2000_MSF_VIRT_BASE,
|
||||||
.physical = IXP2000_MSF_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_MSF_PHYS_BASE),
|
||||||
.length = IXP2000_MSF_SIZE,
|
.length = IXP2000_MSF_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_PCI_IO_VIRT_BASE,
|
.virtual = IXP2000_PCI_IO_VIRT_BASE,
|
||||||
.physical = IXP2000_PCI_IO_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_PCI_IO_PHYS_BASE),
|
||||||
.length = IXP2000_PCI_IO_SIZE,
|
.length = IXP2000_PCI_IO_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_PCI_CFG0_VIRT_BASE,
|
.virtual = IXP2000_PCI_CFG0_VIRT_BASE,
|
||||||
.physical = IXP2000_PCI_CFG0_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_PCI_CFG0_PHYS_BASE),
|
||||||
.length = IXP2000_PCI_CFG0_SIZE,
|
.length = IXP2000_PCI_CFG0_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, {
|
}, {
|
||||||
.virtual = IXP2000_PCI_CFG1_VIRT_BASE,
|
.virtual = IXP2000_PCI_CFG1_VIRT_BASE,
|
||||||
.physical = IXP2000_PCI_CFG1_PHYS_BASE,
|
.pfn = __phys_to_pfn(IXP2000_PCI_CFG1_PHYS_BASE),
|
||||||
.length = IXP2000_PCI_CFG1_SIZE,
|
.length = IXP2000_PCI_CFG1_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}
|
}
|
||||||
|
|
|
@ -176,7 +176,7 @@ void ixdp2x00_init_irq(volatile unsigned long *stat_reg, volatile unsigned long
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
static struct map_desc ixdp2x00_io_desc __initdata = {
|
static struct map_desc ixdp2x00_io_desc __initdata = {
|
||||||
.virtual = IXDP2X00_VIRT_CPLD_BASE,
|
.virtual = IXDP2X00_VIRT_CPLD_BASE,
|
||||||
.physical = IXDP2X00_PHYS_CPLD_BASE,
|
.pfn = __phys_to_pfn(IXDP2X00_PHYS_CPLD_BASE),
|
||||||
.length = IXDP2X00_CPLD_SIZE,
|
.length = IXDP2X00_CPLD_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
};
|
};
|
||||||
|
|
|
@ -136,7 +136,7 @@ void __init ixdp2x01_init_irq(void)
|
||||||
*************************************************************************/
|
*************************************************************************/
|
||||||
static struct map_desc ixdp2x01_io_desc __initdata = {
|
static struct map_desc ixdp2x01_io_desc __initdata = {
|
||||||
.virtual = IXDP2X01_VIRT_CPLD_BASE,
|
.virtual = IXDP2X01_VIRT_CPLD_BASE,
|
||||||
.physical = IXDP2X01_PHYS_CPLD_BASE,
|
.pfn = __phys_to_pfn(IXDP2X01_PHYS_CPLD_BASE),
|
||||||
.length = IXDP2X01_CPLD_REGION_SIZE,
|
.length = IXDP2X01_CPLD_REGION_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
};
|
};
|
||||||
|
|
|
@ -44,24 +44,24 @@
|
||||||
static struct map_desc ixp4xx_io_desc[] __initdata = {
|
static struct map_desc ixp4xx_io_desc[] __initdata = {
|
||||||
{ /* UART, Interrupt ctrl, GPIO, timers, NPEs, MACs, USB .... */
|
{ /* UART, Interrupt ctrl, GPIO, timers, NPEs, MACs, USB .... */
|
||||||
.virtual = IXP4XX_PERIPHERAL_BASE_VIRT,
|
.virtual = IXP4XX_PERIPHERAL_BASE_VIRT,
|
||||||
.physical = IXP4XX_PERIPHERAL_BASE_PHYS,
|
.pfn = __phys_to_pfn(IXP4XX_PERIPHERAL_BASE_PHYS),
|
||||||
.length = IXP4XX_PERIPHERAL_REGION_SIZE,
|
.length = IXP4XX_PERIPHERAL_REGION_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, { /* Expansion Bus Config Registers */
|
}, { /* Expansion Bus Config Registers */
|
||||||
.virtual = IXP4XX_EXP_CFG_BASE_VIRT,
|
.virtual = IXP4XX_EXP_CFG_BASE_VIRT,
|
||||||
.physical = IXP4XX_EXP_CFG_BASE_PHYS,
|
.pfn = __phys_to_pfn(IXP4XX_EXP_CFG_BASE_PHYS),
|
||||||
.length = IXP4XX_EXP_CFG_REGION_SIZE,
|
.length = IXP4XX_EXP_CFG_REGION_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}, { /* PCI Registers */
|
}, { /* PCI Registers */
|
||||||
.virtual = IXP4XX_PCI_CFG_BASE_VIRT,
|
.virtual = IXP4XX_PCI_CFG_BASE_VIRT,
|
||||||
.physical = IXP4XX_PCI_CFG_BASE_PHYS,
|
.pfn = __phys_to_pfn(IXP4XX_PCI_CFG_BASE_PHYS),
|
||||||
.length = IXP4XX_PCI_CFG_REGION_SIZE,
|
.length = IXP4XX_PCI_CFG_REGION_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
},
|
},
|
||||||
#ifdef CONFIG_DEBUG_LL
|
#ifdef CONFIG_DEBUG_LL
|
||||||
{ /* Debug UART mapping */
|
{ /* Debug UART mapping */
|
||||||
.virtual = IXP4XX_DEBUG_UART_BASE_VIRT,
|
.virtual = IXP4XX_DEBUG_UART_BASE_VIRT,
|
||||||
.physical = IXP4XX_DEBUG_UART_BASE_PHYS,
|
.pfn = __phys_to_pfn(IXP4XX_DEBUG_UART_BASE_PHYS),
|
||||||
.length = IXP4XX_DEBUG_UART_REGION_SIZE,
|
.length = IXP4XX_DEBUG_UART_REGION_SIZE,
|
||||||
.type = MT_DEVICE
|
.type = MT_DEVICE
|
||||||
}
|
}
|
||||||
|
|
|
@ -26,8 +26,17 @@
|
||||||
/* This function calls the board specific IRQ initialization function. */
|
/* This function calls the board specific IRQ initialization function. */
|
||||||
|
|
||||||
static struct map_desc kev7a400_io_desc[] __initdata = {
|
static struct map_desc kev7a400_io_desc[] __initdata = {
|
||||||
{ IO_VIRT, IO_PHYS, IO_SIZE, MT_DEVICE },
|
{
|
||||||
{ CPLD_VIRT, CPLD_PHYS, CPLD_SIZE, MT_DEVICE },
|
.virtual = IO_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IO_PHYS),
|
||||||
|
.length = IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD_PHYS),
|
||||||
|
.length = CPLD_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init kev7a400_map_io(void)
|
void __init kev7a400_map_io(void)
|
||||||
|
|
|
@ -227,23 +227,79 @@ void __init lh7a40x_init_board_irq (void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc lpd7a400_io_desc[] __initdata = {
|
static struct map_desc lpd7a400_io_desc[] __initdata = {
|
||||||
{ IO_VIRT, IO_PHYS, IO_SIZE, MT_DEVICE },
|
{
|
||||||
/* Mapping added to work around chip select problems */
|
.virtual = IO_VIRT,
|
||||||
{ IOBARRIER_VIRT, IOBARRIER_PHYS, IOBARRIER_SIZE, MT_DEVICE },
|
.pfn = __phys_to_pfn(IO_PHYS),
|
||||||
{ CF_VIRT, CF_PHYS, CF_SIZE, MT_DEVICE },
|
.length = IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* Mapping added to work around chip select problems */
|
||||||
|
.virtual = IOBARRIER_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IOBARRIER_PHYS),
|
||||||
|
.length = IOBARRIER_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CF_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CF_PHYS),
|
||||||
|
.length = CF_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD02_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD02_PHYS),
|
||||||
|
.length = CPLD02_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD06_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD06_PHYS),
|
||||||
|
.length = CPLD06_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD08_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD08_PHYS),
|
||||||
|
.length = CPLD08_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD0C_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD0C_PHYS),
|
||||||
|
.length = CPLD0C_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD0E_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD0E_PHYS),
|
||||||
|
.length = CPLD0E_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD10_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD10_PHYS),
|
||||||
|
.length = CPLD10_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD12_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD12_PHYS),
|
||||||
|
.length = CPLD12_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD14_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD14_PHYS),
|
||||||
|
.length = CPLD14_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD16_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD16_PHYS),
|
||||||
|
.length = CPLD16_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD18_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD18_PHYS),
|
||||||
|
.length = CPLD18_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = CPLD1A_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(CPLD1A_PHYS),
|
||||||
|
.length = CPLD1A_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
},
|
||||||
/* This mapping is redundant since the smc driver performs another. */
|
/* This mapping is redundant since the smc driver performs another. */
|
||||||
/* { CPLD00_VIRT, CPLD00_PHYS, CPLD00_SIZE, MT_DEVICE }, */
|
/* { CPLD00_VIRT, CPLD00_PHYS, CPLD00_SIZE, MT_DEVICE }, */
|
||||||
{ CPLD02_VIRT, CPLD02_PHYS, CPLD02_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD06_VIRT, CPLD06_PHYS, CPLD06_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD08_VIRT, CPLD08_PHYS, CPLD08_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD0C_VIRT, CPLD0C_PHYS, CPLD0C_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD0E_VIRT, CPLD0E_PHYS, CPLD0E_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD10_VIRT, CPLD10_PHYS, CPLD10_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD12_VIRT, CPLD12_PHYS, CPLD12_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD14_VIRT, CPLD14_PHYS, CPLD14_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD16_VIRT, CPLD16_PHYS, CPLD16_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD18_VIRT, CPLD18_PHYS, CPLD18_SIZE, MT_DEVICE },
|
|
||||||
{ CPLD1A_VIRT, CPLD1A_PHYS, CPLD1A_SIZE, MT_DEVICE },
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init
|
void __init
|
||||||
|
|
|
@ -103,8 +103,12 @@ static struct platform_device innovator_flash_device = {
|
||||||
|
|
||||||
/* Only FPGA needs to be mapped here. All others are done with ioremap */
|
/* Only FPGA needs to be mapped here. All others are done with ioremap */
|
||||||
static struct map_desc innovator1510_io_desc[] __initdata = {
|
static struct map_desc innovator1510_io_desc[] __initdata = {
|
||||||
{ OMAP1510_FPGA_BASE, OMAP1510_FPGA_START, OMAP1510_FPGA_SIZE,
|
{
|
||||||
MT_DEVICE },
|
.virtual = OMAP1510_FPGA_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP1510_FPGA_START),
|
||||||
|
.length = OMAP1510_FPGA_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct resource innovator1510_smc91x_resources[] = {
|
static struct resource innovator1510_smc91x_resources[] = {
|
||||||
|
|
|
@ -134,8 +134,12 @@ void omap_perseus2_init_irq(void)
|
||||||
|
|
||||||
/* Only FPGA needs to be mapped here. All others are done with ioremap */
|
/* Only FPGA needs to be mapped here. All others are done with ioremap */
|
||||||
static struct map_desc omap_perseus2_io_desc[] __initdata = {
|
static struct map_desc omap_perseus2_io_desc[] __initdata = {
|
||||||
{H2P2_DBG_FPGA_BASE, H2P2_DBG_FPGA_START, H2P2_DBG_FPGA_SIZE,
|
{
|
||||||
MT_DEVICE},
|
.virtual = H2P2_DBG_FPGA_BASE,
|
||||||
|
.pfn = __phys_to_pfn(H2P2_DBG_FPGA_START),
|
||||||
|
.length = H2P2_DBG_FPGA_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init omap_perseus2_map_io(void)
|
static void __init omap_perseus2_map_io(void)
|
||||||
|
|
|
@ -26,27 +26,59 @@ extern void omap_sram_init(void);
|
||||||
* default mapping provided here.
|
* default mapping provided here.
|
||||||
*/
|
*/
|
||||||
static struct map_desc omap_io_desc[] __initdata = {
|
static struct map_desc omap_io_desc[] __initdata = {
|
||||||
{ IO_VIRT, IO_PHYS, IO_SIZE, MT_DEVICE },
|
{
|
||||||
|
.virtual = IO_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(IO_PHYS),
|
||||||
|
.length = IO_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_OMAP730
|
#ifdef CONFIG_ARCH_OMAP730
|
||||||
static struct map_desc omap730_io_desc[] __initdata = {
|
static struct map_desc omap730_io_desc[] __initdata = {
|
||||||
{ OMAP730_DSP_BASE, OMAP730_DSP_START, OMAP730_DSP_SIZE, MT_DEVICE },
|
{
|
||||||
{ OMAP730_DSPREG_BASE, OMAP730_DSPREG_START, OMAP730_DSPREG_SIZE, MT_DEVICE },
|
.virtual = OMAP730_DSP_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP730_DSP_START),
|
||||||
|
.length = OMAP730_DSP_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = OMAP730_DSPREG_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP730_DSPREG_START),
|
||||||
|
.length = OMAP730_DSPREG_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_OMAP1510
|
#ifdef CONFIG_ARCH_OMAP1510
|
||||||
static struct map_desc omap1510_io_desc[] __initdata = {
|
static struct map_desc omap1510_io_desc[] __initdata = {
|
||||||
{ OMAP1510_DSP_BASE, OMAP1510_DSP_START, OMAP1510_DSP_SIZE, MT_DEVICE },
|
{
|
||||||
{ OMAP1510_DSPREG_BASE, OMAP1510_DSPREG_START, OMAP1510_DSPREG_SIZE, MT_DEVICE },
|
.virtual = OMAP1510_DSP_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP1510_DSP_START),
|
||||||
|
.length = OMAP1510_DSP_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = OMAP1510_DSPREG_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP1510_DSPREG_START),
|
||||||
|
.length = OMAP1510_DSPREG_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(CONFIG_ARCH_OMAP16XX)
|
#if defined(CONFIG_ARCH_OMAP16XX)
|
||||||
static struct map_desc omap16xx_io_desc[] __initdata = {
|
static struct map_desc omap16xx_io_desc[] __initdata = {
|
||||||
{ OMAP16XX_DSP_BASE, OMAP16XX_DSP_START, OMAP16XX_DSP_SIZE, MT_DEVICE },
|
{
|
||||||
{ OMAP16XX_DSPREG_BASE, OMAP16XX_DSPREG_START, OMAP16XX_DSPREG_SIZE, MT_DEVICE },
|
.virtual = OMAP16XX_DSP_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP16XX_DSP_START),
|
||||||
|
.length = OMAP16XX_DSP_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, {
|
||||||
|
.virtual = OMAP16XX_DSPREG_BASE,
|
||||||
|
.pfn = __phys_to_pfn(OMAP16XX_DSPREG_START),
|
||||||
|
.length = OMAP16XX_DSPREG_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -222,24 +222,22 @@ static int corgi_ssp_remove(struct device *dev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int corgi_ssp_suspend(struct device *dev, pm_message_t state, u32 level)
|
static int corgi_ssp_suspend(struct device *dev, pm_message_t state)
|
||||||
{
|
{
|
||||||
if (level == SUSPEND_POWER_DOWN) {
|
|
||||||
ssp_flush(&corgi_ssp_dev);
|
ssp_flush(&corgi_ssp_dev);
|
||||||
ssp_save_state(&corgi_ssp_dev,&corgi_ssp_state);
|
ssp_save_state(&corgi_ssp_dev,&corgi_ssp_state);
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int corgi_ssp_resume(struct device *dev, u32 level)
|
static int corgi_ssp_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
if (level == RESUME_POWER_ON) {
|
|
||||||
GPSR(ssp_machinfo->cs_lcdcon) = GPIO_bit(ssp_machinfo->cs_lcdcon); /* High - Disable LCD Control/Timing Gen */
|
GPSR(ssp_machinfo->cs_lcdcon) = GPIO_bit(ssp_machinfo->cs_lcdcon); /* High - Disable LCD Control/Timing Gen */
|
||||||
GPSR(ssp_machinfo->cs_max1111) = GPIO_bit(ssp_machinfo->cs_max1111); /* High - Disable MAX1111*/
|
GPSR(ssp_machinfo->cs_max1111) = GPIO_bit(ssp_machinfo->cs_max1111); /* High - Disable MAX1111*/
|
||||||
GPSR(ssp_machinfo->cs_ads7846) = GPIO_bit(ssp_machinfo->cs_ads7846); /* High - Disable ADS7846*/
|
GPSR(ssp_machinfo->cs_ads7846) = GPIO_bit(ssp_machinfo->cs_ads7846); /* High - Disable ADS7846*/
|
||||||
ssp_restore_state(&corgi_ssp_dev,&corgi_ssp_state);
|
ssp_restore_state(&corgi_ssp_dev,&corgi_ssp_state);
|
||||||
ssp_enable(&corgi_ssp_dev);
|
ssp_enable(&corgi_ssp_dev);
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
#include <asm/arch/udc.h>
|
#include <asm/arch/udc.h>
|
||||||
#include <asm/arch/pxafb.h>
|
#include <asm/arch/pxafb.h>
|
||||||
#include <asm/arch/mmc.h>
|
#include <asm/arch/mmc.h>
|
||||||
|
#include <asm/arch/irda.h>
|
||||||
#include <asm/arch/i2c.h>
|
#include <asm/arch/i2c.h>
|
||||||
|
|
||||||
#include "generic.h"
|
#include "generic.h"
|
||||||
|
@ -92,14 +93,42 @@ EXPORT_SYMBOL(pxa_set_cken);
|
||||||
* and cache flush area.
|
* and cache flush area.
|
||||||
*/
|
*/
|
||||||
static struct map_desc standard_io_desc[] __initdata = {
|
static struct map_desc standard_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{ /* Devs */
|
||||||
{ 0xf2000000, 0x40000000, 0x02000000, MT_DEVICE }, /* Devs */
|
.virtual = 0xf2000000,
|
||||||
{ 0xf4000000, 0x44000000, 0x00100000, MT_DEVICE }, /* LCD */
|
.pfn = __phys_to_pfn(0x40000000),
|
||||||
{ 0xf6000000, 0x48000000, 0x00100000, MT_DEVICE }, /* Mem Ctl */
|
.length = 0x02000000,
|
||||||
{ 0xf8000000, 0x4c000000, 0x00100000, MT_DEVICE }, /* USB host */
|
.type = MT_DEVICE
|
||||||
{ 0xfa000000, 0x50000000, 0x00100000, MT_DEVICE }, /* Camera */
|
}, { /* LCD */
|
||||||
{ 0xfe000000, 0x58000000, 0x00100000, MT_DEVICE }, /* IMem ctl */
|
.virtual = 0xf4000000,
|
||||||
{ 0xff000000, 0x00000000, 0x00100000, MT_DEVICE } /* UNCACHED_PHYS_0 */
|
.pfn = __phys_to_pfn(0x44000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* Mem Ctl */
|
||||||
|
.virtual = 0xf6000000,
|
||||||
|
.pfn = __phys_to_pfn(0x48000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* USB host */
|
||||||
|
.virtual = 0xf8000000,
|
||||||
|
.pfn = __phys_to_pfn(0x4c000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* Camera */
|
||||||
|
.virtual = 0xfa000000,
|
||||||
|
.pfn = __phys_to_pfn(0x50000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* IMem ctl */
|
||||||
|
.virtual = 0xfe000000,
|
||||||
|
.pfn = __phys_to_pfn(0x58000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* UNCACHED_PHYS_0 */
|
||||||
|
.virtual = 0xff000000,
|
||||||
|
.pfn = __phys_to_pfn(0x00000000),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init pxa_map_io(void)
|
void __init pxa_map_io(void)
|
||||||
|
@ -225,6 +254,10 @@ static struct platform_device stuart_device = {
|
||||||
.name = "pxa2xx-uart",
|
.name = "pxa2xx-uart",
|
||||||
.id = 2,
|
.id = 2,
|
||||||
};
|
};
|
||||||
|
static struct platform_device hwuart_device = {
|
||||||
|
.name = "pxa2xx-uart",
|
||||||
|
.id = 3,
|
||||||
|
};
|
||||||
|
|
||||||
static struct resource i2c_resources[] = {
|
static struct resource i2c_resources[] = {
|
||||||
{
|
{
|
||||||
|
@ -265,10 +298,26 @@ static struct resource i2s_resources[] = {
|
||||||
static struct platform_device i2s_device = {
|
static struct platform_device i2s_device = {
|
||||||
.name = "pxa2xx-i2s",
|
.name = "pxa2xx-i2s",
|
||||||
.id = -1,
|
.id = -1,
|
||||||
.resource = i2c_resources,
|
.resource = i2s_resources,
|
||||||
.num_resources = ARRAY_SIZE(i2s_resources),
|
.num_resources = ARRAY_SIZE(i2s_resources),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static u64 pxaficp_dmamask = ~(u32)0;
|
||||||
|
|
||||||
|
static struct platform_device pxaficp_device = {
|
||||||
|
.name = "pxa2xx-ir",
|
||||||
|
.id = -1,
|
||||||
|
.dev = {
|
||||||
|
.dma_mask = &pxaficp_dmamask,
|
||||||
|
.coherent_dma_mask = 0xffffffff,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
void __init pxa_set_ficp_info(struct pxaficp_platform_data *info)
|
||||||
|
{
|
||||||
|
pxaficp_device.dev.platform_data = info;
|
||||||
|
}
|
||||||
|
|
||||||
static struct platform_device *devices[] __initdata = {
|
static struct platform_device *devices[] __initdata = {
|
||||||
&pxamci_device,
|
&pxamci_device,
|
||||||
&udc_device,
|
&udc_device,
|
||||||
|
@ -276,13 +325,26 @@ static struct platform_device *devices[] __initdata = {
|
||||||
&ffuart_device,
|
&ffuart_device,
|
||||||
&btuart_device,
|
&btuart_device,
|
||||||
&stuart_device,
|
&stuart_device,
|
||||||
|
&pxaficp_device,
|
||||||
&i2c_device,
|
&i2c_device,
|
||||||
&i2s_device,
|
&i2s_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int __init pxa_init(void)
|
static int __init pxa_init(void)
|
||||||
{
|
{
|
||||||
return platform_add_devices(devices, ARRAY_SIZE(devices));
|
int cpuid, ret;
|
||||||
|
|
||||||
|
ret = platform_add_devices(devices, ARRAY_SIZE(devices));
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
/* Only add HWUART for PXA255/26x; PXA210/250/27x do not have it. */
|
||||||
|
cpuid = read_cpuid(CPUID_ID);
|
||||||
|
if (((cpuid >> 4) & 0xfff) == 0x2d0 ||
|
||||||
|
((cpuid >> 4) & 0xfff) == 0x290)
|
||||||
|
ret = platform_device_register(&hwuart_device);
|
||||||
|
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
subsys_initcall(pxa_init);
|
subsys_initcall(pxa_init);
|
||||||
|
|
|
@ -152,16 +152,17 @@ static void __init idp_init_irq(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc idp_io_desc[] __initdata = {
|
static struct map_desc idp_io_desc[] __initdata = {
|
||||||
/* virtual physical length type */
|
{
|
||||||
|
.virtual = IDP_COREVOLT_VIRT,
|
||||||
{ IDP_COREVOLT_VIRT,
|
.pfn = __phys_to_pfn(IDP_COREVOLT_PHYS),
|
||||||
IDP_COREVOLT_PHYS,
|
.length = IDP_COREVOLT_SIZE,
|
||||||
IDP_COREVOLT_SIZE,
|
.type = MT_DEVICE
|
||||||
MT_DEVICE },
|
}, {
|
||||||
{ IDP_CPLD_VIRT,
|
.virtual = IDP_CPLD_VIRT,
|
||||||
IDP_CPLD_PHYS,
|
.pfn = __phys_to_pfn(IDP_CPLD_PHYS),
|
||||||
IDP_CPLD_SIZE,
|
.length = IDP_CPLD_SIZE,
|
||||||
MT_DEVICE }
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init idp_map_io(void)
|
static void __init idp_map_io(void)
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include <asm/arch/pxa-regs.h>
|
#include <asm/arch/pxa-regs.h>
|
||||||
#include <asm/arch/lubbock.h>
|
#include <asm/arch/lubbock.h>
|
||||||
#include <asm/arch/udc.h>
|
#include <asm/arch/udc.h>
|
||||||
|
#include <asm/arch/irda.h>
|
||||||
#include <asm/arch/pxafb.h>
|
#include <asm/arch/pxafb.h>
|
||||||
#include <asm/arch/mmc.h>
|
#include <asm/arch/mmc.h>
|
||||||
|
|
||||||
|
@ -237,16 +238,40 @@ static struct pxamci_platform_data lubbock_mci_platform_data = {
|
||||||
.init = lubbock_mci_init,
|
.init = lubbock_mci_init,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void lubbock_irda_transceiver_mode(struct device *dev, int mode)
|
||||||
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
local_irq_save(flags);
|
||||||
|
if (mode & IR_SIRMODE) {
|
||||||
|
LUB_MISC_WR &= ~(1 << 4);
|
||||||
|
} else if (mode & IR_FIRMODE) {
|
||||||
|
LUB_MISC_WR |= 1 << 4;
|
||||||
|
}
|
||||||
|
local_irq_restore(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pxaficp_platform_data lubbock_ficp_platform_data = {
|
||||||
|
.transceiver_cap = IR_SIRMODE | IR_FIRMODE,
|
||||||
|
.transceiver_mode = lubbock_irda_transceiver_mode,
|
||||||
|
};
|
||||||
|
|
||||||
static void __init lubbock_init(void)
|
static void __init lubbock_init(void)
|
||||||
{
|
{
|
||||||
pxa_set_udc_info(&udc_info);
|
pxa_set_udc_info(&udc_info);
|
||||||
set_pxa_fb_info(&sharp_lm8v31);
|
set_pxa_fb_info(&sharp_lm8v31);
|
||||||
pxa_set_mci_info(&lubbock_mci_platform_data);
|
pxa_set_mci_info(&lubbock_mci_platform_data);
|
||||||
|
pxa_set_ficp_info(&lubbock_ficp_platform_data);
|
||||||
(void) platform_add_devices(devices, ARRAY_SIZE(devices));
|
(void) platform_add_devices(devices, ARRAY_SIZE(devices));
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct map_desc lubbock_io_desc[] __initdata = {
|
static struct map_desc lubbock_io_desc[] __initdata = {
|
||||||
{ LUBBOCK_FPGA_VIRT, LUBBOCK_FPGA_PHYS, 0x00100000, MT_DEVICE }, /* CPLD */
|
{ /* CPLD */
|
||||||
|
.virtual = LUBBOCK_FPGA_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(LUBBOCK_FPGA_PHYS),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init lubbock_map_io(void)
|
static void __init lubbock_map_io(void)
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include <asm/arch/audio.h>
|
#include <asm/arch/audio.h>
|
||||||
#include <asm/arch/pxafb.h>
|
#include <asm/arch/pxafb.h>
|
||||||
#include <asm/arch/mmc.h>
|
#include <asm/arch/mmc.h>
|
||||||
|
#include <asm/arch/irda.h>
|
||||||
|
|
||||||
#include "generic.h"
|
#include "generic.h"
|
||||||
|
|
||||||
|
@ -294,6 +295,29 @@ static struct pxamci_platform_data mainstone_mci_platform_data = {
|
||||||
.exit = mainstone_mci_exit,
|
.exit = mainstone_mci_exit,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void mainstone_irda_transceiver_mode(struct device *dev, int mode)
|
||||||
|
{
|
||||||
|
unsigned long flags;
|
||||||
|
|
||||||
|
local_irq_save(flags);
|
||||||
|
if (mode & IR_SIRMODE) {
|
||||||
|
MST_MSCWR1 &= ~MST_MSCWR1_IRDA_FIR;
|
||||||
|
} else if (mode & IR_FIRMODE) {
|
||||||
|
MST_MSCWR1 |= MST_MSCWR1_IRDA_FIR;
|
||||||
|
}
|
||||||
|
if (mode & IR_OFF) {
|
||||||
|
MST_MSCWR1 = (MST_MSCWR1 & ~MST_MSCWR1_IRDA_MASK) | MST_MSCWR1_IRDA_OFF;
|
||||||
|
} else {
|
||||||
|
MST_MSCWR1 = (MST_MSCWR1 & ~MST_MSCWR1_IRDA_MASK) | MST_MSCWR1_IRDA_FULL;
|
||||||
|
}
|
||||||
|
local_irq_restore(flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct pxaficp_platform_data mainstone_ficp_platform_data = {
|
||||||
|
.transceiver_cap = IR_SIRMODE | IR_FIRMODE | IR_OFF,
|
||||||
|
.transceiver_mode = mainstone_irda_transceiver_mode,
|
||||||
|
};
|
||||||
|
|
||||||
static void __init mainstone_init(void)
|
static void __init mainstone_init(void)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
|
@ -313,11 +337,17 @@ static void __init mainstone_init(void)
|
||||||
set_pxa_fb_info(&toshiba_ltm035a776c);
|
set_pxa_fb_info(&toshiba_ltm035a776c);
|
||||||
|
|
||||||
pxa_set_mci_info(&mainstone_mci_platform_data);
|
pxa_set_mci_info(&mainstone_mci_platform_data);
|
||||||
|
pxa_set_ficp_info(&mainstone_ficp_platform_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static struct map_desc mainstone_io_desc[] __initdata = {
|
static struct map_desc mainstone_io_desc[] __initdata = {
|
||||||
{ MST_FPGA_VIRT, MST_FPGA_PHYS, 0x00100000, MT_DEVICE }, /* CPLD */
|
{ /* CPLD */
|
||||||
|
.virtual = MST_FPGA_VIRT,
|
||||||
|
.pfn = __phys_to_pfn(MST_FPGA_PHYS),
|
||||||
|
.length = 0x00100000,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init mainstone_map_io(void)
|
static void __init mainstone_map_io(void)
|
||||||
|
|
|
@ -129,7 +129,7 @@ void pxa_cpu_pm_enter(suspend_state_t state)
|
||||||
case PM_SUSPEND_MEM:
|
case PM_SUSPEND_MEM:
|
||||||
/* set resume return address */
|
/* set resume return address */
|
||||||
PSPR = virt_to_phys(pxa_cpu_resume);
|
PSPR = virt_to_phys(pxa_cpu_resume);
|
||||||
pxa_cpu_suspend(3);
|
pxa_cpu_suspend(PWRMODE_SLEEP);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -157,7 +157,7 @@ void pxa_cpu_pm_enter(suspend_state_t state)
|
||||||
case PM_SUSPEND_MEM:
|
case PM_SUSPEND_MEM:
|
||||||
/* set resume return address */
|
/* set resume return address */
|
||||||
PSPR = virt_to_phys(pxa_cpu_resume);
|
PSPR = virt_to_phys(pxa_cpu_resume);
|
||||||
pxa_cpu_suspend(3);
|
pxa_cpu_suspend(PWRMODE_SLEEP);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,7 +28,9 @@
|
||||||
/*
|
/*
|
||||||
* pxa_cpu_suspend()
|
* pxa_cpu_suspend()
|
||||||
*
|
*
|
||||||
* Forces CPU into sleep state
|
* Forces CPU into sleep state.
|
||||||
|
*
|
||||||
|
* r0 = value for PWRMODE M field for desired sleep state
|
||||||
*/
|
*/
|
||||||
|
|
||||||
ENTRY(pxa_cpu_suspend)
|
ENTRY(pxa_cpu_suspend)
|
||||||
|
@ -53,6 +55,7 @@ ENTRY(pxa_cpu_suspend)
|
||||||
mov r10, sp
|
mov r10, sp
|
||||||
stmfd sp!, {r3 - r10}
|
stmfd sp!, {r3 - r10}
|
||||||
|
|
||||||
|
mov r5, r0 @ save sleep mode
|
||||||
@ preserve phys address of stack
|
@ preserve phys address of stack
|
||||||
mov r0, sp
|
mov r0, sp
|
||||||
bl sleep_phys_sp
|
bl sleep_phys_sp
|
||||||
|
@ -66,7 +69,7 @@ ENTRY(pxa_cpu_suspend)
|
||||||
@ (also workaround for sighting 28071)
|
@ (also workaround for sighting 28071)
|
||||||
|
|
||||||
@ prepare value for sleep mode
|
@ prepare value for sleep mode
|
||||||
mov r1, #3 @ sleep mode
|
mov r1, r5 @ sleep mode
|
||||||
|
|
||||||
@ prepare pointer to physical address 0 (virtual mapping in generic.c)
|
@ prepare pointer to physical address 0 (virtual mapping in generic.c)
|
||||||
mov r2, #UNCACHED_PHYS_0
|
mov r2, #UNCACHED_PHYS_0
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
ENTRY(pxa_cpu_standby)
|
ENTRY(pxa_cpu_standby)
|
||||||
ldr r0, =PSSR
|
ldr r0, =PSSR
|
||||||
mov r1, #(PSSR_PH | PSSR_STS)
|
mov r1, #(PSSR_PH | PSSR_STS)
|
||||||
mov r2, #2
|
mov r2, #PWRMODE_STANDBY
|
||||||
mov r3, #UNCACHED_PHYS_0 @ Read mem context in.
|
mov r3, #UNCACHED_PHYS_0 @ Read mem context in.
|
||||||
ldr ip, [r3]
|
ldr ip, [r3]
|
||||||
b 1f
|
b 1f
|
||||||
|
|
|
@ -61,9 +61,22 @@ static int __init parse_tag_acorn(const struct tag *tag)
|
||||||
__tagtable(ATAG_ACORN, parse_tag_acorn);
|
__tagtable(ATAG_ACORN, parse_tag_acorn);
|
||||||
|
|
||||||
static struct map_desc rpc_io_desc[] __initdata = {
|
static struct map_desc rpc_io_desc[] __initdata = {
|
||||||
{ SCREEN_BASE, SCREEN_START, 2*1048576, MT_DEVICE }, /* VRAM */
|
{ /* VRAM */
|
||||||
{ (u32)IO_BASE, IO_START, IO_SIZE , MT_DEVICE }, /* IO space */
|
.virtual = SCREEN_BASE,
|
||||||
{ EASI_BASE, EASI_START, EASI_SIZE, MT_DEVICE } /* EASI space */
|
.pfn = __phys_to_pfn(SCREEN_START),
|
||||||
|
.length = 2*1048576,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* IO space */
|
||||||
|
.virtual = (u32)IO_BASE,
|
||||||
|
.pfn = __phys_to_pfn(IO_START),
|
||||||
|
.length = IO_SIZE ,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}, { /* EASI space */
|
||||||
|
.virtual = EASI_BASE,
|
||||||
|
.pfn = __phys_to_pfn(EASI_START),
|
||||||
|
.length = EASI_SIZE,
|
||||||
|
.type = MT_DEVICE
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init rpc_map_io(void)
|
static void __init rpc_map_io(void)
|
||||||
|
|
|
@ -21,7 +21,7 @@
|
||||||
|
|
||||||
/* todo - fix when rmk changes iodescs to use `void __iomem *` */
|
/* todo - fix when rmk changes iodescs to use `void __iomem *` */
|
||||||
|
|
||||||
#define IODESC_ENT(x) { (unsigned long)S3C24XX_VA_##x, S3C2410_PA_##x, S3C24XX_SZ_##x, MT_DEVICE }
|
#define IODESC_ENT(x) { (unsigned long)S3C24XX_VA_##x, __phys_to_pfn(S3C2410_PA_##x), S3C24XX_SZ_##x, MT_DEVICE }
|
||||||
|
|
||||||
#ifndef MHZ
|
#ifndef MHZ
|
||||||
#define MHZ (1000*1000)
|
#define MHZ (1000*1000)
|
||||||
|
|
|
@ -47,7 +47,7 @@ struct platform_device *s3c24xx_uart_devs[3];
|
||||||
static struct resource s3c_usb_resource[] = {
|
static struct resource s3c_usb_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_USBHOST,
|
.start = S3C2410_PA_USBHOST,
|
||||||
.end = S3C2410_PA_USBHOST + S3C24XX_SZ_USBHOST,
|
.end = S3C2410_PA_USBHOST + S3C24XX_SZ_USBHOST - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -77,7 +77,7 @@ EXPORT_SYMBOL(s3c_device_usb);
|
||||||
static struct resource s3c_lcd_resource[] = {
|
static struct resource s3c_lcd_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_LCD,
|
.start = S3C2410_PA_LCD,
|
||||||
.end = S3C2410_PA_LCD + S3C24XX_SZ_LCD,
|
.end = S3C2410_PA_LCD + S3C24XX_SZ_LCD - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -103,21 +103,25 @@ struct platform_device s3c_device_lcd = {
|
||||||
|
|
||||||
EXPORT_SYMBOL(s3c_device_lcd);
|
EXPORT_SYMBOL(s3c_device_lcd);
|
||||||
|
|
||||||
static struct s3c2410fb_mach_info s3c2410fb_info;
|
void __init s3c24xx_fb_set_platdata(struct s3c2410fb_mach_info *pd)
|
||||||
|
|
||||||
void __init set_s3c2410fb_info(struct s3c2410fb_mach_info *hard_s3c2410fb_info)
|
|
||||||
{
|
{
|
||||||
memcpy(&s3c2410fb_info,hard_s3c2410fb_info,sizeof(struct s3c2410fb_mach_info));
|
struct s3c2410fb_mach_info *npd;
|
||||||
s3c_device_lcd.dev.platform_data = &s3c2410fb_info;
|
|
||||||
|
npd = kmalloc(sizeof(*npd), GFP_KERNEL);
|
||||||
|
if (npd) {
|
||||||
|
memcpy(npd, pd, sizeof(*npd));
|
||||||
|
s3c_device_lcd.dev.platform_data = npd;
|
||||||
|
} else {
|
||||||
|
printk(KERN_ERR "no memory for LCD platform data\n");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(set_s3c2410fb_info);
|
|
||||||
|
|
||||||
/* NAND Controller */
|
/* NAND Controller */
|
||||||
|
|
||||||
static struct resource s3c_nand_resource[] = {
|
static struct resource s3c_nand_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_NAND,
|
.start = S3C2410_PA_NAND,
|
||||||
.end = S3C2410_PA_NAND + S3C24XX_SZ_NAND,
|
.end = S3C2410_PA_NAND + S3C24XX_SZ_NAND - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -136,7 +140,7 @@ EXPORT_SYMBOL(s3c_device_nand);
|
||||||
static struct resource s3c_usbgadget_resource[] = {
|
static struct resource s3c_usbgadget_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_USBDEV,
|
.start = S3C2410_PA_USBDEV,
|
||||||
.end = S3C2410_PA_USBDEV + S3C24XX_SZ_USBDEV,
|
.end = S3C2410_PA_USBDEV + S3C24XX_SZ_USBDEV - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -161,7 +165,7 @@ EXPORT_SYMBOL(s3c_device_usbgadget);
|
||||||
static struct resource s3c_wdt_resource[] = {
|
static struct resource s3c_wdt_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_WATCHDOG,
|
.start = S3C2410_PA_WATCHDOG,
|
||||||
.end = S3C2410_PA_WATCHDOG + S3C24XX_SZ_WATCHDOG,
|
.end = S3C2410_PA_WATCHDOG + S3C24XX_SZ_WATCHDOG - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -186,7 +190,7 @@ EXPORT_SYMBOL(s3c_device_wdt);
|
||||||
static struct resource s3c_i2c_resource[] = {
|
static struct resource s3c_i2c_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_IIC,
|
.start = S3C2410_PA_IIC,
|
||||||
.end = S3C2410_PA_IIC + S3C24XX_SZ_IIC,
|
.end = S3C2410_PA_IIC + S3C24XX_SZ_IIC - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -211,7 +215,7 @@ EXPORT_SYMBOL(s3c_device_i2c);
|
||||||
static struct resource s3c_iis_resource[] = {
|
static struct resource s3c_iis_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_IIS,
|
.start = S3C2410_PA_IIS,
|
||||||
.end = S3C2410_PA_IIS + S3C24XX_SZ_IIS,
|
.end = S3C2410_PA_IIS + S3C24XX_SZ_IIS -1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -265,7 +269,7 @@ EXPORT_SYMBOL(s3c_device_rtc);
|
||||||
static struct resource s3c_adc_resource[] = {
|
static struct resource s3c_adc_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_ADC,
|
.start = S3C2410_PA_ADC,
|
||||||
.end = S3C2410_PA_ADC + S3C24XX_SZ_ADC,
|
.end = S3C2410_PA_ADC + S3C24XX_SZ_ADC - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -288,7 +292,7 @@ struct platform_device s3c_device_adc = {
|
||||||
static struct resource s3c_sdi_resource[] = {
|
static struct resource s3c_sdi_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2410_PA_SDI,
|
.start = S3C2410_PA_SDI,
|
||||||
.end = S3C2410_PA_SDI + S3C24XX_SZ_SDI,
|
.end = S3C2410_PA_SDI + S3C24XX_SZ_SDI - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
@ -465,7 +469,7 @@ EXPORT_SYMBOL(s3c_device_timer3);
|
||||||
static struct resource s3c_camif_resource[] = {
|
static struct resource s3c_camif_resource[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = S3C2440_PA_CAMIF,
|
.start = S3C2440_PA_CAMIF,
|
||||||
.end = S3C2440_PA_CAMIF + S3C2440_SZ_CAMIF,
|
.end = S3C2440_PA_CAMIF + S3C2440_SZ_CAMIF - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
* 04-Oct-2004 BJD Added irq filter controls for GPIO
|
* 04-Oct-2004 BJD Added irq filter controls for GPIO
|
||||||
* 05-Nov-2004 BJD EXPORT_SYMBOL() added for all code
|
* 05-Nov-2004 BJD EXPORT_SYMBOL() added for all code
|
||||||
* 13-Mar-2005 BJD Updates for __iomem
|
* 13-Mar-2005 BJD Updates for __iomem
|
||||||
|
* 26-Oct-2005 BJD Added generic configuration types
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
@ -58,6 +59,27 @@ void s3c2410_gpio_cfgpin(unsigned int pin, unsigned int function)
|
||||||
mask = 3 << S3C2410_GPIO_OFFSET(pin)*2;
|
mask = 3 << S3C2410_GPIO_OFFSET(pin)*2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
switch (function) {
|
||||||
|
case S3C2410_GPIO_LEAVE:
|
||||||
|
mask = 0;
|
||||||
|
function = 0;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case S3C2410_GPIO_INPUT:
|
||||||
|
case S3C2410_GPIO_OUTPUT:
|
||||||
|
case S3C2410_GPIO_SFN2:
|
||||||
|
case S3C2410_GPIO_SFN3:
|
||||||
|
if (pin < S3C2410_GPIO_BANKB) {
|
||||||
|
function &= 1;
|
||||||
|
function <<= S3C2410_GPIO_OFFSET(pin);
|
||||||
|
} else {
|
||||||
|
function &= 3;
|
||||||
|
function <<= S3C2410_GPIO_OFFSET(pin)*2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* modify the specified register wwith IRQs off */
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
|
|
||||||
con = __raw_readl(base + 0x00);
|
con = __raw_readl(base + 0x00);
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue