mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
Merge branch 'linus' into perf/core
Pick up the latest ring-buffer fixes, before applying a new fix. Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
commit
a2fe194723
@ -142,13 +142,14 @@ KernelVersion: 3.4
|
|||||||
Contact: linux-mtd@lists.infradead.org
|
Contact: linux-mtd@lists.infradead.org
|
||||||
Description:
|
Description:
|
||||||
This allows the user to examine and adjust the criteria by which
|
This allows the user to examine and adjust the criteria by which
|
||||||
mtd returns -EUCLEAN from mtd_read(). If the maximum number of
|
mtd returns -EUCLEAN from mtd_read() and mtd_read_oob(). If the
|
||||||
bit errors that were corrected on any single region comprising
|
maximum number of bit errors that were corrected on any single
|
||||||
an ecc step (as reported by the driver) equals or exceeds this
|
region comprising an ecc step (as reported by the driver) equals
|
||||||
value, -EUCLEAN is returned. Otherwise, absent an error, 0 is
|
or exceeds this value, -EUCLEAN is returned. Otherwise, absent
|
||||||
returned. Higher layers (e.g., UBI) use this return code as an
|
an error, 0 is returned. Higher layers (e.g., UBI) use this
|
||||||
indication that an erase block may be degrading and should be
|
return code as an indication that an erase block may be
|
||||||
scrutinized as a candidate for being marked as bad.
|
degrading and should be scrutinized as a candidate for being
|
||||||
|
marked as bad.
|
||||||
|
|
||||||
The initial value may be specified by the flash device driver.
|
The initial value may be specified by the flash device driver.
|
||||||
If not, then the default value is ecc_strength.
|
If not, then the default value is ecc_strength.
|
||||||
@ -167,7 +168,7 @@ Description:
|
|||||||
block degradation, but high enough to avoid the consequences of
|
block degradation, but high enough to avoid the consequences of
|
||||||
a persistent return value of -EUCLEAN on devices where sticky
|
a persistent return value of -EUCLEAN on devices where sticky
|
||||||
bitflips occur. Note that if bitflip_threshold exceeds
|
bitflips occur. Note that if bitflip_threshold exceeds
|
||||||
ecc_strength, -EUCLEAN is never returned by mtd_read().
|
ecc_strength, -EUCLEAN is never returned by the read operations.
|
||||||
Conversely, if bitflip_threshold is zero, -EUCLEAN is always
|
Conversely, if bitflip_threshold is zero, -EUCLEAN is always
|
||||||
returned, absent a hard error.
|
returned, absent a hard error.
|
||||||
|
|
||||||
|
@ -3988,7 +3988,7 @@ interface and may change in the future.</para>
|
|||||||
from RGB to Y'CbCr color space.
|
from RGB to Y'CbCr color space.
|
||||||
</entry>
|
</entry>
|
||||||
</row>
|
</row>
|
||||||
<row id = "v4l2-jpeg-chroma-subsampling">
|
<row>
|
||||||
<entrytbl spanname="descr" cols="2">
|
<entrytbl spanname="descr" cols="2">
|
||||||
<tbody valign="top">
|
<tbody valign="top">
|
||||||
<row>
|
<row>
|
||||||
|
@ -284,13 +284,6 @@ These controls are described in <xref
|
|||||||
processing controls. These controls are described in <xref
|
processing controls. These controls are described in <xref
|
||||||
linkend="image-process-controls" />.</entry>
|
linkend="image-process-controls" />.</entry>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
|
||||||
<entry><constant>V4L2_CTRL_CLASS_JPEG</constant></entry>
|
|
||||||
<entry>0x9d0000</entry>
|
|
||||||
<entry>The class containing JPEG compression controls.
|
|
||||||
These controls are described in <xref
|
|
||||||
linkend="jpeg-controls" />.</entry>
|
|
||||||
</row>
|
|
||||||
</tbody>
|
</tbody>
|
||||||
</tgroup>
|
</tgroup>
|
||||||
</table>
|
</table>
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
- compatible : "fsl,mma8450".
|
- compatible : "fsl,mma8450".
|
||||||
|
- reg: the I2C address of MMA8450
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
@ -46,8 +46,8 @@ Examples:
|
|||||||
|
|
||||||
ecspi@70010000 { /* ECSPI1 */
|
ecspi@70010000 { /* ECSPI1 */
|
||||||
fsl,spi-num-chipselects = <2>;
|
fsl,spi-num-chipselects = <2>;
|
||||||
cs-gpios = <&gpio3 24 0>, /* GPIO4_24 */
|
cs-gpios = <&gpio4 24 0>, /* GPIO4_24 */
|
||||||
<&gpio3 25 0>; /* GPIO4_25 */
|
<&gpio4 25 0>; /* GPIO4_25 */
|
||||||
status = "okay";
|
status = "okay";
|
||||||
|
|
||||||
pmic: mc13892@0 {
|
pmic: mc13892@0 {
|
||||||
|
@ -29,6 +29,6 @@ esdhc@70008000 {
|
|||||||
compatible = "fsl,imx51-esdhc";
|
compatible = "fsl,imx51-esdhc";
|
||||||
reg = <0x70008000 0x4000>;
|
reg = <0x70008000 0x4000>;
|
||||||
interrupts = <2>;
|
interrupts = <2>;
|
||||||
cd-gpios = <&gpio0 6 0>; /* GPIO1_6 */
|
cd-gpios = <&gpio1 6 0>; /* GPIO1_6 */
|
||||||
wp-gpios = <&gpio0 5 0>; /* GPIO1_5 */
|
wp-gpios = <&gpio1 5 0>; /* GPIO1_5 */
|
||||||
};
|
};
|
||||||
|
@ -19,6 +19,6 @@ ethernet@83fec000 {
|
|||||||
reg = <0x83fec000 0x4000>;
|
reg = <0x83fec000 0x4000>;
|
||||||
interrupts = <87>;
|
interrupts = <87>;
|
||||||
phy-mode = "mii";
|
phy-mode = "mii";
|
||||||
phy-reset-gpios = <&gpio1 14 0>; /* GPIO2_14 */
|
phy-reset-gpios = <&gpio2 14 0>; /* GPIO2_14 */
|
||||||
local-mac-address = [00 04 9F 01 1B B9];
|
local-mac-address = [00 04 9F 01 1B B9];
|
||||||
};
|
};
|
||||||
|
@ -1626,3 +1626,5 @@ MX6Q_PAD_SD2_DAT3__PCIE_CTRL_MUX_11 1587
|
|||||||
MX6Q_PAD_SD2_DAT3__GPIO_1_12 1588
|
MX6Q_PAD_SD2_DAT3__GPIO_1_12 1588
|
||||||
MX6Q_PAD_SD2_DAT3__SJC_DONE 1589
|
MX6Q_PAD_SD2_DAT3__SJC_DONE 1589
|
||||||
MX6Q_PAD_SD2_DAT3__ANATOP_TESTO_3 1590
|
MX6Q_PAD_SD2_DAT3__ANATOP_TESTO_3 1590
|
||||||
|
MX6Q_PAD_ENET_RX_ER__ANATOP_USBOTG_ID 1591
|
||||||
|
MX6Q_PAD_GPIO_1__ANATOP_USBOTG_ID 1592
|
||||||
|
@ -17,6 +17,6 @@ ecspi@70010000 {
|
|||||||
reg = <0x70010000 0x4000>;
|
reg = <0x70010000 0x4000>;
|
||||||
interrupts = <36>;
|
interrupts = <36>;
|
||||||
fsl,spi-num-chipselects = <2>;
|
fsl,spi-num-chipselects = <2>;
|
||||||
cs-gpios = <&gpio3 24 0>, /* GPIO4_24 */
|
cs-gpios = <&gpio3 24 0>, /* GPIO3_24 */
|
||||||
<&gpio3 25 0>; /* GPIO4_25 */
|
<&gpio3 25 0>; /* GPIO3_25 */
|
||||||
};
|
};
|
||||||
|
@ -3,6 +3,7 @@ Device tree binding vendor prefix registry. Keep list in alphabetical order.
|
|||||||
This isn't an exhaustive list, but you should add new prefixes to it before
|
This isn't an exhaustive list, but you should add new prefixes to it before
|
||||||
using them to avoid name-space collisions.
|
using them to avoid name-space collisions.
|
||||||
|
|
||||||
|
ad Avionic Design GmbH
|
||||||
adi Analog Devices, Inc.
|
adi Analog Devices, Inc.
|
||||||
amcc Applied Micro Circuits Corporation (APM, formally AMCC)
|
amcc Applied Micro Circuits Corporation (APM, formally AMCC)
|
||||||
apm Applied Micro Circuits Corporation (APM)
|
apm Applied Micro Circuits Corporation (APM)
|
||||||
|
@ -25,6 +25,13 @@ bits will no longer change the uid or gid; file capabilities will not
|
|||||||
add to the permitted set, and LSMs will not relax constraints after
|
add to the permitted set, and LSMs will not relax constraints after
|
||||||
execve.
|
execve.
|
||||||
|
|
||||||
|
To set no_new_privs, use prctl(PR_SET_NO_NEW_PRIVS, 1, 0, 0, 0).
|
||||||
|
|
||||||
|
Be careful, though: LSMs might also not tighten constraints on exec
|
||||||
|
in no_new_privs mode. (This means that setting up a general-purpose
|
||||||
|
service launcher to set no_new_privs before execing daemons may
|
||||||
|
interfere with LSM-based sandboxing.)
|
||||||
|
|
||||||
Note that no_new_privs does not prevent privilege changes that do not
|
Note that no_new_privs does not prevent privilege changes that do not
|
||||||
involve execve. An appropriately privileged task can still call
|
involve execve. An appropriately privileged task can still call
|
||||||
setuid(2) and receive SCM_RIGHTS datagrams.
|
setuid(2) and receive SCM_RIGHTS datagrams.
|
||||||
|
@ -1930,6 +1930,23 @@ The "pte_enc" field provides a value that can OR'ed into the hash
|
|||||||
PTE's RPN field (ie, it needs to be shifted left by 12 to OR it
|
PTE's RPN field (ie, it needs to be shifted left by 12 to OR it
|
||||||
into the hash PTE second double word).
|
into the hash PTE second double word).
|
||||||
|
|
||||||
|
4.75 KVM_IRQFD
|
||||||
|
|
||||||
|
Capability: KVM_CAP_IRQFD
|
||||||
|
Architectures: x86
|
||||||
|
Type: vm ioctl
|
||||||
|
Parameters: struct kvm_irqfd (in)
|
||||||
|
Returns: 0 on success, -1 on error
|
||||||
|
|
||||||
|
Allows setting an eventfd to directly trigger a guest interrupt.
|
||||||
|
kvm_irqfd.fd specifies the file descriptor to use as the eventfd and
|
||||||
|
kvm_irqfd.gsi specifies the irqchip pin toggled by this event. When
|
||||||
|
an event is tiggered on the eventfd, an interrupt is injected into
|
||||||
|
the guest using the specified gsi pin. The irqfd is removed using
|
||||||
|
the KVM_IRQFD_FLAG_DEASSIGN flag, specifying both kvm_irqfd.fd
|
||||||
|
and kvm_irqfd.gsi.
|
||||||
|
|
||||||
|
|
||||||
5. The kvm_run structure
|
5. The kvm_run structure
|
||||||
------------------------
|
------------------------
|
||||||
|
|
||||||
|
@ -3433,13 +3433,14 @@ S: Supported
|
|||||||
F: drivers/idle/i7300_idle.c
|
F: drivers/idle/i7300_idle.c
|
||||||
|
|
||||||
IEEE 802.15.4 SUBSYSTEM
|
IEEE 802.15.4 SUBSYSTEM
|
||||||
|
M: Alexander Smirnov <alex.bluesman.smirnov@gmail.com>
|
||||||
M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
|
M: Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
|
||||||
M: Sergey Lapin <slapin@ossfans.org>
|
|
||||||
L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers)
|
L: linux-zigbee-devel@lists.sourceforge.net (moderated for non-subscribers)
|
||||||
W: http://apps.sourceforge.net/trac/linux-zigbee
|
W: http://apps.sourceforge.net/trac/linux-zigbee
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/lowpan/lowpan.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: net/ieee802154/
|
F: net/ieee802154/
|
||||||
|
F: net/mac802154/
|
||||||
F: drivers/ieee802154/
|
F: drivers/ieee802154/
|
||||||
|
|
||||||
IIO SUBSYSTEM AND DRIVERS
|
IIO SUBSYSTEM AND DRIVERS
|
||||||
@ -4857,6 +4858,7 @@ M: Kevin Hilman <khilman@ti.com>
|
|||||||
L: linux-omap@vger.kernel.org
|
L: linux-omap@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: arch/arm/*omap*/*pm*
|
F: arch/arm/*omap*/*pm*
|
||||||
|
F: drivers/cpufreq/omap-cpufreq.c
|
||||||
|
|
||||||
OMAP POWERDOMAIN/CLOCKDOMAIN SOC ADAPTATION LAYER SUPPORT
|
OMAP POWERDOMAIN/CLOCKDOMAIN SOC ADAPTATION LAYER SUPPORT
|
||||||
M: Rajendra Nayak <rnayak@ti.com>
|
M: Rajendra Nayak <rnayak@ti.com>
|
||||||
@ -5909,7 +5911,7 @@ M: Ingo Molnar <mingo@redhat.com>
|
|||||||
M: Peter Zijlstra <peterz@infradead.org>
|
M: Peter Zijlstra <peterz@infradead.org>
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git sched/core
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip.git sched/core
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: kernel/sched*
|
F: kernel/sched/
|
||||||
F: include/linux/sched.h
|
F: include/linux/sched.h
|
||||||
|
|
||||||
SCORE ARCHITECTURE
|
SCORE ARCHITECTURE
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
VERSION = 3
|
VERSION = 3
|
||||||
PATCHLEVEL = 5
|
PATCHLEVEL = 5
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc5
|
EXTRAVERSION = -rc7
|
||||||
NAME = Saber-toothed Squirrel
|
NAME = Saber-toothed Squirrel
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -176,7 +176,6 @@ CONFIG_USB_ANNOUNCE_NEW_DEVICES=y
|
|||||||
CONFIG_USB_DEVICEFS=y
|
CONFIG_USB_DEVICEFS=y
|
||||||
CONFIG_USB_SUSPEND=y
|
CONFIG_USB_SUSPEND=y
|
||||||
CONFIG_USB_MON=y
|
CONFIG_USB_MON=y
|
||||||
CONFIG_USB_EHCI_HCD=y
|
|
||||||
CONFIG_USB_WDM=y
|
CONFIG_USB_WDM=y
|
||||||
CONFIG_USB_STORAGE=y
|
CONFIG_USB_STORAGE=y
|
||||||
CONFIG_USB_LIBUSUAL=y
|
CONFIG_USB_LIBUSUAL=y
|
||||||
|
@ -243,7 +243,7 @@ typedef struct {
|
|||||||
|
|
||||||
#define ATOMIC64_INIT(i) { (i) }
|
#define ATOMIC64_INIT(i) { (i) }
|
||||||
|
|
||||||
static inline u64 atomic64_read(atomic64_t *v)
|
static inline u64 atomic64_read(const atomic64_t *v)
|
||||||
{
|
{
|
||||||
u64 result;
|
u64 result;
|
||||||
|
|
||||||
|
@ -60,13 +60,13 @@
|
|||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
#ifdef CONFIG_CPU_USE_DOMAINS
|
#ifdef CONFIG_CPU_USE_DOMAINS
|
||||||
#define set_domain(x) \
|
static inline void set_domain(unsigned val)
|
||||||
do { \
|
{
|
||||||
__asm__ __volatile__( \
|
asm volatile(
|
||||||
"mcr p15, 0, %0, c3, c0 @ set domain" \
|
"mcr p15, 0, %0, c3, c0 @ set domain"
|
||||||
: : "r" (x)); \
|
: : "r" (val));
|
||||||
isb(); \
|
isb();
|
||||||
} while (0)
|
}
|
||||||
|
|
||||||
#define modify_domain(dom,type) \
|
#define modify_domain(dom,type) \
|
||||||
do { \
|
do { \
|
||||||
@ -78,8 +78,8 @@
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#define set_domain(x) do { } while (0)
|
static inline void set_domain(unsigned val) { }
|
||||||
#define modify_domain(dom,type) do { } while (0)
|
static inline void modify_domain(unsigned dom, unsigned type) { }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -148,7 +148,6 @@ extern int vfp_restore_user_hwstate(struct user_vfp __user *,
|
|||||||
#define TIF_NOTIFY_RESUME 2 /* callback before returning to user */
|
#define TIF_NOTIFY_RESUME 2 /* callback before returning to user */
|
||||||
#define TIF_SYSCALL_TRACE 8
|
#define TIF_SYSCALL_TRACE 8
|
||||||
#define TIF_SYSCALL_AUDIT 9
|
#define TIF_SYSCALL_AUDIT 9
|
||||||
#define TIF_SYSCALL_RESTARTSYS 10
|
|
||||||
#define TIF_POLLING_NRFLAG 16
|
#define TIF_POLLING_NRFLAG 16
|
||||||
#define TIF_USING_IWMMXT 17
|
#define TIF_USING_IWMMXT 17
|
||||||
#define TIF_MEMDIE 18 /* is terminating due to OOM killer */
|
#define TIF_MEMDIE 18 /* is terminating due to OOM killer */
|
||||||
@ -164,11 +163,9 @@ extern int vfp_restore_user_hwstate(struct user_vfp __user *,
|
|||||||
#define _TIF_POLLING_NRFLAG (1 << TIF_POLLING_NRFLAG)
|
#define _TIF_POLLING_NRFLAG (1 << TIF_POLLING_NRFLAG)
|
||||||
#define _TIF_USING_IWMMXT (1 << TIF_USING_IWMMXT)
|
#define _TIF_USING_IWMMXT (1 << TIF_USING_IWMMXT)
|
||||||
#define _TIF_SECCOMP (1 << TIF_SECCOMP)
|
#define _TIF_SECCOMP (1 << TIF_SECCOMP)
|
||||||
#define _TIF_SYSCALL_RESTARTSYS (1 << TIF_SYSCALL_RESTARTSYS)
|
|
||||||
|
|
||||||
/* Checks for any syscall work in entry-common.S */
|
/* Checks for any syscall work in entry-common.S */
|
||||||
#define _TIF_SYSCALL_WORK (_TIF_SYSCALL_TRACE | _TIF_SYSCALL_AUDIT | \
|
#define _TIF_SYSCALL_WORK (_TIF_SYSCALL_TRACE | _TIF_SYSCALL_AUDIT)
|
||||||
_TIF_SYSCALL_RESTARTSYS)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Change these and you break ASM code in entry-common.S
|
* Change these and you break ASM code in entry-common.S
|
||||||
|
@ -187,8 +187,8 @@ void kprobe_arm_test_cases(void)
|
|||||||
TEST_BF_R ("mov pc, r",0,2f,"")
|
TEST_BF_R ("mov pc, r",0,2f,"")
|
||||||
TEST_BF_RR("mov pc, r",0,2f,", asl r",1,0,"")
|
TEST_BF_RR("mov pc, r",0,2f,", asl r",1,0,"")
|
||||||
TEST_BB( "sub pc, pc, #1b-2b+8")
|
TEST_BB( "sub pc, pc, #1b-2b+8")
|
||||||
#if __LINUX_ARM_ARCH__ >= 6
|
#if __LINUX_ARM_ARCH__ == 6 && !defined(CONFIG_CPU_V7)
|
||||||
TEST_BB( "sub pc, pc, #1b-2b+8-2") /* UNPREDICTABLE before ARMv6 */
|
TEST_BB( "sub pc, pc, #1b-2b+8-2") /* UNPREDICTABLE before and after ARMv6 */
|
||||||
#endif
|
#endif
|
||||||
TEST_BB_R( "sub pc, pc, r",14, 1f-2f+8,"")
|
TEST_BB_R( "sub pc, pc, r",14, 1f-2f+8,"")
|
||||||
TEST_BB_R( "rsb pc, r",14,1f-2f+8,", pc")
|
TEST_BB_R( "rsb pc, r",14,1f-2f+8,", pc")
|
||||||
|
@ -503,7 +503,7 @@ __hw_perf_event_init(struct perf_event *event)
|
|||||||
event_requires_mode_exclusion(&event->attr)) {
|
event_requires_mode_exclusion(&event->attr)) {
|
||||||
pr_debug("ARM performance counters do not support "
|
pr_debug("ARM performance counters do not support "
|
||||||
"mode exclusion\n");
|
"mode exclusion\n");
|
||||||
return -EPERM;
|
return -EOPNOTSUPP;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
#include <linux/regset.h>
|
#include <linux/regset.h>
|
||||||
#include <linux/audit.h>
|
#include <linux/audit.h>
|
||||||
#include <linux/tracehook.h>
|
#include <linux/tracehook.h>
|
||||||
#include <linux/unistd.h>
|
|
||||||
|
|
||||||
#include <asm/pgtable.h>
|
#include <asm/pgtable.h>
|
||||||
#include <asm/traps.h>
|
#include <asm/traps.h>
|
||||||
@ -918,8 +917,6 @@ asmlinkage int syscall_trace(int why, struct pt_regs *regs, int scno)
|
|||||||
audit_syscall_entry(AUDIT_ARCH_ARM, scno, regs->ARM_r0,
|
audit_syscall_entry(AUDIT_ARCH_ARM, scno, regs->ARM_r0,
|
||||||
regs->ARM_r1, regs->ARM_r2, regs->ARM_r3);
|
regs->ARM_r1, regs->ARM_r2, regs->ARM_r3);
|
||||||
|
|
||||||
if (why == 0 && test_and_clear_thread_flag(TIF_SYSCALL_RESTARTSYS))
|
|
||||||
scno = __NR_restart_syscall - __NR_SYSCALL_BASE;
|
|
||||||
if (!test_thread_flag(TIF_SYSCALL_TRACE))
|
if (!test_thread_flag(TIF_SYSCALL_TRACE))
|
||||||
return scno;
|
return scno;
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
*/
|
*/
|
||||||
#define SWI_SYS_SIGRETURN (0xef000000|(__NR_sigreturn)|(__NR_OABI_SYSCALL_BASE))
|
#define SWI_SYS_SIGRETURN (0xef000000|(__NR_sigreturn)|(__NR_OABI_SYSCALL_BASE))
|
||||||
#define SWI_SYS_RT_SIGRETURN (0xef000000|(__NR_rt_sigreturn)|(__NR_OABI_SYSCALL_BASE))
|
#define SWI_SYS_RT_SIGRETURN (0xef000000|(__NR_rt_sigreturn)|(__NR_OABI_SYSCALL_BASE))
|
||||||
|
#define SWI_SYS_RESTART (0xef000000|__NR_restart_syscall|__NR_OABI_SYSCALL_BASE)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* With EABI, the syscall number has to be loaded into r7.
|
* With EABI, the syscall number has to be loaded into r7.
|
||||||
@ -46,6 +47,18 @@ const unsigned long sigreturn_codes[7] = {
|
|||||||
MOV_R7_NR_RT_SIGRETURN, SWI_SYS_RT_SIGRETURN, SWI_THUMB_RT_SIGRETURN,
|
MOV_R7_NR_RT_SIGRETURN, SWI_SYS_RT_SIGRETURN, SWI_THUMB_RT_SIGRETURN,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Either we support OABI only, or we have EABI with the OABI
|
||||||
|
* compat layer enabled. In the later case we don't know if
|
||||||
|
* user space is EABI or not, and if not we must not clobber r7.
|
||||||
|
* Always using the OABI syscall solves that issue and works for
|
||||||
|
* all those cases.
|
||||||
|
*/
|
||||||
|
const unsigned long syscall_restart_code[2] = {
|
||||||
|
SWI_SYS_RESTART, /* swi __NR_restart_syscall */
|
||||||
|
0xe49df004, /* ldr pc, [sp], #4 */
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* atomically swap in the new signal mask, and wait for a signal.
|
* atomically swap in the new signal mask, and wait for a signal.
|
||||||
*/
|
*/
|
||||||
@ -592,10 +605,12 @@ static void do_signal(struct pt_regs *regs, int syscall)
|
|||||||
case -ERESTARTNOHAND:
|
case -ERESTARTNOHAND:
|
||||||
case -ERESTARTSYS:
|
case -ERESTARTSYS:
|
||||||
case -ERESTARTNOINTR:
|
case -ERESTARTNOINTR:
|
||||||
case -ERESTART_RESTARTBLOCK:
|
|
||||||
regs->ARM_r0 = regs->ARM_ORIG_r0;
|
regs->ARM_r0 = regs->ARM_ORIG_r0;
|
||||||
regs->ARM_pc = restart_addr;
|
regs->ARM_pc = restart_addr;
|
||||||
break;
|
break;
|
||||||
|
case -ERESTART_RESTARTBLOCK:
|
||||||
|
regs->ARM_r0 = -EINTR;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -611,14 +626,12 @@ static void do_signal(struct pt_regs *regs, int syscall)
|
|||||||
* debugger has chosen to restart at a different PC.
|
* debugger has chosen to restart at a different PC.
|
||||||
*/
|
*/
|
||||||
if (regs->ARM_pc == restart_addr) {
|
if (regs->ARM_pc == restart_addr) {
|
||||||
if (retval == -ERESTARTNOHAND ||
|
if (retval == -ERESTARTNOHAND
|
||||||
retval == -ERESTART_RESTARTBLOCK
|
|
||||||
|| (retval == -ERESTARTSYS
|
|| (retval == -ERESTARTSYS
|
||||||
&& !(ka.sa.sa_flags & SA_RESTART))) {
|
&& !(ka.sa.sa_flags & SA_RESTART))) {
|
||||||
regs->ARM_r0 = -EINTR;
|
regs->ARM_r0 = -EINTR;
|
||||||
regs->ARM_pc = continue_addr;
|
regs->ARM_pc = continue_addr;
|
||||||
}
|
}
|
||||||
clear_thread_flag(TIF_SYSCALL_RESTARTSYS);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
handle_signal(signr, &ka, &info, regs);
|
handle_signal(signr, &ka, &info, regs);
|
||||||
@ -632,8 +645,29 @@ static void do_signal(struct pt_regs *regs, int syscall)
|
|||||||
* ignore the restart.
|
* ignore the restart.
|
||||||
*/
|
*/
|
||||||
if (retval == -ERESTART_RESTARTBLOCK
|
if (retval == -ERESTART_RESTARTBLOCK
|
||||||
&& regs->ARM_pc == restart_addr)
|
&& regs->ARM_pc == continue_addr) {
|
||||||
set_thread_flag(TIF_SYSCALL_RESTARTSYS);
|
if (thumb_mode(regs)) {
|
||||||
|
regs->ARM_r7 = __NR_restart_syscall - __NR_SYSCALL_BASE;
|
||||||
|
regs->ARM_pc -= 2;
|
||||||
|
} else {
|
||||||
|
#if defined(CONFIG_AEABI) && !defined(CONFIG_OABI_COMPAT)
|
||||||
|
regs->ARM_r7 = __NR_restart_syscall;
|
||||||
|
regs->ARM_pc -= 4;
|
||||||
|
#else
|
||||||
|
u32 __user *usp;
|
||||||
|
|
||||||
|
regs->ARM_sp -= 4;
|
||||||
|
usp = (u32 __user *)regs->ARM_sp;
|
||||||
|
|
||||||
|
if (put_user(regs->ARM_pc, usp) == 0) {
|
||||||
|
regs->ARM_pc = KERN_RESTART_CODE;
|
||||||
|
} else {
|
||||||
|
regs->ARM_sp += 4;
|
||||||
|
force_sigsegv(0, current);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
restore_saved_sigmask();
|
restore_saved_sigmask();
|
||||||
|
@ -8,5 +8,7 @@
|
|||||||
* published by the Free Software Foundation.
|
* published by the Free Software Foundation.
|
||||||
*/
|
*/
|
||||||
#define KERN_SIGRETURN_CODE (CONFIG_VECTORS_BASE + 0x00000500)
|
#define KERN_SIGRETURN_CODE (CONFIG_VECTORS_BASE + 0x00000500)
|
||||||
|
#define KERN_RESTART_CODE (KERN_SIGRETURN_CODE + sizeof(sigreturn_codes))
|
||||||
|
|
||||||
extern const unsigned long sigreturn_codes[7];
|
extern const unsigned long sigreturn_codes[7];
|
||||||
|
extern const unsigned long syscall_restart_code[2];
|
||||||
|
@ -820,6 +820,8 @@ void __init early_trap_init(void *vectors_base)
|
|||||||
*/
|
*/
|
||||||
memcpy((void *)(vectors + KERN_SIGRETURN_CODE - CONFIG_VECTORS_BASE),
|
memcpy((void *)(vectors + KERN_SIGRETURN_CODE - CONFIG_VECTORS_BASE),
|
||||||
sigreturn_codes, sizeof(sigreturn_codes));
|
sigreturn_codes, sizeof(sigreturn_codes));
|
||||||
|
memcpy((void *)(vectors + KERN_RESTART_CODE - CONFIG_VECTORS_BASE),
|
||||||
|
syscall_restart_code, sizeof(syscall_restart_code));
|
||||||
|
|
||||||
flush_icache_range(vectors, vectors + PAGE_SIZE);
|
flush_icache_range(vectors, vectors + PAGE_SIZE);
|
||||||
modify_domain(DOMAIN_USER, DOMAIN_CLIENT);
|
modify_domain(DOMAIN_USER, DOMAIN_CLIENT);
|
||||||
|
@ -50,5 +50,6 @@
|
|||||||
#define POWER_MANAGEMENT (BRIDGE_VIRT_BASE | 0x011c)
|
#define POWER_MANAGEMENT (BRIDGE_VIRT_BASE | 0x011c)
|
||||||
|
|
||||||
#define TIMER_VIRT_BASE (BRIDGE_VIRT_BASE | 0x0300)
|
#define TIMER_VIRT_BASE (BRIDGE_VIRT_BASE | 0x0300)
|
||||||
|
#define TIMER_PHYS_BASE (BRIDGE_PHYS_BASE | 0x0300)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -78,6 +78,7 @@
|
|||||||
|
|
||||||
/* North-South Bridge */
|
/* North-South Bridge */
|
||||||
#define BRIDGE_VIRT_BASE (DOVE_SB_REGS_VIRT_BASE | 0x20000)
|
#define BRIDGE_VIRT_BASE (DOVE_SB_REGS_VIRT_BASE | 0x20000)
|
||||||
|
#define BRIDGE_PHYS_BASE (DOVE_SB_REGS_PHYS_BASE | 0x20000)
|
||||||
|
|
||||||
/* Cryptographic Engine */
|
/* Cryptographic Engine */
|
||||||
#define DOVE_CRYPT_PHYS_BASE (DOVE_SB_REGS_PHYS_BASE | 0x30000)
|
#define DOVE_CRYPT_PHYS_BASE (DOVE_SB_REGS_PHYS_BASE | 0x30000)
|
||||||
|
@ -119,7 +119,9 @@ static __init void exynos_pm_add_dev_to_genpd(struct platform_device *pdev,
|
|||||||
struct exynos_pm_domain *pd)
|
struct exynos_pm_domain *pd)
|
||||||
{
|
{
|
||||||
if (pdev->dev.bus) {
|
if (pdev->dev.bus) {
|
||||||
if (pm_genpd_add_device(&pd->pd, &pdev->dev))
|
if (!pm_genpd_add_device(&pd->pd, &pdev->dev))
|
||||||
|
pm_genpd_dev_need_restore(&pdev->dev, true);
|
||||||
|
else
|
||||||
pr_info("%s: error in adding %s device to %s power"
|
pr_info("%s: error in adding %s device to %s power"
|
||||||
"domain\n", __func__, dev_name(&pdev->dev),
|
"domain\n", __func__, dev_name(&pdev->dev),
|
||||||
pd->name);
|
pd->name);
|
||||||
@ -151,9 +153,12 @@ static __init int exynos4_pm_init_power_domain(void)
|
|||||||
if (of_have_populated_dt())
|
if (of_have_populated_dt())
|
||||||
return exynos_pm_dt_parse_domains();
|
return exynos_pm_dt_parse_domains();
|
||||||
|
|
||||||
for (idx = 0; idx < ARRAY_SIZE(exynos4_pm_domains); idx++)
|
for (idx = 0; idx < ARRAY_SIZE(exynos4_pm_domains); idx++) {
|
||||||
pm_genpd_init(&exynos4_pm_domains[idx]->pd, NULL,
|
struct exynos_pm_domain *pd = exynos4_pm_domains[idx];
|
||||||
exynos4_pm_domains[idx]->is_off);
|
int on = __raw_readl(pd->base + 0x4) & S5P_INT_LOCAL_PWR_EN;
|
||||||
|
|
||||||
|
pm_genpd_init(&pd->pd, NULL, !on);
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_S5P_DEV_FIMD0
|
#ifdef CONFIG_S5P_DEV_FIMD0
|
||||||
exynos_pm_add_dev_to_genpd(&s5p_device_fimd0, &exynos4_pd_lcd0);
|
exynos_pm_add_dev_to_genpd(&s5p_device_fimd0, &exynos4_pd_lcd0);
|
||||||
|
@ -201,7 +201,6 @@ int __init mx35_clocks_init()
|
|||||||
pr_err("i.MX35 clk %d: register failed with %ld\n",
|
pr_err("i.MX35 clk %d: register failed with %ld\n",
|
||||||
i, PTR_ERR(clk[i]));
|
i, PTR_ERR(clk[i]));
|
||||||
|
|
||||||
|
|
||||||
clk_register_clkdev(clk[pata_gate], NULL, "pata_imx");
|
clk_register_clkdev(clk[pata_gate], NULL, "pata_imx");
|
||||||
clk_register_clkdev(clk[can1_gate], NULL, "flexcan.0");
|
clk_register_clkdev(clk[can1_gate], NULL, "flexcan.0");
|
||||||
clk_register_clkdev(clk[can2_gate], NULL, "flexcan.1");
|
clk_register_clkdev(clk[can2_gate], NULL, "flexcan.1");
|
||||||
@ -264,6 +263,14 @@ int __init mx35_clocks_init()
|
|||||||
clk_prepare_enable(clk[iim_gate]);
|
clk_prepare_enable(clk[iim_gate]);
|
||||||
clk_prepare_enable(clk[emi_gate]);
|
clk_prepare_enable(clk[emi_gate]);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* SCC is needed to boot via mmc after a watchdog reset. The clock code
|
||||||
|
* before conversion to common clk also enabled UART1 (which isn't
|
||||||
|
* handled here and not needed for mmc) and IIM (which is enabled
|
||||||
|
* unconditionally above).
|
||||||
|
*/
|
||||||
|
clk_prepare_enable(clk[scc_gate]);
|
||||||
|
|
||||||
imx_print_silicon_rev("i.MX35", mx35_revision());
|
imx_print_silicon_rev("i.MX35", mx35_revision());
|
||||||
|
|
||||||
#ifdef CONFIG_MXC_USE_EPIT
|
#ifdef CONFIG_MXC_USE_EPIT
|
||||||
|
@ -38,7 +38,7 @@
|
|||||||
#include <asm/mach-types.h>
|
#include <asm/mach-types.h>
|
||||||
#include <asm/mach/arch.h>
|
#include <asm/mach/arch.h>
|
||||||
#include <asm/mach/time.h>
|
#include <asm/mach/time.h>
|
||||||
#include <asm/system.h>
|
#include <asm/system_info.h>
|
||||||
#include <mach/common.h>
|
#include <mach/common.h>
|
||||||
#include <mach/iomux-mx27.h>
|
#include <mach/iomux-mx27.h>
|
||||||
|
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
#ifndef __ASM_MACH_GPIO_PXA_H
|
|
||||||
#define __ASM_MACH_GPIO_PXA_H
|
|
||||||
|
|
||||||
#include <mach/addr-map.h>
|
|
||||||
#include <mach/cputype.h>
|
|
||||||
#include <mach/irqs.h>
|
|
||||||
|
|
||||||
#define GPIO_REGS_VIRT (APB_VIRT_BASE + 0x19000)
|
|
||||||
|
|
||||||
#define BANK_OFF(n) (((n) < 3) ? (n) << 2 : 0x100 + (((n) - 3) << 2))
|
|
||||||
#define GPIO_REG(x) (*(volatile u32 *)(GPIO_REGS_VIRT + (x)))
|
|
||||||
|
|
||||||
#define gpio_to_bank(gpio) ((gpio) >> 5)
|
|
||||||
|
|
||||||
/* NOTE: these macros are defined here to make optimization of
|
|
||||||
* gpio_{get,set}_value() to work when 'gpio' is a constant.
|
|
||||||
* Usage of these macros otherwise is no longer recommended,
|
|
||||||
* use generic GPIO API whenever possible.
|
|
||||||
*/
|
|
||||||
#define GPIO_bit(gpio) (1 << ((gpio) & 0x1f))
|
|
||||||
|
|
||||||
#define GPLR(x) GPIO_REG(BANK_OFF(gpio_to_bank(x)) + 0x00)
|
|
||||||
#define GPDR(x) GPIO_REG(BANK_OFF(gpio_to_bank(x)) + 0x0c)
|
|
||||||
#define GPSR(x) GPIO_REG(BANK_OFF(gpio_to_bank(x)) + 0x18)
|
|
||||||
#define GPCR(x) GPIO_REG(BANK_OFF(gpio_to_bank(x)) + 0x24)
|
|
||||||
|
|
||||||
#include <plat/gpio-pxa.h>
|
|
||||||
|
|
||||||
#endif /* __ASM_MACH_GPIO_PXA_H */
|
|
@ -31,5 +31,6 @@
|
|||||||
#define IRQ_MASK_HIGH_OFF 0x0014
|
#define IRQ_MASK_HIGH_OFF 0x0014
|
||||||
|
|
||||||
#define TIMER_VIRT_BASE (BRIDGE_VIRT_BASE | 0x0300)
|
#define TIMER_VIRT_BASE (BRIDGE_VIRT_BASE | 0x0300)
|
||||||
|
#define TIMER_PHYS_BASE (BRIDGE_PHYS_BASE | 0x0300)
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -42,6 +42,7 @@
|
|||||||
#define MV78XX0_CORE0_REGS_PHYS_BASE 0xf1020000
|
#define MV78XX0_CORE0_REGS_PHYS_BASE 0xf1020000
|
||||||
#define MV78XX0_CORE1_REGS_PHYS_BASE 0xf1024000
|
#define MV78XX0_CORE1_REGS_PHYS_BASE 0xf1024000
|
||||||
#define MV78XX0_CORE_REGS_VIRT_BASE 0xfe400000
|
#define MV78XX0_CORE_REGS_VIRT_BASE 0xfe400000
|
||||||
|
#define MV78XX0_CORE_REGS_PHYS_BASE 0xfe400000
|
||||||
#define MV78XX0_CORE_REGS_SIZE SZ_16K
|
#define MV78XX0_CORE_REGS_SIZE SZ_16K
|
||||||
|
|
||||||
#define MV78XX0_PCIE_IO_PHYS_BASE(i) (0xf0800000 + ((i) << 20))
|
#define MV78XX0_PCIE_IO_PHYS_BASE(i) (0xf0800000 + ((i) << 20))
|
||||||
@ -59,6 +60,7 @@
|
|||||||
* Core-specific peripheral registers.
|
* Core-specific peripheral registers.
|
||||||
*/
|
*/
|
||||||
#define BRIDGE_VIRT_BASE (MV78XX0_CORE_REGS_VIRT_BASE)
|
#define BRIDGE_VIRT_BASE (MV78XX0_CORE_REGS_VIRT_BASE)
|
||||||
|
#define BRIDGE_PHYS_BASE (MV78XX0_CORE_REGS_PHYS_BASE)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Register Map
|
* Register Map
|
||||||
|
@ -205,6 +205,16 @@ static int apx4devkit_phy_fixup(struct phy_device *phy)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __init apx4devkit_fec_phy_clk_enable(void)
|
||||||
|
{
|
||||||
|
struct clk *clk;
|
||||||
|
|
||||||
|
/* Enable fec phy clock */
|
||||||
|
clk = clk_get_sys("enet_out", NULL);
|
||||||
|
if (!IS_ERR(clk))
|
||||||
|
clk_prepare_enable(clk);
|
||||||
|
}
|
||||||
|
|
||||||
static void __init apx4devkit_init(void)
|
static void __init apx4devkit_init(void)
|
||||||
{
|
{
|
||||||
mx28_soc_init();
|
mx28_soc_init();
|
||||||
@ -225,6 +235,7 @@ static void __init apx4devkit_init(void)
|
|||||||
phy_register_fixup_for_uid(PHY_ID_KS8051, MICREL_PHY_ID_MASK,
|
phy_register_fixup_for_uid(PHY_ID_KS8051, MICREL_PHY_ID_MASK,
|
||||||
apx4devkit_phy_fixup);
|
apx4devkit_phy_fixup);
|
||||||
|
|
||||||
|
apx4devkit_fec_phy_clk_enable();
|
||||||
mx28_add_fec(0, &mx28_fec_pdata);
|
mx28_add_fec(0, &mx28_fec_pdata);
|
||||||
|
|
||||||
mx28_add_mxs_mmc(0, &apx4devkit_mmc_pdata);
|
mx28_add_mxs_mmc(0, &apx4devkit_mmc_pdata);
|
||||||
|
@ -494,8 +494,8 @@ static void __init overo_init(void)
|
|||||||
|
|
||||||
regulator_register_fixed(0, dummy_supplies, ARRAY_SIZE(dummy_supplies));
|
regulator_register_fixed(0, dummy_supplies, ARRAY_SIZE(dummy_supplies));
|
||||||
omap3_mux_init(board_mux, OMAP_PACKAGE_CBB);
|
omap3_mux_init(board_mux, OMAP_PACKAGE_CBB);
|
||||||
omap_hsmmc_init(mmc);
|
|
||||||
overo_i2c_init();
|
overo_i2c_init();
|
||||||
|
omap_hsmmc_init(mmc);
|
||||||
omap_display_init(&overo_dss_data);
|
omap_display_init(&overo_dss_data);
|
||||||
omap_serial_init();
|
omap_serial_init();
|
||||||
omap_sdrc_init(mt46h32m32lf6_sdrc_params,
|
omap_sdrc_init(mt46h32m32lf6_sdrc_params,
|
||||||
|
@ -31,12 +31,16 @@
|
|||||||
*
|
*
|
||||||
* CLKDM_NO_AUTODEPS: Prevent "autodeps" from being added/removed from this
|
* CLKDM_NO_AUTODEPS: Prevent "autodeps" from being added/removed from this
|
||||||
* clockdomain. (Currently, this applies to OMAP3 clockdomains only.)
|
* clockdomain. (Currently, this applies to OMAP3 clockdomains only.)
|
||||||
|
* CLKDM_ACTIVE_WITH_MPU: The PRCM guarantees that this clockdomain is
|
||||||
|
* active whenever the MPU is active. True for interconnects and
|
||||||
|
* the WKUP clockdomains.
|
||||||
*/
|
*/
|
||||||
#define CLKDM_CAN_FORCE_SLEEP (1 << 0)
|
#define CLKDM_CAN_FORCE_SLEEP (1 << 0)
|
||||||
#define CLKDM_CAN_FORCE_WAKEUP (1 << 1)
|
#define CLKDM_CAN_FORCE_WAKEUP (1 << 1)
|
||||||
#define CLKDM_CAN_ENABLE_AUTO (1 << 2)
|
#define CLKDM_CAN_ENABLE_AUTO (1 << 2)
|
||||||
#define CLKDM_CAN_DISABLE_AUTO (1 << 3)
|
#define CLKDM_CAN_DISABLE_AUTO (1 << 3)
|
||||||
#define CLKDM_NO_AUTODEPS (1 << 4)
|
#define CLKDM_NO_AUTODEPS (1 << 4)
|
||||||
|
#define CLKDM_ACTIVE_WITH_MPU (1 << 5)
|
||||||
|
|
||||||
#define CLKDM_CAN_HWSUP (CLKDM_CAN_ENABLE_AUTO | CLKDM_CAN_DISABLE_AUTO)
|
#define CLKDM_CAN_HWSUP (CLKDM_CAN_ENABLE_AUTO | CLKDM_CAN_DISABLE_AUTO)
|
||||||
#define CLKDM_CAN_SWSUP (CLKDM_CAN_FORCE_SLEEP | CLKDM_CAN_FORCE_WAKEUP)
|
#define CLKDM_CAN_SWSUP (CLKDM_CAN_FORCE_SLEEP | CLKDM_CAN_FORCE_WAKEUP)
|
||||||
|
@ -88,4 +88,5 @@ struct clockdomain wkup_common_clkdm = {
|
|||||||
.name = "wkup_clkdm",
|
.name = "wkup_clkdm",
|
||||||
.pwrdm = { .name = "wkup_pwrdm" },
|
.pwrdm = { .name = "wkup_pwrdm" },
|
||||||
.dep_bit = OMAP_EN_WKUP_SHIFT,
|
.dep_bit = OMAP_EN_WKUP_SHIFT,
|
||||||
|
.flags = CLKDM_ACTIVE_WITH_MPU,
|
||||||
};
|
};
|
||||||
|
@ -381,7 +381,7 @@ static struct clockdomain l4_wkup_44xx_clkdm = {
|
|||||||
.cm_inst = OMAP4430_PRM_WKUP_CM_INST,
|
.cm_inst = OMAP4430_PRM_WKUP_CM_INST,
|
||||||
.clkdm_offs = OMAP4430_PRM_WKUP_CM_WKUP_CDOFFS,
|
.clkdm_offs = OMAP4430_PRM_WKUP_CM_WKUP_CDOFFS,
|
||||||
.dep_bit = OMAP4430_L4WKUP_STATDEP_SHIFT,
|
.dep_bit = OMAP4430_L4WKUP_STATDEP_SHIFT,
|
||||||
.flags = CLKDM_CAN_HWSUP,
|
.flags = CLKDM_CAN_HWSUP | CLKDM_ACTIVE_WITH_MPU,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct clockdomain emu_sys_44xx_clkdm = {
|
static struct clockdomain emu_sys_44xx_clkdm = {
|
||||||
|
@ -1124,15 +1124,18 @@ static struct omap_hwmod_addr_space * __init _find_mpu_rt_addr_space(struct omap
|
|||||||
* _enable_sysc - try to bring a module out of idle via OCP_SYSCONFIG
|
* _enable_sysc - try to bring a module out of idle via OCP_SYSCONFIG
|
||||||
* @oh: struct omap_hwmod *
|
* @oh: struct omap_hwmod *
|
||||||
*
|
*
|
||||||
* If module is marked as SWSUP_SIDLE, force the module out of slave
|
* Ensure that the OCP_SYSCONFIG register for the IP block represented
|
||||||
* idle; otherwise, configure it for smart-idle. If module is marked
|
* by @oh is set to indicate to the PRCM that the IP block is active.
|
||||||
* as SWSUP_MSUSPEND, force the module out of master standby;
|
* Usually this means placing the module into smart-idle mode and
|
||||||
* otherwise, configure it for smart-standby. No return value.
|
* smart-standby, but if there is a bug in the automatic idle handling
|
||||||
|
* for the IP block, it may need to be placed into the force-idle or
|
||||||
|
* no-idle variants of these modes. No return value.
|
||||||
*/
|
*/
|
||||||
static void _enable_sysc(struct omap_hwmod *oh)
|
static void _enable_sysc(struct omap_hwmod *oh)
|
||||||
{
|
{
|
||||||
u8 idlemode, sf;
|
u8 idlemode, sf;
|
||||||
u32 v;
|
u32 v;
|
||||||
|
bool clkdm_act;
|
||||||
|
|
||||||
if (!oh->class->sysc)
|
if (!oh->class->sysc)
|
||||||
return;
|
return;
|
||||||
@ -1141,8 +1144,16 @@ static void _enable_sysc(struct omap_hwmod *oh)
|
|||||||
sf = oh->class->sysc->sysc_flags;
|
sf = oh->class->sysc->sysc_flags;
|
||||||
|
|
||||||
if (sf & SYSC_HAS_SIDLEMODE) {
|
if (sf & SYSC_HAS_SIDLEMODE) {
|
||||||
idlemode = (oh->flags & HWMOD_SWSUP_SIDLE) ?
|
clkdm_act = ((oh->clkdm &&
|
||||||
HWMOD_IDLEMODE_NO : HWMOD_IDLEMODE_SMART;
|
oh->clkdm->flags & CLKDM_ACTIVE_WITH_MPU) ||
|
||||||
|
(oh->_clk && oh->_clk->clkdm &&
|
||||||
|
oh->_clk->clkdm->flags & CLKDM_ACTIVE_WITH_MPU));
|
||||||
|
if (clkdm_act && !(oh->class->sysc->idlemodes &
|
||||||
|
(SIDLE_SMART | SIDLE_SMART_WKUP)))
|
||||||
|
idlemode = HWMOD_IDLEMODE_FORCE;
|
||||||
|
else
|
||||||
|
idlemode = (oh->flags & HWMOD_SWSUP_SIDLE) ?
|
||||||
|
HWMOD_IDLEMODE_NO : HWMOD_IDLEMODE_SMART;
|
||||||
_set_slave_idlemode(oh, idlemode, &v);
|
_set_slave_idlemode(oh, idlemode, &v);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1208,8 +1219,13 @@ static void _idle_sysc(struct omap_hwmod *oh)
|
|||||||
sf = oh->class->sysc->sysc_flags;
|
sf = oh->class->sysc->sysc_flags;
|
||||||
|
|
||||||
if (sf & SYSC_HAS_SIDLEMODE) {
|
if (sf & SYSC_HAS_SIDLEMODE) {
|
||||||
idlemode = (oh->flags & HWMOD_SWSUP_SIDLE) ?
|
/* XXX What about HWMOD_IDLEMODE_SMART_WKUP? */
|
||||||
HWMOD_IDLEMODE_FORCE : HWMOD_IDLEMODE_SMART;
|
if (oh->flags & HWMOD_SWSUP_SIDLE ||
|
||||||
|
!(oh->class->sysc->idlemodes &
|
||||||
|
(SIDLE_SMART | SIDLE_SMART_WKUP)))
|
||||||
|
idlemode = HWMOD_IDLEMODE_FORCE;
|
||||||
|
else
|
||||||
|
idlemode = HWMOD_IDLEMODE_SMART;
|
||||||
_set_slave_idlemode(oh, idlemode, &v);
|
_set_slave_idlemode(oh, idlemode, &v);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1928,7 +1928,7 @@ static struct omap_hwmod_dma_info omap44xx_mcbsp1_sdma_reqs[] = {
|
|||||||
|
|
||||||
static struct omap_hwmod_opt_clk mcbsp1_opt_clks[] = {
|
static struct omap_hwmod_opt_clk mcbsp1_opt_clks[] = {
|
||||||
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
||||||
{ .role = "prcm_clk", .clk = "mcbsp1_sync_mux_ck" },
|
{ .role = "prcm_fck", .clk = "mcbsp1_sync_mux_ck" },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct omap_hwmod omap44xx_mcbsp1_hwmod = {
|
static struct omap_hwmod omap44xx_mcbsp1_hwmod = {
|
||||||
@ -1963,7 +1963,7 @@ static struct omap_hwmod_dma_info omap44xx_mcbsp2_sdma_reqs[] = {
|
|||||||
|
|
||||||
static struct omap_hwmod_opt_clk mcbsp2_opt_clks[] = {
|
static struct omap_hwmod_opt_clk mcbsp2_opt_clks[] = {
|
||||||
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
||||||
{ .role = "prcm_clk", .clk = "mcbsp2_sync_mux_ck" },
|
{ .role = "prcm_fck", .clk = "mcbsp2_sync_mux_ck" },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct omap_hwmod omap44xx_mcbsp2_hwmod = {
|
static struct omap_hwmod omap44xx_mcbsp2_hwmod = {
|
||||||
@ -1998,7 +1998,7 @@ static struct omap_hwmod_dma_info omap44xx_mcbsp3_sdma_reqs[] = {
|
|||||||
|
|
||||||
static struct omap_hwmod_opt_clk mcbsp3_opt_clks[] = {
|
static struct omap_hwmod_opt_clk mcbsp3_opt_clks[] = {
|
||||||
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
||||||
{ .role = "prcm_clk", .clk = "mcbsp3_sync_mux_ck" },
|
{ .role = "prcm_fck", .clk = "mcbsp3_sync_mux_ck" },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct omap_hwmod omap44xx_mcbsp3_hwmod = {
|
static struct omap_hwmod omap44xx_mcbsp3_hwmod = {
|
||||||
@ -2033,7 +2033,7 @@ static struct omap_hwmod_dma_info omap44xx_mcbsp4_sdma_reqs[] = {
|
|||||||
|
|
||||||
static struct omap_hwmod_opt_clk mcbsp4_opt_clks[] = {
|
static struct omap_hwmod_opt_clk mcbsp4_opt_clks[] = {
|
||||||
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
{ .role = "pad_fck", .clk = "pad_clks_ck" },
|
||||||
{ .role = "prcm_clk", .clk = "mcbsp4_sync_mux_ck" },
|
{ .role = "prcm_fck", .clk = "mcbsp4_sync_mux_ck" },
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct omap_hwmod omap44xx_mcbsp4_hwmod = {
|
static struct omap_hwmod omap44xx_mcbsp4_hwmod = {
|
||||||
@ -3864,7 +3864,7 @@ static struct omap_hwmod_ocp_if omap44xx_l4_cfg__l3_main_2 = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* usb_host_fs -> l3_main_2 */
|
/* usb_host_fs -> l3_main_2 */
|
||||||
static struct omap_hwmod_ocp_if omap44xx_usb_host_fs__l3_main_2 = {
|
static struct omap_hwmod_ocp_if __maybe_unused omap44xx_usb_host_fs__l3_main_2 = {
|
||||||
.master = &omap44xx_usb_host_fs_hwmod,
|
.master = &omap44xx_usb_host_fs_hwmod,
|
||||||
.slave = &omap44xx_l3_main_2_hwmod,
|
.slave = &omap44xx_l3_main_2_hwmod,
|
||||||
.clk = "l3_div_ck",
|
.clk = "l3_div_ck",
|
||||||
@ -3922,7 +3922,7 @@ static struct omap_hwmod_ocp_if omap44xx_l4_cfg__l3_main_3 = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* aess -> l4_abe */
|
/* aess -> l4_abe */
|
||||||
static struct omap_hwmod_ocp_if omap44xx_aess__l4_abe = {
|
static struct omap_hwmod_ocp_if __maybe_unused omap44xx_aess__l4_abe = {
|
||||||
.master = &omap44xx_aess_hwmod,
|
.master = &omap44xx_aess_hwmod,
|
||||||
.slave = &omap44xx_l4_abe_hwmod,
|
.slave = &omap44xx_l4_abe_hwmod,
|
||||||
.clk = "ocp_abe_iclk",
|
.clk = "ocp_abe_iclk",
|
||||||
@ -4013,7 +4013,7 @@ static struct omap_hwmod_addr_space omap44xx_aess_addrs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* l4_abe -> aess */
|
/* l4_abe -> aess */
|
||||||
static struct omap_hwmod_ocp_if omap44xx_l4_abe__aess = {
|
static struct omap_hwmod_ocp_if __maybe_unused omap44xx_l4_abe__aess = {
|
||||||
.master = &omap44xx_l4_abe_hwmod,
|
.master = &omap44xx_l4_abe_hwmod,
|
||||||
.slave = &omap44xx_aess_hwmod,
|
.slave = &omap44xx_aess_hwmod,
|
||||||
.clk = "ocp_abe_iclk",
|
.clk = "ocp_abe_iclk",
|
||||||
@ -4031,7 +4031,7 @@ static struct omap_hwmod_addr_space omap44xx_aess_dma_addrs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* l4_abe -> aess (dma) */
|
/* l4_abe -> aess (dma) */
|
||||||
static struct omap_hwmod_ocp_if omap44xx_l4_abe__aess_dma = {
|
static struct omap_hwmod_ocp_if __maybe_unused omap44xx_l4_abe__aess_dma = {
|
||||||
.master = &omap44xx_l4_abe_hwmod,
|
.master = &omap44xx_l4_abe_hwmod,
|
||||||
.slave = &omap44xx_aess_hwmod,
|
.slave = &omap44xx_aess_hwmod,
|
||||||
.clk = "ocp_abe_iclk",
|
.clk = "ocp_abe_iclk",
|
||||||
@ -5857,7 +5857,7 @@ static struct omap_hwmod_addr_space omap44xx_usb_host_fs_addrs[] = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
/* l4_cfg -> usb_host_fs */
|
/* l4_cfg -> usb_host_fs */
|
||||||
static struct omap_hwmod_ocp_if omap44xx_l4_cfg__usb_host_fs = {
|
static struct omap_hwmod_ocp_if __maybe_unused omap44xx_l4_cfg__usb_host_fs = {
|
||||||
.master = &omap44xx_l4_cfg_hwmod,
|
.master = &omap44xx_l4_cfg_hwmod,
|
||||||
.slave = &omap44xx_usb_host_fs_hwmod,
|
.slave = &omap44xx_usb_host_fs_hwmod,
|
||||||
.clk = "l4_div_ck",
|
.clk = "l4_div_ck",
|
||||||
@ -6014,13 +6014,13 @@ static struct omap_hwmod_ocp_if *omap44xx_hwmod_ocp_ifs[] __initdata = {
|
|||||||
&omap44xx_iva__l3_main_2,
|
&omap44xx_iva__l3_main_2,
|
||||||
&omap44xx_l3_main_1__l3_main_2,
|
&omap44xx_l3_main_1__l3_main_2,
|
||||||
&omap44xx_l4_cfg__l3_main_2,
|
&omap44xx_l4_cfg__l3_main_2,
|
||||||
&omap44xx_usb_host_fs__l3_main_2,
|
/* &omap44xx_usb_host_fs__l3_main_2, */
|
||||||
&omap44xx_usb_host_hs__l3_main_2,
|
&omap44xx_usb_host_hs__l3_main_2,
|
||||||
&omap44xx_usb_otg_hs__l3_main_2,
|
&omap44xx_usb_otg_hs__l3_main_2,
|
||||||
&omap44xx_l3_main_1__l3_main_3,
|
&omap44xx_l3_main_1__l3_main_3,
|
||||||
&omap44xx_l3_main_2__l3_main_3,
|
&omap44xx_l3_main_2__l3_main_3,
|
||||||
&omap44xx_l4_cfg__l3_main_3,
|
&omap44xx_l4_cfg__l3_main_3,
|
||||||
&omap44xx_aess__l4_abe,
|
/* &omap44xx_aess__l4_abe, */
|
||||||
&omap44xx_dsp__l4_abe,
|
&omap44xx_dsp__l4_abe,
|
||||||
&omap44xx_l3_main_1__l4_abe,
|
&omap44xx_l3_main_1__l4_abe,
|
||||||
&omap44xx_mpu__l4_abe,
|
&omap44xx_mpu__l4_abe,
|
||||||
@ -6029,8 +6029,8 @@ static struct omap_hwmod_ocp_if *omap44xx_hwmod_ocp_ifs[] __initdata = {
|
|||||||
&omap44xx_l4_cfg__l4_wkup,
|
&omap44xx_l4_cfg__l4_wkup,
|
||||||
&omap44xx_mpu__mpu_private,
|
&omap44xx_mpu__mpu_private,
|
||||||
&omap44xx_l4_cfg__ocp_wp_noc,
|
&omap44xx_l4_cfg__ocp_wp_noc,
|
||||||
&omap44xx_l4_abe__aess,
|
/* &omap44xx_l4_abe__aess, */
|
||||||
&omap44xx_l4_abe__aess_dma,
|
/* &omap44xx_l4_abe__aess_dma, */
|
||||||
&omap44xx_l3_main_2__c2c,
|
&omap44xx_l3_main_2__c2c,
|
||||||
&omap44xx_l4_wkup__counter_32k,
|
&omap44xx_l4_wkup__counter_32k,
|
||||||
&omap44xx_l4_cfg__ctrl_module_core,
|
&omap44xx_l4_cfg__ctrl_module_core,
|
||||||
@ -6136,7 +6136,7 @@ static struct omap_hwmod_ocp_if *omap44xx_hwmod_ocp_ifs[] __initdata = {
|
|||||||
&omap44xx_l4_per__uart2,
|
&omap44xx_l4_per__uart2,
|
||||||
&omap44xx_l4_per__uart3,
|
&omap44xx_l4_per__uart3,
|
||||||
&omap44xx_l4_per__uart4,
|
&omap44xx_l4_per__uart4,
|
||||||
&omap44xx_l4_cfg__usb_host_fs,
|
/* &omap44xx_l4_cfg__usb_host_fs, */
|
||||||
&omap44xx_l4_cfg__usb_host_hs,
|
&omap44xx_l4_cfg__usb_host_hs,
|
||||||
&omap44xx_l4_cfg__usb_otg_hs,
|
&omap44xx_l4_cfg__usb_otg_hs,
|
||||||
&omap44xx_l4_cfg__usb_tll_hs,
|
&omap44xx_l4_cfg__usb_tll_hs,
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "twl-common.h"
|
#include "twl-common.h"
|
||||||
#include "pm.h"
|
#include "pm.h"
|
||||||
#include "voltage.h"
|
#include "voltage.h"
|
||||||
|
#include "mux.h"
|
||||||
|
|
||||||
static struct i2c_board_info __initdata pmic_i2c_board_info = {
|
static struct i2c_board_info __initdata pmic_i2c_board_info = {
|
||||||
.addr = 0x48,
|
.addr = 0x48,
|
||||||
@ -77,6 +78,7 @@ void __init omap4_pmic_init(const char *pmic_type,
|
|||||||
struct twl6040_platform_data *twl6040_data, int twl6040_irq)
|
struct twl6040_platform_data *twl6040_data, int twl6040_irq)
|
||||||
{
|
{
|
||||||
/* PMIC part*/
|
/* PMIC part*/
|
||||||
|
omap_mux_init_signal("sys_nirq1", OMAP_PIN_INPUT_PULLUP | OMAP_PIN_OFF_WAKEUPENABLE);
|
||||||
strncpy(omap4_i2c1_board_info[0].type, pmic_type,
|
strncpy(omap4_i2c1_board_info[0].type, pmic_type,
|
||||||
sizeof(omap4_i2c1_board_info[0].type));
|
sizeof(omap4_i2c1_board_info[0].type));
|
||||||
omap4_i2c1_board_info[0].irq = OMAP44XX_IRQ_SYS_1N;
|
omap4_i2c1_board_info[0].irq = OMAP44XX_IRQ_SYS_1N;
|
||||||
|
@ -127,7 +127,11 @@ static unsigned long hx4700_pin_config[] __initdata = {
|
|||||||
GPIO19_SSP2_SCLK,
|
GPIO19_SSP2_SCLK,
|
||||||
GPIO86_SSP2_RXD,
|
GPIO86_SSP2_RXD,
|
||||||
GPIO87_SSP2_TXD,
|
GPIO87_SSP2_TXD,
|
||||||
GPIO88_GPIO,
|
GPIO88_GPIO | MFP_LPM_DRIVE_HIGH, /* TSC2046_CS */
|
||||||
|
|
||||||
|
/* BQ24022 Regulator */
|
||||||
|
GPIO72_GPIO | MFP_LPM_KEEP_OUTPUT, /* BQ24022_nCHARGE_EN */
|
||||||
|
GPIO96_GPIO | MFP_LPM_KEEP_OUTPUT, /* BQ24022_ISET2 */
|
||||||
|
|
||||||
/* HX4700 specific input GPIOs */
|
/* HX4700 specific input GPIOs */
|
||||||
GPIO12_GPIO | WAKEUP_ON_EDGE_RISE, /* ASIC3_IRQ */
|
GPIO12_GPIO | WAKEUP_ON_EDGE_RISE, /* ASIC3_IRQ */
|
||||||
@ -135,6 +139,10 @@ static unsigned long hx4700_pin_config[] __initdata = {
|
|||||||
GPIO14_GPIO, /* nWLAN_IRQ */
|
GPIO14_GPIO, /* nWLAN_IRQ */
|
||||||
|
|
||||||
/* HX4700 specific output GPIOs */
|
/* HX4700 specific output GPIOs */
|
||||||
|
GPIO61_GPIO | MFP_LPM_DRIVE_HIGH, /* W3220_nRESET */
|
||||||
|
GPIO71_GPIO | MFP_LPM_DRIVE_HIGH, /* ASIC3_nRESET */
|
||||||
|
GPIO81_GPIO | MFP_LPM_DRIVE_HIGH, /* CPU_GP_nRESET */
|
||||||
|
GPIO116_GPIO | MFP_LPM_DRIVE_HIGH, /* CPU_HW_nRESET */
|
||||||
GPIO102_GPIO | MFP_LPM_DRIVE_LOW, /* SYNAPTICS_POWER_ON */
|
GPIO102_GPIO | MFP_LPM_DRIVE_LOW, /* SYNAPTICS_POWER_ON */
|
||||||
|
|
||||||
GPIO10_GPIO, /* GSM_IRQ */
|
GPIO10_GPIO, /* GSM_IRQ */
|
||||||
@ -872,14 +880,19 @@ static struct gpio global_gpios[] = {
|
|||||||
{ GPIO110_HX4700_LCD_LVDD_3V3_ON, GPIOF_OUT_INIT_HIGH, "LCD_LVDD" },
|
{ GPIO110_HX4700_LCD_LVDD_3V3_ON, GPIOF_OUT_INIT_HIGH, "LCD_LVDD" },
|
||||||
{ GPIO111_HX4700_LCD_AVDD_3V3_ON, GPIOF_OUT_INIT_HIGH, "LCD_AVDD" },
|
{ GPIO111_HX4700_LCD_AVDD_3V3_ON, GPIOF_OUT_INIT_HIGH, "LCD_AVDD" },
|
||||||
{ GPIO32_HX4700_RS232_ON, GPIOF_OUT_INIT_HIGH, "RS232_ON" },
|
{ GPIO32_HX4700_RS232_ON, GPIOF_OUT_INIT_HIGH, "RS232_ON" },
|
||||||
|
{ GPIO61_HX4700_W3220_nRESET, GPIOF_OUT_INIT_HIGH, "W3220_nRESET" },
|
||||||
{ GPIO71_HX4700_ASIC3_nRESET, GPIOF_OUT_INIT_HIGH, "ASIC3_nRESET" },
|
{ GPIO71_HX4700_ASIC3_nRESET, GPIOF_OUT_INIT_HIGH, "ASIC3_nRESET" },
|
||||||
|
{ GPIO81_HX4700_CPU_GP_nRESET, GPIOF_OUT_INIT_HIGH, "CPU_GP_nRESET" },
|
||||||
{ GPIO82_HX4700_EUART_RESET, GPIOF_OUT_INIT_HIGH, "EUART_RESET" },
|
{ GPIO82_HX4700_EUART_RESET, GPIOF_OUT_INIT_HIGH, "EUART_RESET" },
|
||||||
|
{ GPIO116_HX4700_CPU_HW_nRESET, GPIOF_OUT_INIT_HIGH, "CPU_HW_nRESET" },
|
||||||
};
|
};
|
||||||
|
|
||||||
static void __init hx4700_init(void)
|
static void __init hx4700_init(void)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
PCFR = PCFR_GPR_EN | PCFR_OPDE;
|
||||||
|
|
||||||
pxa2xx_mfp_config(ARRAY_AND_SIZE(hx4700_pin_config));
|
pxa2xx_mfp_config(ARRAY_AND_SIZE(hx4700_pin_config));
|
||||||
gpio_set_wake(GPIO12_HX4700_ASIC3_IRQ, 1);
|
gpio_set_wake(GPIO12_HX4700_ASIC3_IRQ, 1);
|
||||||
ret = gpio_request_array(ARRAY_AND_SIZE(global_gpios));
|
ret = gpio_request_array(ARRAY_AND_SIZE(global_gpios));
|
||||||
|
@ -106,7 +106,7 @@ static struct clk s3c2440_clk_cam_upll = {
|
|||||||
static struct clk s3c2440_clk_ac97 = {
|
static struct clk s3c2440_clk_ac97 = {
|
||||||
.name = "ac97",
|
.name = "ac97",
|
||||||
.enable = s3c2410_clkcon_enable,
|
.enable = s3c2410_clkcon_enable,
|
||||||
.ctrlbit = S3C2440_CLKCON_CAMERA,
|
.ctrlbit = S3C2440_CLKCON_AC97,
|
||||||
};
|
};
|
||||||
|
|
||||||
static unsigned long s3c2440_fclk_n_getrate(struct clk *clk)
|
static unsigned long s3c2440_fclk_n_getrate(struct clk *clk)
|
||||||
|
@ -22,8 +22,13 @@
|
|||||||
#include <mach/common.h>
|
#include <mach/common.h>
|
||||||
#include <mach/emev2.h>
|
#include <mach/emev2.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_ARCH_SH73A0
|
||||||
#define is_sh73a0() (machine_is_ag5evm() || machine_is_kota2() || \
|
#define is_sh73a0() (machine_is_ag5evm() || machine_is_kota2() || \
|
||||||
of_machine_is_compatible("renesas,sh73a0"))
|
of_machine_is_compatible("renesas,sh73a0"))
|
||||||
|
#else
|
||||||
|
#define is_sh73a0() (0)
|
||||||
|
#endif
|
||||||
|
|
||||||
#define is_r8a7779() machine_is_marzen()
|
#define is_r8a7779() machine_is_marzen()
|
||||||
|
|
||||||
#ifdef CONFIG_ARCH_EMEV2
|
#ifdef CONFIG_ARCH_EMEV2
|
||||||
|
@ -625,11 +625,6 @@ static struct platform_device *snowball_platform_devs[] __initdata = {
|
|||||||
&ab8500_device,
|
&ab8500_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct platform_device *snowball_of_platform_devs[] __initdata = {
|
|
||||||
&snowball_led_dev,
|
|
||||||
&snowball_key_dev,
|
|
||||||
};
|
|
||||||
|
|
||||||
static void __init mop500_init_machine(void)
|
static void __init mop500_init_machine(void)
|
||||||
{
|
{
|
||||||
struct device *parent = NULL;
|
struct device *parent = NULL;
|
||||||
@ -769,6 +764,11 @@ MACHINE_END
|
|||||||
|
|
||||||
#ifdef CONFIG_MACH_UX500_DT
|
#ifdef CONFIG_MACH_UX500_DT
|
||||||
|
|
||||||
|
static struct platform_device *snowball_of_platform_devs[] __initdata = {
|
||||||
|
&snowball_led_dev,
|
||||||
|
&snowball_key_dev,
|
||||||
|
};
|
||||||
|
|
||||||
struct of_dev_auxdata u8500_auxdata_lookup[] __initdata = {
|
struct of_dev_auxdata u8500_auxdata_lookup[] __initdata = {
|
||||||
/* Requires DMA and call-back bindings. */
|
/* Requires DMA and call-back bindings. */
|
||||||
OF_DEV_AUXDATA("arm,pl011", 0x80120000, "uart0", &uart0_plat),
|
OF_DEV_AUXDATA("arm,pl011", 0x80120000, "uart0", &uart0_plat),
|
||||||
@ -786,6 +786,8 @@ struct of_dev_auxdata u8500_auxdata_lookup[] __initdata = {
|
|||||||
OF_DEV_AUXDATA("st,nomadik-gpio", 0x8011e000, "gpio.6", NULL),
|
OF_DEV_AUXDATA("st,nomadik-gpio", 0x8011e000, "gpio.6", NULL),
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", 0x8011e080, "gpio.7", NULL),
|
OF_DEV_AUXDATA("st,nomadik-gpio", 0x8011e080, "gpio.7", NULL),
|
||||||
OF_DEV_AUXDATA("st,nomadik-gpio", 0xa03fe000, "gpio.8", NULL),
|
OF_DEV_AUXDATA("st,nomadik-gpio", 0xa03fe000, "gpio.8", NULL),
|
||||||
|
/* Requires device name bindings. */
|
||||||
|
OF_DEV_AUXDATA("stericsson,nmk_pinctrl", 0, "pinctrl-db8500", NULL),
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -63,8 +63,10 @@ static void __init ux500_timer_init(void)
|
|||||||
|
|
||||||
/* TODO: Once MTU has been DT:ed place code above into else. */
|
/* TODO: Once MTU has been DT:ed place code above into else. */
|
||||||
if (of_have_populated_dt()) {
|
if (of_have_populated_dt()) {
|
||||||
|
#ifdef CONFIG_OF
|
||||||
np = of_find_matching_node(NULL, prcmu_timer_of_match);
|
np = of_find_matching_node(NULL, prcmu_timer_of_match);
|
||||||
if (!np)
|
if (!np)
|
||||||
|
#endif
|
||||||
goto dt_fail;
|
goto dt_fail;
|
||||||
|
|
||||||
tmp_base = of_iomap(np, 0);
|
tmp_base = of_iomap(np, 0);
|
||||||
|
@ -339,7 +339,6 @@ void __init pci_versatile_preinit(void)
|
|||||||
static int __init versatile_map_irq(const struct pci_dev *dev, u8 slot, u8 pin)
|
static int __init versatile_map_irq(const struct pci_dev *dev, u8 slot, u8 pin)
|
||||||
{
|
{
|
||||||
int irq;
|
int irq;
|
||||||
int devslot = PCI_SLOT(dev->devfn);
|
|
||||||
|
|
||||||
/* slot, pin, irq
|
/* slot, pin, irq
|
||||||
* 24 1 27
|
* 24 1 27
|
||||||
|
@ -1091,7 +1091,7 @@ error:
|
|||||||
while (--i)
|
while (--i)
|
||||||
if (pages[i])
|
if (pages[i])
|
||||||
__free_pages(pages[i], 0);
|
__free_pages(pages[i], 0);
|
||||||
if (array_size < PAGE_SIZE)
|
if (array_size <= PAGE_SIZE)
|
||||||
kfree(pages);
|
kfree(pages);
|
||||||
else
|
else
|
||||||
vfree(pages);
|
vfree(pages);
|
||||||
@ -1106,7 +1106,7 @@ static int __iommu_free_buffer(struct device *dev, struct page **pages, size_t s
|
|||||||
for (i = 0; i < count; i++)
|
for (i = 0; i < count; i++)
|
||||||
if (pages[i])
|
if (pages[i])
|
||||||
__free_pages(pages[i], 0);
|
__free_pages(pages[i], 0);
|
||||||
if (array_size < PAGE_SIZE)
|
if (array_size <= PAGE_SIZE)
|
||||||
kfree(pages);
|
kfree(pages);
|
||||||
else
|
else
|
||||||
vfree(pages);
|
vfree(pages);
|
||||||
|
@ -64,7 +64,7 @@ extern void __flush_dcache_page(struct address_space *mapping, struct page *page
|
|||||||
#ifdef CONFIG_ZONE_DMA
|
#ifdef CONFIG_ZONE_DMA
|
||||||
extern phys_addr_t arm_dma_limit;
|
extern phys_addr_t arm_dma_limit;
|
||||||
#else
|
#else
|
||||||
#define arm_dma_limit ((u32)~0)
|
#define arm_dma_limit ((phys_addr_t)~0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
extern phys_addr_t arm_lowmem_limit;
|
extern phys_addr_t arm_lowmem_limit;
|
||||||
|
@ -157,11 +157,13 @@ int s3c_adc_start(struct s3c_adc_client *client,
|
|||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (client->is_ts && adc->ts_pend)
|
|
||||||
return -EAGAIN;
|
|
||||||
|
|
||||||
spin_lock_irqsave(&adc->lock, flags);
|
spin_lock_irqsave(&adc->lock, flags);
|
||||||
|
|
||||||
|
if (client->is_ts && adc->ts_pend) {
|
||||||
|
spin_unlock_irqrestore(&adc->lock, flags);
|
||||||
|
return -EAGAIN;
|
||||||
|
}
|
||||||
|
|
||||||
client->channel = channel;
|
client->channel = channel;
|
||||||
client->nr_samples = nr_samples;
|
client->nr_samples = nr_samples;
|
||||||
|
|
||||||
|
@ -126,7 +126,8 @@ struct platform_device s3c_device_adc = {
|
|||||||
#ifdef CONFIG_CPU_S3C2440
|
#ifdef CONFIG_CPU_S3C2440
|
||||||
static struct resource s3c_camif_resource[] = {
|
static struct resource s3c_camif_resource[] = {
|
||||||
[0] = DEFINE_RES_MEM(S3C2440_PA_CAMIF, S3C2440_SZ_CAMIF),
|
[0] = DEFINE_RES_MEM(S3C2440_PA_CAMIF, S3C2440_SZ_CAMIF),
|
||||||
[1] = DEFINE_RES_IRQ(IRQ_CAM),
|
[1] = DEFINE_RES_IRQ(IRQ_S3C2440_CAM_C),
|
||||||
|
[2] = DEFINE_RES_IRQ(IRQ_S3C2440_CAM_P),
|
||||||
};
|
};
|
||||||
|
|
||||||
struct platform_device s3c_device_camif = {
|
struct platform_device s3c_device_camif = {
|
||||||
|
@ -37,6 +37,7 @@ struct clk clk_ext_xtal_mux = {
|
|||||||
struct clk clk_xusbxti = {
|
struct clk clk_xusbxti = {
|
||||||
.name = "xusbxti",
|
.name = "xusbxti",
|
||||||
.id = -1,
|
.id = -1,
|
||||||
|
.rate = 24000000,
|
||||||
};
|
};
|
||||||
|
|
||||||
struct clk s5p_clk_27m = {
|
struct clk s5p_clk_27m = {
|
||||||
|
@ -70,4 +70,7 @@ extern int is_in_rom(unsigned long);
|
|||||||
#define VMALLOC_END 0xffffffff
|
#define VMALLOC_END 0xffffffff
|
||||||
|
|
||||||
#define arch_enter_lazy_cpu_mode() do {} while (0)
|
#define arch_enter_lazy_cpu_mode() do {} while (0)
|
||||||
|
|
||||||
|
#include <asm-generic/pgtable.h>
|
||||||
|
|
||||||
#endif /* _H8300_PGTABLE_H */
|
#endif /* _H8300_PGTABLE_H */
|
||||||
|
@ -100,7 +100,6 @@ extern int __put_user_bad(void);
|
|||||||
break; \
|
break; \
|
||||||
default: \
|
default: \
|
||||||
__gu_err = __get_user_bad(); \
|
__gu_err = __get_user_bad(); \
|
||||||
__gu_val = 0; \
|
|
||||||
break; \
|
break; \
|
||||||
} \
|
} \
|
||||||
(x) = __gu_val; \
|
(x) = __gu_val; \
|
||||||
@ -159,4 +158,6 @@ clear_user(void *to, unsigned long n)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define __clear_user clear_user
|
||||||
|
|
||||||
#endif /* _H8300_UACCESS_H */
|
#endif /* _H8300_UACCESS_H */
|
||||||
|
@ -447,7 +447,7 @@ handle_signal(unsigned long sig, siginfo_t *info, struct k_sigaction *ka,
|
|||||||
* want to handle. Thus you cannot kill init even with a SIGKILL even by
|
* want to handle. Thus you cannot kill init even with a SIGKILL even by
|
||||||
* mistake.
|
* mistake.
|
||||||
*/
|
*/
|
||||||
statis void do_signal(struct pt_regs *regs)
|
static void do_signal(struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
siginfo_t info;
|
siginfo_t info;
|
||||||
int signr;
|
int signr;
|
||||||
|
@ -27,6 +27,7 @@
|
|||||||
#include <linux/profile.h>
|
#include <linux/profile.h>
|
||||||
|
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
#include <asm/irq_regs.h>
|
||||||
#include <asm/timer.h>
|
#include <asm/timer.h>
|
||||||
|
|
||||||
#define TICK_SIZE (tick_nsec / 1000)
|
#define TICK_SIZE (tick_nsec / 1000)
|
||||||
|
@ -129,7 +129,7 @@ static int __devinit ltq_pci_startup(struct platform_device *pdev)
|
|||||||
|
|
||||||
/* setup reset gpio used by pci */
|
/* setup reset gpio used by pci */
|
||||||
reset_gpio = of_get_named_gpio(node, "gpio-reset", 0);
|
reset_gpio = of_get_named_gpio(node, "gpio-reset", 0);
|
||||||
if (reset_gpio > 0)
|
if (gpio_is_valid(reset_gpio))
|
||||||
devm_gpio_request(&pdev->dev, reset_gpio, "pci-reset");
|
devm_gpio_request(&pdev->dev, reset_gpio, "pci-reset");
|
||||||
|
|
||||||
/* enable auto-switching between PCI and EBU */
|
/* enable auto-switching between PCI and EBU */
|
||||||
@ -192,7 +192,7 @@ static int __devinit ltq_pci_startup(struct platform_device *pdev)
|
|||||||
ltq_ebu_w32(ltq_ebu_r32(LTQ_EBU_PCC_IEN) | 0x10, LTQ_EBU_PCC_IEN);
|
ltq_ebu_w32(ltq_ebu_r32(LTQ_EBU_PCC_IEN) | 0x10, LTQ_EBU_PCC_IEN);
|
||||||
|
|
||||||
/* toggle reset pin */
|
/* toggle reset pin */
|
||||||
if (reset_gpio > 0) {
|
if (gpio_is_valid(reset_gpio)) {
|
||||||
__gpio_set_value(reset_gpio, 0);
|
__gpio_set_value(reset_gpio, 0);
|
||||||
wmb();
|
wmb();
|
||||||
mdelay(1);
|
mdelay(1);
|
||||||
|
@ -81,9 +81,6 @@ struct pt_regs {
|
|||||||
#define PTRACE_GETFPREGS 14
|
#define PTRACE_GETFPREGS 14
|
||||||
#define PTRACE_SETFPREGS 15
|
#define PTRACE_SETFPREGS 15
|
||||||
|
|
||||||
/* options set using PTRACE_SETOPTIONS */
|
|
||||||
#define PTRACE_O_TRACESYSGOOD 0x00000001
|
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
#ifdef __KERNEL__
|
||||||
|
|
||||||
#define user_mode(regs) (((regs)->epsw & EPSW_nSL) == EPSW_nSL)
|
#define user_mode(regs) (((regs)->epsw & EPSW_nSL) == EPSW_nSL)
|
||||||
|
@ -123,7 +123,7 @@ static inline unsigned long current_stack_pointer(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifndef CONFIG_KGDB
|
#ifndef CONFIG_KGDB
|
||||||
void arch_release_thread_info(struct thread_info *ti)
|
void arch_release_thread_info(struct thread_info *ti);
|
||||||
#endif
|
#endif
|
||||||
#define get_thread_info(ti) get_task_struct((ti)->task)
|
#define get_thread_info(ti) get_task_struct((ti)->task)
|
||||||
#define put_thread_info(ti) put_task_struct((ti)->task)
|
#define put_thread_info(ti) put_task_struct((ti)->task)
|
||||||
|
@ -11,7 +11,6 @@
|
|||||||
#ifndef _ASM_TIMEX_H
|
#ifndef _ASM_TIMEX_H
|
||||||
#define _ASM_TIMEX_H
|
#define _ASM_TIMEX_H
|
||||||
|
|
||||||
#include <asm/hardirq.h>
|
|
||||||
#include <unit/timex.h>
|
#include <unit/timex.h>
|
||||||
|
|
||||||
#define TICK_SIZE (tick_nsec / 1000)
|
#define TICK_SIZE (tick_nsec / 1000)
|
||||||
@ -30,16 +29,6 @@ static inline cycles_t get_cycles(void)
|
|||||||
extern int init_clockevents(void);
|
extern int init_clockevents(void);
|
||||||
extern int init_clocksource(void);
|
extern int init_clocksource(void);
|
||||||
|
|
||||||
static inline void setup_jiffies_interrupt(int irq,
|
|
||||||
struct irqaction *action)
|
|
||||||
{
|
|
||||||
u16 tmp;
|
|
||||||
setup_irq(irq, action);
|
|
||||||
set_intr_level(irq, NUM2GxICR_LEVEL(CONFIG_TIMER_IRQ_LEVEL));
|
|
||||||
GxICR(irq) |= GxICR_ENABLE | GxICR_DETECT | GxICR_REQUEST;
|
|
||||||
tmp = GxICR(irq);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* __KERNEL__ */
|
#endif /* __KERNEL__ */
|
||||||
|
|
||||||
#endif /* _ASM_TIMEX_H */
|
#endif /* _ASM_TIMEX_H */
|
||||||
|
@ -70,6 +70,16 @@ static void event_handler(struct clock_event_device *dev)
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void setup_jiffies_interrupt(int irq,
|
||||||
|
struct irqaction *action)
|
||||||
|
{
|
||||||
|
u16 tmp;
|
||||||
|
setup_irq(irq, action);
|
||||||
|
set_intr_level(irq, NUM2GxICR_LEVEL(CONFIG_TIMER_IRQ_LEVEL));
|
||||||
|
GxICR(irq) |= GxICR_ENABLE | GxICR_DETECT | GxICR_REQUEST;
|
||||||
|
tmp = GxICR(irq);
|
||||||
|
}
|
||||||
|
|
||||||
int __init init_clockevents(void)
|
int __init init_clockevents(void)
|
||||||
{
|
{
|
||||||
struct clock_event_device *cd;
|
struct clock_event_device *cd;
|
||||||
|
@ -9,6 +9,8 @@
|
|||||||
* 2 of the Licence, or (at your option) any later version.
|
* 2 of the Licence, or (at your option) any later version.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#include <linux/irqreturn.h>
|
||||||
|
|
||||||
struct clocksource;
|
struct clocksource;
|
||||||
struct clock_event_device;
|
struct clock_event_device;
|
||||||
|
|
||||||
|
@ -170,9 +170,9 @@ mn10300_cpupic_setaffinity(struct irq_data *d, const struct cpumask *mask,
|
|||||||
case SC1TXIRQ:
|
case SC1TXIRQ:
|
||||||
#ifdef CONFIG_MN10300_TTYSM1_TIMER12
|
#ifdef CONFIG_MN10300_TTYSM1_TIMER12
|
||||||
case TM12IRQ:
|
case TM12IRQ:
|
||||||
#elif CONFIG_MN10300_TTYSM1_TIMER9
|
#elif defined(CONFIG_MN10300_TTYSM1_TIMER9)
|
||||||
case TM9IRQ:
|
case TM9IRQ:
|
||||||
#elif CONFIG_MN10300_TTYSM1_TIMER3
|
#elif defined(CONFIG_MN10300_TTYSM1_TIMER3)
|
||||||
case TM3IRQ:
|
case TM3IRQ:
|
||||||
#endif /* CONFIG_MN10300_TTYSM1_TIMER12 */
|
#endif /* CONFIG_MN10300_TTYSM1_TIMER12 */
|
||||||
#endif /* CONFIG_MN10300_TTYSM1 */
|
#endif /* CONFIG_MN10300_TTYSM1 */
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include <linux/kdebug.h>
|
#include <linux/kdebug.h>
|
||||||
#include <linux/bug.h>
|
#include <linux/bug.h>
|
||||||
#include <linux/irq.h>
|
#include <linux/irq.h>
|
||||||
|
#include <linux/export.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <linux/uaccess.h>
|
#include <linux/uaccess.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
#include <linux/pci.h>
|
#include <linux/pci.h>
|
||||||
#include <linux/gfp.h>
|
#include <linux/gfp.h>
|
||||||
|
#include <linux/export.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
|
||||||
static unsigned long pci_sram_allocated = 0xbc000000;
|
static unsigned long pci_sram_allocated = 0xbc000000;
|
||||||
|
@ -11,10 +11,6 @@
|
|||||||
#ifndef _ASM_UNIT_TIMEX_H
|
#ifndef _ASM_UNIT_TIMEX_H
|
||||||
#define _ASM_UNIT_TIMEX_H
|
#define _ASM_UNIT_TIMEX_H
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
|
||||||
#include <linux/irq.h>
|
|
||||||
#endif /* __ASSEMBLY__ */
|
|
||||||
|
|
||||||
#include <asm/timer-regs.h>
|
#include <asm/timer-regs.h>
|
||||||
#include <unit/clock.h>
|
#include <unit/clock.h>
|
||||||
#include <asm/param.h>
|
#include <asm/param.h>
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include <linux/platform_device.h>
|
#include <linux/platform_device.h>
|
||||||
|
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
#include <asm/irq.h>
|
||||||
#include <asm/timex.h>
|
#include <asm/timex.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <asm/intctl-regs.h>
|
#include <asm/intctl-regs.h>
|
||||||
|
@ -11,10 +11,6 @@
|
|||||||
#ifndef _ASM_UNIT_TIMEX_H
|
#ifndef _ASM_UNIT_TIMEX_H
|
||||||
#define _ASM_UNIT_TIMEX_H
|
#define _ASM_UNIT_TIMEX_H
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
|
||||||
#include <linux/irq.h>
|
|
||||||
#endif /* __ASSEMBLY__ */
|
|
||||||
|
|
||||||
#include <asm/timer-regs.h>
|
#include <asm/timer-regs.h>
|
||||||
#include <unit/clock.h>
|
#include <unit/clock.h>
|
||||||
#include <asm/param.h>
|
#include <asm/param.h>
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/pci.h>
|
#include <linux/pci.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
#include <asm/irq.h>
|
||||||
#include <asm/setup.h>
|
#include <asm/setup.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <asm/intctl-regs.h>
|
#include <asm/intctl-regs.h>
|
||||||
|
@ -11,10 +11,6 @@
|
|||||||
#ifndef _ASM_UNIT_TIMEX_H
|
#ifndef _ASM_UNIT_TIMEX_H
|
||||||
#define _ASM_UNIT_TIMEX_H
|
#define _ASM_UNIT_TIMEX_H
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
|
||||||
#include <linux/irq.h>
|
|
||||||
#endif /* __ASSEMBLY__ */
|
|
||||||
|
|
||||||
#include <asm/timer-regs.h>
|
#include <asm/timer-regs.h>
|
||||||
#include <unit/clock.h>
|
#include <unit/clock.h>
|
||||||
#include <asm/param.h>
|
#include <asm/param.h>
|
||||||
|
@ -86,8 +86,8 @@ static inline bool arch_irqs_disabled(void)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_PPC_BOOK3E
|
#ifdef CONFIG_PPC_BOOK3E
|
||||||
#define __hard_irq_enable() asm volatile("wrteei 1" : : : "memory");
|
#define __hard_irq_enable() asm volatile("wrteei 1" : : : "memory")
|
||||||
#define __hard_irq_disable() asm volatile("wrteei 0" : : : "memory");
|
#define __hard_irq_disable() asm volatile("wrteei 0" : : : "memory")
|
||||||
#else
|
#else
|
||||||
#define __hard_irq_enable() __mtmsrd(local_paca->kernel_msr | MSR_EE, 1)
|
#define __hard_irq_enable() __mtmsrd(local_paca->kernel_msr | MSR_EE, 1)
|
||||||
#define __hard_irq_disable() __mtmsrd(local_paca->kernel_msr, 1)
|
#define __hard_irq_disable() __mtmsrd(local_paca->kernel_msr, 1)
|
||||||
@ -125,6 +125,8 @@ static inline bool arch_irq_disabled_regs(struct pt_regs *regs)
|
|||||||
return !regs->softe;
|
return !regs->softe;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern bool prep_irq_for_idle(void);
|
||||||
|
|
||||||
#else /* CONFIG_PPC64 */
|
#else /* CONFIG_PPC64 */
|
||||||
|
|
||||||
#define SET_MSR_EE(x) mtmsr(x)
|
#define SET_MSR_EE(x) mtmsr(x)
|
||||||
|
@ -229,7 +229,7 @@ notrace void arch_local_irq_restore(unsigned long en)
|
|||||||
*/
|
*/
|
||||||
if (unlikely(irq_happened != PACA_IRQ_HARD_DIS))
|
if (unlikely(irq_happened != PACA_IRQ_HARD_DIS))
|
||||||
__hard_irq_disable();
|
__hard_irq_disable();
|
||||||
#ifdef CONFIG_TRACE_IRQFLAG
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
||||||
else {
|
else {
|
||||||
/*
|
/*
|
||||||
* We should already be hard disabled here. We had bugs
|
* We should already be hard disabled here. We had bugs
|
||||||
@ -286,6 +286,52 @@ void notrace restore_interrupts(void)
|
|||||||
__hard_irq_enable();
|
__hard_irq_enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This is a helper to use when about to go into idle low-power
|
||||||
|
* when the latter has the side effect of re-enabling interrupts
|
||||||
|
* (such as calling H_CEDE under pHyp).
|
||||||
|
*
|
||||||
|
* You call this function with interrupts soft-disabled (this is
|
||||||
|
* already the case when ppc_md.power_save is called). The function
|
||||||
|
* will return whether to enter power save or just return.
|
||||||
|
*
|
||||||
|
* In the former case, it will have notified lockdep of interrupts
|
||||||
|
* being re-enabled and generally sanitized the lazy irq state,
|
||||||
|
* and in the latter case it will leave with interrupts hard
|
||||||
|
* disabled and marked as such, so the local_irq_enable() call
|
||||||
|
* in cpu_idle() will properly re-enable everything.
|
||||||
|
*/
|
||||||
|
bool prep_irq_for_idle(void)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* First we need to hard disable to ensure no interrupt
|
||||||
|
* occurs before we effectively enter the low power state
|
||||||
|
*/
|
||||||
|
hard_irq_disable();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If anything happened while we were soft-disabled,
|
||||||
|
* we return now and do not enter the low power state.
|
||||||
|
*/
|
||||||
|
if (lazy_irq_pending())
|
||||||
|
return false;
|
||||||
|
|
||||||
|
/* Tell lockdep we are about to re-enable */
|
||||||
|
trace_hardirqs_on();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Mark interrupts as soft-enabled and clear the
|
||||||
|
* PACA_IRQ_HARD_DIS from the pending mask since we
|
||||||
|
* are about to hard enable as well as a side effect
|
||||||
|
* of entering the low power state.
|
||||||
|
*/
|
||||||
|
local_paca->irq_happened &= ~PACA_IRQ_HARD_DIS;
|
||||||
|
local_paca->soft_enabled = 1;
|
||||||
|
|
||||||
|
/* Tell the caller to enter the low power state */
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_PPC64 */
|
#endif /* CONFIG_PPC64 */
|
||||||
|
|
||||||
int arch_show_interrupts(struct seq_file *p, int prec)
|
int arch_show_interrupts(struct seq_file *p, int prec)
|
||||||
|
@ -241,6 +241,7 @@ int kvmppc_h_pr(struct kvm_vcpu *vcpu, unsigned long cmd)
|
|||||||
case H_PUT_TCE:
|
case H_PUT_TCE:
|
||||||
return kvmppc_h_pr_put_tce(vcpu);
|
return kvmppc_h_pr_put_tce(vcpu);
|
||||||
case H_CEDE:
|
case H_CEDE:
|
||||||
|
vcpu->arch.shared->msr |= MSR_EE;
|
||||||
kvm_vcpu_block(vcpu);
|
kvm_vcpu_block(vcpu);
|
||||||
clear_bit(KVM_REQ_UNHALT, &vcpu->requests);
|
clear_bit(KVM_REQ_UNHALT, &vcpu->requests);
|
||||||
vcpu->stat.halt_wakeup++;
|
vcpu->stat.halt_wakeup++;
|
||||||
|
@ -639,7 +639,7 @@ static void __init parse_drconf_memory(struct device_node *memory)
|
|||||||
unsigned int n, rc, ranges, is_kexec_kdump = 0;
|
unsigned int n, rc, ranges, is_kexec_kdump = 0;
|
||||||
unsigned long lmb_size, base, size, sz;
|
unsigned long lmb_size, base, size, sz;
|
||||||
int nid;
|
int nid;
|
||||||
struct assoc_arrays aa;
|
struct assoc_arrays aa = { .arrays = NULL };
|
||||||
|
|
||||||
n = of_get_drconf_memory(memory, &dm);
|
n = of_get_drconf_memory(memory, &dm);
|
||||||
if (!n)
|
if (!n)
|
||||||
|
@ -42,11 +42,9 @@ static void cbe_power_save(void)
|
|||||||
{
|
{
|
||||||
unsigned long ctrl, thread_switch_control;
|
unsigned long ctrl, thread_switch_control;
|
||||||
|
|
||||||
/*
|
/* Ensure our interrupt state is properly tracked */
|
||||||
* We need to hard disable interrupts, the local_irq_enable() done by
|
if (!prep_irq_for_idle())
|
||||||
* our caller upon return will hard re-enable.
|
return;
|
||||||
*/
|
|
||||||
hard_irq_disable();
|
|
||||||
|
|
||||||
ctrl = mfspr(SPRN_CTRLF);
|
ctrl = mfspr(SPRN_CTRLF);
|
||||||
|
|
||||||
@ -81,6 +79,9 @@ static void cbe_power_save(void)
|
|||||||
*/
|
*/
|
||||||
ctrl &= ~(CTRL_RUNLATCH | CTRL_TE);
|
ctrl &= ~(CTRL_RUNLATCH | CTRL_TE);
|
||||||
mtspr(SPRN_CTRLT, ctrl);
|
mtspr(SPRN_CTRLT, ctrl);
|
||||||
|
|
||||||
|
/* Re-enable interrupts in MSR */
|
||||||
|
__hard_irq_enable();
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cbe_system_reset_exception(struct pt_regs *regs)
|
static int cbe_system_reset_exception(struct pt_regs *regs)
|
||||||
|
@ -99,15 +99,18 @@ out:
|
|||||||
static void check_and_cede_processor(void)
|
static void check_and_cede_processor(void)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Interrupts are soft-disabled at this point,
|
* Ensure our interrupt state is properly tracked,
|
||||||
* but not hard disabled. So an interrupt might have
|
* also checks if no interrupt has occurred while we
|
||||||
* occurred before entering NAP, and would be potentially
|
* were soft-disabled
|
||||||
* lost (edge events, decrementer events, etc...) unless
|
|
||||||
* we first hard disable then check.
|
|
||||||
*/
|
*/
|
||||||
hard_irq_disable();
|
if (prep_irq_for_idle()) {
|
||||||
if (!lazy_irq_pending())
|
|
||||||
cede_processor();
|
cede_processor();
|
||||||
|
#ifdef CONFIG_TRACE_IRQFLAGS
|
||||||
|
/* Ensure that H_CEDE returns with IRQs on */
|
||||||
|
if (WARN_ON(!(mfmsr() & MSR_EE)))
|
||||||
|
__hard_irq_enable();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int dedicated_cede_loop(struct cpuidle_device *dev,
|
static int dedicated_cede_loop(struct cpuidle_device *dev,
|
||||||
|
@ -19,9 +19,20 @@ static inline u32 inl(unsigned long addr)
|
|||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define outb(x, y) BUG()
|
static inline void outb(unsigned char x, unsigned long port)
|
||||||
#define outw(x, y) BUG()
|
{
|
||||||
#define outl(x, y) BUG()
|
BUG();
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void outw(unsigned short x, unsigned long port)
|
||||||
|
{
|
||||||
|
BUG();
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void outl(unsigned int x, unsigned long port)
|
||||||
|
{
|
||||||
|
BUG();
|
||||||
|
}
|
||||||
|
|
||||||
#define inb_p(addr) inb(addr)
|
#define inb_p(addr) inb(addr)
|
||||||
#define inw_p(addr) inw(addr)
|
#define inw_p(addr) inw(addr)
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
#include <linux/serial_core.h>
|
#include <linux/serial_core.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <cpu/serial.h>
|
#include <cpu/serial.h>
|
||||||
#include <asm/gpio.h>
|
#include <cpu/gpio.h>
|
||||||
|
|
||||||
static void sh7720_sci_init_pins(struct uart_port *port, unsigned int cflag)
|
static void sh7720_sci_init_pins(struct uart_port *port, unsigned int cflag)
|
||||||
{
|
{
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
|
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
#include <linux/string.h>
|
#include <linux/string.h>
|
||||||
|
#include <asm/byteorder.h>
|
||||||
#include <asm/backtrace.h>
|
#include <asm/backtrace.h>
|
||||||
#include <asm/tile-desc.h>
|
#include <asm/tile-desc.h>
|
||||||
#include <arch/abi.h>
|
#include <arch/abi.h>
|
||||||
@ -336,8 +337,12 @@ static void find_caller_pc_and_caller_sp(CallerLocation *location,
|
|||||||
bytes_to_prefetch / sizeof(tile_bundle_bits);
|
bytes_to_prefetch / sizeof(tile_bundle_bits);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Decode the next bundle. */
|
/*
|
||||||
bundle.bits = prefetched_bundles[next_bundle++];
|
* Decode the next bundle.
|
||||||
|
* TILE always stores instruction bundles in little-endian
|
||||||
|
* mode, even when the chip is running in big-endian mode.
|
||||||
|
*/
|
||||||
|
bundle.bits = le64_to_cpu(prefetched_bundles[next_bundle++]);
|
||||||
bundle.num_insns =
|
bundle.num_insns =
|
||||||
parse_insn_tile(bundle.bits, pc, bundle.insns);
|
parse_insn_tile(bundle.bits, pc, bundle.insns);
|
||||||
num_info_ops = bt_get_info_ops(&bundle, info_operands);
|
num_info_ops = bt_get_info_ops(&bundle, info_operands);
|
||||||
|
@ -705,7 +705,6 @@ static void stack_proc(void *arg)
|
|||||||
struct task_struct *from = current, *to = arg;
|
struct task_struct *from = current, *to = arg;
|
||||||
|
|
||||||
to->thread.saved_task = from;
|
to->thread.saved_task = from;
|
||||||
rcu_switch_from(from);
|
|
||||||
switch_to(from, to, from);
|
switch_to(from, to, from);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -139,6 +139,19 @@ static int addr_to_vsyscall_nr(unsigned long addr)
|
|||||||
return nr;
|
return nr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_SECCOMP
|
||||||
|
static int vsyscall_seccomp(struct task_struct *tsk, int syscall_nr)
|
||||||
|
{
|
||||||
|
if (!seccomp_mode(&tsk->seccomp))
|
||||||
|
return 0;
|
||||||
|
task_pt_regs(tsk)->orig_ax = syscall_nr;
|
||||||
|
task_pt_regs(tsk)->ax = syscall_nr;
|
||||||
|
return __secure_computing(syscall_nr);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
#define vsyscall_seccomp(_tsk, _nr) 0
|
||||||
|
#endif
|
||||||
|
|
||||||
static bool write_ok_or_segv(unsigned long ptr, size_t size)
|
static bool write_ok_or_segv(unsigned long ptr, size_t size)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@ -174,6 +187,7 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
int vsyscall_nr;
|
int vsyscall_nr;
|
||||||
int prev_sig_on_uaccess_error;
|
int prev_sig_on_uaccess_error;
|
||||||
long ret;
|
long ret;
|
||||||
|
int skip;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* No point in checking CS -- the only way to get here is a user mode
|
* No point in checking CS -- the only way to get here is a user mode
|
||||||
@ -205,9 +219,6 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
}
|
}
|
||||||
|
|
||||||
tsk = current;
|
tsk = current;
|
||||||
if (seccomp_mode(&tsk->seccomp))
|
|
||||||
do_exit(SIGKILL);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* With a real vsyscall, page faults cause SIGSEGV. We want to
|
* With a real vsyscall, page faults cause SIGSEGV. We want to
|
||||||
* preserve that behavior to make writing exploits harder.
|
* preserve that behavior to make writing exploits harder.
|
||||||
@ -222,8 +233,13 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
* address 0".
|
* address 0".
|
||||||
*/
|
*/
|
||||||
ret = -EFAULT;
|
ret = -EFAULT;
|
||||||
|
skip = 0;
|
||||||
switch (vsyscall_nr) {
|
switch (vsyscall_nr) {
|
||||||
case 0:
|
case 0:
|
||||||
|
skip = vsyscall_seccomp(tsk, __NR_gettimeofday);
|
||||||
|
if (skip)
|
||||||
|
break;
|
||||||
|
|
||||||
if (!write_ok_or_segv(regs->di, sizeof(struct timeval)) ||
|
if (!write_ok_or_segv(regs->di, sizeof(struct timeval)) ||
|
||||||
!write_ok_or_segv(regs->si, sizeof(struct timezone)))
|
!write_ok_or_segv(regs->si, sizeof(struct timezone)))
|
||||||
break;
|
break;
|
||||||
@ -234,6 +250,10 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 1:
|
case 1:
|
||||||
|
skip = vsyscall_seccomp(tsk, __NR_time);
|
||||||
|
if (skip)
|
||||||
|
break;
|
||||||
|
|
||||||
if (!write_ok_or_segv(regs->di, sizeof(time_t)))
|
if (!write_ok_or_segv(regs->di, sizeof(time_t)))
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -241,6 +261,10 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 2:
|
case 2:
|
||||||
|
skip = vsyscall_seccomp(tsk, __NR_getcpu);
|
||||||
|
if (skip)
|
||||||
|
break;
|
||||||
|
|
||||||
if (!write_ok_or_segv(regs->di, sizeof(unsigned)) ||
|
if (!write_ok_or_segv(regs->di, sizeof(unsigned)) ||
|
||||||
!write_ok_or_segv(regs->si, sizeof(unsigned)))
|
!write_ok_or_segv(regs->si, sizeof(unsigned)))
|
||||||
break;
|
break;
|
||||||
@ -253,6 +277,12 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
|
|
||||||
current_thread_info()->sig_on_uaccess_error = prev_sig_on_uaccess_error;
|
current_thread_info()->sig_on_uaccess_error = prev_sig_on_uaccess_error;
|
||||||
|
|
||||||
|
if (skip) {
|
||||||
|
if ((long)regs->ax <= 0L) /* seccomp errno emulation */
|
||||||
|
goto do_ret;
|
||||||
|
goto done; /* seccomp trace/trap */
|
||||||
|
}
|
||||||
|
|
||||||
if (ret == -EFAULT) {
|
if (ret == -EFAULT) {
|
||||||
/* Bad news -- userspace fed a bad pointer to a vsyscall. */
|
/* Bad news -- userspace fed a bad pointer to a vsyscall. */
|
||||||
warn_bad_vsyscall(KERN_INFO, regs,
|
warn_bad_vsyscall(KERN_INFO, regs,
|
||||||
@ -271,10 +301,11 @@ bool emulate_vsyscall(struct pt_regs *regs, unsigned long address)
|
|||||||
|
|
||||||
regs->ax = ret;
|
regs->ax = ret;
|
||||||
|
|
||||||
|
do_ret:
|
||||||
/* Emulate a ret instruction. */
|
/* Emulate a ret instruction. */
|
||||||
regs->ip = caller;
|
regs->ip = caller;
|
||||||
regs->sp += 8;
|
regs->sp += 8;
|
||||||
|
done:
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
sigsegv:
|
sigsegv:
|
||||||
|
@ -3934,6 +3934,9 @@ static void kvm_mmu_remove_some_alloc_mmu_pages(struct kvm *kvm,
|
|||||||
{
|
{
|
||||||
struct kvm_mmu_page *page;
|
struct kvm_mmu_page *page;
|
||||||
|
|
||||||
|
if (list_empty(&kvm->arch.active_mmu_pages))
|
||||||
|
return;
|
||||||
|
|
||||||
page = container_of(kvm->arch.active_mmu_pages.prev,
|
page = container_of(kvm->arch.active_mmu_pages.prev,
|
||||||
struct kvm_mmu_page, link);
|
struct kvm_mmu_page, link);
|
||||||
kvm_mmu_prepare_zap_page(kvm, page, invalid_list);
|
kvm_mmu_prepare_zap_page(kvm, page, invalid_list);
|
||||||
|
@ -277,7 +277,7 @@ void xtensa_elf_core_copy_regs (xtensa_gregset_t *elfregs, struct pt_regs *regs)
|
|||||||
|
|
||||||
/* Don't leak any random bits. */
|
/* Don't leak any random bits. */
|
||||||
|
|
||||||
memset(elfregs, 0, sizeof (elfregs));
|
memset(elfregs, 0, sizeof(*elfregs));
|
||||||
|
|
||||||
/* Note: PS.EXCM is not set while user task is running; its
|
/* Note: PS.EXCM is not set while user task is running; its
|
||||||
* being set in regs->ps is for exception handling convenience.
|
* being set in regs->ps is for exception handling convenience.
|
||||||
|
@ -95,18 +95,6 @@ acpi_status acpi_hw_legacy_sleep(u8 sleep_state, u8 flags)
|
|||||||
return_ACPI_STATUS(status);
|
return_ACPI_STATUS(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (sleep_state != ACPI_STATE_S5) {
|
|
||||||
/*
|
|
||||||
* Disable BM arbitration. This feature is contained within an
|
|
||||||
* optional register (PM2 Control), so ignore a BAD_ADDRESS
|
|
||||||
* exception.
|
|
||||||
*/
|
|
||||||
status = acpi_write_bit_register(ACPI_BITREG_ARB_DISABLE, 1);
|
|
||||||
if (ACPI_FAILURE(status) && (status != AE_BAD_ADDRESS)) {
|
|
||||||
return_ACPI_STATUS(status);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 1) Disable/Clear all GPEs
|
* 1) Disable/Clear all GPEs
|
||||||
* 2) Enable all wakeup GPEs
|
* 2) Enable all wakeup GPEs
|
||||||
@ -364,16 +352,6 @@ acpi_status acpi_hw_legacy_wake(u8 sleep_state, u8 flags)
|
|||||||
[ACPI_EVENT_POWER_BUTTON].
|
[ACPI_EVENT_POWER_BUTTON].
|
||||||
status_register_id, ACPI_CLEAR_STATUS);
|
status_register_id, ACPI_CLEAR_STATUS);
|
||||||
|
|
||||||
/*
|
|
||||||
* Enable BM arbitration. This feature is contained within an
|
|
||||||
* optional register (PM2 Control), so ignore a BAD_ADDRESS
|
|
||||||
* exception.
|
|
||||||
*/
|
|
||||||
status = acpi_write_bit_register(ACPI_BITREG_ARB_DISABLE, 0);
|
|
||||||
if (ACPI_FAILURE(status) && (status != AE_BAD_ADDRESS)) {
|
|
||||||
return_ACPI_STATUS(status);
|
|
||||||
}
|
|
||||||
|
|
||||||
acpi_hw_execute_sleep_method(METHOD_PATHNAME__SST, ACPI_SST_WORKING);
|
acpi_hw_execute_sleep_method(METHOD_PATHNAME__SST, ACPI_SST_WORKING);
|
||||||
return_ACPI_STATUS(status);
|
return_ACPI_STATUS(status);
|
||||||
}
|
}
|
||||||
|
@ -638,7 +638,7 @@ acpi_ns_check_package(struct acpi_predefined_data *data,
|
|||||||
/* Create the new outer package and populate it */
|
/* Create the new outer package and populate it */
|
||||||
|
|
||||||
status =
|
status =
|
||||||
acpi_ns_wrap_with_package(data, *elements,
|
acpi_ns_wrap_with_package(data, return_object,
|
||||||
return_object_ptr);
|
return_object_ptr);
|
||||||
if (ACPI_FAILURE(status)) {
|
if (ACPI_FAILURE(status)) {
|
||||||
return (status);
|
return (status);
|
||||||
|
@ -189,10 +189,12 @@ int acpi_get_cpuid(acpi_handle handle, int type, u32 acpi_id)
|
|||||||
* Processor (CPU3, 0x03, 0x00000410, 0x06) {}
|
* Processor (CPU3, 0x03, 0x00000410, 0x06) {}
|
||||||
* }
|
* }
|
||||||
*
|
*
|
||||||
* Ignores apic_id and always return 0 for CPU0's handle.
|
* Ignores apic_id and always returns 0 for the processor
|
||||||
|
* handle with acpi id 0 if nr_cpu_ids is 1.
|
||||||
|
* This should be the case if SMP tables are not found.
|
||||||
* Return -1 for other CPU's handle.
|
* Return -1 for other CPU's handle.
|
||||||
*/
|
*/
|
||||||
if (acpi_id == 0)
|
if (nr_cpu_ids <= 1 && acpi_id == 0)
|
||||||
return acpi_id;
|
return acpi_id;
|
||||||
else
|
else
|
||||||
return apic_id;
|
return apic_id;
|
||||||
|
@ -1597,14 +1597,12 @@ static int loop_add(struct loop_device **l, int i)
|
|||||||
struct gendisk *disk;
|
struct gendisk *disk;
|
||||||
int err;
|
int err;
|
||||||
|
|
||||||
|
err = -ENOMEM;
|
||||||
lo = kzalloc(sizeof(*lo), GFP_KERNEL);
|
lo = kzalloc(sizeof(*lo), GFP_KERNEL);
|
||||||
if (!lo) {
|
if (!lo)
|
||||||
err = -ENOMEM;
|
|
||||||
goto out;
|
goto out;
|
||||||
}
|
|
||||||
|
|
||||||
err = idr_pre_get(&loop_index_idr, GFP_KERNEL);
|
if (!idr_pre_get(&loop_index_idr, GFP_KERNEL))
|
||||||
if (err < 0)
|
|
||||||
goto out_free_dev;
|
goto out_free_dev;
|
||||||
|
|
||||||
if (i >= 0) {
|
if (i >= 0) {
|
||||||
|
@ -136,7 +136,7 @@ config GPIO_MPC8XXX
|
|||||||
|
|
||||||
config GPIO_MSM_V1
|
config GPIO_MSM_V1
|
||||||
tristate "Qualcomm MSM GPIO v1"
|
tristate "Qualcomm MSM GPIO v1"
|
||||||
depends on GPIOLIB && ARCH_MSM
|
depends on GPIOLIB && ARCH_MSM && (ARCH_MSM7X00A || ARCH_MSM7X30 || ARCH_QSD8X50)
|
||||||
help
|
help
|
||||||
Say yes here to support the GPIO interface on ARM v6 based
|
Say yes here to support the GPIO interface on ARM v6 based
|
||||||
Qualcomm MSM chips. Most of the pins on the MSM can be
|
Qualcomm MSM chips. Most of the pins on the MSM can be
|
||||||
|
@ -98,6 +98,7 @@ int devm_gpio_request_one(struct device *dev, unsigned gpio,
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(devm_gpio_request_one);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* devm_gpio_free - free an interrupt
|
* devm_gpio_free - free an interrupt
|
||||||
|
@ -398,10 +398,12 @@ static int __devinit mxc_gpio_probe(struct platform_device *pdev)
|
|||||||
writel(~0, port->base + GPIO_ISR);
|
writel(~0, port->base + GPIO_ISR);
|
||||||
|
|
||||||
if (mxc_gpio_hwtype == IMX21_GPIO) {
|
if (mxc_gpio_hwtype == IMX21_GPIO) {
|
||||||
/* setup one handler for all GPIO interrupts */
|
/*
|
||||||
if (pdev->id == 0)
|
* Setup one handler for all GPIO interrupts. Actually setting
|
||||||
irq_set_chained_handler(port->irq,
|
* the handler is needed only once, but doing it for every port
|
||||||
mx2_gpio_irq_handler);
|
* is more robust and easier.
|
||||||
|
*/
|
||||||
|
irq_set_chained_handler(port->irq, mx2_gpio_irq_handler);
|
||||||
} else {
|
} else {
|
||||||
/* setup one handler for each entry */
|
/* setup one handler for each entry */
|
||||||
irq_set_chained_handler(port->irq, mx3_gpio_irq_handler);
|
irq_set_chained_handler(port->irq, mx3_gpio_irq_handler);
|
||||||
|
@ -174,12 +174,22 @@ static inline void _gpio_dbck_enable(struct gpio_bank *bank)
|
|||||||
if (bank->dbck_enable_mask && !bank->dbck_enabled) {
|
if (bank->dbck_enable_mask && !bank->dbck_enabled) {
|
||||||
clk_enable(bank->dbck);
|
clk_enable(bank->dbck);
|
||||||
bank->dbck_enabled = true;
|
bank->dbck_enabled = true;
|
||||||
|
|
||||||
|
__raw_writel(bank->dbck_enable_mask,
|
||||||
|
bank->base + bank->regs->debounce_en);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void _gpio_dbck_disable(struct gpio_bank *bank)
|
static inline void _gpio_dbck_disable(struct gpio_bank *bank)
|
||||||
{
|
{
|
||||||
if (bank->dbck_enable_mask && bank->dbck_enabled) {
|
if (bank->dbck_enable_mask && bank->dbck_enabled) {
|
||||||
|
/*
|
||||||
|
* Disable debounce before cutting it's clock. If debounce is
|
||||||
|
* enabled but the clock is not, GPIO module seems to be unable
|
||||||
|
* to detect events and generate interrupts at least on OMAP3.
|
||||||
|
*/
|
||||||
|
__raw_writel(0, bank->base + bank->regs->debounce_en);
|
||||||
|
|
||||||
clk_disable(bank->dbck);
|
clk_disable(bank->dbck);
|
||||||
bank->dbck_enabled = false;
|
bank->dbck_enabled = false;
|
||||||
}
|
}
|
||||||
@ -1081,7 +1091,6 @@ static int __devinit omap_gpio_probe(struct platform_device *pdev)
|
|||||||
bank->is_mpuio = pdata->is_mpuio;
|
bank->is_mpuio = pdata->is_mpuio;
|
||||||
bank->non_wakeup_gpios = pdata->non_wakeup_gpios;
|
bank->non_wakeup_gpios = pdata->non_wakeup_gpios;
|
||||||
bank->loses_context = pdata->loses_context;
|
bank->loses_context = pdata->loses_context;
|
||||||
bank->get_context_loss_count = pdata->get_context_loss_count;
|
|
||||||
bank->regs = pdata->regs;
|
bank->regs = pdata->regs;
|
||||||
#ifdef CONFIG_OF_GPIO
|
#ifdef CONFIG_OF_GPIO
|
||||||
bank->chip.of_node = of_node_get(node);
|
bank->chip.of_node = of_node_get(node);
|
||||||
@ -1135,6 +1144,9 @@ static int __devinit omap_gpio_probe(struct platform_device *pdev)
|
|||||||
omap_gpio_chip_init(bank);
|
omap_gpio_chip_init(bank);
|
||||||
omap_gpio_show_rev(bank);
|
omap_gpio_show_rev(bank);
|
||||||
|
|
||||||
|
if (bank->loses_context)
|
||||||
|
bank->get_context_loss_count = pdata->get_context_loss_count;
|
||||||
|
|
||||||
pm_runtime_put(bank->dev);
|
pm_runtime_put(bank->dev);
|
||||||
|
|
||||||
list_add_tail(&bank->node, &omap_gpio_list);
|
list_add_tail(&bank->node, &omap_gpio_list);
|
||||||
|
@ -383,8 +383,9 @@ static int __devinit gsta_probe(struct platform_device *dev)
|
|||||||
}
|
}
|
||||||
spin_lock_init(&chip->lock);
|
spin_lock_init(&chip->lock);
|
||||||
gsta_gpio_setup(chip);
|
gsta_gpio_setup(chip);
|
||||||
for (i = 0; i < GSTA_NR_GPIO; i++)
|
if (gpio_pdata)
|
||||||
gsta_set_config(chip, i, gpio_pdata->pinconfig[i]);
|
for (i = 0; i < GSTA_NR_GPIO; i++)
|
||||||
|
gsta_set_config(chip, i, gpio_pdata->pinconfig[i]);
|
||||||
|
|
||||||
/* 384 was used in previous code: be compatible for other drivers */
|
/* 384 was used in previous code: be compatible for other drivers */
|
||||||
err = irq_alloc_descs(-1, 384, GSTA_NR_GPIO, NUMA_NO_NODE);
|
err = irq_alloc_descs(-1, 384, GSTA_NR_GPIO, NUMA_NO_NODE);
|
||||||
|
@ -149,6 +149,9 @@ static int __devinit tps65910_gpio_probe(struct platform_device *pdev)
|
|||||||
tps65910_gpio->gpio_chip.set = tps65910_gpio_set;
|
tps65910_gpio->gpio_chip.set = tps65910_gpio_set;
|
||||||
tps65910_gpio->gpio_chip.get = tps65910_gpio_get;
|
tps65910_gpio->gpio_chip.get = tps65910_gpio_get;
|
||||||
tps65910_gpio->gpio_chip.dev = &pdev->dev;
|
tps65910_gpio->gpio_chip.dev = &pdev->dev;
|
||||||
|
#ifdef CONFIG_OF_GPIO
|
||||||
|
tps65910_gpio->gpio_chip.of_node = tps65910->dev->of_node;
|
||||||
|
#endif
|
||||||
if (pdata && pdata->gpio_base)
|
if (pdata && pdata->gpio_base)
|
||||||
tps65910_gpio->gpio_chip.base = pdata->gpio_base;
|
tps65910_gpio->gpio_chip.base = pdata->gpio_base;
|
||||||
else
|
else
|
||||||
|
@ -89,8 +89,11 @@ static int wm8994_gpio_direction_out(struct gpio_chip *chip,
|
|||||||
struct wm8994_gpio *wm8994_gpio = to_wm8994_gpio(chip);
|
struct wm8994_gpio *wm8994_gpio = to_wm8994_gpio(chip);
|
||||||
struct wm8994 *wm8994 = wm8994_gpio->wm8994;
|
struct wm8994 *wm8994 = wm8994_gpio->wm8994;
|
||||||
|
|
||||||
|
if (value)
|
||||||
|
value = WM8994_GPN_LVL;
|
||||||
|
|
||||||
return wm8994_set_bits(wm8994, WM8994_GPIO_1 + offset,
|
return wm8994_set_bits(wm8994, WM8994_GPIO_1 + offset,
|
||||||
WM8994_GPN_DIR, 0);
|
WM8994_GPN_DIR | WM8994_GPN_LVL, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void wm8994_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
|
static void wm8994_gpio_set(struct gpio_chip *chip, unsigned offset, int value)
|
||||||
|
@ -78,21 +78,6 @@ static int cdv_backlight_combination_mode(struct drm_device *dev)
|
|||||||
return REG_READ(BLC_PWM_CTL2) & PWM_LEGACY_MODE;
|
return REG_READ(BLC_PWM_CTL2) & PWM_LEGACY_MODE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int cdv_get_brightness(struct backlight_device *bd)
|
|
||||||
{
|
|
||||||
struct drm_device *dev = bl_get_data(bd);
|
|
||||||
u32 val = REG_READ(BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
|
|
||||||
|
|
||||||
if (cdv_backlight_combination_mode(dev)) {
|
|
||||||
u8 lbpc;
|
|
||||||
|
|
||||||
val &= ~1;
|
|
||||||
pci_read_config_byte(dev->pdev, 0xF4, &lbpc);
|
|
||||||
val *= lbpc;
|
|
||||||
}
|
|
||||||
return val;
|
|
||||||
}
|
|
||||||
|
|
||||||
static u32 cdv_get_max_backlight(struct drm_device *dev)
|
static u32 cdv_get_max_backlight(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
u32 max = REG_READ(BLC_PWM_CTL);
|
u32 max = REG_READ(BLC_PWM_CTL);
|
||||||
@ -110,6 +95,22 @@ static u32 cdv_get_max_backlight(struct drm_device *dev)
|
|||||||
return max;
|
return max;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int cdv_get_brightness(struct backlight_device *bd)
|
||||||
|
{
|
||||||
|
struct drm_device *dev = bl_get_data(bd);
|
||||||
|
u32 val = REG_READ(BLC_PWM_CTL) & BACKLIGHT_DUTY_CYCLE_MASK;
|
||||||
|
|
||||||
|
if (cdv_backlight_combination_mode(dev)) {
|
||||||
|
u8 lbpc;
|
||||||
|
|
||||||
|
val &= ~1;
|
||||||
|
pci_read_config_byte(dev->pdev, 0xF4, &lbpc);
|
||||||
|
val *= lbpc;
|
||||||
|
}
|
||||||
|
return (val * 100)/cdv_get_max_backlight(dev);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
static int cdv_set_brightness(struct backlight_device *bd)
|
static int cdv_set_brightness(struct backlight_device *bd)
|
||||||
{
|
{
|
||||||
struct drm_device *dev = bl_get_data(bd);
|
struct drm_device *dev = bl_get_data(bd);
|
||||||
@ -120,6 +121,9 @@ static int cdv_set_brightness(struct backlight_device *bd)
|
|||||||
if (level < 1)
|
if (level < 1)
|
||||||
level = 1;
|
level = 1;
|
||||||
|
|
||||||
|
level *= cdv_get_max_backlight(dev);
|
||||||
|
level /= 100;
|
||||||
|
|
||||||
if (cdv_backlight_combination_mode(dev)) {
|
if (cdv_backlight_combination_mode(dev)) {
|
||||||
u32 max = cdv_get_max_backlight(dev);
|
u32 max = cdv_get_max_backlight(dev);
|
||||||
u8 lbpc;
|
u8 lbpc;
|
||||||
@ -157,7 +161,6 @@ static int cdv_backlight_init(struct drm_device *dev)
|
|||||||
|
|
||||||
cdv_backlight_device->props.brightness =
|
cdv_backlight_device->props.brightness =
|
||||||
cdv_get_brightness(cdv_backlight_device);
|
cdv_get_brightness(cdv_backlight_device);
|
||||||
cdv_backlight_device->props.max_brightness = cdv_get_max_backlight(dev);
|
|
||||||
backlight_update_status(cdv_backlight_device);
|
backlight_update_status(cdv_backlight_device);
|
||||||
dev_priv->backlight_device = cdv_backlight_device;
|
dev_priv->backlight_device = cdv_backlight_device;
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -144,6 +144,8 @@ struct opregion_asle {
|
|||||||
|
|
||||||
#define ASLE_CBLV_VALID (1<<31)
|
#define ASLE_CBLV_VALID (1<<31)
|
||||||
|
|
||||||
|
static struct psb_intel_opregion *system_opregion;
|
||||||
|
|
||||||
static u32 asle_set_backlight(struct drm_device *dev, u32 bclp)
|
static u32 asle_set_backlight(struct drm_device *dev, u32 bclp)
|
||||||
{
|
{
|
||||||
struct drm_psb_private *dev_priv = dev->dev_private;
|
struct drm_psb_private *dev_priv = dev->dev_private;
|
||||||
@ -205,7 +207,7 @@ void psb_intel_opregion_enable_asle(struct drm_device *dev)
|
|||||||
struct drm_psb_private *dev_priv = dev->dev_private;
|
struct drm_psb_private *dev_priv = dev->dev_private;
|
||||||
struct opregion_asle *asle = dev_priv->opregion.asle;
|
struct opregion_asle *asle = dev_priv->opregion.asle;
|
||||||
|
|
||||||
if (asle) {
|
if (asle && system_opregion ) {
|
||||||
/* Don't do this on Medfield or other non PC like devices, they
|
/* Don't do this on Medfield or other non PC like devices, they
|
||||||
use the bit for something different altogether */
|
use the bit for something different altogether */
|
||||||
psb_enable_pipestat(dev_priv, 0, PIPE_LEGACY_BLC_EVENT_ENABLE);
|
psb_enable_pipestat(dev_priv, 0, PIPE_LEGACY_BLC_EVENT_ENABLE);
|
||||||
@ -221,7 +223,6 @@ void psb_intel_opregion_enable_asle(struct drm_device *dev)
|
|||||||
#define ACPI_EV_LID (1<<1)
|
#define ACPI_EV_LID (1<<1)
|
||||||
#define ACPI_EV_DOCK (1<<2)
|
#define ACPI_EV_DOCK (1<<2)
|
||||||
|
|
||||||
static struct psb_intel_opregion *system_opregion;
|
|
||||||
|
|
||||||
static int psb_intel_opregion_video_event(struct notifier_block *nb,
|
static int psb_intel_opregion_video_event(struct notifier_block *nb,
|
||||||
unsigned long val, void *data)
|
unsigned long val, void *data)
|
||||||
@ -266,9 +267,6 @@ void psb_intel_opregion_init(struct drm_device *dev)
|
|||||||
system_opregion = opregion;
|
system_opregion = opregion;
|
||||||
register_acpi_notifier(&psb_intel_opregion_notifier);
|
register_acpi_notifier(&psb_intel_opregion_notifier);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (opregion->asle)
|
|
||||||
psb_intel_opregion_enable_asle(dev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void psb_intel_opregion_fini(struct drm_device *dev)
|
void psb_intel_opregion_fini(struct drm_device *dev)
|
||||||
|
@ -27,6 +27,7 @@ extern void psb_intel_opregion_asle_intr(struct drm_device *dev);
|
|||||||
extern void psb_intel_opregion_init(struct drm_device *dev);
|
extern void psb_intel_opregion_init(struct drm_device *dev);
|
||||||
extern void psb_intel_opregion_fini(struct drm_device *dev);
|
extern void psb_intel_opregion_fini(struct drm_device *dev);
|
||||||
extern int psb_intel_opregion_setup(struct drm_device *dev);
|
extern int psb_intel_opregion_setup(struct drm_device *dev);
|
||||||
|
extern void psb_intel_opregion_enable_asle(struct drm_device *dev);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
@ -46,4 +47,8 @@ extern inline int psb_intel_opregion_setup(struct drm_device *dev)
|
|||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern inline void psb_intel_opregion_enable_asle(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@ -144,6 +144,10 @@ static int psb_backlight_init(struct drm_device *dev)
|
|||||||
psb_backlight_device->props.max_brightness = 100;
|
psb_backlight_device->props.max_brightness = 100;
|
||||||
backlight_update_status(psb_backlight_device);
|
backlight_update_status(psb_backlight_device);
|
||||||
dev_priv->backlight_device = psb_backlight_device;
|
dev_priv->backlight_device = psb_backlight_device;
|
||||||
|
|
||||||
|
/* This must occur after the backlight is properly initialised */
|
||||||
|
psb_lid_timer_init(dev_priv);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -354,13 +358,6 @@ static int psb_chip_setup(struct drm_device *dev)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Not exactly an erratum more an irritation */
|
|
||||||
static void psb_chip_errata(struct drm_device *dev)
|
|
||||||
{
|
|
||||||
struct drm_psb_private *dev_priv = dev->dev_private;
|
|
||||||
psb_lid_timer_init(dev_priv);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void psb_chip_teardown(struct drm_device *dev)
|
static void psb_chip_teardown(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_psb_private *dev_priv = dev->dev_private;
|
struct drm_psb_private *dev_priv = dev->dev_private;
|
||||||
@ -379,7 +376,6 @@ const struct psb_ops psb_chip_ops = {
|
|||||||
.sgx_offset = PSB_SGX_OFFSET,
|
.sgx_offset = PSB_SGX_OFFSET,
|
||||||
.chip_setup = psb_chip_setup,
|
.chip_setup = psb_chip_setup,
|
||||||
.chip_teardown = psb_chip_teardown,
|
.chip_teardown = psb_chip_teardown,
|
||||||
.errata = psb_chip_errata,
|
|
||||||
|
|
||||||
.crtc_helper = &psb_intel_helper_funcs,
|
.crtc_helper = &psb_intel_helper_funcs,
|
||||||
.crtc_funcs = &psb_intel_crtc_funcs,
|
.crtc_funcs = &psb_intel_crtc_funcs,
|
||||||
|
@ -374,6 +374,7 @@ static int psb_driver_load(struct drm_device *dev, unsigned long chipset)
|
|||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
return ret;
|
return ret;
|
||||||
|
psb_intel_opregion_enable_asle(dev);
|
||||||
#if 0
|
#if 0
|
||||||
/*enable runtime pm at last*/
|
/*enable runtime pm at last*/
|
||||||
pm_runtime_enable(&dev->pdev->dev);
|
pm_runtime_enable(&dev->pdev->dev);
|
||||||
|
@ -517,6 +517,12 @@ static const struct hid_device_id apple_devices[] = {
|
|||||||
.driver_data = APPLE_HAS_FN | APPLE_ISO_KEYBOARD },
|
.driver_data = APPLE_HAS_FN | APPLE_ISO_KEYBOARD },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING5A_JIS),
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING5A_JIS),
|
||||||
.driver_data = APPLE_HAS_FN | APPLE_RDESC_JIS },
|
.driver_data = APPLE_HAS_FN | APPLE_RDESC_JIS },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ANSI),
|
||||||
|
.driver_data = APPLE_HAS_FN },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ISO),
|
||||||
|
.driver_data = APPLE_HAS_FN | APPLE_ISO_KEYBOARD },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_JIS),
|
||||||
|
.driver_data = APPLE_HAS_FN | APPLE_RDESC_JIS },
|
||||||
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ANSI),
|
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ANSI),
|
||||||
.driver_data = APPLE_NUMLOCK_EMULATION | APPLE_HAS_FN },
|
.driver_data = APPLE_NUMLOCK_EMULATION | APPLE_HAS_FN },
|
||||||
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ISO),
|
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ISO),
|
||||||
|
@ -1503,6 +1503,9 @@ static const struct hid_device_id hid_have_special_driver[] = {
|
|||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ANSI) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ANSI) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ISO) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ISO) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_JIS) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_JIS) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ANSI) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ISO) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_JIS) },
|
||||||
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ANSI) },
|
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ANSI) },
|
||||||
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ISO) },
|
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_ISO) },
|
||||||
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_JIS) },
|
{ HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_ALU_WIRELESS_2009_JIS) },
|
||||||
@ -1995,6 +1998,7 @@ static const struct hid_device_id hid_ignore_list[] = {
|
|||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_MCT) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_MCT) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_HYBRID) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_HYBRID) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_HEATCONTROL) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_LD, USB_DEVICE_ID_LD_HEATCONTROL) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_MADCATZ, USB_DEVICE_ID_MADCATZ_BEATPAD) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1024LS) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1024LS) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1208LS) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_MCC, USB_DEVICE_ID_MCC_PMD1208LS) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_MICROCHIP, USB_DEVICE_ID_PICKIT1) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_MICROCHIP, USB_DEVICE_ID_PICKIT1) },
|
||||||
@ -2089,6 +2093,9 @@ static const struct hid_device_id hid_mouse_ignore_list[] = {
|
|||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ANSI) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ANSI) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ISO) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_ISO) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_JIS) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING6A_JIS) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ANSI) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_ISO) },
|
||||||
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_WELLSPRING7_JIS) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_FOUNTAIN_TP_ONLY) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_FOUNTAIN_TP_ONLY) },
|
||||||
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER1_TP_ONLY) },
|
{ HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER1_TP_ONLY) },
|
||||||
{ }
|
{ }
|
||||||
|
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