Merge branch 'irq/urgent' into irq/core
Reason: Get mainline fixes integrated. Further patches conflict with them Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
This commit is contained in:
commit
285c1a2c3a
1
.mailmap
1
.mailmap
@ -23,6 +23,7 @@ Andy Adamson <andros@citi.umich.edu>
|
|||||||
Arnaud Patard <arnaud.patard@rtp-net.org>
|
Arnaud Patard <arnaud.patard@rtp-net.org>
|
||||||
Arnd Bergmann <arnd@arndb.de>
|
Arnd Bergmann <arnd@arndb.de>
|
||||||
Axel Dyks <xl@xlsigned.net>
|
Axel Dyks <xl@xlsigned.net>
|
||||||
|
Axel Lin <axel.lin@gmail.com>
|
||||||
Ben Gardner <bgardner@wabtec.com>
|
Ben Gardner <bgardner@wabtec.com>
|
||||||
Ben M Cahill <ben.m.cahill@intel.com>
|
Ben M Cahill <ben.m.cahill@intel.com>
|
||||||
Björn Steinbrink <B.Steinbrink@gmx.de>
|
Björn Steinbrink <B.Steinbrink@gmx.de>
|
||||||
|
25
Documentation/ABI/testing/sysfs-platform-at91
Normal file
25
Documentation/ABI/testing/sysfs-platform-at91
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
What: /sys/devices/platform/at91_can/net/<iface>/mb0_id
|
||||||
|
Date: January 2011
|
||||||
|
KernelVersion: 2.6.38
|
||||||
|
Contact: Marc Kleine-Budde <kernel@pengutronix.de>
|
||||||
|
Description:
|
||||||
|
Value representing the can_id of mailbox 0.
|
||||||
|
|
||||||
|
Default: 0x7ff (standard frame)
|
||||||
|
|
||||||
|
Due to a chip bug (errata 50.2.6.3 & 50.3.5.3 in
|
||||||
|
"AT91SAM9263 Preliminary 6249H-ATARM-27-Jul-09") the
|
||||||
|
contents of mailbox 0 may be send under certain
|
||||||
|
conditions (even if disabled or in rx mode).
|
||||||
|
|
||||||
|
The workaround in the errata suggests not to use the
|
||||||
|
mailbox and load it with an unused identifier.
|
||||||
|
|
||||||
|
In order to use an extended can_id add the
|
||||||
|
CAN_EFF_FLAG (0x80000000U) to the can_id. Example:
|
||||||
|
|
||||||
|
- standard id 0x7ff:
|
||||||
|
echo 0x7ff > /sys/class/net/can0/mb0_id
|
||||||
|
|
||||||
|
- extended id 0x1fffffff:
|
||||||
|
echo 0x9fffffff > /sys/class/net/can0/mb0_id
|
@ -217,8 +217,8 @@ X!Isound/sound_firmware.c
|
|||||||
<chapter id="uart16x50">
|
<chapter id="uart16x50">
|
||||||
<title>16x50 UART Driver</title>
|
<title>16x50 UART Driver</title>
|
||||||
!Iinclude/linux/serial_core.h
|
!Iinclude/linux/serial_core.h
|
||||||
!Edrivers/serial/serial_core.c
|
!Edrivers/tty/serial/serial_core.c
|
||||||
!Edrivers/serial/8250.c
|
!Edrivers/tty/serial/8250.c
|
||||||
</chapter>
|
</chapter>
|
||||||
|
|
||||||
<chapter id="fbdev">
|
<chapter id="fbdev">
|
||||||
|
@ -603,3 +603,19 @@ Why: The adm9240, w83792d and w83793 hardware monitoring drivers have
|
|||||||
Who: Jean Delvare <khali@linux-fr.org>
|
Who: Jean Delvare <khali@linux-fr.org>
|
||||||
|
|
||||||
----------------------------
|
----------------------------
|
||||||
|
|
||||||
|
What: noswapaccount kernel command line parameter
|
||||||
|
When: 2.6.40
|
||||||
|
Why: The original implementation of memsw feature enabled by
|
||||||
|
CONFIG_CGROUP_MEM_RES_CTLR_SWAP could be disabled by the noswapaccount
|
||||||
|
kernel parameter (introduced in 2.6.29-rc1). Later on, this decision
|
||||||
|
turned out to be not ideal because we cannot have the feature compiled
|
||||||
|
in and disabled by default and let only interested to enable it
|
||||||
|
(e.g. general distribution kernels might need it). Therefore we have
|
||||||
|
added swapaccount[=0|1] parameter (introduced in 2.6.37) which provides
|
||||||
|
the both possibilities. If we remove noswapaccount we will have
|
||||||
|
less command line parameters with the same functionality and we
|
||||||
|
can also cleanup the parameter handling a bit ().
|
||||||
|
Who: Michal Hocko <mhocko@suse.cz>
|
||||||
|
|
||||||
|
----------------------------
|
||||||
|
@ -460,6 +460,8 @@ Note, a technical ChangeLog aimed at kernel hackers is in fs/ntfs/ChangeLog.
|
|||||||
2.1.30:
|
2.1.30:
|
||||||
- Fix writev() (it kept writing the first segment over and over again
|
- Fix writev() (it kept writing the first segment over and over again
|
||||||
instead of moving onto subsequent segments).
|
instead of moving onto subsequent segments).
|
||||||
|
- Fix crash in ntfs_mft_record_alloc() when mapping the new extent mft
|
||||||
|
record failed.
|
||||||
2.1.29:
|
2.1.29:
|
||||||
- Fix a deadlock when mounting read-write.
|
- Fix a deadlock when mounting read-write.
|
||||||
2.1.28:
|
2.1.28:
|
||||||
|
@ -43,11 +43,11 @@ parameter is applicable:
|
|||||||
AVR32 AVR32 architecture is enabled.
|
AVR32 AVR32 architecture is enabled.
|
||||||
AX25 Appropriate AX.25 support is enabled.
|
AX25 Appropriate AX.25 support is enabled.
|
||||||
BLACKFIN Blackfin architecture is enabled.
|
BLACKFIN Blackfin architecture is enabled.
|
||||||
|
DRM Direct Rendering Management support is enabled.
|
||||||
|
DYNAMIC_DEBUG Build in debug messages and enable them at runtime
|
||||||
EDD BIOS Enhanced Disk Drive Services (EDD) is enabled
|
EDD BIOS Enhanced Disk Drive Services (EDD) is enabled
|
||||||
EFI EFI Partitioning (GPT) is enabled
|
EFI EFI Partitioning (GPT) is enabled
|
||||||
EIDE EIDE/ATAPI support is enabled.
|
EIDE EIDE/ATAPI support is enabled.
|
||||||
DRM Direct Rendering Management support is enabled.
|
|
||||||
DYNAMIC_DEBUG Build in debug messages and enable them at runtime
|
|
||||||
FB The frame buffer device is enabled.
|
FB The frame buffer device is enabled.
|
||||||
GCOV GCOV profiling is enabled.
|
GCOV GCOV profiling is enabled.
|
||||||
HW Appropriate hardware is enabled.
|
HW Appropriate hardware is enabled.
|
||||||
|
@ -49,7 +49,8 @@ Table of Contents
|
|||||||
3.3 Configuring Bonding Manually with Ifenslave
|
3.3 Configuring Bonding Manually with Ifenslave
|
||||||
3.3.1 Configuring Multiple Bonds Manually
|
3.3.1 Configuring Multiple Bonds Manually
|
||||||
3.4 Configuring Bonding Manually via Sysfs
|
3.4 Configuring Bonding Manually via Sysfs
|
||||||
3.5 Overriding Configuration for Special Cases
|
3.5 Configuration with Interfaces Support
|
||||||
|
3.6 Overriding Configuration for Special Cases
|
||||||
|
|
||||||
4. Querying Bonding Configuration
|
4. Querying Bonding Configuration
|
||||||
4.1 Bonding Configuration
|
4.1 Bonding Configuration
|
||||||
@ -161,8 +162,8 @@ onwards) do not have /usr/include/linux symbolically linked to the
|
|||||||
default kernel source include directory.
|
default kernel source include directory.
|
||||||
|
|
||||||
SECOND IMPORTANT NOTE:
|
SECOND IMPORTANT NOTE:
|
||||||
If you plan to configure bonding using sysfs, you do not need
|
If you plan to configure bonding using sysfs or using the
|
||||||
to use ifenslave.
|
/etc/network/interfaces file, you do not need to use ifenslave.
|
||||||
|
|
||||||
2. Bonding Driver Options
|
2. Bonding Driver Options
|
||||||
=========================
|
=========================
|
||||||
@ -779,22 +780,26 @@ resend_igmp
|
|||||||
|
|
||||||
You can configure bonding using either your distro's network
|
You can configure bonding using either your distro's network
|
||||||
initialization scripts, or manually using either ifenslave or the
|
initialization scripts, or manually using either ifenslave or the
|
||||||
sysfs interface. Distros generally use one of two packages for the
|
sysfs interface. Distros generally use one of three packages for the
|
||||||
network initialization scripts: initscripts or sysconfig. Recent
|
network initialization scripts: initscripts, sysconfig or interfaces.
|
||||||
versions of these packages have support for bonding, while older
|
Recent versions of these packages have support for bonding, while older
|
||||||
versions do not.
|
versions do not.
|
||||||
|
|
||||||
We will first describe the options for configuring bonding for
|
We will first describe the options for configuring bonding for
|
||||||
distros using versions of initscripts and sysconfig with full or
|
distros using versions of initscripts, sysconfig and interfaces with full
|
||||||
partial support for bonding, then provide information on enabling
|
or partial support for bonding, then provide information on enabling
|
||||||
bonding without support from the network initialization scripts (i.e.,
|
bonding without support from the network initialization scripts (i.e.,
|
||||||
older versions of initscripts or sysconfig).
|
older versions of initscripts or sysconfig).
|
||||||
|
|
||||||
If you're unsure whether your distro uses sysconfig or
|
If you're unsure whether your distro uses sysconfig,
|
||||||
initscripts, or don't know if it's new enough, have no fear.
|
initscripts or interfaces, or don't know if it's new enough, have no fear.
|
||||||
Determining this is fairly straightforward.
|
Determining this is fairly straightforward.
|
||||||
|
|
||||||
First, issue the command:
|
First, look for a file called interfaces in /etc/network directory.
|
||||||
|
If this file is present in your system, then your system use interfaces. See
|
||||||
|
Configuration with Interfaces Support.
|
||||||
|
|
||||||
|
Else, issue the command:
|
||||||
|
|
||||||
$ rpm -qf /sbin/ifup
|
$ rpm -qf /sbin/ifup
|
||||||
|
|
||||||
@ -1327,8 +1332,62 @@ echo 2000 > /sys/class/net/bond1/bonding/arp_interval
|
|||||||
echo +eth2 > /sys/class/net/bond1/bonding/slaves
|
echo +eth2 > /sys/class/net/bond1/bonding/slaves
|
||||||
echo +eth3 > /sys/class/net/bond1/bonding/slaves
|
echo +eth3 > /sys/class/net/bond1/bonding/slaves
|
||||||
|
|
||||||
3.5 Overriding Configuration for Special Cases
|
3.5 Configuration with Interfaces Support
|
||||||
|
-----------------------------------------
|
||||||
|
|
||||||
|
This section applies to distros which use /etc/network/interfaces file
|
||||||
|
to describe network interface configuration, most notably Debian and it's
|
||||||
|
derivatives.
|
||||||
|
|
||||||
|
The ifup and ifdown commands on Debian don't support bonding out of
|
||||||
|
the box. The ifenslave-2.6 package should be installed to provide bonding
|
||||||
|
support. Once installed, this package will provide bond-* options to be used
|
||||||
|
into /etc/network/interfaces.
|
||||||
|
|
||||||
|
Note that ifenslave-2.6 package will load the bonding module and use
|
||||||
|
the ifenslave command when appropriate.
|
||||||
|
|
||||||
|
Example Configurations
|
||||||
|
----------------------
|
||||||
|
|
||||||
|
In /etc/network/interfaces, the following stanza will configure bond0, in
|
||||||
|
active-backup mode, with eth0 and eth1 as slaves.
|
||||||
|
|
||||||
|
auto bond0
|
||||||
|
iface bond0 inet dhcp
|
||||||
|
bond-slaves eth0 eth1
|
||||||
|
bond-mode active-backup
|
||||||
|
bond-miimon 100
|
||||||
|
bond-primary eth0 eth1
|
||||||
|
|
||||||
|
If the above configuration doesn't work, you might have a system using
|
||||||
|
upstart for system startup. This is most notably true for recent
|
||||||
|
Ubuntu versions. The following stanza in /etc/network/interfaces will
|
||||||
|
produce the same result on those systems.
|
||||||
|
|
||||||
|
auto bond0
|
||||||
|
iface bond0 inet dhcp
|
||||||
|
bond-slaves none
|
||||||
|
bond-mode active-backup
|
||||||
|
bond-miimon 100
|
||||||
|
|
||||||
|
auto eth0
|
||||||
|
iface eth0 inet manual
|
||||||
|
bond-master bond0
|
||||||
|
bond-primary eth0 eth1
|
||||||
|
|
||||||
|
auto eth1
|
||||||
|
iface eth1 inet manual
|
||||||
|
bond-master bond0
|
||||||
|
bond-primary eth0 eth1
|
||||||
|
|
||||||
|
For a full list of bond-* supported options in /etc/network/interfaces and some
|
||||||
|
more advanced examples tailored to you particular distros, see the files in
|
||||||
|
/usr/share/doc/ifenslave-2.6.
|
||||||
|
|
||||||
|
3.6 Overriding Configuration for Special Cases
|
||||||
----------------------------------------------
|
----------------------------------------------
|
||||||
|
|
||||||
When using the bonding driver, the physical port which transmits a frame is
|
When using the bonding driver, the physical port which transmits a frame is
|
||||||
typically selected by the bonding driver, and is not relevant to the user or
|
typically selected by the bonding driver, and is not relevant to the user or
|
||||||
system administrator. The output port is simply selected using the policies of
|
system administrator. The output port is simply selected using the policies of
|
||||||
|
@ -187,7 +187,7 @@ tcp_cookie_size - INTEGER
|
|||||||
tcp_dsack - BOOLEAN
|
tcp_dsack - BOOLEAN
|
||||||
Allows TCP to send "duplicate" SACKs.
|
Allows TCP to send "duplicate" SACKs.
|
||||||
|
|
||||||
tcp_ecn - BOOLEAN
|
tcp_ecn - INTEGER
|
||||||
Enable Explicit Congestion Notification (ECN) in TCP. ECN is only
|
Enable Explicit Congestion Notification (ECN) in TCP. ECN is only
|
||||||
used when both ends of the TCP flow support it. It is useful to
|
used when both ends of the TCP flow support it. It is useful to
|
||||||
avoid losses due to congestion (when the bottleneck router supports
|
avoid losses due to congestion (when the bottleneck router supports
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
Version 15 of schedstats dropped counters for some sched_yield:
|
||||||
|
yld_exp_empty, yld_act_empty and yld_both_empty. Otherwise, it is
|
||||||
|
identical to version 14.
|
||||||
|
|
||||||
Version 14 of schedstats includes support for sched_domains, which hit the
|
Version 14 of schedstats includes support for sched_domains, which hit the
|
||||||
mainline kernel in 2.6.20 although it is identical to the stats from version
|
mainline kernel in 2.6.20 although it is identical to the stats from version
|
||||||
12 which was in the kernel from 2.6.13-2.6.19 (version 13 never saw a kernel
|
12 which was in the kernel from 2.6.13-2.6.19 (version 13 never saw a kernel
|
||||||
@ -28,32 +32,25 @@ to write their own scripts, the fields are described here.
|
|||||||
|
|
||||||
CPU statistics
|
CPU statistics
|
||||||
--------------
|
--------------
|
||||||
cpu<N> 1 2 3 4 5 6 7 8 9 10 11 12
|
cpu<N> 1 2 3 4 5 6 7 8 9
|
||||||
|
|
||||||
NOTE: In the sched_yield() statistics, the active queue is considered empty
|
First field is a sched_yield() statistic:
|
||||||
if it has only one process in it, since obviously the process calling
|
1) # of times sched_yield() was called
|
||||||
sched_yield() is that process.
|
|
||||||
|
|
||||||
First four fields are sched_yield() statistics:
|
|
||||||
1) # of times both the active and the expired queue were empty
|
|
||||||
2) # of times just the active queue was empty
|
|
||||||
3) # of times just the expired queue was empty
|
|
||||||
4) # of times sched_yield() was called
|
|
||||||
|
|
||||||
Next three are schedule() statistics:
|
Next three are schedule() statistics:
|
||||||
5) # of times we switched to the expired queue and reused it
|
2) # of times we switched to the expired queue and reused it
|
||||||
6) # of times schedule() was called
|
3) # of times schedule() was called
|
||||||
7) # of times schedule() left the processor idle
|
4) # of times schedule() left the processor idle
|
||||||
|
|
||||||
Next two are try_to_wake_up() statistics:
|
Next two are try_to_wake_up() statistics:
|
||||||
8) # of times try_to_wake_up() was called
|
5) # of times try_to_wake_up() was called
|
||||||
9) # of times try_to_wake_up() was called to wake up the local cpu
|
6) # of times try_to_wake_up() was called to wake up the local cpu
|
||||||
|
|
||||||
Next three are statistics describing scheduling latency:
|
Next three are statistics describing scheduling latency:
|
||||||
10) sum of all time spent running by tasks on this processor (in jiffies)
|
7) sum of all time spent running by tasks on this processor (in jiffies)
|
||||||
11) sum of all time spent waiting to run by tasks on this processor (in
|
8) sum of all time spent waiting to run by tasks on this processor (in
|
||||||
jiffies)
|
jiffies)
|
||||||
12) # of timeslices run on this cpu
|
9) # of timeslices run on this cpu
|
||||||
|
|
||||||
|
|
||||||
Domain statistics
|
Domain statistics
|
||||||
|
68
MAINTAINERS
68
MAINTAINERS
@ -978,6 +978,8 @@ S: Maintained
|
|||||||
F: arch/arm/plat-samsung/
|
F: arch/arm/plat-samsung/
|
||||||
F: arch/arm/plat-s3c24xx/
|
F: arch/arm/plat-s3c24xx/
|
||||||
F: arch/arm/plat-s5p/
|
F: arch/arm/plat-s5p/
|
||||||
|
F: drivers/*/*s3c2410*
|
||||||
|
F: drivers/*/*/*s3c2410*
|
||||||
|
|
||||||
ARM/S3C2410 ARM ARCHITECTURE
|
ARM/S3C2410 ARM ARCHITECTURE
|
||||||
M: Ben Dooks <ben-linux@fluff.org>
|
M: Ben Dooks <ben-linux@fluff.org>
|
||||||
@ -3139,6 +3141,12 @@ S: Maintained
|
|||||||
F: net/ieee802154/
|
F: net/ieee802154/
|
||||||
F: drivers/ieee802154/
|
F: drivers/ieee802154/
|
||||||
|
|
||||||
|
IKANOS/ADI EAGLE ADSL USB DRIVER
|
||||||
|
M: Matthieu Castet <castet.matthieu@free.fr>
|
||||||
|
M: Stanislaw Gruszka <stf_xl@wp.pl>
|
||||||
|
S: Maintained
|
||||||
|
F: drivers/usb/atm/ueagle-atm.c
|
||||||
|
|
||||||
INTEGRITY MEASUREMENT ARCHITECTURE (IMA)
|
INTEGRITY MEASUREMENT ARCHITECTURE (IMA)
|
||||||
M: Mimi Zohar <zohar@us.ibm.com>
|
M: Mimi Zohar <zohar@us.ibm.com>
|
||||||
S: Supported
|
S: Supported
|
||||||
@ -3327,7 +3335,6 @@ F: drivers/net/wimax/i2400m/
|
|||||||
F: include/linux/wimax/i2400m.h
|
F: include/linux/wimax/i2400m.h
|
||||||
|
|
||||||
INTEL WIRELESS WIFI LINK (iwlwifi)
|
INTEL WIRELESS WIFI LINK (iwlwifi)
|
||||||
M: Reinette Chatre <reinette.chatre@intel.com>
|
|
||||||
M: Wey-Yi Guy <wey-yi.w.guy@intel.com>
|
M: Wey-Yi Guy <wey-yi.w.guy@intel.com>
|
||||||
M: Intel Linux Wireless <ilw@linux.intel.com>
|
M: Intel Linux Wireless <ilw@linux.intel.com>
|
||||||
L: linux-wireless@vger.kernel.org
|
L: linux-wireless@vger.kernel.org
|
||||||
@ -3674,6 +3681,28 @@ F: include/linux/key-type.h
|
|||||||
F: include/keys/
|
F: include/keys/
|
||||||
F: security/keys/
|
F: security/keys/
|
||||||
|
|
||||||
|
KEYS-TRUSTED
|
||||||
|
M: David Safford <safford@watson.ibm.com>
|
||||||
|
M: Mimi Zohar <zohar@us.ibm.com>
|
||||||
|
L: linux-security-module@vger.kernel.org
|
||||||
|
L: keyrings@linux-nfs.org
|
||||||
|
S: Supported
|
||||||
|
F: Documentation/keys-trusted-encrypted.txt
|
||||||
|
F: include/keys/trusted-type.h
|
||||||
|
F: security/keys/trusted.c
|
||||||
|
F: security/keys/trusted.h
|
||||||
|
|
||||||
|
KEYS-ENCRYPTED
|
||||||
|
M: Mimi Zohar <zohar@us.ibm.com>
|
||||||
|
M: David Safford <safford@watson.ibm.com>
|
||||||
|
L: linux-security-module@vger.kernel.org
|
||||||
|
L: keyrings@linux-nfs.org
|
||||||
|
S: Supported
|
||||||
|
F: Documentation/keys-trusted-encrypted.txt
|
||||||
|
F: include/keys/encrypted-type.h
|
||||||
|
F: security/keys/encrypted.c
|
||||||
|
F: security/keys/encrypted.h
|
||||||
|
|
||||||
KGDB / KDB /debug_core
|
KGDB / KDB /debug_core
|
||||||
M: Jason Wessel <jason.wessel@windriver.com>
|
M: Jason Wessel <jason.wessel@windriver.com>
|
||||||
W: http://kgdb.wiki.kernel.org/
|
W: http://kgdb.wiki.kernel.org/
|
||||||
@ -5522,12 +5551,11 @@ S: Supported
|
|||||||
F: drivers/scsi/be2iscsi/
|
F: drivers/scsi/be2iscsi/
|
||||||
|
|
||||||
SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER
|
SERVER ENGINES 10Gbps NIC - BladeEngine 2 DRIVER
|
||||||
M: Sathya Perla <sathyap@serverengines.com>
|
M: Sathya Perla <sathya.perla@emulex.com>
|
||||||
M: Subbu Seetharaman <subbus@serverengines.com>
|
M: Subbu Seetharaman <subbu.seetharaman@emulex.com>
|
||||||
M: Sarveshwar Bandi <sarveshwarb@serverengines.com>
|
M: Ajit Khaparde <ajit.khaparde@emulex.com>
|
||||||
M: Ajit Khaparde <ajitk@serverengines.com>
|
|
||||||
L: netdev@vger.kernel.org
|
L: netdev@vger.kernel.org
|
||||||
W: http://www.serverengines.com
|
W: http://www.emulex.com
|
||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/net/benet/
|
F: drivers/net/benet/
|
||||||
|
|
||||||
@ -5587,18 +5615,20 @@ F: include/linux/sfi*.h
|
|||||||
|
|
||||||
SIMTEC EB110ATX (Chalice CATS)
|
SIMTEC EB110ATX (Chalice CATS)
|
||||||
P: Ben Dooks
|
P: Ben Dooks
|
||||||
M: Vincent Sanders <support@simtec.co.uk>
|
P: Vincent Sanders <vince@simtec.co.uk>
|
||||||
|
M: Simtec Linux Team <linux@simtec.co.uk>
|
||||||
W: http://www.simtec.co.uk/products/EB110ATX/
|
W: http://www.simtec.co.uk/products/EB110ATX/
|
||||||
S: Supported
|
S: Supported
|
||||||
|
|
||||||
SIMTEC EB2410ITX (BAST)
|
SIMTEC EB2410ITX (BAST)
|
||||||
P: Ben Dooks
|
P: Ben Dooks
|
||||||
M: Vincent Sanders <support@simtec.co.uk>
|
P: Vincent Sanders <vince@simtec.co.uk>
|
||||||
|
M: Simtec Linux Team <linux@simtec.co.uk>
|
||||||
W: http://www.simtec.co.uk/products/EB2410ITX/
|
W: http://www.simtec.co.uk/products/EB2410ITX/
|
||||||
S: Supported
|
S: Supported
|
||||||
F: arch/arm/mach-s3c2410/
|
F: arch/arm/mach-s3c2410/mach-bast.c
|
||||||
F: drivers/*/*s3c2410*
|
F: arch/arm/mach-s3c2410/bast-ide.c
|
||||||
F: drivers/*/*/*s3c2410*
|
F: arch/arm/mach-s3c2410/bast-irq.c
|
||||||
|
|
||||||
TI DAVINCI MACHINE SUPPORT
|
TI DAVINCI MACHINE SUPPORT
|
||||||
M: Kevin Hilman <khilman@deeprootsystems.com>
|
M: Kevin Hilman <khilman@deeprootsystems.com>
|
||||||
@ -6573,6 +6603,16 @@ S: Maintained
|
|||||||
F: drivers/char/virtio_console.c
|
F: drivers/char/virtio_console.c
|
||||||
F: include/linux/virtio_console.h
|
F: include/linux/virtio_console.h
|
||||||
|
|
||||||
|
VIRTIO CORE, NET AND BLOCK DRIVERS
|
||||||
|
M: Rusty Russell <rusty@rustcorp.com.au>
|
||||||
|
M: "Michael S. Tsirkin" <mst@redhat.com>
|
||||||
|
L: virtualization@lists.linux-foundation.org
|
||||||
|
S: Maintained
|
||||||
|
F: drivers/virtio/
|
||||||
|
F: drivers/net/virtio_net.c
|
||||||
|
F: drivers/block/virtio_blk.c
|
||||||
|
F: include/linux/virtio_*.h
|
||||||
|
|
||||||
VIRTIO HOST (VHOST)
|
VIRTIO HOST (VHOST)
|
||||||
M: "Michael S. Tsirkin" <mst@redhat.com>
|
M: "Michael S. Tsirkin" <mst@redhat.com>
|
||||||
L: kvm@vger.kernel.org
|
L: kvm@vger.kernel.org
|
||||||
@ -6746,12 +6786,12 @@ S: Maintained
|
|||||||
F: drivers/net/wireless/wl1251/*
|
F: drivers/net/wireless/wl1251/*
|
||||||
|
|
||||||
WL1271 WIRELESS DRIVER
|
WL1271 WIRELESS DRIVER
|
||||||
M: Luciano Coelho <luciano.coelho@nokia.com>
|
M: Luciano Coelho <coelho@ti.com>
|
||||||
L: linux-wireless@vger.kernel.org
|
L: linux-wireless@vger.kernel.org
|
||||||
W: http://wireless.kernel.org
|
W: http://wireless.kernel.org/en/users/Drivers/wl12xx
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/luca/wl12xx.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/luca/wl12xx.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/net/wireless/wl12xx/wl1271*
|
F: drivers/net/wireless/wl12xx/
|
||||||
F: include/linux/wl12xx.h
|
F: include/linux/wl12xx.h
|
||||||
|
|
||||||
WL3501 WIRELESS PCMCIA CARD DRIVER
|
WL3501 WIRELESS PCMCIA CARD DRIVER
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
VERSION = 2
|
VERSION = 2
|
||||||
PATCHLEVEL = 6
|
PATCHLEVEL = 6
|
||||||
SUBLEVEL = 38
|
SUBLEVEL = 38
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc3
|
||||||
NAME = Flesh-Eating Bats with Fangs
|
NAME = Flesh-Eating Bats with Fangs
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -50,6 +50,12 @@
|
|||||||
#define SCPCELLID2 0xFF8
|
#define SCPCELLID2 0xFF8
|
||||||
#define SCPCELLID3 0xFFC
|
#define SCPCELLID3 0xFFC
|
||||||
|
|
||||||
|
#define SCCTRL_TIMEREN0SEL_REFCLK (0 << 15)
|
||||||
|
#define SCCTRL_TIMEREN0SEL_TIMCLK (1 << 15)
|
||||||
|
|
||||||
|
#define SCCTRL_TIMEREN1SEL_REFCLK (0 << 17)
|
||||||
|
#define SCCTRL_TIMEREN1SEL_TIMCLK (1 << 17)
|
||||||
|
|
||||||
static inline void sysctl_soft_reset(void __iomem *base)
|
static inline void sysctl_soft_reset(void __iomem *base)
|
||||||
{
|
{
|
||||||
/* writing any value to SCSYSSTAT reg will reset system */
|
/* writing any value to SCSYSSTAT reg will reset system */
|
||||||
|
@ -95,6 +95,15 @@ static inline void __iomem *__typesafe_io(unsigned long addr)
|
|||||||
return (void __iomem *)addr;
|
return (void __iomem *)addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* IO barriers */
|
||||||
|
#ifdef CONFIG_ARM_DMA_MEM_BUFFERABLE
|
||||||
|
#define __iormb() rmb()
|
||||||
|
#define __iowmb() wmb()
|
||||||
|
#else
|
||||||
|
#define __iormb() do { } while (0)
|
||||||
|
#define __iowmb() do { } while (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Now, pick up the machine-defined IO definitions
|
* Now, pick up the machine-defined IO definitions
|
||||||
*/
|
*/
|
||||||
@ -125,17 +134,17 @@ static inline void __iomem *__typesafe_io(unsigned long addr)
|
|||||||
* The {in,out}[bwl] macros are for emulating x86-style PCI/ISA IO space.
|
* The {in,out}[bwl] macros are for emulating x86-style PCI/ISA IO space.
|
||||||
*/
|
*/
|
||||||
#ifdef __io
|
#ifdef __io
|
||||||
#define outb(v,p) __raw_writeb(v,__io(p))
|
#define outb(v,p) ({ __iowmb(); __raw_writeb(v,__io(p)); })
|
||||||
#define outw(v,p) __raw_writew((__force __u16) \
|
#define outw(v,p) ({ __iowmb(); __raw_writew((__force __u16) \
|
||||||
cpu_to_le16(v),__io(p))
|
cpu_to_le16(v),__io(p)); })
|
||||||
#define outl(v,p) __raw_writel((__force __u32) \
|
#define outl(v,p) ({ __iowmb(); __raw_writel((__force __u32) \
|
||||||
cpu_to_le32(v),__io(p))
|
cpu_to_le32(v),__io(p)); })
|
||||||
|
|
||||||
#define inb(p) ({ __u8 __v = __raw_readb(__io(p)); __v; })
|
#define inb(p) ({ __u8 __v = __raw_readb(__io(p)); __iormb(); __v; })
|
||||||
#define inw(p) ({ __u16 __v = le16_to_cpu((__force __le16) \
|
#define inw(p) ({ __u16 __v = le16_to_cpu((__force __le16) \
|
||||||
__raw_readw(__io(p))); __v; })
|
__raw_readw(__io(p))); __iormb(); __v; })
|
||||||
#define inl(p) ({ __u32 __v = le32_to_cpu((__force __le32) \
|
#define inl(p) ({ __u32 __v = le32_to_cpu((__force __le32) \
|
||||||
__raw_readl(__io(p))); __v; })
|
__raw_readl(__io(p))); __iormb(); __v; })
|
||||||
|
|
||||||
#define outsb(p,d,l) __raw_writesb(__io(p),d,l)
|
#define outsb(p,d,l) __raw_writesb(__io(p),d,l)
|
||||||
#define outsw(p,d,l) __raw_writesw(__io(p),d,l)
|
#define outsw(p,d,l) __raw_writesw(__io(p),d,l)
|
||||||
@ -192,14 +201,6 @@ extern void _memset_io(volatile void __iomem *, int, size_t);
|
|||||||
#define writel_relaxed(v,c) ((void)__raw_writel((__force u32) \
|
#define writel_relaxed(v,c) ((void)__raw_writel((__force u32) \
|
||||||
cpu_to_le32(v),__mem_pci(c)))
|
cpu_to_le32(v),__mem_pci(c)))
|
||||||
|
|
||||||
#ifdef CONFIG_ARM_DMA_MEM_BUFFERABLE
|
|
||||||
#define __iormb() rmb()
|
|
||||||
#define __iowmb() wmb()
|
|
||||||
#else
|
|
||||||
#define __iormb() do { } while (0)
|
|
||||||
#define __iowmb() do { } while (0)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define readb(c) ({ u8 __v = readb_relaxed(c); __iormb(); __v; })
|
#define readb(c) ({ u8 __v = readb_relaxed(c); __iormb(); __v; })
|
||||||
#define readw(c) ({ u16 __v = readw_relaxed(c); __iormb(); __v; })
|
#define readw(c) ({ u16 __v = readw_relaxed(c); __iormb(); __v; })
|
||||||
#define readl(c) ({ u32 __v = readl_relaxed(c); __iormb(); __v; })
|
#define readl(c) ({ u32 __v = readl_relaxed(c); __iormb(); __v; })
|
||||||
|
@ -188,7 +188,7 @@
|
|||||||
* translation for translating DMA addresses. Use the driver
|
* translation for translating DMA addresses. Use the driver
|
||||||
* DMA support - see dma-mapping.h.
|
* DMA support - see dma-mapping.h.
|
||||||
*/
|
*/
|
||||||
static inline unsigned long virt_to_phys(void *x)
|
static inline unsigned long virt_to_phys(const volatile void *x)
|
||||||
{
|
{
|
||||||
return __virt_to_phys((unsigned long)(x));
|
return __virt_to_phys((unsigned long)(x));
|
||||||
}
|
}
|
||||||
|
@ -392,24 +392,22 @@ ENDPROC(__turn_mmu_on)
|
|||||||
|
|
||||||
#ifdef CONFIG_SMP_ON_UP
|
#ifdef CONFIG_SMP_ON_UP
|
||||||
__fixup_smp:
|
__fixup_smp:
|
||||||
mov r4, #0x00070000
|
and r3, r9, #0x000f0000 @ architecture version
|
||||||
orr r3, r4, #0xff000000 @ mask 0xff070000
|
teq r3, #0x000f0000 @ CPU ID supported?
|
||||||
orr r4, r4, #0x41000000 @ val 0x41070000
|
|
||||||
and r0, r9, r3
|
|
||||||
teq r0, r4 @ ARM CPU and ARMv6/v7?
|
|
||||||
bne __fixup_smp_on_up @ no, assume UP
|
bne __fixup_smp_on_up @ no, assume UP
|
||||||
|
|
||||||
orr r3, r3, #0x0000ff00
|
bic r3, r9, #0x00ff0000
|
||||||
orr r3, r3, #0x000000f0 @ mask 0xff07fff0
|
bic r3, r3, #0x0000000f @ mask 0xff00fff0
|
||||||
|
mov r4, #0x41000000
|
||||||
orr r4, r4, #0x0000b000
|
orr r4, r4, #0x0000b000
|
||||||
orr r4, r4, #0x00000020 @ val 0x4107b020
|
orr r4, r4, #0x00000020 @ val 0x4100b020
|
||||||
and r0, r9, r3
|
teq r3, r4 @ ARM 11MPCore?
|
||||||
teq r0, r4 @ ARM 11MPCore?
|
|
||||||
moveq pc, lr @ yes, assume SMP
|
moveq pc, lr @ yes, assume SMP
|
||||||
|
|
||||||
mrc p15, 0, r0, c0, c0, 5 @ read MPIDR
|
mrc p15, 0, r0, c0, c0, 5 @ read MPIDR
|
||||||
tst r0, #1 << 31
|
and r0, r0, #0xc0000000 @ multiprocessing extensions and
|
||||||
movne pc, lr @ bit 31 => SMP
|
teq r0, #0x80000000 @ not part of a uniprocessor system?
|
||||||
|
moveq pc, lr @ yes, assume SMP
|
||||||
|
|
||||||
__fixup_smp_on_up:
|
__fixup_smp_on_up:
|
||||||
adr r0, 1f
|
adr r0, 1f
|
||||||
|
@ -36,6 +36,7 @@ static void twd_set_mode(enum clock_event_mode mode,
|
|||||||
/* timer load already set up */
|
/* timer load already set up */
|
||||||
ctrl = TWD_TIMER_CONTROL_ENABLE | TWD_TIMER_CONTROL_IT_ENABLE
|
ctrl = TWD_TIMER_CONTROL_ENABLE | TWD_TIMER_CONTROL_IT_ENABLE
|
||||||
| TWD_TIMER_CONTROL_PERIODIC;
|
| TWD_TIMER_CONTROL_PERIODIC;
|
||||||
|
__raw_writel(twd_timer_rate / HZ, twd_base + TWD_TIMER_LOAD);
|
||||||
break;
|
break;
|
||||||
case CLOCK_EVT_MODE_ONESHOT:
|
case CLOCK_EVT_MODE_ONESHOT:
|
||||||
/* period set, and timer enabled in 'next_event' hook */
|
/* period set, and timer enabled in 'next_event' hook */
|
||||||
@ -81,7 +82,7 @@ int twd_timer_ack(void)
|
|||||||
|
|
||||||
static void __cpuinit twd_calibrate_rate(void)
|
static void __cpuinit twd_calibrate_rate(void)
|
||||||
{
|
{
|
||||||
unsigned long load, count;
|
unsigned long count;
|
||||||
u64 waitjiffies;
|
u64 waitjiffies;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -116,10 +117,6 @@ static void __cpuinit twd_calibrate_rate(void)
|
|||||||
printk("%lu.%02luMHz.\n", twd_timer_rate / 1000000,
|
printk("%lu.%02luMHz.\n", twd_timer_rate / 1000000,
|
||||||
(twd_timer_rate / 1000000) % 100);
|
(twd_timer_rate / 1000000) % 100);
|
||||||
}
|
}
|
||||||
|
|
||||||
load = twd_timer_rate / HZ;
|
|
||||||
|
|
||||||
__raw_writel(load, twd_base + TWD_TIMER_LOAD);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -427,6 +427,13 @@ void __init ep93xx_gpio_init(void)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
/* Set Ports C, D, E, G, and H for GPIO use */
|
||||||
|
ep93xx_devcfg_set_bits(EP93XX_SYSCON_DEVCFG_KEYS |
|
||||||
|
EP93XX_SYSCON_DEVCFG_GONK |
|
||||||
|
EP93XX_SYSCON_DEVCFG_EONIDE |
|
||||||
|
EP93XX_SYSCON_DEVCFG_GONIDE |
|
||||||
|
EP93XX_SYSCON_DEVCFG_HONIDE);
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(ep93xx_gpio_banks); i++)
|
for (i = 0; i < ARRAY_SIZE(ep93xx_gpio_banks); i++)
|
||||||
gpiochip_add(&ep93xx_gpio_banks[i].chip);
|
gpiochip_add(&ep93xx_gpio_banks[i].chip);
|
||||||
}
|
}
|
||||||
|
@ -17,8 +17,8 @@
|
|||||||
/* For NetWinder debugging */
|
/* For NetWinder debugging */
|
||||||
.macro addruart, rp, rv
|
.macro addruart, rp, rv
|
||||||
mov \rp, #0x000003f8
|
mov \rp, #0x000003f8
|
||||||
orr \rv, \rp, #0x7c000000 @ physical
|
orr \rv, \rp, #0xff000000 @ virtual
|
||||||
orr \rp, \rp, #0xff000000 @ virtual
|
orr \rp, \rp, #0x7c000000 @ physical
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
#define UART_SHIFT 0
|
#define UART_SHIFT 0
|
||||||
|
@ -9,6 +9,7 @@ config ARCH_OMAP730
|
|||||||
depends on ARCH_OMAP1
|
depends on ARCH_OMAP1
|
||||||
bool "OMAP730 Based System"
|
bool "OMAP730 Based System"
|
||||||
select CPU_ARM926T
|
select CPU_ARM926T
|
||||||
|
select OMAP_MPU_TIMER
|
||||||
select ARCH_OMAP_OTG
|
select ARCH_OMAP_OTG
|
||||||
|
|
||||||
config ARCH_OMAP850
|
config ARCH_OMAP850
|
||||||
@ -22,6 +23,7 @@ config ARCH_OMAP15XX
|
|||||||
default y
|
default y
|
||||||
bool "OMAP15xx Based System"
|
bool "OMAP15xx Based System"
|
||||||
select CPU_ARM925T
|
select CPU_ARM925T
|
||||||
|
select OMAP_MPU_TIMER
|
||||||
|
|
||||||
config ARCH_OMAP16XX
|
config ARCH_OMAP16XX
|
||||||
depends on ARCH_OMAP1
|
depends on ARCH_OMAP1
|
||||||
|
@ -3,12 +3,11 @@
|
|||||||
#
|
#
|
||||||
|
|
||||||
# Common support
|
# Common support
|
||||||
obj-y := io.o id.o sram.o irq.o mux.o flash.o serial.o devices.o dma.o
|
obj-y := io.o id.o sram.o time.o irq.o mux.o flash.o serial.o devices.o dma.o
|
||||||
obj-y += clock.o clock_data.o opp_data.o
|
obj-y += clock.o clock_data.o opp_data.o
|
||||||
|
|
||||||
obj-$(CONFIG_OMAP_MCBSP) += mcbsp.o
|
obj-$(CONFIG_OMAP_MCBSP) += mcbsp.o
|
||||||
|
|
||||||
obj-$(CONFIG_OMAP_MPU_TIMER) += time.o
|
|
||||||
obj-$(CONFIG_OMAP_32K_TIMER) += timer32k.o
|
obj-$(CONFIG_OMAP_32K_TIMER) += timer32k.o
|
||||||
|
|
||||||
# Power Management
|
# Power Management
|
||||||
|
@ -14,19 +14,6 @@
|
|||||||
#include <mach/irqs.h>
|
#include <mach/irqs.h>
|
||||||
#include <asm/hardware/gic.h>
|
#include <asm/hardware/gic.h>
|
||||||
|
|
||||||
/*
|
|
||||||
* We use __glue to avoid errors with multiple definitions of
|
|
||||||
* .globl omap_irq_flags as it's included from entry-armv.S but not
|
|
||||||
* from entry-common.S.
|
|
||||||
*/
|
|
||||||
#ifdef __glue
|
|
||||||
.pushsection .data
|
|
||||||
.globl omap_irq_flags
|
|
||||||
omap_irq_flags:
|
|
||||||
.word 0
|
|
||||||
.popsection
|
|
||||||
#endif
|
|
||||||
|
|
||||||
.macro disable_fiq
|
.macro disable_fiq
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
@ -57,6 +57,7 @@ struct omap_irq_bank {
|
|||||||
unsigned long wake_enable;
|
unsigned long wake_enable;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
u32 omap_irq_flags;
|
||||||
static unsigned int irq_bank_count;
|
static unsigned int irq_bank_count;
|
||||||
static struct omap_irq_bank *irq_banks;
|
static struct omap_irq_bank *irq_banks;
|
||||||
|
|
||||||
@ -176,7 +177,6 @@ static struct irq_chip omap_irq_chip = {
|
|||||||
|
|
||||||
void __init omap_init_irq(void)
|
void __init omap_init_irq(void)
|
||||||
{
|
{
|
||||||
extern unsigned int omap_irq_flags;
|
|
||||||
int i, j;
|
int i, j;
|
||||||
|
|
||||||
#if defined(CONFIG_ARCH_OMAP730) || defined(CONFIG_ARCH_OMAP850)
|
#if defined(CONFIG_ARCH_OMAP730) || defined(CONFIG_ARCH_OMAP850)
|
||||||
|
@ -44,16 +44,21 @@
|
|||||||
#include <linux/clocksource.h>
|
#include <linux/clocksource.h>
|
||||||
#include <linux/clockchips.h>
|
#include <linux/clockchips.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
|
#include <linux/sched.h>
|
||||||
|
|
||||||
#include <asm/system.h>
|
#include <asm/system.h>
|
||||||
#include <mach/hardware.h>
|
#include <mach/hardware.h>
|
||||||
#include <asm/leds.h>
|
#include <asm/leds.h>
|
||||||
#include <asm/irq.h>
|
#include <asm/irq.h>
|
||||||
|
#include <asm/sched_clock.h>
|
||||||
|
|
||||||
#include <asm/mach/irq.h>
|
#include <asm/mach/irq.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
|
|
||||||
#include <plat/common.h>
|
#include <plat/common.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_OMAP_MPU_TIMER
|
||||||
|
|
||||||
#define OMAP_MPU_TIMER_BASE OMAP_MPU_TIMER1_BASE
|
#define OMAP_MPU_TIMER_BASE OMAP_MPU_TIMER1_BASE
|
||||||
#define OMAP_MPU_TIMER_OFFSET 0x100
|
#define OMAP_MPU_TIMER_OFFSET 0x100
|
||||||
|
|
||||||
@ -67,7 +72,7 @@ typedef struct {
|
|||||||
((volatile omap_mpu_timer_regs_t*)OMAP1_IO_ADDRESS(OMAP_MPU_TIMER_BASE + \
|
((volatile omap_mpu_timer_regs_t*)OMAP1_IO_ADDRESS(OMAP_MPU_TIMER_BASE + \
|
||||||
(n)*OMAP_MPU_TIMER_OFFSET))
|
(n)*OMAP_MPU_TIMER_OFFSET))
|
||||||
|
|
||||||
static inline unsigned long omap_mpu_timer_read(int nr)
|
static inline unsigned long notrace omap_mpu_timer_read(int nr)
|
||||||
{
|
{
|
||||||
volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr);
|
volatile omap_mpu_timer_regs_t* timer = omap_mpu_timer_base(nr);
|
||||||
return timer->read_tim;
|
return timer->read_tim;
|
||||||
@ -212,6 +217,32 @@ static struct clocksource clocksource_mpu = {
|
|||||||
.flags = CLOCK_SOURCE_IS_CONTINUOUS,
|
.flags = CLOCK_SOURCE_IS_CONTINUOUS,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static DEFINE_CLOCK_DATA(cd);
|
||||||
|
|
||||||
|
static inline unsigned long long notrace _omap_mpu_sched_clock(void)
|
||||||
|
{
|
||||||
|
u32 cyc = mpu_read(&clocksource_mpu);
|
||||||
|
return cyc_to_sched_clock(&cd, cyc, (u32)~0);
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifndef CONFIG_OMAP_32K_TIMER
|
||||||
|
unsigned long long notrace sched_clock(void)
|
||||||
|
{
|
||||||
|
return _omap_mpu_sched_clock();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static unsigned long long notrace omap_mpu_sched_clock(void)
|
||||||
|
{
|
||||||
|
return _omap_mpu_sched_clock();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static void notrace mpu_update_sched_clock(void)
|
||||||
|
{
|
||||||
|
u32 cyc = mpu_read(&clocksource_mpu);
|
||||||
|
update_sched_clock(&cd, cyc, (u32)~0);
|
||||||
|
}
|
||||||
|
|
||||||
static void __init omap_init_clocksource(unsigned long rate)
|
static void __init omap_init_clocksource(unsigned long rate)
|
||||||
{
|
{
|
||||||
static char err[] __initdata = KERN_ERR
|
static char err[] __initdata = KERN_ERR
|
||||||
@ -219,17 +250,13 @@ static void __init omap_init_clocksource(unsigned long rate)
|
|||||||
|
|
||||||
setup_irq(INT_TIMER2, &omap_mpu_timer2_irq);
|
setup_irq(INT_TIMER2, &omap_mpu_timer2_irq);
|
||||||
omap_mpu_timer_start(1, ~0, 1);
|
omap_mpu_timer_start(1, ~0, 1);
|
||||||
|
init_sched_clock(&cd, mpu_update_sched_clock, 32, rate);
|
||||||
|
|
||||||
if (clocksource_register_hz(&clocksource_mpu, rate))
|
if (clocksource_register_hz(&clocksource_mpu, rate))
|
||||||
printk(err, clocksource_mpu.name);
|
printk(err, clocksource_mpu.name);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
static void __init omap_mpu_timer_init(void)
|
||||||
* ---------------------------------------------------------------------------
|
|
||||||
* Timer initialization
|
|
||||||
* ---------------------------------------------------------------------------
|
|
||||||
*/
|
|
||||||
static void __init omap_timer_init(void)
|
|
||||||
{
|
{
|
||||||
struct clk *ck_ref = clk_get(NULL, "ck_ref");
|
struct clk *ck_ref = clk_get(NULL, "ck_ref");
|
||||||
unsigned long rate;
|
unsigned long rate;
|
||||||
@ -246,6 +273,66 @@ static void __init omap_timer_init(void)
|
|||||||
omap_init_clocksource(rate);
|
omap_init_clocksource(rate);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
static inline void omap_mpu_timer_init(void)
|
||||||
|
{
|
||||||
|
pr_err("Bogus timer, should not happen\n");
|
||||||
|
}
|
||||||
|
#endif /* CONFIG_OMAP_MPU_TIMER */
|
||||||
|
|
||||||
|
#if defined(CONFIG_OMAP_MPU_TIMER) && defined(CONFIG_OMAP_32K_TIMER)
|
||||||
|
static unsigned long long (*preferred_sched_clock)(void);
|
||||||
|
|
||||||
|
unsigned long long notrace sched_clock(void)
|
||||||
|
{
|
||||||
|
if (!preferred_sched_clock)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return preferred_sched_clock();
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void preferred_sched_clock_init(bool use_32k_sched_clock)
|
||||||
|
{
|
||||||
|
if (use_32k_sched_clock)
|
||||||
|
preferred_sched_clock = omap_32k_sched_clock;
|
||||||
|
else
|
||||||
|
preferred_sched_clock = omap_mpu_sched_clock;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static inline void preferred_sched_clock_init(bool use_32k_sched_clcok)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static inline int omap_32k_timer_usable(void)
|
||||||
|
{
|
||||||
|
int res = false;
|
||||||
|
|
||||||
|
if (cpu_is_omap730() || cpu_is_omap15xx())
|
||||||
|
return res;
|
||||||
|
|
||||||
|
#ifdef CONFIG_OMAP_32K_TIMER
|
||||||
|
res = omap_32k_timer_init();
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ---------------------------------------------------------------------------
|
||||||
|
* Timer initialization
|
||||||
|
* ---------------------------------------------------------------------------
|
||||||
|
*/
|
||||||
|
static void __init omap_timer_init(void)
|
||||||
|
{
|
||||||
|
if (omap_32k_timer_usable()) {
|
||||||
|
preferred_sched_clock_init(1);
|
||||||
|
} else {
|
||||||
|
omap_mpu_timer_init();
|
||||||
|
preferred_sched_clock_init(0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
struct sys_timer omap_timer = {
|
struct sys_timer omap_timer = {
|
||||||
.init = omap_timer_init,
|
.init = omap_timer_init,
|
||||||
};
|
};
|
||||||
|
@ -52,10 +52,9 @@
|
|||||||
#include <asm/irq.h>
|
#include <asm/irq.h>
|
||||||
#include <asm/mach/irq.h>
|
#include <asm/mach/irq.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
|
#include <plat/common.h>
|
||||||
#include <plat/dmtimer.h>
|
#include <plat/dmtimer.h>
|
||||||
|
|
||||||
struct sys_timer omap_timer;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* ---------------------------------------------------------------------------
|
* ---------------------------------------------------------------------------
|
||||||
* 32KHz OS timer
|
* 32KHz OS timer
|
||||||
@ -181,14 +180,14 @@ static __init void omap_init_32k_timer(void)
|
|||||||
* Timer initialization
|
* Timer initialization
|
||||||
* ---------------------------------------------------------------------------
|
* ---------------------------------------------------------------------------
|
||||||
*/
|
*/
|
||||||
static void __init omap_timer_init(void)
|
bool __init omap_32k_timer_init(void)
|
||||||
{
|
{
|
||||||
|
omap_init_clocksource_32k();
|
||||||
|
|
||||||
#ifdef CONFIG_OMAP_DM_TIMER
|
#ifdef CONFIG_OMAP_DM_TIMER
|
||||||
omap_dm_timer_init();
|
omap_dm_timer_init();
|
||||||
#endif
|
#endif
|
||||||
omap_init_32k_timer();
|
omap_init_32k_timer();
|
||||||
}
|
|
||||||
|
|
||||||
struct sys_timer omap_timer = {
|
return true;
|
||||||
.init = omap_timer_init,
|
}
|
||||||
};
|
|
||||||
|
@ -124,8 +124,9 @@ static inline void cm_t3517_init_hecc(void) {}
|
|||||||
#if defined(CONFIG_RTC_DRV_V3020) || defined(CONFIG_RTC_DRV_V3020_MODULE)
|
#if defined(CONFIG_RTC_DRV_V3020) || defined(CONFIG_RTC_DRV_V3020_MODULE)
|
||||||
#define RTC_IO_GPIO (153)
|
#define RTC_IO_GPIO (153)
|
||||||
#define RTC_WR_GPIO (154)
|
#define RTC_WR_GPIO (154)
|
||||||
#define RTC_RD_GPIO (160)
|
#define RTC_RD_GPIO (53)
|
||||||
#define RTC_CS_GPIO (163)
|
#define RTC_CS_GPIO (163)
|
||||||
|
#define RTC_CS_EN_GPIO (160)
|
||||||
|
|
||||||
struct v3020_platform_data cm_t3517_v3020_pdata = {
|
struct v3020_platform_data cm_t3517_v3020_pdata = {
|
||||||
.use_gpio = 1,
|
.use_gpio = 1,
|
||||||
@ -145,6 +146,16 @@ static struct platform_device cm_t3517_rtc_device = {
|
|||||||
|
|
||||||
static void __init cm_t3517_init_rtc(void)
|
static void __init cm_t3517_init_rtc(void)
|
||||||
{
|
{
|
||||||
|
int err;
|
||||||
|
|
||||||
|
err = gpio_request(RTC_CS_EN_GPIO, "rtc cs en");
|
||||||
|
if (err) {
|
||||||
|
pr_err("CM-T3517: rtc cs en gpio request failed: %d\n", err);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
gpio_direction_output(RTC_CS_EN_GPIO, 1);
|
||||||
|
|
||||||
platform_device_register(&cm_t3517_rtc_device);
|
platform_device_register(&cm_t3517_rtc_device);
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
@ -214,12 +225,12 @@ static struct mtd_partition cm_t3517_nand_partitions[] = {
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
.name = "linux",
|
.name = "linux",
|
||||||
.offset = MTDPART_OFS_APPEND, /* Offset = 0x280000 */
|
.offset = MTDPART_OFS_APPEND, /* Offset = 0x2A0000 */
|
||||||
.size = 32 * NAND_BLOCK_SIZE,
|
.size = 32 * NAND_BLOCK_SIZE,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
.name = "rootfs",
|
.name = "rootfs",
|
||||||
.offset = MTDPART_OFS_APPEND, /* Offset = 0x680000 */
|
.offset = MTDPART_OFS_APPEND, /* Offset = 0x6A0000 */
|
||||||
.size = MTDPART_SIZ_FULL,
|
.size = MTDPART_SIZ_FULL,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
@ -256,11 +267,19 @@ static void __init cm_t3517_init_irq(void)
|
|||||||
static struct omap_board_mux board_mux[] __initdata = {
|
static struct omap_board_mux board_mux[] __initdata = {
|
||||||
/* GPIO186 - Green LED */
|
/* GPIO186 - Green LED */
|
||||||
OMAP3_MUX(SYS_CLKOUT2, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
|
OMAP3_MUX(SYS_CLKOUT2, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
|
||||||
/* RTC GPIOs: IO, WR#, RD#, CS# */
|
|
||||||
|
/* RTC GPIOs: */
|
||||||
|
/* IO - GPIO153 */
|
||||||
OMAP3_MUX(MCBSP4_DR, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
OMAP3_MUX(MCBSP4_DR, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
||||||
|
/* WR# - GPIO154 */
|
||||||
OMAP3_MUX(MCBSP4_DX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
OMAP3_MUX(MCBSP4_DX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
||||||
OMAP3_MUX(MCBSP_CLKS, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
/* RD# - GPIO53 */
|
||||||
|
OMAP3_MUX(GPMC_NCS2, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
||||||
|
/* CS# - GPIO163 */
|
||||||
OMAP3_MUX(UART3_CTS_RCTX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
OMAP3_MUX(UART3_CTS_RCTX, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
||||||
|
/* CS EN - GPIO160 */
|
||||||
|
OMAP3_MUX(MCBSP_CLKS, OMAP_MUX_MODE4 | OMAP_PIN_INPUT),
|
||||||
|
|
||||||
/* HSUSB1 RESET */
|
/* HSUSB1 RESET */
|
||||||
OMAP3_MUX(UART2_TX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
|
OMAP3_MUX(UART2_TX, OMAP_MUX_MODE4 | OMAP_PIN_OUTPUT),
|
||||||
/* HSUSB2 RESET */
|
/* HSUSB2 RESET */
|
||||||
|
@ -275,8 +275,7 @@ static struct twl4030_gpio_platform_data devkit8000_gpio_data = {
|
|||||||
.irq_base = TWL4030_GPIO_IRQ_BASE,
|
.irq_base = TWL4030_GPIO_IRQ_BASE,
|
||||||
.irq_end = TWL4030_GPIO_IRQ_END,
|
.irq_end = TWL4030_GPIO_IRQ_END,
|
||||||
.use_leds = true,
|
.use_leds = true,
|
||||||
.pullups = BIT(1),
|
.pulldowns = BIT(1) | BIT(2) | BIT(6) | BIT(8) | BIT(13)
|
||||||
.pulldowns = BIT(2) | BIT(6) | BIT(7) | BIT(8) | BIT(13)
|
|
||||||
| BIT(15) | BIT(16) | BIT(17),
|
| BIT(15) | BIT(16) | BIT(17),
|
||||||
.setup = devkit8000_twl_gpio_setup,
|
.setup = devkit8000_twl_gpio_setup,
|
||||||
};
|
};
|
||||||
|
@ -34,7 +34,6 @@
|
|||||||
#include "cm2_44xx.h"
|
#include "cm2_44xx.h"
|
||||||
#include "cm-regbits-44xx.h"
|
#include "cm-regbits-44xx.h"
|
||||||
#include "prm44xx.h"
|
#include "prm44xx.h"
|
||||||
#include "prm44xx.h"
|
|
||||||
#include "prm-regbits-44xx.h"
|
#include "prm-regbits-44xx.h"
|
||||||
#include "control.h"
|
#include "control.h"
|
||||||
#include "scrm44xx.h"
|
#include "scrm44xx.h"
|
||||||
|
@ -423,6 +423,12 @@ int clkdm_add_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2)
|
|||||||
{
|
{
|
||||||
struct clkdm_dep *cd;
|
struct clkdm_dep *cd;
|
||||||
|
|
||||||
|
if (!cpu_is_omap24xx() && !cpu_is_omap34xx()) {
|
||||||
|
pr_err("clockdomain: %s/%s: %s: not yet implemented\n",
|
||||||
|
clkdm1->name, clkdm2->name, __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!clkdm1 || !clkdm2)
|
if (!clkdm1 || !clkdm2)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
@ -458,6 +464,12 @@ int clkdm_del_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2)
|
|||||||
{
|
{
|
||||||
struct clkdm_dep *cd;
|
struct clkdm_dep *cd;
|
||||||
|
|
||||||
|
if (!cpu_is_omap24xx() && !cpu_is_omap34xx()) {
|
||||||
|
pr_err("clockdomain: %s/%s: %s: not yet implemented\n",
|
||||||
|
clkdm1->name, clkdm2->name, __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!clkdm1 || !clkdm2)
|
if (!clkdm1 || !clkdm2)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
@ -500,6 +512,12 @@ int clkdm_read_wkdep(struct clockdomain *clkdm1, struct clockdomain *clkdm2)
|
|||||||
if (!clkdm1 || !clkdm2)
|
if (!clkdm1 || !clkdm2)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (!cpu_is_omap24xx() && !cpu_is_omap34xx()) {
|
||||||
|
pr_err("clockdomain: %s/%s: %s: not yet implemented\n",
|
||||||
|
clkdm1->name, clkdm2->name, __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
cd = _clkdm_deps_lookup(clkdm2, clkdm1->wkdep_srcs);
|
cd = _clkdm_deps_lookup(clkdm2, clkdm1->wkdep_srcs);
|
||||||
if (IS_ERR(cd)) {
|
if (IS_ERR(cd)) {
|
||||||
pr_debug("clockdomain: hardware cannot set/clear wake up of "
|
pr_debug("clockdomain: hardware cannot set/clear wake up of "
|
||||||
@ -527,6 +545,12 @@ int clkdm_clear_all_wkdeps(struct clockdomain *clkdm)
|
|||||||
struct clkdm_dep *cd;
|
struct clkdm_dep *cd;
|
||||||
u32 mask = 0;
|
u32 mask = 0;
|
||||||
|
|
||||||
|
if (!cpu_is_omap24xx() && !cpu_is_omap34xx()) {
|
||||||
|
pr_err("clockdomain: %s: %s: not yet implemented\n",
|
||||||
|
clkdm->name, __func__);
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
if (!clkdm)
|
if (!clkdm)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
@ -830,8 +854,7 @@ void omap2_clkdm_allow_idle(struct clockdomain *clkdm)
|
|||||||
* dependency code and data for OMAP4.
|
* dependency code and data for OMAP4.
|
||||||
*/
|
*/
|
||||||
if (cpu_is_omap44xx()) {
|
if (cpu_is_omap44xx()) {
|
||||||
WARN_ONCE(1, "clockdomain: OMAP4 wakeup/sleep dependency "
|
pr_err("clockdomain: %s: OMAP4 wakeup/sleep dependency support: not yet implemented\n", clkdm->name);
|
||||||
"support is not yet implemented\n");
|
|
||||||
} else {
|
} else {
|
||||||
if (atomic_read(&clkdm->usecount) > 0)
|
if (atomic_read(&clkdm->usecount) > 0)
|
||||||
_clkdm_add_autodeps(clkdm);
|
_clkdm_add_autodeps(clkdm);
|
||||||
@ -872,8 +895,7 @@ void omap2_clkdm_deny_idle(struct clockdomain *clkdm)
|
|||||||
* dependency code and data for OMAP4.
|
* dependency code and data for OMAP4.
|
||||||
*/
|
*/
|
||||||
if (cpu_is_omap44xx()) {
|
if (cpu_is_omap44xx()) {
|
||||||
WARN_ONCE(1, "clockdomain: OMAP4 wakeup/sleep dependency "
|
pr_err("clockdomain: %s: OMAP4 wakeup/sleep dependency support: not yet implemented\n", clkdm->name);
|
||||||
"support is not yet implemented\n");
|
|
||||||
} else {
|
} else {
|
||||||
if (atomic_read(&clkdm->usecount) > 0)
|
if (atomic_read(&clkdm->usecount) > 0)
|
||||||
_clkdm_del_autodeps(clkdm);
|
_clkdm_del_autodeps(clkdm);
|
||||||
|
@ -30,8 +30,6 @@
|
|||||||
#include "cm1_44xx.h"
|
#include "cm1_44xx.h"
|
||||||
#include "cm2_44xx.h"
|
#include "cm2_44xx.h"
|
||||||
|
|
||||||
#include "cm1_44xx.h"
|
|
||||||
#include "cm2_44xx.h"
|
|
||||||
#include "cm-regbits-44xx.h"
|
#include "cm-regbits-44xx.h"
|
||||||
#include "prm44xx.h"
|
#include "prm44xx.h"
|
||||||
#include "prcm44xx.h"
|
#include "prcm44xx.h"
|
||||||
|
@ -264,7 +264,7 @@ static int __init omap2_system_dma_init_dev(struct omap_hwmod *oh, void *unused)
|
|||||||
if (IS_ERR(od)) {
|
if (IS_ERR(od)) {
|
||||||
pr_err("%s: Cant build omap_device for %s:%s.\n",
|
pr_err("%s: Cant build omap_device for %s:%s.\n",
|
||||||
__func__, name, oh->name);
|
__func__, name, oh->name);
|
||||||
return IS_ERR(od);
|
return PTR_ERR(od);
|
||||||
}
|
}
|
||||||
|
|
||||||
mem = platform_get_resource(&od->pdev, IORESOURCE_MEM, 0);
|
mem = platform_get_resource(&od->pdev, IORESOURCE_MEM, 0);
|
||||||
|
@ -38,20 +38,6 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef MULTI_OMAP2
|
#ifdef MULTI_OMAP2
|
||||||
|
|
||||||
/*
|
|
||||||
* We use __glue to avoid errors with multiple definitions of
|
|
||||||
* .globl omap_irq_base as it's included from entry-armv.S but not
|
|
||||||
* from entry-common.S.
|
|
||||||
*/
|
|
||||||
#ifdef __glue
|
|
||||||
.pushsection .data
|
|
||||||
.globl omap_irq_base
|
|
||||||
omap_irq_base:
|
|
||||||
.word 0
|
|
||||||
.popsection
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Configure the interrupt base on the first interrupt.
|
* Configure the interrupt base on the first interrupt.
|
||||||
* See also omap_irq_base_init for setting omap_irq_base.
|
* See also omap_irq_base_init for setting omap_irq_base.
|
||||||
|
@ -314,14 +314,13 @@ static int _set_hwmod_postsetup_state(struct omap_hwmod *oh, void *data)
|
|||||||
return omap_hwmod_set_postsetup_state(oh, *(u8 *)data);
|
return omap_hwmod_set_postsetup_state(oh, *(u8 *)data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void __iomem *omap_irq_base;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Initialize asm_irq_base for entry-macro.S
|
* Initialize asm_irq_base for entry-macro.S
|
||||||
*/
|
*/
|
||||||
static inline void omap_irq_base_init(void)
|
static inline void omap_irq_base_init(void)
|
||||||
{
|
{
|
||||||
extern void __iomem *omap_irq_base;
|
|
||||||
|
|
||||||
#ifdef MULTI_OMAP2
|
|
||||||
if (cpu_is_omap24xx())
|
if (cpu_is_omap24xx())
|
||||||
omap_irq_base = OMAP2_L4_IO_ADDRESS(OMAP24XX_IC_BASE);
|
omap_irq_base = OMAP2_L4_IO_ADDRESS(OMAP24XX_IC_BASE);
|
||||||
else if (cpu_is_omap34xx())
|
else if (cpu_is_omap34xx())
|
||||||
@ -330,7 +329,6 @@ static inline void omap_irq_base_init(void)
|
|||||||
omap_irq_base = OMAP2_L4_IO_ADDRESS(OMAP44XX_GIC_CPU_BASE);
|
omap_irq_base = OMAP2_L4_IO_ADDRESS(OMAP44XX_GIC_CPU_BASE);
|
||||||
else
|
else
|
||||||
pr_err("Could not initialize omap_irq_base\n");
|
pr_err("Could not initialize omap_irq_base\n");
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void __init omap2_init_common_infrastructure(void)
|
void __init omap2_init_common_infrastructure(void)
|
||||||
|
@ -160,7 +160,7 @@ static int __init _omap_mux_get_by_name(struct omap_mux_partition *partition,
|
|||||||
struct omap_mux *mux = NULL;
|
struct omap_mux *mux = NULL;
|
||||||
struct omap_mux_entry *e;
|
struct omap_mux_entry *e;
|
||||||
const char *mode_name;
|
const char *mode_name;
|
||||||
int found = 0, found_mode, mode0_len = 0;
|
int found = 0, found_mode = 0, mode0_len = 0;
|
||||||
struct list_head *muxmodes = &partition->muxmodes;
|
struct list_head *muxmodes = &partition->muxmodes;
|
||||||
|
|
||||||
mode_name = strchr(muxname, '.');
|
mode_name = strchr(muxname, '.');
|
||||||
|
@ -134,7 +134,7 @@ static void omap2_enter_full_retention(void)
|
|||||||
|
|
||||||
/* Block console output in case it is on one of the OMAP UARTs */
|
/* Block console output in case it is on one of the OMAP UARTs */
|
||||||
if (!is_suspending())
|
if (!is_suspending())
|
||||||
if (try_acquire_console_sem())
|
if (!console_trylock())
|
||||||
goto no_sleep;
|
goto no_sleep;
|
||||||
|
|
||||||
omap_uart_prepare_idle(0);
|
omap_uart_prepare_idle(0);
|
||||||
@ -151,7 +151,7 @@ static void omap2_enter_full_retention(void)
|
|||||||
omap_uart_resume_idle(0);
|
omap_uart_resume_idle(0);
|
||||||
|
|
||||||
if (!is_suspending())
|
if (!is_suspending())
|
||||||
release_console_sem();
|
console_unlock();
|
||||||
|
|
||||||
no_sleep:
|
no_sleep:
|
||||||
if (omap2_pm_debug) {
|
if (omap2_pm_debug) {
|
||||||
|
@ -398,7 +398,7 @@ void omap_sram_idle(void)
|
|||||||
if (!is_suspending())
|
if (!is_suspending())
|
||||||
if (per_next_state < PWRDM_POWER_ON ||
|
if (per_next_state < PWRDM_POWER_ON ||
|
||||||
core_next_state < PWRDM_POWER_ON)
|
core_next_state < PWRDM_POWER_ON)
|
||||||
if (try_acquire_console_sem())
|
if (!console_trylock())
|
||||||
goto console_still_active;
|
goto console_still_active;
|
||||||
|
|
||||||
/* PER */
|
/* PER */
|
||||||
@ -481,7 +481,7 @@ void omap_sram_idle(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!is_suspending())
|
if (!is_suspending())
|
||||||
release_console_sem();
|
console_unlock();
|
||||||
|
|
||||||
console_still_active:
|
console_still_active:
|
||||||
/* Disable IO-PAD and IO-CHAIN wakeup */
|
/* Disable IO-PAD and IO-CHAIN wakeup */
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
#include <plat/prcm.h>
|
#include <plat/prcm.h>
|
||||||
|
|
||||||
#include "powerdomain.h"
|
#include "powerdomain.h"
|
||||||
#include "prm-regbits-34xx.h"
|
|
||||||
#include "prm.h"
|
#include "prm.h"
|
||||||
#include "prm-regbits-24xx.h"
|
#include "prm-regbits-24xx.h"
|
||||||
#include "prm-regbits-34xx.h"
|
#include "prm-regbits-34xx.h"
|
||||||
|
@ -812,7 +812,7 @@ void __init omap_serial_init_port(struct omap_board_data *bdata)
|
|||||||
|
|
||||||
oh->dev_attr = uart;
|
oh->dev_attr = uart;
|
||||||
|
|
||||||
acquire_console_sem(); /* in case the earlycon is on the UART */
|
console_lock(); /* in case the earlycon is on the UART */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Because of early UART probing, UART did not get idled
|
* Because of early UART probing, UART did not get idled
|
||||||
@ -838,7 +838,7 @@ void __init omap_serial_init_port(struct omap_board_data *bdata)
|
|||||||
omap_uart_block_sleep(uart);
|
omap_uart_block_sleep(uart);
|
||||||
uart->timeout = DEFAULT_TIMEOUT;
|
uart->timeout = DEFAULT_TIMEOUT;
|
||||||
|
|
||||||
release_console_sem();
|
console_unlock();
|
||||||
|
|
||||||
if ((cpu_is_omap34xx() && uart->padconf) ||
|
if ((cpu_is_omap34xx() && uart->padconf) ||
|
||||||
(uart->wk_en && uart->wk_mask)) {
|
(uart->wk_en && uart->wk_mask)) {
|
||||||
|
@ -42,6 +42,8 @@
|
|||||||
|
|
||||||
#include "timer-gp.h"
|
#include "timer-gp.h"
|
||||||
|
|
||||||
|
#include <plat/common.h>
|
||||||
|
|
||||||
/* MAX_GPTIMER_ID: number of GPTIMERs on the chip */
|
/* MAX_GPTIMER_ID: number of GPTIMERs on the chip */
|
||||||
#define MAX_GPTIMER_ID 12
|
#define MAX_GPTIMER_ID 12
|
||||||
|
|
||||||
@ -176,10 +178,14 @@ static void __init omap2_gp_clockevent_init(void)
|
|||||||
/*
|
/*
|
||||||
* When 32k-timer is enabled, don't use GPTimer for clocksource
|
* When 32k-timer is enabled, don't use GPTimer for clocksource
|
||||||
* instead, just leave default clocksource which uses the 32k
|
* instead, just leave default clocksource which uses the 32k
|
||||||
* sync counter. See clocksource setup in see plat-omap/common.c.
|
* sync counter. See clocksource setup in plat-omap/counter_32k.c
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static inline void __init omap2_gp_clocksource_init(void) {}
|
static void __init omap2_gp_clocksource_init(void)
|
||||||
|
{
|
||||||
|
omap_init_clocksource_32k();
|
||||||
|
}
|
||||||
|
|
||||||
#else
|
#else
|
||||||
/*
|
/*
|
||||||
* clocksource
|
* clocksource
|
||||||
|
@ -2,52 +2,56 @@ menu "RealView platform type"
|
|||||||
depends on ARCH_REALVIEW
|
depends on ARCH_REALVIEW
|
||||||
|
|
||||||
config MACH_REALVIEW_EB
|
config MACH_REALVIEW_EB
|
||||||
bool "Support RealView/EB platform"
|
bool "Support RealView(R) Emulation Baseboard"
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) RealView Emulation Baseboard platform.
|
Include support for the ARM(R) RealView(R) Emulation Baseboard
|
||||||
|
platform.
|
||||||
|
|
||||||
config REALVIEW_EB_A9MP
|
config REALVIEW_EB_A9MP
|
||||||
bool "Support Multicore Cortex-A9"
|
bool "Support Multicore Cortex-A9 Tile"
|
||||||
depends on MACH_REALVIEW_EB
|
depends on MACH_REALVIEW_EB
|
||||||
select CPU_V7
|
select CPU_V7
|
||||||
help
|
help
|
||||||
Enable support for the Cortex-A9MPCore tile on the Realview platform.
|
Enable support for the Cortex-A9MPCore tile fitted to the
|
||||||
|
Realview(R) Emulation Baseboard platform.
|
||||||
|
|
||||||
config REALVIEW_EB_ARM11MP
|
config REALVIEW_EB_ARM11MP
|
||||||
bool "Support ARM11MPCore tile"
|
bool "Support ARM11MPCore Tile"
|
||||||
depends on MACH_REALVIEW_EB
|
depends on MACH_REALVIEW_EB
|
||||||
select CPU_V6
|
select CPU_V6
|
||||||
select ARCH_HAS_BARRIERS if SMP
|
select ARCH_HAS_BARRIERS if SMP
|
||||||
help
|
help
|
||||||
Enable support for the ARM11MPCore tile on the Realview platform.
|
Enable support for the ARM11MPCore tile fitted to the Realview(R)
|
||||||
|
Emulation Baseboard platform.
|
||||||
|
|
||||||
config REALVIEW_EB_ARM11MP_REVB
|
config REALVIEW_EB_ARM11MP_REVB
|
||||||
bool "Support ARM11MPCore RevB tile"
|
bool "Support ARM11MPCore RevB Tile"
|
||||||
depends on REALVIEW_EB_ARM11MP
|
depends on REALVIEW_EB_ARM11MP
|
||||||
help
|
help
|
||||||
Enable support for the ARM11MPCore RevB tile on the Realview
|
Enable support for the ARM11MPCore Revision B tile on the
|
||||||
platform. Since there are device address differences, a
|
Realview(R) Emulation Baseboard platform. Since there are device
|
||||||
kernel built with this option enabled is not compatible with
|
address differences, a kernel built with this option enabled is
|
||||||
other revisions of the ARM11MPCore tile.
|
not compatible with other revisions of the ARM11MPCore tile.
|
||||||
|
|
||||||
config MACH_REALVIEW_PB11MP
|
config MACH_REALVIEW_PB11MP
|
||||||
bool "Support RealView/PB11MPCore platform"
|
bool "Support RealView(R) Platform Baseboard for ARM11MPCore"
|
||||||
select CPU_V6
|
select CPU_V6
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select HAVE_PATA_PLATFORM
|
select HAVE_PATA_PLATFORM
|
||||||
select ARCH_HAS_BARRIERS if SMP
|
select ARCH_HAS_BARRIERS if SMP
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) RealView MPCore Platform Baseboard.
|
Include support for the ARM(R) RealView(R) Platform Baseboard for
|
||||||
PB11MPCore is a platform with an on-board ARM11MPCore and has
|
the ARM11MPCore. This platform has an on-board ARM11MPCore and has
|
||||||
support for PCI-E and Compact Flash.
|
support for PCI-E and Compact Flash.
|
||||||
|
|
||||||
config MACH_REALVIEW_PB1176
|
config MACH_REALVIEW_PB1176
|
||||||
bool "Support RealView/PB1176 platform"
|
bool "Support RealView(R) Platform Baseboard for ARM1176JZF-S"
|
||||||
select CPU_V6
|
select CPU_V6
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) RealView ARM1176 Platform Baseboard.
|
Include support for the ARM(R) RealView(R) Platform Baseboard for
|
||||||
|
ARM1176JZF-S.
|
||||||
|
|
||||||
config REALVIEW_PB1176_SECURE_FLASH
|
config REALVIEW_PB1176_SECURE_FLASH
|
||||||
bool "Allow access to the secure flash memory block"
|
bool "Allow access to the secure flash memory block"
|
||||||
@ -59,23 +63,24 @@ config REALVIEW_PB1176_SECURE_FLASH
|
|||||||
block (64MB @ 0x3c000000) is required.
|
block (64MB @ 0x3c000000) is required.
|
||||||
|
|
||||||
config MACH_REALVIEW_PBA8
|
config MACH_REALVIEW_PBA8
|
||||||
bool "Support RealView/PB-A8 platform"
|
bool "Support RealView(R) Platform Baseboard for Cortex(tm)-A8 platform"
|
||||||
select CPU_V7
|
select CPU_V7
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select HAVE_PATA_PLATFORM
|
select HAVE_PATA_PLATFORM
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) RealView Cortex-A8 Platform Baseboard.
|
Include support for the ARM(R) RealView Platform Baseboard for
|
||||||
PB-A8 is a platform with an on-board Cortex-A8 and has support for
|
Cortex(tm)-A8. This platform has an on-board Cortex-A8 and has
|
||||||
PCI-E and Compact Flash.
|
support for PCI-E and Compact Flash.
|
||||||
|
|
||||||
config MACH_REALVIEW_PBX
|
config MACH_REALVIEW_PBX
|
||||||
bool "Support RealView/PBX platform"
|
bool "Support RealView(R) Platform Baseboard Explore"
|
||||||
select ARM_GIC
|
select ARM_GIC
|
||||||
select HAVE_PATA_PLATFORM
|
select HAVE_PATA_PLATFORM
|
||||||
select ARCH_SPARSEMEM_ENABLE if CPU_V7 && !REALVIEW_HIGH_PHYS_OFFSET
|
select ARCH_SPARSEMEM_ENABLE if CPU_V7 && !REALVIEW_HIGH_PHYS_OFFSET
|
||||||
select ZONE_DMA if SPARSEMEM
|
select ZONE_DMA if SPARSEMEM
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) RealView PBX platform.
|
Include support for the ARM(R) RealView(R) Platform Baseboard
|
||||||
|
Explore.
|
||||||
|
|
||||||
config REALVIEW_HIGH_PHYS_OFFSET
|
config REALVIEW_HIGH_PHYS_OFFSET
|
||||||
bool "High physical base address for the RealView platform"
|
bool "High physical base address for the RealView platform"
|
||||||
|
@ -41,7 +41,7 @@ volatile int __cpuinitdata pen_release = -1;
|
|||||||
* observers, irrespective of whether they're taking part in coherency
|
* observers, irrespective of whether they're taking part in coherency
|
||||||
* or not. This is necessary for the hotplug code to work reliably.
|
* or not. This is necessary for the hotplug code to work reliably.
|
||||||
*/
|
*/
|
||||||
static void write_pen_release(int val)
|
static void __cpuinit write_pen_release(int val)
|
||||||
{
|
{
|
||||||
pen_release = val;
|
pen_release = val;
|
||||||
smp_wmb();
|
smp_wmb();
|
||||||
|
@ -60,6 +60,8 @@ endchoice
|
|||||||
|
|
||||||
config MACH_AG5EVM
|
config MACH_AG5EVM
|
||||||
bool "AG5EVM board"
|
bool "AG5EVM board"
|
||||||
|
select ARCH_REQUIRE_GPIOLIB
|
||||||
|
select SH_LCD_MIPI_DSI
|
||||||
depends on ARCH_SH73A0
|
depends on ARCH_SH73A0
|
||||||
|
|
||||||
config MACH_MACKEREL
|
config MACH_MACKEREL
|
||||||
|
@ -34,9 +34,10 @@
|
|||||||
#include <linux/input/sh_keysc.h>
|
#include <linux/input/sh_keysc.h>
|
||||||
#include <linux/mmc/host.h>
|
#include <linux/mmc/host.h>
|
||||||
#include <linux/mmc/sh_mmcif.h>
|
#include <linux/mmc/sh_mmcif.h>
|
||||||
|
#include <linux/sh_clk.h>
|
||||||
|
#include <video/sh_mobile_lcdc.h>
|
||||||
|
#include <video/sh_mipi_dsi.h>
|
||||||
#include <sound/sh_fsi.h>
|
#include <sound/sh_fsi.h>
|
||||||
|
|
||||||
#include <mach/hardware.h>
|
#include <mach/hardware.h>
|
||||||
#include <mach/sh73a0.h>
|
#include <mach/sh73a0.h>
|
||||||
#include <mach/common.h>
|
#include <mach/common.h>
|
||||||
@ -183,11 +184,165 @@ static struct platform_device mmc_device = {
|
|||||||
.resource = sh_mmcif_resources,
|
.resource = sh_mmcif_resources,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* IrDA */
|
||||||
|
static struct resource irda_resources[] = {
|
||||||
|
[0] = {
|
||||||
|
.start = 0xE6D00000,
|
||||||
|
.end = 0xE6D01FD4 - 1,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
[1] = {
|
||||||
|
.start = gic_spi(95),
|
||||||
|
.flags = IORESOURCE_IRQ,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device irda_device = {
|
||||||
|
.name = "sh_irda",
|
||||||
|
.id = 0,
|
||||||
|
.resource = irda_resources,
|
||||||
|
.num_resources = ARRAY_SIZE(irda_resources),
|
||||||
|
};
|
||||||
|
|
||||||
|
static unsigned char lcd_backlight_seq[3][2] = {
|
||||||
|
{ 0x04, 0x07 },
|
||||||
|
{ 0x23, 0x80 },
|
||||||
|
{ 0x03, 0x01 },
|
||||||
|
};
|
||||||
|
|
||||||
|
static void lcd_backlight_on(void)
|
||||||
|
{
|
||||||
|
struct i2c_adapter *a;
|
||||||
|
struct i2c_msg msg;
|
||||||
|
int k;
|
||||||
|
|
||||||
|
a = i2c_get_adapter(1);
|
||||||
|
for (k = 0; a && k < 3; k++) {
|
||||||
|
msg.addr = 0x6d;
|
||||||
|
msg.buf = &lcd_backlight_seq[k][0];
|
||||||
|
msg.len = 2;
|
||||||
|
msg.flags = 0;
|
||||||
|
if (i2c_transfer(a, &msg, 1) != 1)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_backlight_reset(void)
|
||||||
|
{
|
||||||
|
gpio_set_value(GPIO_PORT235, 0);
|
||||||
|
mdelay(24);
|
||||||
|
gpio_set_value(GPIO_PORT235, 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_on(void *board_data, struct fb_info *info)
|
||||||
|
{
|
||||||
|
lcd_backlight_on();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void lcd_off(void *board_data)
|
||||||
|
{
|
||||||
|
lcd_backlight_reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
/* LCDC0 */
|
||||||
|
static const struct fb_videomode lcdc0_modes[] = {
|
||||||
|
{
|
||||||
|
.name = "R63302(QHD)",
|
||||||
|
.xres = 544,
|
||||||
|
.yres = 961,
|
||||||
|
.left_margin = 72,
|
||||||
|
.right_margin = 600,
|
||||||
|
.hsync_len = 16,
|
||||||
|
.upper_margin = 8,
|
||||||
|
.lower_margin = 8,
|
||||||
|
.vsync_len = 2,
|
||||||
|
.sync = FB_SYNC_VERT_HIGH_ACT | FB_SYNC_HOR_HIGH_ACT,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct sh_mobile_lcdc_info lcdc0_info = {
|
||||||
|
.clock_source = LCDC_CLK_PERIPHERAL,
|
||||||
|
.ch[0] = {
|
||||||
|
.chan = LCDC_CHAN_MAINLCD,
|
||||||
|
.interface_type = RGB24,
|
||||||
|
.clock_divider = 1,
|
||||||
|
.flags = LCDC_FLAGS_DWPOL,
|
||||||
|
.lcd_size_cfg.width = 44,
|
||||||
|
.lcd_size_cfg.height = 79,
|
||||||
|
.bpp = 16,
|
||||||
|
.lcd_cfg = lcdc0_modes,
|
||||||
|
.num_cfg = ARRAY_SIZE(lcdc0_modes),
|
||||||
|
.board_cfg = {
|
||||||
|
.display_on = lcd_on,
|
||||||
|
.display_off = lcd_off,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct resource lcdc0_resources[] = {
|
||||||
|
[0] = {
|
||||||
|
.name = "LCDC0",
|
||||||
|
.start = 0xfe940000, /* P4-only space */
|
||||||
|
.end = 0xfe943fff,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
[1] = {
|
||||||
|
.start = intcs_evt2irq(0x580),
|
||||||
|
.flags = IORESOURCE_IRQ,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device lcdc0_device = {
|
||||||
|
.name = "sh_mobile_lcdc_fb",
|
||||||
|
.num_resources = ARRAY_SIZE(lcdc0_resources),
|
||||||
|
.resource = lcdc0_resources,
|
||||||
|
.id = 0,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &lcdc0_info,
|
||||||
|
.coherent_dma_mask = ~0,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
/* MIPI-DSI */
|
||||||
|
static struct resource mipidsi0_resources[] = {
|
||||||
|
[0] = {
|
||||||
|
.start = 0xfeab0000,
|
||||||
|
.end = 0xfeab3fff,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
[1] = {
|
||||||
|
.start = 0xfeab4000,
|
||||||
|
.end = 0xfeab7fff,
|
||||||
|
.flags = IORESOURCE_MEM,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct sh_mipi_dsi_info mipidsi0_info = {
|
||||||
|
.data_format = MIPI_RGB888,
|
||||||
|
.lcd_chan = &lcdc0_info.ch[0],
|
||||||
|
.vsynw_offset = 20,
|
||||||
|
.clksrc = 1,
|
||||||
|
.flags = SH_MIPI_DSI_HSABM,
|
||||||
|
};
|
||||||
|
|
||||||
|
static struct platform_device mipidsi0_device = {
|
||||||
|
.name = "sh-mipi-dsi",
|
||||||
|
.num_resources = ARRAY_SIZE(mipidsi0_resources),
|
||||||
|
.resource = mipidsi0_resources,
|
||||||
|
.id = 0,
|
||||||
|
.dev = {
|
||||||
|
.platform_data = &mipidsi0_info,
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
static struct platform_device *ag5evm_devices[] __initdata = {
|
static struct platform_device *ag5evm_devices[] __initdata = {
|
||||||
ð_device,
|
ð_device,
|
||||||
&keysc_device,
|
&keysc_device,
|
||||||
&fsi_device,
|
&fsi_device,
|
||||||
&mmc_device,
|
&mmc_device,
|
||||||
|
&irda_device,
|
||||||
|
&lcdc0_device,
|
||||||
|
&mipidsi0_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct map_desc ag5evm_io_desc[] __initdata = {
|
static struct map_desc ag5evm_io_desc[] __initdata = {
|
||||||
@ -224,6 +379,8 @@ void __init ag5evm_init_irq(void)
|
|||||||
__raw_writew(__raw_readw(PINTCR0A) | (2<<10), PINTCR0A);
|
__raw_writew(__raw_readw(PINTCR0A) | (2<<10), PINTCR0A);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define DSI0PHYCR 0xe615006c
|
||||||
|
|
||||||
static void __init ag5evm_init(void)
|
static void __init ag5evm_init(void)
|
||||||
{
|
{
|
||||||
sh73a0_pinmux_init();
|
sh73a0_pinmux_init();
|
||||||
@ -287,6 +444,25 @@ static void __init ag5evm_init(void)
|
|||||||
gpio_request(GPIO_FN_FSIAISLD, NULL);
|
gpio_request(GPIO_FN_FSIAISLD, NULL);
|
||||||
gpio_request(GPIO_FN_FSIAOSLD, NULL);
|
gpio_request(GPIO_FN_FSIAOSLD, NULL);
|
||||||
|
|
||||||
|
/* IrDA */
|
||||||
|
gpio_request(GPIO_FN_PORT241_IRDA_OUT, NULL);
|
||||||
|
gpio_request(GPIO_FN_PORT242_IRDA_IN, NULL);
|
||||||
|
gpio_request(GPIO_FN_PORT243_IRDA_FIRSEL, NULL);
|
||||||
|
|
||||||
|
/* LCD panel */
|
||||||
|
gpio_request(GPIO_PORT217, NULL); /* RESET */
|
||||||
|
gpio_direction_output(GPIO_PORT217, 0);
|
||||||
|
mdelay(1);
|
||||||
|
gpio_set_value(GPIO_PORT217, 1);
|
||||||
|
|
||||||
|
/* LCD backlight controller */
|
||||||
|
gpio_request(GPIO_PORT235, NULL); /* RESET */
|
||||||
|
gpio_direction_output(GPIO_PORT235, 0);
|
||||||
|
lcd_backlight_reset();
|
||||||
|
|
||||||
|
/* MIPI-DSI clock setup */
|
||||||
|
__raw_writel(0x2a809010, DSI0PHYCR);
|
||||||
|
|
||||||
#ifdef CONFIG_CACHE_L2X0
|
#ifdef CONFIG_CACHE_L2X0
|
||||||
/* Shared attribute override enable, 64K*8way */
|
/* Shared attribute override enable, 64K*8way */
|
||||||
l2x0_init(__io(0xf0100000), 0x00460000, 0xc2000fff);
|
l2x0_init(__io(0xf0100000), 0x00460000, 0xc2000fff);
|
||||||
|
@ -347,7 +347,6 @@ static void __init g3evm_init(void)
|
|||||||
gpio_request(GPIO_FN_IRDA_OUT, NULL);
|
gpio_request(GPIO_FN_IRDA_OUT, NULL);
|
||||||
gpio_request(GPIO_FN_IRDA_IN, NULL);
|
gpio_request(GPIO_FN_IRDA_IN, NULL);
|
||||||
gpio_request(GPIO_FN_IRDA_FIRSEL, NULL);
|
gpio_request(GPIO_FN_IRDA_FIRSEL, NULL);
|
||||||
set_irq_type(evt2irq(0x480), IRQ_TYPE_LEVEL_LOW);
|
|
||||||
|
|
||||||
sh7367_add_standard_devices();
|
sh7367_add_standard_devices();
|
||||||
|
|
||||||
|
@ -169,9 +169,8 @@
|
|||||||
* SW1 | SW33
|
* SW1 | SW33
|
||||||
* | bit1 | bit2 | bit3 | bit4
|
* | bit1 | bit2 | bit3 | bit4
|
||||||
* -------------+------+------+------+-------
|
* -------------+------+------+------+-------
|
||||||
* MMC0 OFF | OFF | ON | ON | X
|
* MMC0 OFF | OFF | X | ON | X (Use MMCIF)
|
||||||
* MMC1 ON | OFF | ON | X | ON
|
* SDHI1 OFF | ON | X | OFF | X (Use MFD_SH_MOBILE_SDHI)
|
||||||
* SDHI1 OFF | ON | X | OFF | ON
|
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -234,7 +234,9 @@ static int pllc2_set_rate(struct clk *clk, unsigned long rate)
|
|||||||
|
|
||||||
value = __raw_readl(PLLC2CR) & ~(0x3f << 24);
|
value = __raw_readl(PLLC2CR) & ~(0x3f << 24);
|
||||||
|
|
||||||
__raw_writel((value & ~0x80000000) | ((idx + 19) << 24), PLLC2CR);
|
__raw_writel(value | ((idx + 19) << 24), PLLC2CR);
|
||||||
|
|
||||||
|
clk->rate = clk->freq_table[idx].frequency;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -118,8 +118,16 @@ static unsigned long pll_recalc(struct clk *clk)
|
|||||||
{
|
{
|
||||||
unsigned long mult = 1;
|
unsigned long mult = 1;
|
||||||
|
|
||||||
if (__raw_readl(PLLECR) & (1 << clk->enable_bit))
|
if (__raw_readl(PLLECR) & (1 << clk->enable_bit)) {
|
||||||
mult = (((__raw_readl(clk->enable_reg) >> 24) & 0x3f) + 1);
|
mult = (((__raw_readl(clk->enable_reg) >> 24) & 0x3f) + 1);
|
||||||
|
/* handle CFG bit for PLL1 and PLL2 */
|
||||||
|
switch (clk->enable_bit) {
|
||||||
|
case 1:
|
||||||
|
case 2:
|
||||||
|
if (__raw_readl(clk->enable_reg) & (1 << 20))
|
||||||
|
mult *= 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return clk->parent->rate * mult;
|
return clk->parent->rate * mult;
|
||||||
}
|
}
|
||||||
@ -212,7 +220,7 @@ enum { DIV4_I, DIV4_ZG, DIV4_M3, DIV4_B, DIV4_M1, DIV4_M2,
|
|||||||
static struct clk div4_clks[DIV4_NR] = {
|
static struct clk div4_clks[DIV4_NR] = {
|
||||||
[DIV4_I] = DIV4(FRQCRA, 20, 0xfff, CLK_ENABLE_ON_INIT),
|
[DIV4_I] = DIV4(FRQCRA, 20, 0xfff, CLK_ENABLE_ON_INIT),
|
||||||
[DIV4_ZG] = DIV4(FRQCRA, 16, 0xbff, CLK_ENABLE_ON_INIT),
|
[DIV4_ZG] = DIV4(FRQCRA, 16, 0xbff, CLK_ENABLE_ON_INIT),
|
||||||
[DIV4_M3] = DIV4(FRQCRA, 8, 0xfff, CLK_ENABLE_ON_INIT),
|
[DIV4_M3] = DIV4(FRQCRA, 12, 0xfff, CLK_ENABLE_ON_INIT),
|
||||||
[DIV4_B] = DIV4(FRQCRA, 8, 0xfff, CLK_ENABLE_ON_INIT),
|
[DIV4_B] = DIV4(FRQCRA, 8, 0xfff, CLK_ENABLE_ON_INIT),
|
||||||
[DIV4_M1] = DIV4(FRQCRA, 4, 0xfff, 0),
|
[DIV4_M1] = DIV4(FRQCRA, 4, 0xfff, 0),
|
||||||
[DIV4_M2] = DIV4(FRQCRA, 0, 0xfff, 0),
|
[DIV4_M2] = DIV4(FRQCRA, 0, 0xfff, 0),
|
||||||
@ -255,10 +263,10 @@ static struct clk div6_clks[DIV6_NR] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
enum { MSTP001,
|
enum { MSTP001,
|
||||||
MSTP125, MSTP116,
|
MSTP125, MSTP118, MSTP116, MSTP100,
|
||||||
MSTP219,
|
MSTP219,
|
||||||
MSTP207, MSTP206, MSTP204, MSTP203, MSTP202, MSTP201, MSTP200,
|
MSTP207, MSTP206, MSTP204, MSTP203, MSTP202, MSTP201, MSTP200,
|
||||||
MSTP331, MSTP329, MSTP323, MSTP312,
|
MSTP331, MSTP329, MSTP325, MSTP323, MSTP312,
|
||||||
MSTP411, MSTP410, MSTP403,
|
MSTP411, MSTP410, MSTP403,
|
||||||
MSTP_NR };
|
MSTP_NR };
|
||||||
|
|
||||||
@ -268,7 +276,9 @@ enum { MSTP001,
|
|||||||
static struct clk mstp_clks[MSTP_NR] = {
|
static struct clk mstp_clks[MSTP_NR] = {
|
||||||
[MSTP001] = MSTP(&div4_clks[DIV4_HP], SMSTPCR0, 1, 0), /* IIC2 */
|
[MSTP001] = MSTP(&div4_clks[DIV4_HP], SMSTPCR0, 1, 0), /* IIC2 */
|
||||||
[MSTP125] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR1, 25, 0), /* TMU0 */
|
[MSTP125] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR1, 25, 0), /* TMU0 */
|
||||||
|
[MSTP118] = MSTP(&div4_clks[DIV4_B], SMSTPCR1, 18, 0), /* DSITX0 */
|
||||||
[MSTP116] = MSTP(&div4_clks[DIV4_HP], SMSTPCR1, 16, 0), /* IIC0 */
|
[MSTP116] = MSTP(&div4_clks[DIV4_HP], SMSTPCR1, 16, 0), /* IIC0 */
|
||||||
|
[MSTP100] = MSTP(&div4_clks[DIV4_B], SMSTPCR1, 0, 0), /* LCDC0 */
|
||||||
[MSTP219] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 19, 0), /* SCIFA7 */
|
[MSTP219] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 19, 0), /* SCIFA7 */
|
||||||
[MSTP207] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 7, 0), /* SCIFA5 */
|
[MSTP207] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 7, 0), /* SCIFA5 */
|
||||||
[MSTP206] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 6, 0), /* SCIFB */
|
[MSTP206] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 6, 0), /* SCIFB */
|
||||||
@ -279,6 +289,7 @@ static struct clk mstp_clks[MSTP_NR] = {
|
|||||||
[MSTP200] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 0, 0), /* SCIFA4 */
|
[MSTP200] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR2, 0, 0), /* SCIFA4 */
|
||||||
[MSTP331] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR3, 31, 0), /* SCIFA6 */
|
[MSTP331] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR3, 31, 0), /* SCIFA6 */
|
||||||
[MSTP329] = MSTP(&r_clk, SMSTPCR3, 29, 0), /* CMT10 */
|
[MSTP329] = MSTP(&r_clk, SMSTPCR3, 29, 0), /* CMT10 */
|
||||||
|
[MSTP325] = MSTP(&div6_clks[DIV6_SUB], SMSTPCR3, 25, 0), /* IrDA */
|
||||||
[MSTP323] = MSTP(&div4_clks[DIV4_HP], SMSTPCR3, 23, 0), /* IIC1 */
|
[MSTP323] = MSTP(&div4_clks[DIV4_HP], SMSTPCR3, 23, 0), /* IIC1 */
|
||||||
[MSTP312] = MSTP(&div4_clks[DIV4_HP], SMSTPCR3, 12, 0), /* MMCIF0 */
|
[MSTP312] = MSTP(&div4_clks[DIV4_HP], SMSTPCR3, 12, 0), /* MMCIF0 */
|
||||||
[MSTP411] = MSTP(&div4_clks[DIV4_HP], SMSTPCR4, 11, 0), /* IIC3 */
|
[MSTP411] = MSTP(&div4_clks[DIV4_HP], SMSTPCR4, 11, 0), /* IIC3 */
|
||||||
@ -288,16 +299,25 @@ static struct clk mstp_clks[MSTP_NR] = {
|
|||||||
|
|
||||||
#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk }
|
#define CLKDEV_CON_ID(_id, _clk) { .con_id = _id, .clk = _clk }
|
||||||
#define CLKDEV_DEV_ID(_id, _clk) { .dev_id = _id, .clk = _clk }
|
#define CLKDEV_DEV_ID(_id, _clk) { .dev_id = _id, .clk = _clk }
|
||||||
|
#define CLKDEV_ICK_ID(_cid, _did, _clk) { .con_id = _cid, .dev_id = _did, .clk = _clk }
|
||||||
|
|
||||||
static struct clk_lookup lookups[] = {
|
static struct clk_lookup lookups[] = {
|
||||||
/* main clocks */
|
/* main clocks */
|
||||||
CLKDEV_CON_ID("r_clk", &r_clk),
|
CLKDEV_CON_ID("r_clk", &r_clk),
|
||||||
|
|
||||||
|
/* DIV6 clocks */
|
||||||
|
CLKDEV_ICK_ID("dsit_clk", "sh-mipi-dsi.0", &div6_clks[DIV6_DSIT]),
|
||||||
|
CLKDEV_ICK_ID("dsit_clk", "sh-mipi-dsi.1", &div6_clks[DIV6_DSIT]),
|
||||||
|
CLKDEV_ICK_ID("dsi0p_clk", "sh-mipi-dsi.0", &div6_clks[DIV6_DSI0P]),
|
||||||
|
CLKDEV_ICK_ID("dsi1p_clk", "sh-mipi-dsi.1", &div6_clks[DIV6_DSI1P]),
|
||||||
|
|
||||||
/* MSTP32 clocks */
|
/* MSTP32 clocks */
|
||||||
CLKDEV_DEV_ID("i2c-sh_mobile.2", &mstp_clks[MSTP001]), /* I2C2 */
|
CLKDEV_DEV_ID("i2c-sh_mobile.2", &mstp_clks[MSTP001]), /* I2C2 */
|
||||||
|
CLKDEV_DEV_ID("sh_mobile_lcdc_fb.0", &mstp_clks[MSTP100]), /* LCDC0 */
|
||||||
CLKDEV_DEV_ID("sh_tmu.0", &mstp_clks[MSTP125]), /* TMU00 */
|
CLKDEV_DEV_ID("sh_tmu.0", &mstp_clks[MSTP125]), /* TMU00 */
|
||||||
CLKDEV_DEV_ID("sh_tmu.1", &mstp_clks[MSTP125]), /* TMU01 */
|
CLKDEV_DEV_ID("sh_tmu.1", &mstp_clks[MSTP125]), /* TMU01 */
|
||||||
CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[MSTP116]), /* I2C0 */
|
CLKDEV_DEV_ID("i2c-sh_mobile.0", &mstp_clks[MSTP116]), /* I2C0 */
|
||||||
|
CLKDEV_DEV_ID("sh-mipi-dsi.0", &mstp_clks[MSTP118]), /* DSITX */
|
||||||
CLKDEV_DEV_ID("sh-sci.7", &mstp_clks[MSTP219]), /* SCIFA7 */
|
CLKDEV_DEV_ID("sh-sci.7", &mstp_clks[MSTP219]), /* SCIFA7 */
|
||||||
CLKDEV_DEV_ID("sh-sci.5", &mstp_clks[MSTP207]), /* SCIFA5 */
|
CLKDEV_DEV_ID("sh-sci.5", &mstp_clks[MSTP207]), /* SCIFA5 */
|
||||||
CLKDEV_DEV_ID("sh-sci.8", &mstp_clks[MSTP206]), /* SCIFB */
|
CLKDEV_DEV_ID("sh-sci.8", &mstp_clks[MSTP206]), /* SCIFB */
|
||||||
@ -308,6 +328,7 @@ static struct clk_lookup lookups[] = {
|
|||||||
CLKDEV_DEV_ID("sh-sci.4", &mstp_clks[MSTP200]), /* SCIFA4 */
|
CLKDEV_DEV_ID("sh-sci.4", &mstp_clks[MSTP200]), /* SCIFA4 */
|
||||||
CLKDEV_DEV_ID("sh-sci.6", &mstp_clks[MSTP331]), /* SCIFA6 */
|
CLKDEV_DEV_ID("sh-sci.6", &mstp_clks[MSTP331]), /* SCIFA6 */
|
||||||
CLKDEV_DEV_ID("sh_cmt.10", &mstp_clks[MSTP329]), /* CMT10 */
|
CLKDEV_DEV_ID("sh_cmt.10", &mstp_clks[MSTP329]), /* CMT10 */
|
||||||
|
CLKDEV_DEV_ID("sh_irda.0", &mstp_clks[MSTP325]), /* IrDA */
|
||||||
CLKDEV_DEV_ID("i2c-sh_mobile.1", &mstp_clks[MSTP323]), /* I2C1 */
|
CLKDEV_DEV_ID("i2c-sh_mobile.1", &mstp_clks[MSTP323]), /* I2C1 */
|
||||||
CLKDEV_DEV_ID("sh_mmcif.0", &mstp_clks[MSTP312]), /* MMCIF0 */
|
CLKDEV_DEV_ID("sh_mmcif.0", &mstp_clks[MSTP312]), /* MMCIF0 */
|
||||||
CLKDEV_DEV_ID("i2c-sh_mobile.3", &mstp_clks[MSTP411]), /* I2C3 */
|
CLKDEV_DEV_ID("i2c-sh_mobile.3", &mstp_clks[MSTP411]), /* I2C3 */
|
||||||
|
@ -365,6 +365,7 @@ static struct intc_desc intca_desc __initdata = {
|
|||||||
|
|
||||||
enum {
|
enum {
|
||||||
UNUSED_INTCS = 0,
|
UNUSED_INTCS = 0,
|
||||||
|
ENABLED_INTCS,
|
||||||
|
|
||||||
INTCS,
|
INTCS,
|
||||||
|
|
||||||
@ -413,7 +414,7 @@ enum {
|
|||||||
CMT4,
|
CMT4,
|
||||||
DSITX1_DSITX1_0,
|
DSITX1_DSITX1_0,
|
||||||
DSITX1_DSITX1_1,
|
DSITX1_DSITX1_1,
|
||||||
/* MFIS2 */
|
MFIS2_INTCS, /* Priority always enabled using ENABLED_INTCS */
|
||||||
CPORTS2R,
|
CPORTS2R,
|
||||||
/* CEC */
|
/* CEC */
|
||||||
JPU6E,
|
JPU6E,
|
||||||
@ -477,7 +478,7 @@ static struct intc_vect intcs_vectors[] = {
|
|||||||
INTCS_VECT(CMT4, 0x1980),
|
INTCS_VECT(CMT4, 0x1980),
|
||||||
INTCS_VECT(DSITX1_DSITX1_0, 0x19a0),
|
INTCS_VECT(DSITX1_DSITX1_0, 0x19a0),
|
||||||
INTCS_VECT(DSITX1_DSITX1_1, 0x19c0),
|
INTCS_VECT(DSITX1_DSITX1_1, 0x19c0),
|
||||||
/* MFIS2 */
|
INTCS_VECT(MFIS2_INTCS, 0x1a00),
|
||||||
INTCS_VECT(CPORTS2R, 0x1a20),
|
INTCS_VECT(CPORTS2R, 0x1a20),
|
||||||
/* CEC */
|
/* CEC */
|
||||||
INTCS_VECT(JPU6E, 0x1a80),
|
INTCS_VECT(JPU6E, 0x1a80),
|
||||||
@ -543,7 +544,7 @@ static struct intc_mask_reg intcs_mask_registers[] = {
|
|||||||
{ 0, TMU1_TUNI2, TMU1_TUNI1, TMU1_TUNI0,
|
{ 0, TMU1_TUNI2, TMU1_TUNI1, TMU1_TUNI0,
|
||||||
CMT4, DSITX1_DSITX1_0, DSITX1_DSITX1_1, 0 } },
|
CMT4, DSITX1_DSITX1_0, DSITX1_DSITX1_1, 0 } },
|
||||||
{ 0xffd5019c, 0xffd501dc, 8, /* IMR7SA3 / IMCR7SA3 */
|
{ 0xffd5019c, 0xffd501dc, 8, /* IMR7SA3 / IMCR7SA3 */
|
||||||
{ 0, CPORTS2R, 0, 0,
|
{ MFIS2_INTCS, CPORTS2R, 0, 0,
|
||||||
JPU6E, 0, 0, 0 } },
|
JPU6E, 0, 0, 0 } },
|
||||||
{ 0xffd20104, 0, 16, /* INTAMASK */
|
{ 0xffd20104, 0, 16, /* INTAMASK */
|
||||||
{ 0, 0, 0, 0, 0, 0, 0, 0,
|
{ 0, 0, 0, 0, 0, 0, 0, 0,
|
||||||
@ -571,7 +572,8 @@ static struct intc_prio_reg intcs_prio_registers[] = {
|
|||||||
{ 0xffd50030, 0, 16, 4, /* IPRMS3 */ { TMU1, 0, 0, 0 } },
|
{ 0xffd50030, 0, 16, 4, /* IPRMS3 */ { TMU1, 0, 0, 0 } },
|
||||||
{ 0xffd50034, 0, 16, 4, /* IPRNS3 */ { CMT4, DSITX1_DSITX1_0,
|
{ 0xffd50034, 0, 16, 4, /* IPRNS3 */ { CMT4, DSITX1_DSITX1_0,
|
||||||
DSITX1_DSITX1_1, 0 } },
|
DSITX1_DSITX1_1, 0 } },
|
||||||
{ 0xffd50038, 0, 16, 4, /* IPROS3 */ { 0, CPORTS2R, 0, 0 } },
|
{ 0xffd50038, 0, 16, 4, /* IPROS3 */ { ENABLED_INTCS, CPORTS2R,
|
||||||
|
0, 0 } },
|
||||||
{ 0xffd5003c, 0, 16, 4, /* IPRPS3 */ { JPU6E, 0, 0, 0 } },
|
{ 0xffd5003c, 0, 16, 4, /* IPRPS3 */ { JPU6E, 0, 0, 0 } },
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -590,6 +592,7 @@ static struct resource intcs_resources[] __initdata = {
|
|||||||
|
|
||||||
static struct intc_desc intcs_desc __initdata = {
|
static struct intc_desc intcs_desc __initdata = {
|
||||||
.name = "sh7372-intcs",
|
.name = "sh7372-intcs",
|
||||||
|
.force_enable = ENABLED_INTCS,
|
||||||
.resource = intcs_resources,
|
.resource = intcs_resources,
|
||||||
.num_resources = ARRAY_SIZE(intcs_resources),
|
.num_resources = ARRAY_SIZE(intcs_resources),
|
||||||
.hw = INTC_HW_DESC(intcs_vectors, intcs_groups, intcs_mask_registers,
|
.hw = INTC_HW_DESC(intcs_vectors, intcs_groups, intcs_mask_registers,
|
||||||
|
@ -252,10 +252,11 @@ static irqreturn_t sh73a0_intcs_demux(int irq, void *dev_id)
|
|||||||
|
|
||||||
void __init sh73a0_init_irq(void)
|
void __init sh73a0_init_irq(void)
|
||||||
{
|
{
|
||||||
void __iomem *gic_base = __io(0xf0001000);
|
void __iomem *gic_dist_base = __io(0xf0001000);
|
||||||
|
void __iomem *gic_cpu_base = __io(0xf0000100);
|
||||||
void __iomem *intevtsa = ioremap_nocache(0xffd20100, PAGE_SIZE);
|
void __iomem *intevtsa = ioremap_nocache(0xffd20100, PAGE_SIZE);
|
||||||
|
|
||||||
gic_init(0, 29, gic_base, gic_base);
|
gic_init(0, 29, gic_dist_base, gic_cpu_base);
|
||||||
|
|
||||||
register_intc_controller(&intcs_desc);
|
register_intc_controller(&intcs_desc);
|
||||||
|
|
||||||
|
@ -207,9 +207,9 @@ static int tegra_gpio_irq_set_type(struct irq_data *d, unsigned int type)
|
|||||||
spin_unlock_irqrestore(&bank->lvl_lock[port], flags);
|
spin_unlock_irqrestore(&bank->lvl_lock[port], flags);
|
||||||
|
|
||||||
if (type & (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH))
|
if (type & (IRQ_TYPE_LEVEL_LOW | IRQ_TYPE_LEVEL_HIGH))
|
||||||
__set_irq_handler_unlocked(irq, handle_level_irq);
|
__set_irq_handler_unlocked(d->irq, handle_level_irq);
|
||||||
else if (type & (IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING))
|
else if (type & (IRQ_TYPE_EDGE_FALLING | IRQ_TYPE_EDGE_RISING))
|
||||||
__set_irq_handler_unlocked(irq, handle_edge_irq);
|
__set_irq_handler_unlocked(d->irq, handle_edge_irq);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
#ifndef __MACH_CLK_H
|
#ifndef __MACH_CLK_H
|
||||||
#define __MACH_CLK_H
|
#define __MACH_CLK_H
|
||||||
|
|
||||||
|
struct clk;
|
||||||
|
|
||||||
void tegra_periph_reset_deassert(struct clk *c);
|
void tegra_periph_reset_deassert(struct clk *c);
|
||||||
void tegra_periph_reset_assert(struct clk *c);
|
void tegra_periph_reset_assert(struct clk *c);
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@
|
|||||||
#ifndef __MACH_CLKDEV_H
|
#ifndef __MACH_CLKDEV_H
|
||||||
#define __MACH_CLKDEV_H
|
#define __MACH_CLKDEV_H
|
||||||
|
|
||||||
|
struct clk;
|
||||||
|
|
||||||
static inline int __clk_get(struct clk *clk)
|
static inline int __clk_get(struct clk *clk)
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
|
61
arch/arm/mach-tegra/include/mach/kbc.h
Normal file
61
arch/arm/mach-tegra/include/mach/kbc.h
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* Platform definitions for tegra-kbc keyboard input driver
|
||||||
|
*
|
||||||
|
* Copyright (c) 2010-2011, NVIDIA 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.,
|
||||||
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef ASMARM_ARCH_TEGRA_KBC_H
|
||||||
|
#define ASMARM_ARCH_TEGRA_KBC_H
|
||||||
|
|
||||||
|
#include <linux/types.h>
|
||||||
|
#include <linux/input/matrix_keypad.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_TEGRA_2x_SOC
|
||||||
|
#define KBC_MAX_GPIO 24
|
||||||
|
#define KBC_MAX_KPENT 8
|
||||||
|
#else
|
||||||
|
#define KBC_MAX_GPIO 20
|
||||||
|
#define KBC_MAX_KPENT 7
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define KBC_MAX_ROW 16
|
||||||
|
#define KBC_MAX_COL 8
|
||||||
|
#define KBC_MAX_KEY (KBC_MAX_ROW * KBC_MAX_COL)
|
||||||
|
|
||||||
|
struct tegra_kbc_pin_cfg {
|
||||||
|
bool is_row;
|
||||||
|
unsigned char num;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct tegra_kbc_wake_key {
|
||||||
|
u8 row:4;
|
||||||
|
u8 col:4;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct tegra_kbc_platform_data {
|
||||||
|
unsigned int debounce_cnt;
|
||||||
|
unsigned int repeat_cnt;
|
||||||
|
|
||||||
|
unsigned int wake_cnt; /* 0:wake on any key >1:wake on wake_cfg */
|
||||||
|
const struct tegra_kbc_wake_key *wake_cfg;
|
||||||
|
|
||||||
|
struct tegra_kbc_pin_cfg pin_cfg[KBC_MAX_GPIO];
|
||||||
|
const struct matrix_keymap_data *keymap_data;
|
||||||
|
|
||||||
|
bool wakeup;
|
||||||
|
};
|
||||||
|
#endif
|
@ -46,24 +46,24 @@
|
|||||||
#define ICTLR_COP_IER_CLR 0x38
|
#define ICTLR_COP_IER_CLR 0x38
|
||||||
#define ICTLR_COP_IEP_CLASS 0x3c
|
#define ICTLR_COP_IEP_CLASS 0x3c
|
||||||
|
|
||||||
static void (*gic_mask_irq)(struct irq_data *d);
|
static void (*tegra_gic_mask_irq)(struct irq_data *d);
|
||||||
static void (*gic_unmask_irq)(struct irq_data *d);
|
static void (*tegra_gic_unmask_irq)(struct irq_data *d);
|
||||||
|
|
||||||
#define irq_to_ictlr(irq) (((irq)-32) >> 5)
|
#define irq_to_ictlr(irq) (((irq) - 32) >> 5)
|
||||||
static void __iomem *tegra_ictlr_base = IO_ADDRESS(TEGRA_PRIMARY_ICTLR_BASE);
|
static void __iomem *tegra_ictlr_base = IO_ADDRESS(TEGRA_PRIMARY_ICTLR_BASE);
|
||||||
#define ictlr_to_virt(ictlr) (tegra_ictlr_base + (ictlr)*0x100)
|
#define ictlr_to_virt(ictlr) (tegra_ictlr_base + (ictlr) * 0x100)
|
||||||
|
|
||||||
static void tegra_mask(struct irq_data *d)
|
static void tegra_mask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
void __iomem *addr = ictlr_to_virt(irq_to_ictlr(d->irq));
|
void __iomem *addr = ictlr_to_virt(irq_to_ictlr(d->irq));
|
||||||
gic_mask_irq(d);
|
tegra_gic_mask_irq(d);
|
||||||
writel(1<<(d->irq&31), addr+ICTLR_CPU_IER_CLR);
|
writel(1 << (d->irq & 31), addr+ICTLR_CPU_IER_CLR);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void tegra_unmask(struct irq_data *d)
|
static void tegra_unmask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
void __iomem *addr = ictlr_to_virt(irq_to_ictlr(d->irq));
|
void __iomem *addr = ictlr_to_virt(irq_to_ictlr(d->irq));
|
||||||
gic_unmask_irq(d);
|
tegra_gic_unmask_irq(d);
|
||||||
writel(1<<(d->irq&31), addr+ICTLR_CPU_IER_SET);
|
writel(1<<(d->irq&31), addr+ICTLR_CPU_IER_SET);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -98,8 +98,8 @@ void __init tegra_init_irq(void)
|
|||||||
IO_ADDRESS(TEGRA_ARM_PERIF_BASE + 0x100));
|
IO_ADDRESS(TEGRA_ARM_PERIF_BASE + 0x100));
|
||||||
|
|
||||||
gic = get_irq_chip(29);
|
gic = get_irq_chip(29);
|
||||||
gic_unmask_irq = gic->irq_unmask;
|
tegra_gic_unmask_irq = gic->irq_unmask;
|
||||||
gic_mask_irq = gic->irq_mask;
|
tegra_gic_mask_irq = gic->irq_mask;
|
||||||
tegra_irq.irq_ack = gic->irq_ack;
|
tegra_irq.irq_ack = gic->irq_ack;
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
tegra_irq.irq_set_affinity = gic->irq_set_affinity;
|
tegra_irq.irq_set_affinity = gic->irq_set_affinity;
|
||||||
|
@ -2,17 +2,19 @@ menu "Versatile platform type"
|
|||||||
depends on ARCH_VERSATILE
|
depends on ARCH_VERSATILE
|
||||||
|
|
||||||
config ARCH_VERSATILE_PB
|
config ARCH_VERSATILE_PB
|
||||||
bool "Support Versatile/PB platform"
|
bool "Support Versatile Platform Baseboard for ARM926EJ-S"
|
||||||
select CPU_ARM926T
|
select CPU_ARM926T
|
||||||
select MIGHT_HAVE_PCI
|
select MIGHT_HAVE_PCI
|
||||||
default y
|
default y
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) Versatile/PB platform.
|
Include support for the ARM(R) Versatile Platform Baseboard
|
||||||
|
for the ARM926EJ-S.
|
||||||
|
|
||||||
config MACH_VERSATILE_AB
|
config MACH_VERSATILE_AB
|
||||||
bool "Support Versatile/AB platform"
|
bool "Support Versatile Application Baseboard for ARM926EJ-S"
|
||||||
select CPU_ARM926T
|
select CPU_ARM926T
|
||||||
help
|
help
|
||||||
Include support for the ARM(R) Versatile/AP platform.
|
Include support for the ARM(R) Versatile Application Baseboard
|
||||||
|
for the ARM926EJ-S.
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
@ -39,7 +39,7 @@ volatile int __cpuinitdata pen_release = -1;
|
|||||||
* observers, irrespective of whether they're taking part in coherency
|
* observers, irrespective of whether they're taking part in coherency
|
||||||
* or not. This is necessary for the hotplug code to work reliably.
|
* or not. This is necessary for the hotplug code to work reliably.
|
||||||
*/
|
*/
|
||||||
static void write_pen_release(int val)
|
static void __cpuinit write_pen_release(int val)
|
||||||
{
|
{
|
||||||
pen_release = val;
|
pen_release = val;
|
||||||
smp_wmb();
|
smp_wmb();
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
#include <asm/hardware/arm_timer.h>
|
#include <asm/hardware/arm_timer.h>
|
||||||
#include <asm/hardware/timer-sp.h>
|
#include <asm/hardware/timer-sp.h>
|
||||||
|
#include <asm/hardware/sp810.h>
|
||||||
|
|
||||||
#include <mach/motherboard.h>
|
#include <mach/motherboard.h>
|
||||||
|
|
||||||
@ -50,8 +51,16 @@ void __init v2m_map_io(struct map_desc *tile, size_t num)
|
|||||||
|
|
||||||
static void __init v2m_timer_init(void)
|
static void __init v2m_timer_init(void)
|
||||||
{
|
{
|
||||||
|
u32 scctrl;
|
||||||
|
|
||||||
versatile_sched_clock_init(MMIO_P2V(V2M_SYS_24MHZ), 24000000);
|
versatile_sched_clock_init(MMIO_P2V(V2M_SYS_24MHZ), 24000000);
|
||||||
|
|
||||||
|
/* Select 1MHz TIMCLK as the reference clock for SP804 timers */
|
||||||
|
scctrl = readl(MMIO_P2V(V2M_SYSCTL + SCCTRL));
|
||||||
|
scctrl |= SCCTRL_TIMEREN0SEL_TIMCLK;
|
||||||
|
scctrl |= SCCTRL_TIMEREN1SEL_TIMCLK;
|
||||||
|
writel(scctrl, MMIO_P2V(V2M_SYSCTL + SCCTRL));
|
||||||
|
|
||||||
writel(0, MMIO_P2V(V2M_TIMER0) + TIMER_CTRL);
|
writel(0, MMIO_P2V(V2M_TIMER0) + TIMER_CTRL);
|
||||||
writel(0, MMIO_P2V(V2M_TIMER1) + TIMER_CTRL);
|
writel(0, MMIO_P2V(V2M_TIMER1) + TIMER_CTRL);
|
||||||
|
|
||||||
|
@ -297,6 +297,12 @@ void __init arm_memblock_init(struct meminfo *mi, struct machine_desc *mdesc)
|
|||||||
memblock_reserve(__pa(_stext), _end - _stext);
|
memblock_reserve(__pa(_stext), _end - _stext);
|
||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_BLK_DEV_INITRD
|
#ifdef CONFIG_BLK_DEV_INITRD
|
||||||
|
if (phys_initrd_size &&
|
||||||
|
memblock_is_region_reserved(phys_initrd_start, phys_initrd_size)) {
|
||||||
|
pr_err("INITRD: 0x%08lx+0x%08lx overlaps in-use memory region - disabling initrd\n",
|
||||||
|
phys_initrd_start, phys_initrd_size);
|
||||||
|
phys_initrd_start = phys_initrd_size = 0;
|
||||||
|
}
|
||||||
if (phys_initrd_size) {
|
if (phys_initrd_size) {
|
||||||
memblock_reserve(phys_initrd_start, phys_initrd_size);
|
memblock_reserve(phys_initrd_start, phys_initrd_size);
|
||||||
|
|
||||||
|
@ -144,12 +144,9 @@ config OMAP_IOMMU_DEBUG
|
|||||||
config OMAP_IOMMU_IVA2
|
config OMAP_IOMMU_IVA2
|
||||||
bool
|
bool
|
||||||
|
|
||||||
choice
|
|
||||||
prompt "System timer"
|
|
||||||
default OMAP_32K_TIMER if !ARCH_OMAP15XX
|
|
||||||
|
|
||||||
config OMAP_MPU_TIMER
|
config OMAP_MPU_TIMER
|
||||||
bool "Use mpu timer"
|
bool "Use mpu timer"
|
||||||
|
depends on ARCH_OMAP1
|
||||||
help
|
help
|
||||||
Select this option if you want to use the OMAP mpu timer. This
|
Select this option if you want to use the OMAP mpu timer. This
|
||||||
timer provides more intra-tick resolution than the 32KHz timer,
|
timer provides more intra-tick resolution than the 32KHz timer,
|
||||||
@ -158,6 +155,7 @@ config OMAP_MPU_TIMER
|
|||||||
config OMAP_32K_TIMER
|
config OMAP_32K_TIMER
|
||||||
bool "Use 32KHz timer"
|
bool "Use 32KHz timer"
|
||||||
depends on ARCH_OMAP16XX || ARCH_OMAP2PLUS
|
depends on ARCH_OMAP16XX || ARCH_OMAP2PLUS
|
||||||
|
default y if (ARCH_OMAP16XX || ARCH_OMAP2PLUS)
|
||||||
help
|
help
|
||||||
Select this option if you want to enable the OMAP 32KHz timer.
|
Select this option if you want to enable the OMAP 32KHz timer.
|
||||||
This timer saves power compared to the OMAP_MPU_TIMER, and has
|
This timer saves power compared to the OMAP_MPU_TIMER, and has
|
||||||
@ -165,8 +163,6 @@ config OMAP_32K_TIMER
|
|||||||
intra-tick resolution than OMAP_MPU_TIMER. The 32KHz timer is
|
intra-tick resolution than OMAP_MPU_TIMER. The 32KHz timer is
|
||||||
currently only available for OMAP16XX, 24XX, 34XX and OMAP4.
|
currently only available for OMAP16XX, 24XX, 34XX and OMAP4.
|
||||||
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config OMAP3_L2_AUX_SECURE_SAVE_RESTORE
|
config OMAP3_L2_AUX_SECURE_SAVE_RESTORE
|
||||||
bool "OMAP3 HS/EMU save and restore for L2 AUX control register"
|
bool "OMAP3 HS/EMU save and restore for L2 AUX control register"
|
||||||
depends on ARCH_OMAP3 && PM
|
depends on ARCH_OMAP3 && PM
|
||||||
|
@ -36,8 +36,6 @@
|
|||||||
|
|
||||||
#define OMAP16XX_TIMER_32K_SYNCHRONIZED 0xfffbc410
|
#define OMAP16XX_TIMER_32K_SYNCHRONIZED 0xfffbc410
|
||||||
|
|
||||||
#if !(defined(CONFIG_ARCH_OMAP730) || defined(CONFIG_ARCH_OMAP15XX))
|
|
||||||
|
|
||||||
#include <linux/clocksource.h>
|
#include <linux/clocksource.h>
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -122,12 +120,24 @@ static DEFINE_CLOCK_DATA(cd);
|
|||||||
#define SC_MULT 4000000000u
|
#define SC_MULT 4000000000u
|
||||||
#define SC_SHIFT 17
|
#define SC_SHIFT 17
|
||||||
|
|
||||||
unsigned long long notrace sched_clock(void)
|
static inline unsigned long long notrace _omap_32k_sched_clock(void)
|
||||||
{
|
{
|
||||||
u32 cyc = clocksource_32k.read(&clocksource_32k);
|
u32 cyc = clocksource_32k.read(&clocksource_32k);
|
||||||
return cyc_to_fixed_sched_clock(&cd, cyc, (u32)~0, SC_MULT, SC_SHIFT);
|
return cyc_to_fixed_sched_clock(&cd, cyc, (u32)~0, SC_MULT, SC_SHIFT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef CONFIG_OMAP_MPU_TIMER
|
||||||
|
unsigned long long notrace sched_clock(void)
|
||||||
|
{
|
||||||
|
return _omap_32k_sched_clock();
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
unsigned long long notrace omap_32k_sched_clock(void)
|
||||||
|
{
|
||||||
|
return _omap_32k_sched_clock();
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static void notrace omap_update_sched_clock(void)
|
static void notrace omap_update_sched_clock(void)
|
||||||
{
|
{
|
||||||
u32 cyc = clocksource_32k.read(&clocksource_32k);
|
u32 cyc = clocksource_32k.read(&clocksource_32k);
|
||||||
@ -160,7 +170,7 @@ void read_persistent_clock(struct timespec *ts)
|
|||||||
*ts = *tsp;
|
*ts = *tsp;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init omap_init_clocksource_32k(void)
|
int __init omap_init_clocksource_32k(void)
|
||||||
{
|
{
|
||||||
static char err[] __initdata = KERN_ERR
|
static char err[] __initdata = KERN_ERR
|
||||||
"%s: can't register clocksource!\n";
|
"%s: can't register clocksource!\n";
|
||||||
@ -195,7 +205,3 @@ static int __init omap_init_clocksource_32k(void)
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
arch_initcall(omap_init_clocksource_32k);
|
|
||||||
|
|
||||||
#endif /* !(defined(CONFIG_ARCH_OMAP730) || defined(CONFIG_ARCH_OMAP15XX)) */
|
|
||||||
|
|
||||||
|
@ -53,7 +53,7 @@ enum { DMA_CHAIN_STARTED, DMA_CHAIN_NOTSTARTED };
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define OMAP_DMA_ACTIVE 0x01
|
#define OMAP_DMA_ACTIVE 0x01
|
||||||
#define OMAP2_DMA_CSR_CLEAR_MASK 0xffe
|
#define OMAP2_DMA_CSR_CLEAR_MASK 0xffffffff
|
||||||
|
|
||||||
#define OMAP_FUNC_MUX_ARM_BASE (0xfffe1000 + 0xec)
|
#define OMAP_FUNC_MUX_ARM_BASE (0xfffe1000 + 0xec)
|
||||||
|
|
||||||
@ -1873,7 +1873,7 @@ static int omap2_dma_handle_ch(int ch)
|
|||||||
printk(KERN_INFO "DMA misaligned error with device %d\n",
|
printk(KERN_INFO "DMA misaligned error with device %d\n",
|
||||||
dma_chan[ch].dev_id);
|
dma_chan[ch].dev_id);
|
||||||
|
|
||||||
p->dma_write(OMAP2_DMA_CSR_CLEAR_MASK, CSR, ch);
|
p->dma_write(status, CSR, ch);
|
||||||
p->dma_write(1 << ch, IRQSTATUS_L0, ch);
|
p->dma_write(1 << ch, IRQSTATUS_L0, ch);
|
||||||
/* read back the register to flush the write */
|
/* read back the register to flush the write */
|
||||||
p->dma_read(IRQSTATUS_L0, ch);
|
p->dma_read(IRQSTATUS_L0, ch);
|
||||||
@ -1893,10 +1893,9 @@ static int omap2_dma_handle_ch(int ch)
|
|||||||
OMAP_DMA_CHAIN_INCQHEAD(chain_id);
|
OMAP_DMA_CHAIN_INCQHEAD(chain_id);
|
||||||
|
|
||||||
status = p->dma_read(CSR, ch);
|
status = p->dma_read(CSR, ch);
|
||||||
|
p->dma_write(status, CSR, ch);
|
||||||
}
|
}
|
||||||
|
|
||||||
p->dma_write(status, CSR, ch);
|
|
||||||
|
|
||||||
if (likely(dma_chan[ch].callback != NULL))
|
if (likely(dma_chan[ch].callback != NULL))
|
||||||
dma_chan[ch].callback(ch, status, dma_chan[ch].data);
|
dma_chan[ch].callback(ch, status, dma_chan[ch].data);
|
||||||
|
|
||||||
|
@ -35,6 +35,9 @@ struct sys_timer;
|
|||||||
|
|
||||||
extern void omap_map_common_io(void);
|
extern void omap_map_common_io(void);
|
||||||
extern struct sys_timer omap_timer;
|
extern struct sys_timer omap_timer;
|
||||||
|
extern bool omap_32k_timer_init(void);
|
||||||
|
extern int __init omap_init_clocksource_32k(void);
|
||||||
|
extern unsigned long long notrace omap_32k_sched_clock(void);
|
||||||
|
|
||||||
extern void omap_reserve(void);
|
extern void omap_reserve(void);
|
||||||
|
|
||||||
|
@ -8,6 +8,7 @@
|
|||||||
#ifndef __ASM_AVR32_PGALLOC_H
|
#ifndef __ASM_AVR32_PGALLOC_H
|
||||||
#define __ASM_AVR32_PGALLOC_H
|
#define __ASM_AVR32_PGALLOC_H
|
||||||
|
|
||||||
|
#include <linux/mm.h>
|
||||||
#include <linux/quicklist.h>
|
#include <linux/quicklist.h>
|
||||||
#include <asm/page.h>
|
#include <asm/page.h>
|
||||||
#include <asm/pgtable.h>
|
#include <asm/pgtable.h>
|
||||||
|
@ -80,7 +80,7 @@ asmlinkage unsigned int do_IRQ(int irq, struct pt_regs *regs)
|
|||||||
#ifdef CONFIG_DEBUG_STACKOVERFLOW
|
#ifdef CONFIG_DEBUG_STACKOVERFLOW
|
||||||
/* FIXME M32R */
|
/* FIXME M32R */
|
||||||
#endif
|
#endif
|
||||||
__do_IRQ(irq);
|
generic_handle_irq(irq);
|
||||||
irq_exit();
|
irq_exit();
|
||||||
set_irq_regs(old_regs);
|
set_irq_regs(old_regs);
|
||||||
|
|
||||||
|
@ -610,17 +610,17 @@ static void amiga_mem_console_write(struct console *co, const char *s,
|
|||||||
|
|
||||||
static int __init amiga_savekmsg_setup(char *arg)
|
static int __init amiga_savekmsg_setup(char *arg)
|
||||||
{
|
{
|
||||||
static struct resource debug_res = { .name = "Debug" };
|
|
||||||
|
|
||||||
if (!MACH_IS_AMIGA || strcmp(arg, "mem"))
|
if (!MACH_IS_AMIGA || strcmp(arg, "mem"))
|
||||||
goto done;
|
return 0;
|
||||||
|
|
||||||
if (!AMIGAHW_PRESENT(CHIP_RAM)) {
|
if (amiga_chip_size < SAVEKMSG_MAXMEM) {
|
||||||
printk("Warning: no chipram present for debugging\n");
|
pr_err("Not enough chipram for debugging\n");
|
||||||
goto done;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
savekmsg = amiga_chip_alloc_res(SAVEKMSG_MAXMEM, &debug_res);
|
/* Just steal the block, the chipram allocator isn't functional yet */
|
||||||
|
amiga_chip_size -= SAVEKMSG_MAXMEM;
|
||||||
|
savekmsg = (void *)ZTWO_VADDR(CHIP_PHYSADDR + amiga_chip_size);
|
||||||
savekmsg->magic1 = SAVEKMSG_MAGIC1;
|
savekmsg->magic1 = SAVEKMSG_MAGIC1;
|
||||||
savekmsg->magic2 = SAVEKMSG_MAGIC2;
|
savekmsg->magic2 = SAVEKMSG_MAGIC2;
|
||||||
savekmsg->magicptr = ZTWO_PADDR(savekmsg);
|
savekmsg->magicptr = ZTWO_PADDR(savekmsg);
|
||||||
@ -628,8 +628,6 @@ static int __init amiga_savekmsg_setup(char *arg)
|
|||||||
|
|
||||||
amiga_console_driver.write = amiga_mem_console_write;
|
amiga_console_driver.write = amiga_mem_console_write;
|
||||||
register_console(&amiga_console_driver);
|
register_console(&amiga_console_driver);
|
||||||
|
|
||||||
done:
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -388,9 +388,9 @@ void __init atari_init_IRQ(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (ATARIHW_PRESENT(SCC) && !atari_SCC_reset_done) {
|
if (ATARIHW_PRESENT(SCC) && !atari_SCC_reset_done) {
|
||||||
scc.cha_a_ctrl = 9;
|
atari_scc.cha_a_ctrl = 9;
|
||||||
MFPDELAY();
|
MFPDELAY();
|
||||||
scc.cha_a_ctrl = (char) 0xc0; /* hardware reset */
|
atari_scc.cha_a_ctrl = (char) 0xc0; /* hardware reset */
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ATARIHW_PRESENT(SCU)) {
|
if (ATARIHW_PRESENT(SCU)) {
|
||||||
|
@ -315,7 +315,7 @@ void __init config_atari(void)
|
|||||||
ATARIHW_SET(SCC_DMA);
|
ATARIHW_SET(SCC_DMA);
|
||||||
printk("SCC_DMA ");
|
printk("SCC_DMA ");
|
||||||
}
|
}
|
||||||
if (scc_test(&scc.cha_a_ctrl)) {
|
if (scc_test(&atari_scc.cha_a_ctrl)) {
|
||||||
ATARIHW_SET(SCC);
|
ATARIHW_SET(SCC);
|
||||||
printk("SCC ");
|
printk("SCC ");
|
||||||
}
|
}
|
||||||
|
@ -53,9 +53,9 @@ static inline void ata_scc_out(char c)
|
|||||||
{
|
{
|
||||||
do {
|
do {
|
||||||
MFPDELAY();
|
MFPDELAY();
|
||||||
} while (!(scc.cha_b_ctrl & 0x04)); /* wait for tx buf empty */
|
} while (!(atari_scc.cha_b_ctrl & 0x04)); /* wait for tx buf empty */
|
||||||
MFPDELAY();
|
MFPDELAY();
|
||||||
scc.cha_b_data = c;
|
atari_scc.cha_b_data = c;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void atari_scc_console_write(struct console *co, const char *str,
|
static void atari_scc_console_write(struct console *co, const char *str,
|
||||||
@ -140,9 +140,9 @@ int atari_scc_console_wait_key(struct console *co)
|
|||||||
{
|
{
|
||||||
do {
|
do {
|
||||||
MFPDELAY();
|
MFPDELAY();
|
||||||
} while (!(scc.cha_b_ctrl & 0x01)); /* wait for rx buf filled */
|
} while (!(atari_scc.cha_b_ctrl & 0x01)); /* wait for rx buf filled */
|
||||||
MFPDELAY();
|
MFPDELAY();
|
||||||
return scc.cha_b_data;
|
return atari_scc.cha_b_data;
|
||||||
}
|
}
|
||||||
|
|
||||||
int atari_midi_console_wait_key(struct console *co)
|
int atari_midi_console_wait_key(struct console *co)
|
||||||
@ -185,9 +185,9 @@ static void __init atari_init_mfp_port(int cflag)
|
|||||||
|
|
||||||
#define SCC_WRITE(reg, val) \
|
#define SCC_WRITE(reg, val) \
|
||||||
do { \
|
do { \
|
||||||
scc.cha_b_ctrl = (reg); \
|
atari_scc.cha_b_ctrl = (reg); \
|
||||||
MFPDELAY(); \
|
MFPDELAY(); \
|
||||||
scc.cha_b_ctrl = (val); \
|
atari_scc.cha_b_ctrl = (val); \
|
||||||
MFPDELAY(); \
|
MFPDELAY(); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
@ -240,7 +240,7 @@ static void __init atari_init_scc_port(int cflag)
|
|||||||
reg3 = (cflag & CSIZE) == CS8 ? 0xc0 : 0x40;
|
reg3 = (cflag & CSIZE) == CS8 ? 0xc0 : 0x40;
|
||||||
reg5 = (cflag & CSIZE) == CS8 ? 0x60 : 0x20 | 0x82 /* assert DTR/RTS */;
|
reg5 = (cflag & CSIZE) == CS8 ? 0x60 : 0x20 | 0x82 /* assert DTR/RTS */;
|
||||||
|
|
||||||
(void)scc.cha_b_ctrl; /* reset reg pointer */
|
(void)atari_scc.cha_b_ctrl; /* reset reg pointer */
|
||||||
SCC_WRITE(9, 0xc0); /* reset */
|
SCC_WRITE(9, 0xc0); /* reset */
|
||||||
LONG_DELAY(); /* extra delay after WR9 access */
|
LONG_DELAY(); /* extra delay after WR9 access */
|
||||||
SCC_WRITE(4, (cflag & PARENB) ? ((cflag & PARODD) ? 0x01 : 0x03)
|
SCC_WRITE(4, (cflag & PARENB) ? ((cflag & PARODD) ? 0x01 : 0x03)
|
||||||
|
@ -449,7 +449,7 @@ struct SCC
|
|||||||
u_char char_dummy3;
|
u_char char_dummy3;
|
||||||
u_char cha_b_data;
|
u_char cha_b_data;
|
||||||
};
|
};
|
||||||
# define scc ((*(volatile struct SCC*)SCC_BAS))
|
# define atari_scc ((*(volatile struct SCC*)SCC_BAS))
|
||||||
|
|
||||||
/* The ESCC (Z85230) in an Atari ST. The channels are reversed! */
|
/* The ESCC (Z85230) in an Atari ST. The channels are reversed! */
|
||||||
# define st_escc ((*(volatile struct SCC*)0xfffffa31))
|
# define st_escc ((*(volatile struct SCC*)0xfffffa31))
|
||||||
|
@ -81,18 +81,6 @@ static inline char *strncpy(char *dest, const char *src, size_t n)
|
|||||||
strcpy(__d + strlen(__d), (s)); \
|
strcpy(__d + strlen(__d), (s)); \
|
||||||
})
|
})
|
||||||
|
|
||||||
#define __HAVE_ARCH_STRCHR
|
|
||||||
static inline char *strchr(const char *s, int c)
|
|
||||||
{
|
|
||||||
char sc, ch = c;
|
|
||||||
|
|
||||||
for (; (sc = *s++) != ch; ) {
|
|
||||||
if (!sc)
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
return (char *)s - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef CONFIG_COLDFIRE
|
#ifndef CONFIG_COLDFIRE
|
||||||
#define __HAVE_ARCH_STRCMP
|
#define __HAVE_ARCH_STRCMP
|
||||||
static inline int strcmp(const char *cs, const char *ct)
|
static inline int strcmp(const char *cs, const char *ct)
|
||||||
|
@ -77,8 +77,18 @@ real_start:
|
|||||||
We ensure r7 points to a valid FDT, just in case the bootloader
|
We ensure r7 points to a valid FDT, just in case the bootloader
|
||||||
is broken or non-existent */
|
is broken or non-existent */
|
||||||
beqi r7, no_fdt_arg /* NULL pointer? don't copy */
|
beqi r7, no_fdt_arg /* NULL pointer? don't copy */
|
||||||
lw r11, r0, r7 /* Does r7 point to a */
|
/* Does r7 point to a valid FDT? Load HEADER magic number */
|
||||||
rsubi r11, r11, OF_DT_HEADER /* valid FDT? */
|
/* Run time Big/Little endian platform */
|
||||||
|
/* Save 1 as word and load byte - 0 - BIG, 1 - LITTLE */
|
||||||
|
addik r11, r0, 0x1 /* BIG/LITTLE checking value */
|
||||||
|
/* __bss_start will be zeroed later - it is just temp location */
|
||||||
|
swi r11, r0, TOPHYS(__bss_start)
|
||||||
|
lbui r11, r0, TOPHYS(__bss_start)
|
||||||
|
beqid r11, big_endian /* DO NOT break delay stop dependency */
|
||||||
|
lw r11, r0, r7 /* Big endian load in delay slot */
|
||||||
|
lwr r11, r0, r7 /* Little endian load */
|
||||||
|
big_endian:
|
||||||
|
rsubi r11, r11, OF_DT_HEADER /* Check FDT header */
|
||||||
beqi r11, _prepare_copy_fdt
|
beqi r11, _prepare_copy_fdt
|
||||||
or r7, r0, r0 /* clear R7 when not valid DTB */
|
or r7, r0, r0 /* clear R7 when not valid DTB */
|
||||||
bnei r11, no_fdt_arg /* No - get out of here */
|
bnei r11, no_fdt_arg /* No - get out of here */
|
||||||
|
@ -147,10 +147,6 @@
|
|||||||
#if CONFIG_XILINX_MICROBLAZE0_USE_BARREL > 0
|
#if CONFIG_XILINX_MICROBLAZE0_USE_BARREL > 0
|
||||||
#define BSRLI(rD, rA, imm) \
|
#define BSRLI(rD, rA, imm) \
|
||||||
bsrli rD, rA, imm
|
bsrli rD, rA, imm
|
||||||
#elif CONFIG_XILINX_MICROBLAZE0_USE_DIV > 0
|
|
||||||
#define BSRLI(rD, rA, imm) \
|
|
||||||
ori rD, r0, (1 << imm); \
|
|
||||||
idivu rD, rD, rA
|
|
||||||
#else
|
#else
|
||||||
#define BSRLI(rD, rA, imm) BSRLI ## imm (rD, rA)
|
#define BSRLI(rD, rA, imm) BSRLI ## imm (rD, rA)
|
||||||
/* Only the used shift constants defined here - add more if needed */
|
/* Only the used shift constants defined here - add more if needed */
|
||||||
|
@ -29,6 +29,10 @@
|
|||||||
* between mem locations with size of xfer spec'd in bytes
|
* between mem locations with size of xfer spec'd in bytes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifdef __MICROBLAZEEL__
|
||||||
|
#error Microblaze LE not support ASM optimized lib func. Disable OPT_LIB_ASM.
|
||||||
|
#endif
|
||||||
|
|
||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
.text
|
.text
|
||||||
.globl memcpy
|
.globl memcpy
|
||||||
|
@ -169,11 +169,11 @@ static int __init pdc_console_tty_driver_init(void)
|
|||||||
|
|
||||||
struct console *tmp;
|
struct console *tmp;
|
||||||
|
|
||||||
acquire_console_sem();
|
console_lock();
|
||||||
for_each_console(tmp)
|
for_each_console(tmp)
|
||||||
if (tmp == &pdc_cons)
|
if (tmp == &pdc_cons)
|
||||||
break;
|
break;
|
||||||
release_console_sem();
|
console_unlock();
|
||||||
|
|
||||||
if (!tmp) {
|
if (!tmp) {
|
||||||
printk(KERN_INFO "PDC console driver not registered anymore, not creating %s\n", pdc_cons.name);
|
printk(KERN_INFO "PDC console driver not registered anymore, not creating %s\n", pdc_cons.name);
|
||||||
|
@ -596,6 +596,7 @@ static void record_and_restart(struct perf_event *event, unsigned long val,
|
|||||||
if (left <= 0)
|
if (left <= 0)
|
||||||
left = period;
|
left = period;
|
||||||
record = 1;
|
record = 1;
|
||||||
|
event->hw.last_period = event->hw.sample_period;
|
||||||
}
|
}
|
||||||
if (left < 0x80000000LL)
|
if (left < 0x80000000LL)
|
||||||
val = 0x80000000LL - left;
|
val = 0x80000000LL - left;
|
||||||
|
@ -406,7 +406,7 @@ config QDIO
|
|||||||
If unsure, say Y.
|
If unsure, say Y.
|
||||||
|
|
||||||
config CHSC_SCH
|
config CHSC_SCH
|
||||||
def_tristate y
|
def_tristate m
|
||||||
prompt "Support for CHSC subchannels"
|
prompt "Support for CHSC subchannels"
|
||||||
help
|
help
|
||||||
This driver allows usage of CHSC subchannels. A CHSC subchannel
|
This driver allows usage of CHSC subchannels. A CHSC subchannel
|
||||||
|
@ -1,29 +1,8 @@
|
|||||||
#ifndef _S390_CACHEFLUSH_H
|
#ifndef _S390_CACHEFLUSH_H
|
||||||
#define _S390_CACHEFLUSH_H
|
#define _S390_CACHEFLUSH_H
|
||||||
|
|
||||||
/* Keep includes the same across arches. */
|
|
||||||
#include <linux/mm.h>
|
|
||||||
|
|
||||||
/* Caches aren't brain-dead on the s390. */
|
/* Caches aren't brain-dead on the s390. */
|
||||||
#define flush_cache_all() do { } while (0)
|
#include <asm-generic/cacheflush.h>
|
||||||
#define flush_cache_mm(mm) do { } while (0)
|
|
||||||
#define flush_cache_dup_mm(mm) do { } while (0)
|
|
||||||
#define flush_cache_range(vma, start, end) do { } while (0)
|
|
||||||
#define flush_cache_page(vma, vmaddr, pfn) do { } while (0)
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 0
|
|
||||||
#define flush_dcache_page(page) do { } while (0)
|
|
||||||
#define flush_dcache_mmap_lock(mapping) do { } while (0)
|
|
||||||
#define flush_dcache_mmap_unlock(mapping) do { } while (0)
|
|
||||||
#define flush_icache_range(start, end) do { } while (0)
|
|
||||||
#define flush_icache_page(vma,pg) do { } while (0)
|
|
||||||
#define flush_icache_user_range(vma,pg,adr,len) do { } while (0)
|
|
||||||
#define flush_cache_vmap(start, end) do { } while (0)
|
|
||||||
#define flush_cache_vunmap(start, end) do { } while (0)
|
|
||||||
|
|
||||||
#define copy_to_user_page(vma, page, vaddr, dst, src, len) \
|
|
||||||
memcpy(dst, src, len)
|
|
||||||
#define copy_from_user_page(vma, page, vaddr, dst, src, len) \
|
|
||||||
memcpy(dst, src, len)
|
|
||||||
|
|
||||||
#ifdef CONFIG_DEBUG_PAGEALLOC
|
#ifdef CONFIG_DEBUG_PAGEALLOC
|
||||||
void kernel_map_pages(struct page *page, int numpages, int enable);
|
void kernel_map_pages(struct page *page, int numpages, int enable);
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
|
#include <linux/pagemap.h>
|
||||||
#include <linux/swap.h>
|
#include <linux/swap.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <asm/pgalloc.h>
|
#include <asm/pgalloc.h>
|
||||||
|
@ -125,9 +125,9 @@ static size_t copy_in_user_std(size_t size, void __user *to,
|
|||||||
unsigned long tmp1;
|
unsigned long tmp1;
|
||||||
|
|
||||||
asm volatile(
|
asm volatile(
|
||||||
|
" sacf 256\n"
|
||||||
" "AHI" %0,-1\n"
|
" "AHI" %0,-1\n"
|
||||||
" jo 5f\n"
|
" jo 5f\n"
|
||||||
" sacf 256\n"
|
|
||||||
" bras %3,3f\n"
|
" bras %3,3f\n"
|
||||||
"0:"AHI" %0,257\n"
|
"0:"AHI" %0,257\n"
|
||||||
"1: mvc 0(1,%1),0(%2)\n"
|
"1: mvc 0(1,%1),0(%2)\n"
|
||||||
@ -142,9 +142,8 @@ static size_t copy_in_user_std(size_t size, void __user *to,
|
|||||||
"3:"AHI" %0,-256\n"
|
"3:"AHI" %0,-256\n"
|
||||||
" jnm 2b\n"
|
" jnm 2b\n"
|
||||||
"4: ex %0,1b-0b(%3)\n"
|
"4: ex %0,1b-0b(%3)\n"
|
||||||
" sacf 0\n"
|
|
||||||
"5: "SLR" %0,%0\n"
|
"5: "SLR" %0,%0\n"
|
||||||
"6:\n"
|
"6: sacf 0\n"
|
||||||
EX_TABLE(1b,6b) EX_TABLE(2b,0b) EX_TABLE(4b,0b)
|
EX_TABLE(1b,6b) EX_TABLE(2b,0b) EX_TABLE(4b,0b)
|
||||||
: "+a" (size), "+a" (to), "+a" (from), "=a" (tmp1)
|
: "+a" (size), "+a" (to), "+a" (from), "=a" (tmp1)
|
||||||
: : "cc", "memory");
|
: : "cc", "memory");
|
||||||
@ -156,9 +155,9 @@ static size_t clear_user_std(size_t size, void __user *to)
|
|||||||
unsigned long tmp1, tmp2;
|
unsigned long tmp1, tmp2;
|
||||||
|
|
||||||
asm volatile(
|
asm volatile(
|
||||||
|
" sacf 256\n"
|
||||||
" "AHI" %0,-1\n"
|
" "AHI" %0,-1\n"
|
||||||
" jo 5f\n"
|
" jo 5f\n"
|
||||||
" sacf 256\n"
|
|
||||||
" bras %3,3f\n"
|
" bras %3,3f\n"
|
||||||
" xc 0(1,%1),0(%1)\n"
|
" xc 0(1,%1),0(%1)\n"
|
||||||
"0:"AHI" %0,257\n"
|
"0:"AHI" %0,257\n"
|
||||||
@ -178,9 +177,8 @@ static size_t clear_user_std(size_t size, void __user *to)
|
|||||||
"3:"AHI" %0,-256\n"
|
"3:"AHI" %0,-256\n"
|
||||||
" jnm 2b\n"
|
" jnm 2b\n"
|
||||||
"4: ex %0,0(%3)\n"
|
"4: ex %0,0(%3)\n"
|
||||||
" sacf 0\n"
|
|
||||||
"5: "SLR" %0,%0\n"
|
"5: "SLR" %0,%0\n"
|
||||||
"6:\n"
|
"6: sacf 0\n"
|
||||||
EX_TABLE(1b,6b) EX_TABLE(2b,0b) EX_TABLE(4b,0b)
|
EX_TABLE(1b,6b) EX_TABLE(2b,0b) EX_TABLE(4b,0b)
|
||||||
: "+a" (size), "+a" (to), "=a" (tmp1), "=a" (tmp2)
|
: "+a" (size), "+a" (to), "=a" (tmp1), "=a" (tmp2)
|
||||||
: : "cc", "memory");
|
: : "cc", "memory");
|
||||||
|
@ -336,7 +336,8 @@ void page_table_free(struct mm_struct *mm, unsigned long *table)
|
|||||||
page->flags ^= bits;
|
page->flags ^= bits;
|
||||||
if (page->flags & FRAG_MASK) {
|
if (page->flags & FRAG_MASK) {
|
||||||
/* Page now has some free pgtable fragments. */
|
/* Page now has some free pgtable fragments. */
|
||||||
list_move(&page->lru, &mm->context.pgtable_list);
|
if (!list_empty(&page->lru))
|
||||||
|
list_move(&page->lru, &mm->context.pgtable_list);
|
||||||
page = NULL;
|
page = NULL;
|
||||||
} else
|
} else
|
||||||
/* All fragments of the 4K page have been freed. */
|
/* All fragments of the 4K page have been freed. */
|
||||||
|
@ -15,6 +15,7 @@ config SUPERH
|
|||||||
select HAVE_KERNEL_GZIP
|
select HAVE_KERNEL_GZIP
|
||||||
select HAVE_KERNEL_BZIP2
|
select HAVE_KERNEL_BZIP2
|
||||||
select HAVE_KERNEL_LZMA
|
select HAVE_KERNEL_LZMA
|
||||||
|
select HAVE_KERNEL_XZ
|
||||||
select HAVE_KERNEL_LZO
|
select HAVE_KERNEL_LZO
|
||||||
select HAVE_SYSCALL_TRACEPOINTS
|
select HAVE_SYSCALL_TRACEPOINTS
|
||||||
select HAVE_REGS_AND_STACK_ACCESS_API
|
select HAVE_REGS_AND_STACK_ACCESS_API
|
||||||
|
@ -200,7 +200,7 @@ endif
|
|||||||
libs-$(CONFIG_SUPERH32) := arch/sh/lib/ $(libs-y)
|
libs-$(CONFIG_SUPERH32) := arch/sh/lib/ $(libs-y)
|
||||||
libs-$(CONFIG_SUPERH64) := arch/sh/lib64/ $(libs-y)
|
libs-$(CONFIG_SUPERH64) := arch/sh/lib64/ $(libs-y)
|
||||||
|
|
||||||
BOOT_TARGETS = uImage uImage.bz2 uImage.gz uImage.lzma uImage.lzo \
|
BOOT_TARGETS = uImage uImage.bz2 uImage.gz uImage.lzma uImage.xz uImage.lzo \
|
||||||
uImage.srec uImage.bin zImage vmlinux.bin vmlinux.srec \
|
uImage.srec uImage.bin zImage vmlinux.bin vmlinux.srec \
|
||||||
romImage
|
romImage
|
||||||
PHONY += $(BOOT_TARGETS)
|
PHONY += $(BOOT_TARGETS)
|
||||||
@ -230,5 +230,6 @@ define archhelp
|
|||||||
@echo '* uImage.gz - Kernel-only image for U-Boot (gzip)'
|
@echo '* uImage.gz - Kernel-only image for U-Boot (gzip)'
|
||||||
@echo ' uImage.bz2 - Kernel-only image for U-Boot (bzip2)'
|
@echo ' uImage.bz2 - Kernel-only image for U-Boot (bzip2)'
|
||||||
@echo ' uImage.lzma - Kernel-only image for U-Boot (lzma)'
|
@echo ' uImage.lzma - Kernel-only image for U-Boot (lzma)'
|
||||||
|
@echo ' uImage.xz - Kernel-only image for U-Boot (xz)'
|
||||||
@echo ' uImage.lzo - Kernel-only image for U-Boot (lzo)'
|
@echo ' uImage.lzo - Kernel-only image for U-Boot (lzo)'
|
||||||
endef
|
endef
|
||||||
|
@ -1294,6 +1294,7 @@ static int __init arch_setup(void)
|
|||||||
i2c_register_board_info(1, i2c1_devices,
|
i2c_register_board_info(1, i2c1_devices,
|
||||||
ARRAY_SIZE(i2c1_devices));
|
ARRAY_SIZE(i2c1_devices));
|
||||||
|
|
||||||
|
#if defined(CONFIG_VIDEO_SH_VOU) || defined(CONFIG_VIDEO_SH_VOU_MODULE)
|
||||||
/* VOU */
|
/* VOU */
|
||||||
gpio_request(GPIO_FN_DV_D15, NULL);
|
gpio_request(GPIO_FN_DV_D15, NULL);
|
||||||
gpio_request(GPIO_FN_DV_D14, NULL);
|
gpio_request(GPIO_FN_DV_D14, NULL);
|
||||||
@ -1325,6 +1326,7 @@ static int __init arch_setup(void)
|
|||||||
|
|
||||||
/* Remove reset */
|
/* Remove reset */
|
||||||
gpio_set_value(GPIO_PTG4, 1);
|
gpio_set_value(GPIO_PTG4, 1);
|
||||||
|
#endif
|
||||||
|
|
||||||
return platform_add_devices(ecovec_devices,
|
return platform_add_devices(ecovec_devices,
|
||||||
ARRAY_SIZE(ecovec_devices));
|
ARRAY_SIZE(ecovec_devices));
|
||||||
|
@ -24,12 +24,13 @@ suffix-y := bin
|
|||||||
suffix-$(CONFIG_KERNEL_GZIP) := gz
|
suffix-$(CONFIG_KERNEL_GZIP) := gz
|
||||||
suffix-$(CONFIG_KERNEL_BZIP2) := bz2
|
suffix-$(CONFIG_KERNEL_BZIP2) := bz2
|
||||||
suffix-$(CONFIG_KERNEL_LZMA) := lzma
|
suffix-$(CONFIG_KERNEL_LZMA) := lzma
|
||||||
|
suffix-$(CONFIG_KERNEL_XZ) := xz
|
||||||
suffix-$(CONFIG_KERNEL_LZO) := lzo
|
suffix-$(CONFIG_KERNEL_LZO) := lzo
|
||||||
|
|
||||||
targets := zImage vmlinux.srec romImage uImage uImage.srec uImage.gz \
|
targets := zImage vmlinux.srec romImage uImage uImage.srec uImage.gz \
|
||||||
uImage.bz2 uImage.lzma uImage.lzo uImage.bin
|
uImage.bz2 uImage.lzma uImage.xz uImage.lzo uImage.bin
|
||||||
extra-y += vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma \
|
extra-y += vmlinux.bin vmlinux.bin.gz vmlinux.bin.bz2 vmlinux.bin.lzma \
|
||||||
vmlinux.bin.lzo
|
vmlinux.bin.xz vmlinux.bin.lzo
|
||||||
subdir- := compressed romimage
|
subdir- := compressed romimage
|
||||||
|
|
||||||
$(obj)/zImage: $(obj)/compressed/vmlinux FORCE
|
$(obj)/zImage: $(obj)/compressed/vmlinux FORCE
|
||||||
@ -76,6 +77,9 @@ $(obj)/vmlinux.bin.bz2: $(obj)/vmlinux.bin FORCE
|
|||||||
$(obj)/vmlinux.bin.lzma: $(obj)/vmlinux.bin FORCE
|
$(obj)/vmlinux.bin.lzma: $(obj)/vmlinux.bin FORCE
|
||||||
$(call if_changed,lzma)
|
$(call if_changed,lzma)
|
||||||
|
|
||||||
|
$(obj)/vmlinux.bin.xz: $(obj)/vmlinux.bin FORCE
|
||||||
|
$(call if_changed,xzkern)
|
||||||
|
|
||||||
$(obj)/vmlinux.bin.lzo: $(obj)/vmlinux.bin FORCE
|
$(obj)/vmlinux.bin.lzo: $(obj)/vmlinux.bin FORCE
|
||||||
$(call if_changed,lzo)
|
$(call if_changed,lzo)
|
||||||
|
|
||||||
@ -88,6 +92,9 @@ $(obj)/uImage.gz: $(obj)/vmlinux.bin.gz
|
|||||||
$(obj)/uImage.lzma: $(obj)/vmlinux.bin.lzma
|
$(obj)/uImage.lzma: $(obj)/vmlinux.bin.lzma
|
||||||
$(call if_changed,uimage,lzma)
|
$(call if_changed,uimage,lzma)
|
||||||
|
|
||||||
|
$(obj)/uImage.xz: $(obj)/vmlinux.bin.xz
|
||||||
|
$(call if_changed,uimage,xz)
|
||||||
|
|
||||||
$(obj)/uImage.lzo: $(obj)/vmlinux.bin.lzo
|
$(obj)/uImage.lzo: $(obj)/vmlinux.bin.lzo
|
||||||
$(call if_changed,uimage,lzo)
|
$(call if_changed,uimage,lzo)
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
|
|
||||||
targets := vmlinux vmlinux.bin vmlinux.bin.gz \
|
targets := vmlinux vmlinux.bin vmlinux.bin.gz \
|
||||||
vmlinux.bin.bz2 vmlinux.bin.lzma \
|
vmlinux.bin.bz2 vmlinux.bin.lzma \
|
||||||
vmlinux.bin.lzo \
|
vmlinux.bin.xz vmlinux.bin.lzo \
|
||||||
head_$(BITS).o misc.o piggy.o
|
head_$(BITS).o misc.o piggy.o
|
||||||
|
|
||||||
OBJECTS = $(obj)/head_$(BITS).o $(obj)/misc.o $(obj)/cache.o
|
OBJECTS = $(obj)/head_$(BITS).o $(obj)/misc.o $(obj)/cache.o
|
||||||
@ -50,6 +50,8 @@ $(obj)/vmlinux.bin.bz2: $(vmlinux.bin.all-y) FORCE
|
|||||||
$(call if_changed,bzip2)
|
$(call if_changed,bzip2)
|
||||||
$(obj)/vmlinux.bin.lzma: $(vmlinux.bin.all-y) FORCE
|
$(obj)/vmlinux.bin.lzma: $(vmlinux.bin.all-y) FORCE
|
||||||
$(call if_changed,lzma)
|
$(call if_changed,lzma)
|
||||||
|
$(obj)/vmlinux.bin.xz: $(vmlinux.bin.all-y) FORCE
|
||||||
|
$(call if_changed,xzkern)
|
||||||
$(obj)/vmlinux.bin.lzo: $(vmlinux.bin.all-y) FORCE
|
$(obj)/vmlinux.bin.lzo: $(vmlinux.bin.all-y) FORCE
|
||||||
$(call if_changed,lzo)
|
$(call if_changed,lzo)
|
||||||
|
|
||||||
|
@ -61,6 +61,10 @@ static unsigned long free_mem_end_ptr;
|
|||||||
#include "../../../../lib/decompress_unlzma.c"
|
#include "../../../../lib/decompress_unlzma.c"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef CONFIG_KERNEL_XZ
|
||||||
|
#include "../../../../lib/decompress_unxz.c"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef CONFIG_KERNEL_LZO
|
#ifdef CONFIG_KERNEL_LZO
|
||||||
#include "../../../../lib/decompress_unlzo.c"
|
#include "../../../../lib/decompress_unlzo.c"
|
||||||
#endif
|
#endif
|
||||||
|
@ -134,6 +134,7 @@ typedef pte_t *pte_addr_t;
|
|||||||
extern void pgtable_cache_init(void);
|
extern void pgtable_cache_init(void);
|
||||||
|
|
||||||
struct vm_area_struct;
|
struct vm_area_struct;
|
||||||
|
struct mm_struct;
|
||||||
|
|
||||||
extern void __update_cache(struct vm_area_struct *vma,
|
extern void __update_cache(struct vm_area_struct *vma,
|
||||||
unsigned long address, pte_t pte);
|
unsigned long address, pte_t pte);
|
||||||
|
@ -230,10 +230,10 @@ static struct platform_device *sh7750_devices[] __initdata = {
|
|||||||
static int __init sh7750_devices_setup(void)
|
static int __init sh7750_devices_setup(void)
|
||||||
{
|
{
|
||||||
if (mach_is_rts7751r2d()) {
|
if (mach_is_rts7751r2d()) {
|
||||||
platform_register_device(&scif_device);
|
platform_device_register(&scif_device);
|
||||||
} else {
|
} else {
|
||||||
platform_register_device(&sci_device);
|
platform_device_register(&sci_device);
|
||||||
platform_register_device(&scif_device);
|
platform_device_register(&scif_device);
|
||||||
}
|
}
|
||||||
|
|
||||||
return platform_add_devices(sh7750_devices,
|
return platform_add_devices(sh7750_devices,
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
static DEFINE_PER_CPU(struct cpu, cpu_devices);
|
static DEFINE_PER_CPU(struct cpu, cpu_devices);
|
||||||
|
|
||||||
cpumask_t cpu_core_map[NR_CPUS];
|
cpumask_t cpu_core_map[NR_CPUS];
|
||||||
|
EXPORT_SYMBOL(cpu_core_map);
|
||||||
|
|
||||||
static cpumask_t cpu_coregroup_map(unsigned int cpu)
|
static cpumask_t cpu_coregroup_map(unsigned int cpu)
|
||||||
{
|
{
|
||||||
|
@ -1,48 +1,8 @@
|
|||||||
#ifndef _ASM_X86_CACHEFLUSH_H
|
#ifndef _ASM_X86_CACHEFLUSH_H
|
||||||
#define _ASM_X86_CACHEFLUSH_H
|
#define _ASM_X86_CACHEFLUSH_H
|
||||||
|
|
||||||
/* Keep includes the same across arches. */
|
|
||||||
#include <linux/mm.h>
|
|
||||||
|
|
||||||
/* Caches aren't brain-dead on the intel. */
|
/* Caches aren't brain-dead on the intel. */
|
||||||
static inline void flush_cache_all(void) { }
|
#include <asm-generic/cacheflush.h>
|
||||||
static inline void flush_cache_mm(struct mm_struct *mm) { }
|
|
||||||
static inline void flush_cache_dup_mm(struct mm_struct *mm) { }
|
|
||||||
static inline void flush_cache_range(struct vm_area_struct *vma,
|
|
||||||
unsigned long start, unsigned long end) { }
|
|
||||||
static inline void flush_cache_page(struct vm_area_struct *vma,
|
|
||||||
unsigned long vmaddr, unsigned long pfn) { }
|
|
||||||
#define ARCH_IMPLEMENTS_FLUSH_DCACHE_PAGE 0
|
|
||||||
static inline void flush_dcache_page(struct page *page) { }
|
|
||||||
static inline void flush_dcache_mmap_lock(struct address_space *mapping) { }
|
|
||||||
static inline void flush_dcache_mmap_unlock(struct address_space *mapping) { }
|
|
||||||
static inline void flush_icache_range(unsigned long start,
|
|
||||||
unsigned long end) { }
|
|
||||||
static inline void flush_icache_page(struct vm_area_struct *vma,
|
|
||||||
struct page *page) { }
|
|
||||||
static inline void flush_icache_user_range(struct vm_area_struct *vma,
|
|
||||||
struct page *page,
|
|
||||||
unsigned long addr,
|
|
||||||
unsigned long len) { }
|
|
||||||
static inline void flush_cache_vmap(unsigned long start, unsigned long end) { }
|
|
||||||
static inline void flush_cache_vunmap(unsigned long start,
|
|
||||||
unsigned long end) { }
|
|
||||||
|
|
||||||
static inline void copy_to_user_page(struct vm_area_struct *vma,
|
|
||||||
struct page *page, unsigned long vaddr,
|
|
||||||
void *dst, const void *src,
|
|
||||||
unsigned long len)
|
|
||||||
{
|
|
||||||
memcpy(dst, src, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void copy_from_user_page(struct vm_area_struct *vma,
|
|
||||||
struct page *page, unsigned long vaddr,
|
|
||||||
void *dst, const void *src,
|
|
||||||
unsigned long len)
|
|
||||||
{
|
|
||||||
memcpy(dst, src, len);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_X86_PAT
|
#ifdef CONFIG_X86_PAT
|
||||||
/*
|
/*
|
||||||
|
@ -32,5 +32,6 @@ extern void arch_unregister_cpu(int);
|
|||||||
|
|
||||||
DECLARE_PER_CPU(int, cpu_state);
|
DECLARE_PER_CPU(int, cpu_state);
|
||||||
|
|
||||||
|
int __cpuinit mwait_usable(const struct cpuinfo_x86 *);
|
||||||
|
|
||||||
#endif /* _ASM_X86_CPU_H */
|
#endif /* _ASM_X86_CPU_H */
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
do { \
|
do { \
|
||||||
asm goto("1:" \
|
asm goto("1:" \
|
||||||
JUMP_LABEL_INITIAL_NOP \
|
JUMP_LABEL_INITIAL_NOP \
|
||||||
".pushsection __jump_table, \"a\" \n\t"\
|
".pushsection __jump_table, \"aw\" \n\t"\
|
||||||
_ASM_PTR "1b, %l[" #label "], %c0 \n\t" \
|
_ASM_PTR "1b, %l[" #label "], %c0 \n\t" \
|
||||||
".popsection \n\t" \
|
".popsection \n\t" \
|
||||||
: : "i" (key) : : label); \
|
: : "i" (key) : : label); \
|
||||||
|
@ -36,8 +36,6 @@ static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next,
|
|||||||
unsigned cpu = smp_processor_id();
|
unsigned cpu = smp_processor_id();
|
||||||
|
|
||||||
if (likely(prev != next)) {
|
if (likely(prev != next)) {
|
||||||
/* stop flush ipis for the previous mm */
|
|
||||||
cpumask_clear_cpu(cpu, mm_cpumask(prev));
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
percpu_write(cpu_tlbstate.state, TLBSTATE_OK);
|
percpu_write(cpu_tlbstate.state, TLBSTATE_OK);
|
||||||
percpu_write(cpu_tlbstate.active_mm, next);
|
percpu_write(cpu_tlbstate.active_mm, next);
|
||||||
@ -47,6 +45,9 @@ static inline void switch_mm(struct mm_struct *prev, struct mm_struct *next,
|
|||||||
/* Re-load page tables */
|
/* Re-load page tables */
|
||||||
load_cr3(next->pgd);
|
load_cr3(next->pgd);
|
||||||
|
|
||||||
|
/* stop flush ipis for the previous mm */
|
||||||
|
cpumask_clear_cpu(cpu, mm_cpumask(prev));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* load the LDT, if the LDT is different:
|
* load the LDT, if the LDT is different:
|
||||||
*/
|
*/
|
||||||
|
@ -558,13 +558,12 @@ static inline void set_pte_at(struct mm_struct *mm, unsigned long addr,
|
|||||||
static inline void set_pmd_at(struct mm_struct *mm, unsigned long addr,
|
static inline void set_pmd_at(struct mm_struct *mm, unsigned long addr,
|
||||||
pmd_t *pmdp, pmd_t pmd)
|
pmd_t *pmdp, pmd_t pmd)
|
||||||
{
|
{
|
||||||
#if PAGETABLE_LEVELS >= 3
|
|
||||||
if (sizeof(pmdval_t) > sizeof(long))
|
if (sizeof(pmdval_t) > sizeof(long))
|
||||||
/* 5 arg words */
|
/* 5 arg words */
|
||||||
pv_mmu_ops.set_pmd_at(mm, addr, pmdp, pmd);
|
pv_mmu_ops.set_pmd_at(mm, addr, pmdp, pmd);
|
||||||
else
|
else
|
||||||
PVOP_VCALL4(pv_mmu_ops.set_pmd_at, mm, addr, pmdp, pmd.pmd);
|
PVOP_VCALL4(pv_mmu_ops.set_pmd_at, mm, addr, pmdp,
|
||||||
#endif
|
native_pmd_val(pmd));
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -273,34 +273,34 @@ do { \
|
|||||||
typeof(var) pxo_new__ = (nval); \
|
typeof(var) pxo_new__ = (nval); \
|
||||||
switch (sizeof(var)) { \
|
switch (sizeof(var)) { \
|
||||||
case 1: \
|
case 1: \
|
||||||
asm("\n1:mov "__percpu_arg(1)",%%al" \
|
asm("\n\tmov "__percpu_arg(1)",%%al" \
|
||||||
"\n\tcmpxchgb %2, "__percpu_arg(1) \
|
"\n1:\tcmpxchgb %2, "__percpu_arg(1) \
|
||||||
"\n\tjnz 1b" \
|
"\n\tjnz 1b" \
|
||||||
: "=a" (pxo_ret__), "+m" (var) \
|
: "=&a" (pxo_ret__), "+m" (var) \
|
||||||
: "q" (pxo_new__) \
|
: "q" (pxo_new__) \
|
||||||
: "memory"); \
|
: "memory"); \
|
||||||
break; \
|
break; \
|
||||||
case 2: \
|
case 2: \
|
||||||
asm("\n1:mov "__percpu_arg(1)",%%ax" \
|
asm("\n\tmov "__percpu_arg(1)",%%ax" \
|
||||||
"\n\tcmpxchgw %2, "__percpu_arg(1) \
|
"\n1:\tcmpxchgw %2, "__percpu_arg(1) \
|
||||||
"\n\tjnz 1b" \
|
"\n\tjnz 1b" \
|
||||||
: "=a" (pxo_ret__), "+m" (var) \
|
: "=&a" (pxo_ret__), "+m" (var) \
|
||||||
: "r" (pxo_new__) \
|
: "r" (pxo_new__) \
|
||||||
: "memory"); \
|
: "memory"); \
|
||||||
break; \
|
break; \
|
||||||
case 4: \
|
case 4: \
|
||||||
asm("\n1:mov "__percpu_arg(1)",%%eax" \
|
asm("\n\tmov "__percpu_arg(1)",%%eax" \
|
||||||
"\n\tcmpxchgl %2, "__percpu_arg(1) \
|
"\n1:\tcmpxchgl %2, "__percpu_arg(1) \
|
||||||
"\n\tjnz 1b" \
|
"\n\tjnz 1b" \
|
||||||
: "=a" (pxo_ret__), "+m" (var) \
|
: "=&a" (pxo_ret__), "+m" (var) \
|
||||||
: "r" (pxo_new__) \
|
: "r" (pxo_new__) \
|
||||||
: "memory"); \
|
: "memory"); \
|
||||||
break; \
|
break; \
|
||||||
case 8: \
|
case 8: \
|
||||||
asm("\n1:mov "__percpu_arg(1)",%%rax" \
|
asm("\n\tmov "__percpu_arg(1)",%%rax" \
|
||||||
"\n\tcmpxchgq %2, "__percpu_arg(1) \
|
"\n1:\tcmpxchgq %2, "__percpu_arg(1) \
|
||||||
"\n\tjnz 1b" \
|
"\n\tjnz 1b" \
|
||||||
: "=a" (pxo_ret__), "+m" (var) \
|
: "=&a" (pxo_ret__), "+m" (var) \
|
||||||
: "r" (pxo_new__) \
|
: "r" (pxo_new__) \
|
||||||
: "memory"); \
|
: "memory"); \
|
||||||
break; \
|
break; \
|
||||||
|
@ -1,22 +0,0 @@
|
|||||||
#ifndef _ASM_X86_SYSTEM_64_H
|
|
||||||
#define _ASM_X86_SYSTEM_64_H
|
|
||||||
|
|
||||||
#include <asm/segment.h>
|
|
||||||
#include <asm/cmpxchg.h>
|
|
||||||
|
|
||||||
|
|
||||||
static inline unsigned long read_cr8(void)
|
|
||||||
{
|
|
||||||
unsigned long cr8;
|
|
||||||
asm volatile("movq %%cr8,%0" : "=r" (cr8));
|
|
||||||
return cr8;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void write_cr8(unsigned long val)
|
|
||||||
{
|
|
||||||
asm volatile("movq %0,%%cr8" :: "r" (val) : "memory");
|
|
||||||
}
|
|
||||||
|
|
||||||
#include <linux/irqflags.h>
|
|
||||||
|
|
||||||
#endif /* _ASM_X86_SYSTEM_64_H */
|
|
@ -45,6 +45,7 @@ static const struct _cache_table __cpuinitconst cache_table[] =
|
|||||||
{ 0x0a, LVL_1_DATA, 8 }, /* 2 way set assoc, 32 byte line size */
|
{ 0x0a, LVL_1_DATA, 8 }, /* 2 way set assoc, 32 byte line size */
|
||||||
{ 0x0c, LVL_1_DATA, 16 }, /* 4-way set assoc, 32 byte line size */
|
{ 0x0c, LVL_1_DATA, 16 }, /* 4-way set assoc, 32 byte line size */
|
||||||
{ 0x0d, LVL_1_DATA, 16 }, /* 4-way set assoc, 64 byte line size */
|
{ 0x0d, LVL_1_DATA, 16 }, /* 4-way set assoc, 64 byte line size */
|
||||||
|
{ 0x0e, LVL_1_DATA, 24 }, /* 6-way set assoc, 64 byte line size */
|
||||||
{ 0x21, LVL_2, 256 }, /* 8-way set assoc, 64 byte line size */
|
{ 0x21, LVL_2, 256 }, /* 8-way set assoc, 64 byte line size */
|
||||||
{ 0x22, LVL_3, 512 }, /* 4-way set assoc, sectored cache, 64 byte line size */
|
{ 0x22, LVL_3, 512 }, /* 4-way set assoc, sectored cache, 64 byte line size */
|
||||||
{ 0x23, LVL_3, MB(1) }, /* 8-way set assoc, sectored cache, 64 byte line size */
|
{ 0x23, LVL_3, MB(1) }, /* 8-way set assoc, sectored cache, 64 byte line size */
|
||||||
@ -66,6 +67,7 @@ static const struct _cache_table __cpuinitconst cache_table[] =
|
|||||||
{ 0x45, LVL_2, MB(2) }, /* 4-way set assoc, 32 byte line size */
|
{ 0x45, LVL_2, MB(2) }, /* 4-way set assoc, 32 byte line size */
|
||||||
{ 0x46, LVL_3, MB(4) }, /* 4-way set assoc, 64 byte line size */
|
{ 0x46, LVL_3, MB(4) }, /* 4-way set assoc, 64 byte line size */
|
||||||
{ 0x47, LVL_3, MB(8) }, /* 8-way set assoc, 64 byte line size */
|
{ 0x47, LVL_3, MB(8) }, /* 8-way set assoc, 64 byte line size */
|
||||||
|
{ 0x48, LVL_2, MB(3) }, /* 12-way set assoc, 64 byte line size */
|
||||||
{ 0x49, LVL_3, MB(4) }, /* 16-way set assoc, 64 byte line size */
|
{ 0x49, LVL_3, MB(4) }, /* 16-way set assoc, 64 byte line size */
|
||||||
{ 0x4a, LVL_3, MB(6) }, /* 12-way set assoc, 64 byte line size */
|
{ 0x4a, LVL_3, MB(6) }, /* 12-way set assoc, 64 byte line size */
|
||||||
{ 0x4b, LVL_3, MB(8) }, /* 16-way set assoc, 64 byte line size */
|
{ 0x4b, LVL_3, MB(8) }, /* 16-way set assoc, 64 byte line size */
|
||||||
@ -87,6 +89,7 @@ static const struct _cache_table __cpuinitconst cache_table[] =
|
|||||||
{ 0x7c, LVL_2, MB(1) }, /* 8-way set assoc, sectored cache, 64 byte line size */
|
{ 0x7c, LVL_2, MB(1) }, /* 8-way set assoc, sectored cache, 64 byte line size */
|
||||||
{ 0x7d, LVL_2, MB(2) }, /* 8-way set assoc, 64 byte line size */
|
{ 0x7d, LVL_2, MB(2) }, /* 8-way set assoc, 64 byte line size */
|
||||||
{ 0x7f, LVL_2, 512 }, /* 2-way set assoc, 64 byte line size */
|
{ 0x7f, LVL_2, 512 }, /* 2-way set assoc, 64 byte line size */
|
||||||
|
{ 0x80, LVL_2, 512 }, /* 8-way set assoc, 64 byte line size */
|
||||||
{ 0x82, LVL_2, 256 }, /* 8-way set assoc, 32 byte line size */
|
{ 0x82, LVL_2, 256 }, /* 8-way set assoc, 32 byte line size */
|
||||||
{ 0x83, LVL_2, 512 }, /* 8-way set assoc, 32 byte line size */
|
{ 0x83, LVL_2, 512 }, /* 8-way set assoc, 32 byte line size */
|
||||||
{ 0x84, LVL_2, MB(1) }, /* 8-way set assoc, 32 byte line size */
|
{ 0x84, LVL_2, MB(1) }, /* 8-way set assoc, 32 byte line size */
|
||||||
|
@ -59,6 +59,7 @@ struct thermal_state {
|
|||||||
|
|
||||||
/* Callback to handle core threshold interrupts */
|
/* Callback to handle core threshold interrupts */
|
||||||
int (*platform_thermal_notify)(__u64 msr_val);
|
int (*platform_thermal_notify)(__u64 msr_val);
|
||||||
|
EXPORT_SYMBOL(platform_thermal_notify);
|
||||||
|
|
||||||
static DEFINE_PER_CPU(struct thermal_state, thermal_state);
|
static DEFINE_PER_CPU(struct thermal_state, thermal_state);
|
||||||
|
|
||||||
|
@ -682,7 +682,7 @@ static int p4_validate_raw_event(struct perf_event *event)
|
|||||||
* if an event is shared accross the logical threads
|
* if an event is shared accross the logical threads
|
||||||
* the user needs special permissions to be able to use it
|
* the user needs special permissions to be able to use it
|
||||||
*/
|
*/
|
||||||
if (p4_event_bind_map[v].shared) {
|
if (p4_ht_active() && p4_event_bind_map[v].shared) {
|
||||||
if (perf_paranoid_cpu() && !capable(CAP_SYS_ADMIN))
|
if (perf_paranoid_cpu() && !capable(CAP_SYS_ADMIN))
|
||||||
return -EACCES;
|
return -EACCES;
|
||||||
}
|
}
|
||||||
@ -727,7 +727,8 @@ static int p4_hw_config(struct perf_event *event)
|
|||||||
event->hw.config = p4_set_ht_bit(event->hw.config);
|
event->hw.config = p4_set_ht_bit(event->hw.config);
|
||||||
|
|
||||||
if (event->attr.type == PERF_TYPE_RAW) {
|
if (event->attr.type == PERF_TYPE_RAW) {
|
||||||
|
struct p4_event_bind *bind;
|
||||||
|
unsigned int esel;
|
||||||
/*
|
/*
|
||||||
* Clear bits we reserve to be managed by kernel itself
|
* Clear bits we reserve to be managed by kernel itself
|
||||||
* and never allowed from a user space
|
* and never allowed from a user space
|
||||||
@ -743,6 +744,13 @@ static int p4_hw_config(struct perf_event *event)
|
|||||||
* bits since we keep additional info here (for cache events and etc)
|
* bits since we keep additional info here (for cache events and etc)
|
||||||
*/
|
*/
|
||||||
event->hw.config |= event->attr.config;
|
event->hw.config |= event->attr.config;
|
||||||
|
bind = p4_config_get_bind(event->attr.config);
|
||||||
|
if (!bind) {
|
||||||
|
rc = -EINVAL;
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
esel = P4_OPCODE_ESEL(bind->opcode);
|
||||||
|
event->hw.config |= p4_config_pack_cccr(P4_CCCR_ESEL(esel));
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = x86_setup_perfctr(event);
|
rc = x86_setup_perfctr(event);
|
||||||
|
@ -149,13 +149,13 @@ void dump_trace(struct task_struct *task,
|
|||||||
unsigned used = 0;
|
unsigned used = 0;
|
||||||
struct thread_info *tinfo;
|
struct thread_info *tinfo;
|
||||||
int graph = 0;
|
int graph = 0;
|
||||||
|
unsigned long dummy;
|
||||||
unsigned long bp;
|
unsigned long bp;
|
||||||
|
|
||||||
if (!task)
|
if (!task)
|
||||||
task = current;
|
task = current;
|
||||||
|
|
||||||
if (!stack) {
|
if (!stack) {
|
||||||
unsigned long dummy;
|
|
||||||
stack = &dummy;
|
stack = &dummy;
|
||||||
if (task && task != current)
|
if (task && task != current)
|
||||||
stack = (unsigned long *)task->thread.sp;
|
stack = (unsigned long *)task->thread.sp;
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#include <linux/utsname.h>
|
#include <linux/utsname.h>
|
||||||
#include <trace/events/power.h>
|
#include <trace/events/power.h>
|
||||||
#include <linux/hw_breakpoint.h>
|
#include <linux/hw_breakpoint.h>
|
||||||
|
#include <asm/cpu.h>
|
||||||
#include <asm/system.h>
|
#include <asm/system.h>
|
||||||
#include <asm/apic.h>
|
#include <asm/apic.h>
|
||||||
#include <asm/syscalls.h>
|
#include <asm/syscalls.h>
|
||||||
@ -505,7 +506,7 @@ static void poll_idle(void)
|
|||||||
#define MWAIT_ECX_EXTENDED_INFO 0x01
|
#define MWAIT_ECX_EXTENDED_INFO 0x01
|
||||||
#define MWAIT_EDX_C1 0xf0
|
#define MWAIT_EDX_C1 0xf0
|
||||||
|
|
||||||
static int __cpuinit mwait_usable(const struct cpuinfo_x86 *c)
|
int __cpuinit mwait_usable(const struct cpuinfo_x86 *c)
|
||||||
{
|
{
|
||||||
u32 eax, ebx, ecx, edx;
|
u32 eax, ebx, ecx, edx;
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user