Linux 3.18-rc4
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQEcBAABAgAGBQJUX/DqAAoJEHm+PkMAQRiGLtQH/iAt3fRHlYDXjaJian/KG1Cb wVP0I+HWZmvVmmd0PzyaxCZLgRNwdmmYHEH4QLy2JwZ3jZfFHlxhy+hDWCgz+67t bIzkLs0Pf1T4kJ2+r8qW2kBEz9PWJHGTQw7NTqZ++Ts3rPptBA6Fg4mEJ6fQigXy qRIY68DpipUkXV9BWBWijnTmrvP5tt7JtPzBr4DC8frMjvWct8+XwYhc2k2tEv2j LwLYb1OW6PUpPv2BQBfWjqqH77vYNQVhJwuwGcDe2YZdI0UFkDheL24+RbbPcZ4f OnrLjJSSgzv6lBWkAaXZK7/WJ/JZbXxEqHzWZQ3xXoQov97bm7lEYJqqi5gDasQ= =6Qpa -----END PGP SIGNATURE----- Merge tag 'v3.18-rc4' into drm-next backmerge to get vmwgfx locking changes into next as the conflict with per-plane locking.
This commit is contained in:
commit
51b44eb17b
|
@ -20,4 +20,4 @@ Date: November 2007
|
||||||
Contact: Konrad Rzeszutek <ketuzsezr@darnok.org>
|
Contact: Konrad Rzeszutek <ketuzsezr@darnok.org>
|
||||||
Description: The /sys/firmware/ibft/ethernetX directory will contain
|
Description: The /sys/firmware/ibft/ethernetX directory will contain
|
||||||
files that expose the iSCSI Boot Firmware Table NIC data.
|
files that expose the iSCSI Boot Firmware Table NIC data.
|
||||||
This can this can the IP address, MAC, and gateway of the NIC.
|
Usually this contains the IP address, MAC, and gateway of the NIC.
|
||||||
|
|
|
@ -25,7 +25,7 @@ GENFILES := $(addprefix $(MEDIA_OBJ_DIR)/, $(MEDIA_TEMP))
|
||||||
PHONY += cleanmediadocs
|
PHONY += cleanmediadocs
|
||||||
|
|
||||||
cleanmediadocs:
|
cleanmediadocs:
|
||||||
-@rm `find $(MEDIA_OBJ_DIR) -type l` $(GENFILES) $(OBJIMGFILES) 2>/dev/null
|
-@rm -f `find $(MEDIA_OBJ_DIR) -type l` $(GENFILES) $(OBJIMGFILES) 2>/dev/null
|
||||||
|
|
||||||
$(obj)/media_api.xml: $(GENFILES) FORCE
|
$(obj)/media_api.xml: $(GENFILES) FORCE
|
||||||
|
|
||||||
|
|
|
@ -2566,6 +2566,10 @@ fields changed from _s32 to _u32.
|
||||||
<para>Added compound control types and &VIDIOC-QUERY-EXT-CTRL;.
|
<para>Added compound control types and &VIDIOC-QUERY-EXT-CTRL;.
|
||||||
</para>
|
</para>
|
||||||
</listitem>
|
</listitem>
|
||||||
|
</orderedlist>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section>
|
||||||
<title>V4L2 in Linux 3.18</title>
|
<title>V4L2 in Linux 3.18</title>
|
||||||
<orderedlist>
|
<orderedlist>
|
||||||
<listitem>
|
<listitem>
|
||||||
|
|
|
@ -324,7 +324,6 @@ tree, they need to be integration-tested. For this purpose, a special
|
||||||
testing repository exists into which virtually all subsystem trees are
|
testing repository exists into which virtually all subsystem trees are
|
||||||
pulled on an almost daily basis:
|
pulled on an almost daily basis:
|
||||||
http://git.kernel.org/?p=linux/kernel/git/next/linux-next.git
|
http://git.kernel.org/?p=linux/kernel/git/next/linux-next.git
|
||||||
http://linux.f-seidel.de/linux-next/pmwiki/
|
|
||||||
|
|
||||||
This way, the -next kernel gives a summary outlook onto what will be
|
This way, the -next kernel gives a summary outlook onto what will be
|
||||||
expected to go into the mainline kernel at the next merge period.
|
expected to go into the mainline kernel at the next merge period.
|
||||||
|
|
|
@ -483,12 +483,10 @@ have been included in the discussion
|
||||||
|
|
||||||
14) Using Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: and Fixes:
|
14) Using Reported-by:, Tested-by:, Reviewed-by:, Suggested-by: and Fixes:
|
||||||
|
|
||||||
If this patch fixes a problem reported by somebody else, consider adding a
|
The Reported-by tag gives credit to people who find bugs and report them and it
|
||||||
Reported-by: tag to credit the reporter for their contribution. Please
|
hopefully inspires them to help us again in the future. Please note that if
|
||||||
note that this tag should not be added without the reporter's permission,
|
the bug was reported in private, then ask for permission first before using the
|
||||||
especially if the problem was not reported in a public forum. That said,
|
Reported-by tag.
|
||||||
if we diligently credit our bug reporters, they will, hopefully, be
|
|
||||||
inspired to help us again in the future.
|
|
||||||
|
|
||||||
A Tested-by: tag indicates that the patch has been successfully tested (in
|
A Tested-by: tag indicates that the patch has been successfully tested (in
|
||||||
some environment) by the person named. This tag informs maintainers that
|
some environment) by the person named. This tag informs maintainers that
|
||||||
|
|
|
@ -289,10 +289,6 @@ lists when they are assembled; they can be downloaded from:
|
||||||
|
|
||||||
http://www.kernel.org/pub/linux/kernel/next/
|
http://www.kernel.org/pub/linux/kernel/next/
|
||||||
|
|
||||||
Some information about linux-next has been gathered at:
|
|
||||||
|
|
||||||
http://linux.f-seidel.de/linux-next/pmwiki/
|
|
||||||
|
|
||||||
Linux-next has become an integral part of the kernel development process;
|
Linux-next has become an integral part of the kernel development process;
|
||||||
all patches merged during a given merge window should really have found
|
all patches merged during a given merge window should really have found
|
||||||
their way into linux-next some time before the merge window opens.
|
their way into linux-next some time before the merge window opens.
|
||||||
|
|
|
@ -22,10 +22,6 @@ Beyond that, a valuable resource for kernel developers is:
|
||||||
|
|
||||||
http://kernelnewbies.org/
|
http://kernelnewbies.org/
|
||||||
|
|
||||||
Information about the linux-next tree gathers at:
|
|
||||||
|
|
||||||
http://linux.f-seidel.de/linux-next/pmwiki/
|
|
||||||
|
|
||||||
And, of course, one should not forget http://kernel.org/, the definitive
|
And, of course, one should not forget http://kernel.org/, the definitive
|
||||||
location for kernel release information.
|
location for kernel release information.
|
||||||
|
|
||||||
|
|
|
@ -11,3 +11,5 @@ Optional properties:
|
||||||
are supported on the device. Valid value for SMSC LAN91c111 are
|
are supported on the device. Valid value for SMSC LAN91c111 are
|
||||||
1, 2 or 4. If it's omitted or invalid, the size would be 2 meaning
|
1, 2 or 4. If it's omitted or invalid, the size would be 2 meaning
|
||||||
16-bit access only.
|
16-bit access only.
|
||||||
|
- power-gpios: GPIO to control the PWRDWN pin
|
||||||
|
- reset-gpios: GPIO to control the RESET pin
|
||||||
|
|
|
@ -7,10 +7,20 @@ Required properties:
|
||||||
|
|
||||||
- clocks : the clock provider of SYS_MCLK
|
- clocks : the clock provider of SYS_MCLK
|
||||||
|
|
||||||
|
- VDDA-supply : the regulator provider of VDDA
|
||||||
|
|
||||||
|
- VDDIO-supply: the regulator provider of VDDIO
|
||||||
|
|
||||||
|
Optional properties:
|
||||||
|
|
||||||
|
- VDDD-supply : the regulator provider of VDDD
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
codec: sgtl5000@0a {
|
codec: sgtl5000@0a {
|
||||||
compatible = "fsl,sgtl5000";
|
compatible = "fsl,sgtl5000";
|
||||||
reg = <0x0a>;
|
reg = <0x0a>;
|
||||||
clocks = <&clks 150>;
|
clocks = <&clks 150>;
|
||||||
|
VDDA-supply = <®_3p3v>;
|
||||||
|
VDDIO-supply = <®_3p3v>;
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,6 +12,9 @@ I. For patch submitters
|
||||||
|
|
||||||
devicetree@vger.kernel.org
|
devicetree@vger.kernel.org
|
||||||
|
|
||||||
|
3) The Documentation/ portion of the patch should come in the series before
|
||||||
|
the code implementing the binding.
|
||||||
|
|
||||||
II. For kernel maintainers
|
II. For kernel maintainers
|
||||||
|
|
||||||
1) If you aren't comfortable reviewing a given binding, reply to it and ask
|
1) If you aren't comfortable reviewing a given binding, reply to it and ask
|
||||||
|
|
|
@ -7,7 +7,10 @@ Required properties:
|
||||||
- "renesas,thermal-r8a73a4" (R-Mobile AP6)
|
- "renesas,thermal-r8a73a4" (R-Mobile AP6)
|
||||||
- "renesas,thermal-r8a7779" (R-Car H1)
|
- "renesas,thermal-r8a7779" (R-Car H1)
|
||||||
- "renesas,thermal-r8a7790" (R-Car H2)
|
- "renesas,thermal-r8a7790" (R-Car H2)
|
||||||
- "renesas,thermal-r8a7791" (R-Car M2)
|
- "renesas,thermal-r8a7791" (R-Car M2-W)
|
||||||
|
- "renesas,thermal-r8a7792" (R-Car V2H)
|
||||||
|
- "renesas,thermal-r8a7793" (R-Car M2-N)
|
||||||
|
- "renesas,thermal-r8a7794" (R-Car E2)
|
||||||
- reg : Address range of the thermal registers.
|
- reg : Address range of the thermal registers.
|
||||||
The 1st reg will be recognized as common register
|
The 1st reg will be recognized as common register
|
||||||
if it has "interrupts".
|
if it has "interrupts".
|
||||||
|
|
|
@ -1264,7 +1264,7 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
||||||
i8042.noloop [HW] Disable the AUX Loopback command while probing
|
i8042.noloop [HW] Disable the AUX Loopback command while probing
|
||||||
for the AUX port
|
for the AUX port
|
||||||
i8042.nomux [HW] Don't check presence of an active multiplexing
|
i8042.nomux [HW] Don't check presence of an active multiplexing
|
||||||
controller. Default: true.
|
controller
|
||||||
i8042.nopnp [HW] Don't use ACPIPnP / PnPBIOS to discover KBD/AUX
|
i8042.nopnp [HW] Don't use ACPIPnP / PnPBIOS to discover KBD/AUX
|
||||||
controllers
|
controllers
|
||||||
i8042.notimeout [HW] Ignore timeout condition signalled by controller
|
i8042.notimeout [HW] Ignore timeout condition signalled by controller
|
||||||
|
@ -1307,6 +1307,18 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
||||||
.cdrom .chs .ignore_cable are additional options
|
.cdrom .chs .ignore_cable are additional options
|
||||||
See Documentation/ide/ide.txt.
|
See Documentation/ide/ide.txt.
|
||||||
|
|
||||||
|
ide-generic.probe-mask= [HW] (E)IDE subsystem
|
||||||
|
Format: <int>
|
||||||
|
Probe mask for legacy ISA IDE ports. Depending on
|
||||||
|
platform up to 6 ports are supported, enabled by
|
||||||
|
setting corresponding bits in the mask to 1. The
|
||||||
|
default value is 0x0, which has a special meaning.
|
||||||
|
On systems that have PCI, it triggers scanning the
|
||||||
|
PCI bus for the first and the second port, which
|
||||||
|
are then probed. On systems without PCI the value
|
||||||
|
of 0x0 enables probing the two first ports as if it
|
||||||
|
was 0x3.
|
||||||
|
|
||||||
ide-pci-generic.all-generic-ide [HW] (E)IDE subsystem
|
ide-pci-generic.all-generic-ide [HW] (E)IDE subsystem
|
||||||
Claim all unknown PCI IDE storage controllers.
|
Claim all unknown PCI IDE storage controllers.
|
||||||
|
|
||||||
|
@ -1587,6 +1599,8 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
||||||
kmemleak= [KNL] Boot-time kmemleak enable/disable
|
kmemleak= [KNL] Boot-time kmemleak enable/disable
|
||||||
Valid arguments: on, off
|
Valid arguments: on, off
|
||||||
Default: on
|
Default: on
|
||||||
|
Built with CONFIG_DEBUG_KMEMLEAK_DEFAULT_OFF=y,
|
||||||
|
the default is off.
|
||||||
|
|
||||||
kmemcheck= [X86] Boot-time kmemcheck enable/disable/one-shot mode
|
kmemcheck= [X86] Boot-time kmemcheck enable/disable/one-shot mode
|
||||||
Valid arguments: 0, 1, 2
|
Valid arguments: 0, 1, 2
|
||||||
|
@ -3607,7 +3621,7 @@ bytes respectively. Such letter suffixes can also be entirely omitted.
|
||||||
|
|
||||||
usb-storage.delay_use=
|
usb-storage.delay_use=
|
||||||
[UMS] The delay in seconds before a new device is
|
[UMS] The delay in seconds before a new device is
|
||||||
scanned for Logical Units (default 5).
|
scanned for Logical Units (default 1).
|
||||||
|
|
||||||
usb-storage.quirks=
|
usb-storage.quirks=
|
||||||
[UMS] A list of quirks entries to supplement or
|
[UMS] A list of quirks entries to supplement or
|
||||||
|
|
|
@ -62,6 +62,10 @@ Memory may be allocated or freed before kmemleak is initialised and
|
||||||
these actions are stored in an early log buffer. The size of this buffer
|
these actions are stored in an early log buffer. The size of this buffer
|
||||||
is configured via the CONFIG_DEBUG_KMEMLEAK_EARLY_LOG_SIZE option.
|
is configured via the CONFIG_DEBUG_KMEMLEAK_EARLY_LOG_SIZE option.
|
||||||
|
|
||||||
|
If CONFIG_DEBUG_KMEMLEAK_DEFAULT_OFF are enabled, the kmemleak is
|
||||||
|
disabled by default. Passing "kmemleak=on" on the kernel command
|
||||||
|
line enables the function.
|
||||||
|
|
||||||
Basic Algorithm
|
Basic Algorithm
|
||||||
---------------
|
---------------
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# List of programs to build
|
# List of programs to build
|
||||||
hostprogs-y := disable-tsc-ctxt-sw-stress-test disable-tsc-on-off-stress-test disable-tsc-test
|
hostprogs-$(CONFIG_X86) := disable-tsc-ctxt-sw-stress-test disable-tsc-on-off-stress-test disable-tsc-test
|
||||||
# Tell kbuild to always build the programs
|
# Tell kbuild to always build the programs
|
||||||
always := $(hostprogs-y)
|
always := $(hostprogs-y)
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
# PTP 1588 clock support - User space test program
|
||||||
|
#
|
||||||
|
# Copyright (C) 2010 OMICRON electronics GmbH
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
|
|
||||||
|
CC = $(CROSS_COMPILE)gcc
|
||||||
|
INC = -I$(KBUILD_OUTPUT)/usr/include
|
||||||
|
CFLAGS = -Wall $(INC)
|
||||||
|
LDLIBS = -lrt
|
||||||
|
PROGS = testptp
|
||||||
|
|
||||||
|
all: $(PROGS)
|
||||||
|
|
||||||
|
testptp: testptp.o
|
||||||
|
|
||||||
|
clean:
|
||||||
|
rm -f testptp.o
|
||||||
|
|
||||||
|
distclean: clean
|
||||||
|
rm -f $(PROGS)
|
|
@ -10,3 +10,6 @@ always := $(hostprogs-y)
|
||||||
HOSTCFLAGS := -I$(objtree)/usr/include -std=gnu99
|
HOSTCFLAGS := -I$(objtree)/usr/include -std=gnu99
|
||||||
HOSTCFLAGS_vdso_standalone_test_x86.o := -fno-asynchronous-unwind-tables -fno-stack-protector
|
HOSTCFLAGS_vdso_standalone_test_x86.o := -fno-asynchronous-unwind-tables -fno-stack-protector
|
||||||
HOSTLOADLIBES_vdso_standalone_test_x86 := -nostdlib
|
HOSTLOADLIBES_vdso_standalone_test_x86 := -nostdlib
|
||||||
|
ifeq ($(CONFIG_X86_32),y)
|
||||||
|
HOSTLOADLIBES_vdso_standalone_test_x86 += -lgcc_s
|
||||||
|
endif
|
||||||
|
|
|
@ -63,7 +63,7 @@ static inline void linux_exit(int code)
|
||||||
x86_syscall3(__NR_exit, code, 0, 0);
|
x86_syscall3(__NR_exit, code, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void to_base10(char *lastdig, uint64_t n)
|
void to_base10(char *lastdig, time_t n)
|
||||||
{
|
{
|
||||||
while (n) {
|
while (n) {
|
||||||
*lastdig = (n % 10) + '0';
|
*lastdig = (n % 10) + '0';
|
||||||
|
|
|
@ -221,12 +221,11 @@ ccs_out_mode: specify the allowed video output crop/compose/scaling combination
|
||||||
key, not quality.
|
key, not quality.
|
||||||
|
|
||||||
multiplanar: select whether each device instance supports multi-planar formats,
|
multiplanar: select whether each device instance supports multi-planar formats,
|
||||||
and thus the V4L2 multi-planar API. By default the first device instance
|
and thus the V4L2 multi-planar API. By default device instances are
|
||||||
is single-planar, the second multi-planar, and it keeps alternating.
|
single-planar.
|
||||||
|
|
||||||
This module option can override that for each instance. Values are:
|
This module option can override that for each instance. Values are:
|
||||||
|
|
||||||
0: use alternating single and multi-planar devices.
|
|
||||||
1: this is a single-planar instance.
|
1: this is a single-planar instance.
|
||||||
2: this is a multi-planar instance.
|
2: this is a multi-planar instance.
|
||||||
|
|
||||||
|
@ -975,9 +974,8 @@ is set, then the alpha component is only used for the color red and set to
|
||||||
0 otherwise.
|
0 otherwise.
|
||||||
|
|
||||||
The driver has to be configured to support the multiplanar formats. By default
|
The driver has to be configured to support the multiplanar formats. By default
|
||||||
the first driver instance is single-planar, the second is multi-planar, and it
|
the driver instances are single-planar. This can be changed by setting the
|
||||||
keeps alternating. This can be changed by setting the multiplanar module option,
|
multiplanar module option, see section 1 for more details on that option.
|
||||||
see section 1 for more details on that option.
|
|
||||||
|
|
||||||
If the driver instance is using the multiplanar formats/API, then the first
|
If the driver instance is using the multiplanar formats/API, then the first
|
||||||
single planar format (YUYV) and the multiplanar NV16M and NV61M formats the
|
single planar format (YUYV) and the multiplanar NV16M and NV61M formats the
|
||||||
|
@ -1021,7 +1019,7 @@ the output overlay for the video output, turn on video looping and capture
|
||||||
to see the blended framebuffer overlay that's being written to by the second
|
to see the blended framebuffer overlay that's being written to by the second
|
||||||
instance. This setup would require the following commands:
|
instance. This setup would require the following commands:
|
||||||
|
|
||||||
$ sudo modprobe vivid n_devs=2 node_types=0x10101,0x1 multiplanar=1,1
|
$ sudo modprobe vivid n_devs=2 node_types=0x10101,0x1
|
||||||
$ v4l2-ctl -d1 --find-fb
|
$ v4l2-ctl -d1 --find-fb
|
||||||
/dev/fb1 is the framebuffer associated with base address 0x12800000
|
/dev/fb1 is the framebuffer associated with base address 0x12800000
|
||||||
$ sudo v4l2-ctl -d2 --set-fbuf fb=1
|
$ sudo v4l2-ctl -d2 --set-fbuf fb=1
|
||||||
|
|
|
@ -274,7 +274,7 @@ This command mounts a (pseudo) filesystem of type hugetlbfs on the directory
|
||||||
/mnt/huge. Any files created on /mnt/huge uses huge pages. The uid and gid
|
/mnt/huge. Any files created on /mnt/huge uses huge pages. The uid and gid
|
||||||
options sets the owner and group of the root of the file system. By default
|
options sets the owner and group of the root of the file system. By default
|
||||||
the uid and gid of the current process are taken. The mode option sets the
|
the uid and gid of the current process are taken. The mode option sets the
|
||||||
mode of root of file system to value & 0777. This value is given in octal.
|
mode of root of file system to value & 01777. This value is given in octal.
|
||||||
By default the value 0755 is picked. The size option sets the maximum value of
|
By default the value 0755 is picked. The size option sets the maximum value of
|
||||||
memory (huge pages) allowed for that filesystem (/mnt/huge). The size is
|
memory (huge pages) allowed for that filesystem (/mnt/huge). The size is
|
||||||
rounded down to HPAGE_SIZE. The option nr_inodes sets the maximum number of
|
rounded down to HPAGE_SIZE. The option nr_inodes sets the maximum number of
|
||||||
|
|
23
MAINTAINERS
23
MAINTAINERS
|
@ -1543,6 +1543,7 @@ F: arch/arm/mach-pxa/include/mach/z2.h
|
||||||
|
|
||||||
ARM/ZYNQ ARCHITECTURE
|
ARM/ZYNQ ARCHITECTURE
|
||||||
M: Michal Simek <michal.simek@xilinx.com>
|
M: Michal Simek <michal.simek@xilinx.com>
|
||||||
|
R: Sören Brinkmann <soren.brinkmann@xilinx.com>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
W: http://wiki.xilinx.com
|
W: http://wiki.xilinx.com
|
||||||
T: git git://git.xilinx.com/linux-xlnx.git
|
T: git git://git.xilinx.com/linux-xlnx.git
|
||||||
|
@ -2071,8 +2072,9 @@ F: drivers/clocksource/bcm_kona_timer.c
|
||||||
|
|
||||||
BROADCOM BCM2835 ARM ARCHITECTURE
|
BROADCOM BCM2835 ARM ARCHITECTURE
|
||||||
M: Stephen Warren <swarren@wwwdotorg.org>
|
M: Stephen Warren <swarren@wwwdotorg.org>
|
||||||
|
M: Lee Jones <lee@kernel.org>
|
||||||
L: linux-rpi-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-rpi-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
T: git git://git.kernel.org/pub/scm/linux/kernel/git/swarren/linux-rpi.git
|
T: git git://git.kernel.org/pub/scm/linux/kernel/git/rpi/linux-rpi.git
|
||||||
S: Maintained
|
S: Maintained
|
||||||
N: bcm2835
|
N: bcm2835
|
||||||
|
|
||||||
|
@ -4312,8 +4314,10 @@ F: Documentation/blockdev/cpqarray.txt
|
||||||
F: drivers/block/cpqarray.*
|
F: drivers/block/cpqarray.*
|
||||||
|
|
||||||
HEWLETT-PACKARD SMART ARRAY RAID DRIVER (hpsa)
|
HEWLETT-PACKARD SMART ARRAY RAID DRIVER (hpsa)
|
||||||
M: "Stephen M. Cameron" <scameron@beardog.cce.hp.com>
|
M: Don Brace <don.brace@pmcs.com>
|
||||||
L: iss_storagedev@hp.com
|
L: iss_storagedev@hp.com
|
||||||
|
L: storagedev@pmcs.com
|
||||||
|
L: linux-scsi@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/scsi/hpsa.txt
|
F: Documentation/scsi/hpsa.txt
|
||||||
F: drivers/scsi/hpsa*.[ch]
|
F: drivers/scsi/hpsa*.[ch]
|
||||||
|
@ -4321,8 +4325,10 @@ F: include/linux/cciss*.h
|
||||||
F: include/uapi/linux/cciss*.h
|
F: include/uapi/linux/cciss*.h
|
||||||
|
|
||||||
HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss)
|
HEWLETT-PACKARD SMART CISS RAID DRIVER (cciss)
|
||||||
M: Mike Miller <mike.miller@hp.com>
|
M: Don Brace <don.brace@pmcs.com>
|
||||||
L: iss_storagedev@hp.com
|
L: iss_storagedev@hp.com
|
||||||
|
L: storagedev@pmcs.com
|
||||||
|
L: linux-scsi@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/blockdev/cciss.txt
|
F: Documentation/blockdev/cciss.txt
|
||||||
F: drivers/block/cciss*
|
F: drivers/block/cciss*
|
||||||
|
@ -4608,7 +4614,7 @@ S: Supported
|
||||||
F: drivers/crypto/nx/
|
F: drivers/crypto/nx/
|
||||||
|
|
||||||
IBM Power 842 compression accelerator
|
IBM Power 842 compression accelerator
|
||||||
M: Nathan Fontenot <nfont@linux.vnet.ibm.com>
|
M: Dan Streetman <ddstreet@us.ibm.com>
|
||||||
S: Supported
|
S: Supported
|
||||||
F: drivers/crypto/nx/nx-842.c
|
F: drivers/crypto/nx/nx-842.c
|
||||||
F: include/linux/nx842.h
|
F: include/linux/nx842.h
|
||||||
|
@ -7175,6 +7181,7 @@ F: drivers/crypto/picoxcell*
|
||||||
|
|
||||||
PIN CONTROL SUBSYSTEM
|
PIN CONTROL SUBSYSTEM
|
||||||
M: Linus Walleij <linus.walleij@linaro.org>
|
M: Linus Walleij <linus.walleij@linaro.org>
|
||||||
|
L: linux-gpio@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/pinctrl/
|
F: drivers/pinctrl/
|
||||||
F: include/linux/pinctrl/
|
F: include/linux/pinctrl/
|
||||||
|
@ -8479,7 +8486,6 @@ F: arch/arm/mach-s3c24xx/bast-irq.c
|
||||||
TI DAVINCI MACHINE SUPPORT
|
TI DAVINCI MACHINE SUPPORT
|
||||||
M: Sekhar Nori <nsekhar@ti.com>
|
M: Sekhar Nori <nsekhar@ti.com>
|
||||||
M: Kevin Hilman <khilman@deeprootsystems.com>
|
M: Kevin Hilman <khilman@deeprootsystems.com>
|
||||||
L: davinci-linux-open-source@linux.davincidsp.com (moderated for non-subscribers)
|
|
||||||
T: git git://gitorious.org/linux-davinci/linux-davinci.git
|
T: git git://gitorious.org/linux-davinci/linux-davinci.git
|
||||||
Q: http://patchwork.kernel.org/project/linux-davinci/list/
|
Q: http://patchwork.kernel.org/project/linux-davinci/list/
|
||||||
S: Supported
|
S: Supported
|
||||||
|
@ -8489,7 +8495,6 @@ F: drivers/i2c/busses/i2c-davinci.c
|
||||||
TI DAVINCI SERIES MEDIA DRIVER
|
TI DAVINCI SERIES MEDIA DRIVER
|
||||||
M: Lad, Prabhakar <prabhakar.csengg@gmail.com>
|
M: Lad, Prabhakar <prabhakar.csengg@gmail.com>
|
||||||
L: linux-media@vger.kernel.org
|
L: linux-media@vger.kernel.org
|
||||||
L: davinci-linux-open-source@linux.davincidsp.com (moderated for non-subscribers)
|
|
||||||
W: http://linuxtv.org/
|
W: http://linuxtv.org/
|
||||||
Q: http://patchwork.linuxtv.org/project/linux-media/list/
|
Q: http://patchwork.linuxtv.org/project/linux-media/list/
|
||||||
T: git git://linuxtv.org/mhadli/v4l-dvb-davinci_devices.git
|
T: git git://linuxtv.org/mhadli/v4l-dvb-davinci_devices.git
|
||||||
|
@ -9606,7 +9611,6 @@ F: drivers/staging/unisys/
|
||||||
|
|
||||||
UNIVERSAL FLASH STORAGE HOST CONTROLLER DRIVER
|
UNIVERSAL FLASH STORAGE HOST CONTROLLER DRIVER
|
||||||
M: Vinayak Holikatti <vinholikatti@gmail.com>
|
M: Vinayak Holikatti <vinholikatti@gmail.com>
|
||||||
M: Santosh Y <santoshsy@gmail.com>
|
|
||||||
L: linux-scsi@vger.kernel.org
|
L: linux-scsi@vger.kernel.org
|
||||||
S: Supported
|
S: Supported
|
||||||
F: Documentation/scsi/ufs.txt
|
F: Documentation/scsi/ufs.txt
|
||||||
|
@ -9700,11 +9704,6 @@ S: Maintained
|
||||||
F: Documentation/hid/hiddev.txt
|
F: Documentation/hid/hiddev.txt
|
||||||
F: drivers/hid/usbhid/
|
F: drivers/hid/usbhid/
|
||||||
|
|
||||||
USB/IP DRIVERS
|
|
||||||
L: linux-usb@vger.kernel.org
|
|
||||||
S: Orphan
|
|
||||||
F: drivers/staging/usbip/
|
|
||||||
|
|
||||||
USB ISP116X DRIVER
|
USB ISP116X DRIVER
|
||||||
M: Olav Kongas <ok@artecdesign.ee>
|
M: Olav Kongas <ok@artecdesign.ee>
|
||||||
L: linux-usb@vger.kernel.org
|
L: linux-usb@vger.kernel.org
|
||||||
|
|
4
Makefile
4
Makefile
|
@ -1,8 +1,8 @@
|
||||||
VERSION = 3
|
VERSION = 3
|
||||||
PATCHLEVEL = 18
|
PATCHLEVEL = 18
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc2
|
EXTRAVERSION = -rc4
|
||||||
NAME = Shuffling Zombie Juror
|
NAME = Diseased Newt
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
# To see a list of typical targets execute "make help"
|
# To see a list of typical targets execute "make help"
|
||||||
|
|
|
@ -1187,7 +1187,7 @@ config DEBUG_UART_VIRT
|
||||||
default 0xf1c28000 if DEBUG_SUNXI_UART0
|
default 0xf1c28000 if DEBUG_SUNXI_UART0
|
||||||
default 0xf1c28400 if DEBUG_SUNXI_UART1
|
default 0xf1c28400 if DEBUG_SUNXI_UART1
|
||||||
default 0xf1f02800 if DEBUG_SUNXI_R_UART
|
default 0xf1f02800 if DEBUG_SUNXI_R_UART
|
||||||
default 0xf2100000 if DEBUG_PXA_UART1
|
default 0xf6200000 if DEBUG_PXA_UART1
|
||||||
default 0xf4090000 if ARCH_LPC32XX
|
default 0xf4090000 if ARCH_LPC32XX
|
||||||
default 0xf4200000 if ARCH_GEMINI
|
default 0xf4200000 if ARCH_GEMINI
|
||||||
default 0xf7000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \
|
default 0xf7000000 if DEBUG_S3C24XX_UART && (DEBUG_S3C_UART0 || \
|
||||||
|
|
|
@ -668,6 +668,8 @@
|
||||||
bank-width = <2>;
|
bank-width = <2>;
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
pinctrl-0 = <ðernet_pins>;
|
pinctrl-0 = <ðernet_pins>;
|
||||||
|
power-gpios = <&gpio3 22 GPIO_ACTIVE_HIGH>; /* gpio86 */
|
||||||
|
reset-gpios = <&gpio6 4 GPIO_ACTIVE_HIGH>; /* gpio164 */
|
||||||
gpmc,device-width = <2>;
|
gpmc,device-width = <2>;
|
||||||
gpmc,sync-clk-ps = <0>;
|
gpmc,sync-clk-ps = <0>;
|
||||||
gpmc,cs-on-ns = <0>;
|
gpmc,cs-on-ns = <0>;
|
||||||
|
|
|
@ -33,6 +33,13 @@
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&esdhc1 {
|
||||||
|
pinctrl-names = "default";
|
||||||
|
pinctrl-0 = <&pinctrl_esdhc1>;
|
||||||
|
bus-width = <4>;
|
||||||
|
status = "okay";
|
||||||
|
};
|
||||||
|
|
||||||
&fec1 {
|
&fec1 {
|
||||||
phy-mode = "rmii";
|
phy-mode = "rmii";
|
||||||
pinctrl-names = "default";
|
pinctrl-names = "default";
|
||||||
|
@ -42,6 +49,18 @@
|
||||||
|
|
||||||
&iomuxc {
|
&iomuxc {
|
||||||
vf610-cosmic {
|
vf610-cosmic {
|
||||||
|
pinctrl_esdhc1: esdhc1grp {
|
||||||
|
fsl,pins = <
|
||||||
|
VF610_PAD_PTA24__ESDHC1_CLK 0x31ef
|
||||||
|
VF610_PAD_PTA25__ESDHC1_CMD 0x31ef
|
||||||
|
VF610_PAD_PTA26__ESDHC1_DAT0 0x31ef
|
||||||
|
VF610_PAD_PTA27__ESDHC1_DAT1 0x31ef
|
||||||
|
VF610_PAD_PTA28__ESDHC1_DATA2 0x31ef
|
||||||
|
VF610_PAD_PTA29__ESDHC1_DAT3 0x31ef
|
||||||
|
VF610_PAD_PTB28__GPIO_98 0x219d
|
||||||
|
>;
|
||||||
|
};
|
||||||
|
|
||||||
pinctrl_fec1: fec1grp {
|
pinctrl_fec1: fec1grp {
|
||||||
fsl,pins = <
|
fsl,pins = <
|
||||||
VF610_PAD_PTC9__ENET_RMII1_MDC 0x30d2
|
VF610_PAD_PTC9__ENET_RMII1_MDC 0x30d2
|
||||||
|
|
|
@ -34,6 +34,10 @@
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
&clkc {
|
||||||
|
fclk-enable = <0xf>;
|
||||||
|
};
|
||||||
|
|
||||||
&gem0 {
|
&gem0 {
|
||||||
status = "okay";
|
status = "okay";
|
||||||
phy-mode = "rgmii-id";
|
phy-mode = "rgmii-id";
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/edma.h>
|
#include <linux/edma.h>
|
||||||
|
#include <linux/dma-mapping.h>
|
||||||
#include <linux/of_address.h>
|
#include <linux/of_address.h>
|
||||||
#include <linux/of_device.h>
|
#include <linux/of_device.h>
|
||||||
#include <linux/of_dma.h>
|
#include <linux/of_dma.h>
|
||||||
|
@ -1623,6 +1624,11 @@ static int edma_probe(struct platform_device *pdev)
|
||||||
struct device_node *node = pdev->dev.of_node;
|
struct device_node *node = pdev->dev.of_node;
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
int ret;
|
int ret;
|
||||||
|
struct platform_device_info edma_dev_info = {
|
||||||
|
.name = "edma-dma-engine",
|
||||||
|
.dma_mask = DMA_BIT_MASK(32),
|
||||||
|
.parent = &pdev->dev,
|
||||||
|
};
|
||||||
|
|
||||||
if (node) {
|
if (node) {
|
||||||
/* Check if this is a second instance registered */
|
/* Check if this is a second instance registered */
|
||||||
|
@ -1793,6 +1799,9 @@ static int edma_probe(struct platform_device *pdev)
|
||||||
edma_write_array(j, EDMA_QRAE, i, 0x0);
|
edma_write_array(j, EDMA_QRAE, i, 0x0);
|
||||||
}
|
}
|
||||||
arch_num_cc++;
|
arch_num_cc++;
|
||||||
|
|
||||||
|
edma_dev_info.id = j;
|
||||||
|
platform_device_register_full(&edma_dev_info);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -97,6 +97,7 @@ CONFIG_SERIAL_IMX_CONSOLE=y
|
||||||
# CONFIG_HW_RANDOM is not set
|
# CONFIG_HW_RANDOM is not set
|
||||||
CONFIG_I2C_CHARDEV=y
|
CONFIG_I2C_CHARDEV=y
|
||||||
CONFIG_I2C_IMX=y
|
CONFIG_I2C_IMX=y
|
||||||
|
CONFIG_SPI=y
|
||||||
CONFIG_SPI_IMX=y
|
CONFIG_SPI_IMX=y
|
||||||
CONFIG_SPI_SPIDEV=y
|
CONFIG_SPI_SPIDEV=y
|
||||||
CONFIG_GPIO_SYSFS=y
|
CONFIG_GPIO_SYSFS=y
|
||||||
|
|
|
@ -158,6 +158,7 @@ CONFIG_I2C_CHARDEV=y
|
||||||
CONFIG_I2C_ALGOPCF=m
|
CONFIG_I2C_ALGOPCF=m
|
||||||
CONFIG_I2C_ALGOPCA=m
|
CONFIG_I2C_ALGOPCA=m
|
||||||
CONFIG_I2C_IMX=y
|
CONFIG_I2C_IMX=y
|
||||||
|
CONFIG_SPI=y
|
||||||
CONFIG_SPI_IMX=y
|
CONFIG_SPI_IMX=y
|
||||||
CONFIG_GPIO_SYSFS=y
|
CONFIG_GPIO_SYSFS=y
|
||||||
CONFIG_GPIO_MC9S08DZ60=y
|
CONFIG_GPIO_MC9S08DZ60=y
|
||||||
|
|
|
@ -235,6 +235,7 @@ CONFIG_SPI_TEGRA20_SLINK=y
|
||||||
CONFIG_SPI_XILINX=y
|
CONFIG_SPI_XILINX=y
|
||||||
CONFIG_PINCTRL_AS3722=y
|
CONFIG_PINCTRL_AS3722=y
|
||||||
CONFIG_PINCTRL_PALMAS=y
|
CONFIG_PINCTRL_PALMAS=y
|
||||||
|
CONFIG_PINCTRL_APQ8084=y
|
||||||
CONFIG_GPIO_SYSFS=y
|
CONFIG_GPIO_SYSFS=y
|
||||||
CONFIG_GPIO_GENERIC_PLATFORM=y
|
CONFIG_GPIO_GENERIC_PLATFORM=y
|
||||||
CONFIG_GPIO_DWAPB=y
|
CONFIG_GPIO_DWAPB=y
|
||||||
|
@ -411,6 +412,7 @@ CONFIG_NVEC_POWER=y
|
||||||
CONFIG_NVEC_PAZ00=y
|
CONFIG_NVEC_PAZ00=y
|
||||||
CONFIG_QCOM_GSBI=y
|
CONFIG_QCOM_GSBI=y
|
||||||
CONFIG_COMMON_CLK_QCOM=y
|
CONFIG_COMMON_CLK_QCOM=y
|
||||||
|
CONFIG_APQ_MMCC_8084=y
|
||||||
CONFIG_MSM_GCC_8660=y
|
CONFIG_MSM_GCC_8660=y
|
||||||
CONFIG_MSM_MMCC_8960=y
|
CONFIG_MSM_MMCC_8960=y
|
||||||
CONFIG_MSM_MMCC_8974=y
|
CONFIG_MSM_MMCC_8974=y
|
||||||
|
|
|
@ -86,7 +86,6 @@ CONFIG_IP_PNP_DHCP=y
|
||||||
CONFIG_IP_PNP_BOOTP=y
|
CONFIG_IP_PNP_BOOTP=y
|
||||||
CONFIG_IP_PNP_RARP=y
|
CONFIG_IP_PNP_RARP=y
|
||||||
# CONFIG_INET_LRO is not set
|
# CONFIG_INET_LRO is not set
|
||||||
CONFIG_IPV6=y
|
|
||||||
CONFIG_NETFILTER=y
|
CONFIG_NETFILTER=y
|
||||||
CONFIG_CAN=m
|
CONFIG_CAN=m
|
||||||
CONFIG_CAN_C_CAN=m
|
CONFIG_CAN_C_CAN=m
|
||||||
|
@ -112,6 +111,7 @@ CONFIG_MTD_OOPS=y
|
||||||
CONFIG_MTD_CFI=y
|
CONFIG_MTD_CFI=y
|
||||||
CONFIG_MTD_CFI_INTELEXT=y
|
CONFIG_MTD_CFI_INTELEXT=y
|
||||||
CONFIG_MTD_NAND=y
|
CONFIG_MTD_NAND=y
|
||||||
|
CONFIG_MTD_NAND_ECC_BCH=y
|
||||||
CONFIG_MTD_NAND_OMAP2=y
|
CONFIG_MTD_NAND_OMAP2=y
|
||||||
CONFIG_MTD_ONENAND=y
|
CONFIG_MTD_ONENAND=y
|
||||||
CONFIG_MTD_ONENAND_VERIFY_WRITE=y
|
CONFIG_MTD_ONENAND_VERIFY_WRITE=y
|
||||||
|
@ -317,7 +317,7 @@ CONFIG_EXT4_FS=y
|
||||||
CONFIG_FANOTIFY=y
|
CONFIG_FANOTIFY=y
|
||||||
CONFIG_QUOTA=y
|
CONFIG_QUOTA=y
|
||||||
CONFIG_QFMT_V2=y
|
CONFIG_QFMT_V2=y
|
||||||
CONFIG_AUTOFS4_FS=y
|
CONFIG_AUTOFS4_FS=m
|
||||||
CONFIG_MSDOS_FS=y
|
CONFIG_MSDOS_FS=y
|
||||||
CONFIG_VFAT_FS=y
|
CONFIG_VFAT_FS=y
|
||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
|
CONFIG_FHANDLE=y
|
||||||
|
CONFIG_HIGH_RES_TIMERS=y
|
||||||
CONFIG_IKCONFIG=y
|
CONFIG_IKCONFIG=y
|
||||||
CONFIG_IKCONFIG_PROC=y
|
CONFIG_IKCONFIG_PROC=y
|
||||||
CONFIG_LOG_BUF_SHIFT=14
|
CONFIG_LOG_BUF_SHIFT=14
|
||||||
|
@ -11,23 +12,17 @@ CONFIG_PROFILING=y
|
||||||
CONFIG_OPROFILE=y
|
CONFIG_OPROFILE=y
|
||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
CONFIG_MODULE_UNLOAD=y
|
CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_HOTPLUG=y
|
|
||||||
# CONFIG_LBDAF is not set
|
# CONFIG_LBDAF is not set
|
||||||
# CONFIG_BLK_DEV_BSG is not set
|
# CONFIG_BLK_DEV_BSG is not set
|
||||||
# CONFIG_IOSCHED_DEADLINE is not set
|
# CONFIG_IOSCHED_DEADLINE is not set
|
||||||
# CONFIG_IOSCHED_CFQ is not set
|
# CONFIG_IOSCHED_CFQ is not set
|
||||||
CONFIG_ARCH_SOCFPGA=y
|
CONFIG_ARCH_SOCFPGA=y
|
||||||
CONFIG_MACH_SOCFPGA_CYCLONE5=y
|
|
||||||
CONFIG_ARM_THUMBEE=y
|
CONFIG_ARM_THUMBEE=y
|
||||||
# CONFIG_ARCH_VEXPRESS_CORTEX_A5_A9_ERRATA is not set
|
|
||||||
# CONFIG_CACHE_L2X0 is not set
|
|
||||||
CONFIG_HIGH_RES_TIMERS=y
|
|
||||||
CONFIG_SMP=y
|
CONFIG_SMP=y
|
||||||
CONFIG_NR_CPUS=2
|
CONFIG_NR_CPUS=2
|
||||||
CONFIG_AEABI=y
|
CONFIG_AEABI=y
|
||||||
CONFIG_ZBOOT_ROM_TEXT=0x0
|
CONFIG_ZBOOT_ROM_TEXT=0x0
|
||||||
CONFIG_ZBOOT_ROM_BSS=0x0
|
CONFIG_ZBOOT_ROM_BSS=0x0
|
||||||
CONFIG_CMDLINE=""
|
|
||||||
CONFIG_VFP=y
|
CONFIG_VFP=y
|
||||||
CONFIG_NEON=y
|
CONFIG_NEON=y
|
||||||
CONFIG_NET=y
|
CONFIG_NET=y
|
||||||
|
@ -41,38 +36,30 @@ CONFIG_IP_PNP=y
|
||||||
CONFIG_IP_PNP_DHCP=y
|
CONFIG_IP_PNP_DHCP=y
|
||||||
CONFIG_IP_PNP_BOOTP=y
|
CONFIG_IP_PNP_BOOTP=y
|
||||||
CONFIG_IP_PNP_RARP=y
|
CONFIG_IP_PNP_RARP=y
|
||||||
|
CONFIG_IPV6=y
|
||||||
|
CONFIG_NETWORK_PHY_TIMESTAMPING=y
|
||||||
|
CONFIG_VLAN_8021Q=y
|
||||||
|
CONFIG_VLAN_8021Q_GVRP=y
|
||||||
CONFIG_CAN=y
|
CONFIG_CAN=y
|
||||||
CONFIG_CAN_RAW=y
|
|
||||||
CONFIG_CAN_BCM=y
|
|
||||||
CONFIG_CAN_GW=y
|
|
||||||
CONFIG_CAN_DEV=y
|
|
||||||
CONFIG_CAN_CALC_BITTIMING=y
|
|
||||||
CONFIG_CAN_C_CAN=y
|
CONFIG_CAN_C_CAN=y
|
||||||
CONFIG_CAN_C_CAN_PLATFORM=y
|
CONFIG_CAN_C_CAN_PLATFORM=y
|
||||||
CONFIG_CAN_DEBUG_DEVICES=y
|
CONFIG_CAN_DEBUG_DEVICES=y
|
||||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||||
CONFIG_DEVTMPFS=y
|
CONFIG_DEVTMPFS=y
|
||||||
CONFIG_PROC_DEVICETREE=y
|
CONFIG_DEVTMPFS_MOUNT=y
|
||||||
CONFIG_BLK_DEV_RAM=y
|
CONFIG_BLK_DEV_RAM=y
|
||||||
CONFIG_BLK_DEV_RAM_COUNT=2
|
CONFIG_BLK_DEV_RAM_COUNT=2
|
||||||
CONFIG_BLK_DEV_RAM_SIZE=8192
|
CONFIG_BLK_DEV_RAM_SIZE=8192
|
||||||
|
CONFIG_SRAM=y
|
||||||
CONFIG_SCSI=y
|
CONFIG_SCSI=y
|
||||||
# CONFIG_SCSI_PROC_FS is not set
|
# CONFIG_SCSI_PROC_FS is not set
|
||||||
CONFIG_BLK_DEV_SD=y
|
CONFIG_BLK_DEV_SD=y
|
||||||
# CONFIG_SCSI_LOWLEVEL is not set
|
# CONFIG_SCSI_LOWLEVEL is not set
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_STMMAC_ETH=y
|
CONFIG_STMMAC_ETH=y
|
||||||
CONFIG_MICREL_PHY=y
|
|
||||||
# CONFIG_STMMAC_PHY_ID_ZERO_WORKAROUND is not set
|
|
||||||
CONFIG_INPUT_EVDEV=y
|
|
||||||
CONFIG_DWMAC_SOCFPGA=y
|
CONFIG_DWMAC_SOCFPGA=y
|
||||||
CONFIG_PPS=y
|
CONFIG_MICREL_PHY=y
|
||||||
CONFIG_NETWORK_PHY_TIMESTAMPING=y
|
CONFIG_INPUT_EVDEV=y
|
||||||
CONFIG_PTP_1588_CLOCK=y
|
|
||||||
CONFIG_VLAN_8021Q=y
|
|
||||||
CONFIG_VLAN_8021Q_GVRP=y
|
|
||||||
CONFIG_GARP=y
|
|
||||||
CONFIG_IPV6=y
|
|
||||||
# CONFIG_SERIO_SERPORT is not set
|
# CONFIG_SERIO_SERPORT is not set
|
||||||
CONFIG_SERIO_AMBAKMI=y
|
CONFIG_SERIO_AMBAKMI=y
|
||||||
CONFIG_LEGACY_PTY_COUNT=16
|
CONFIG_LEGACY_PTY_COUNT=16
|
||||||
|
@ -81,45 +68,43 @@ CONFIG_SERIAL_8250_CONSOLE=y
|
||||||
CONFIG_SERIAL_8250_NR_UARTS=2
|
CONFIG_SERIAL_8250_NR_UARTS=2
|
||||||
CONFIG_SERIAL_8250_RUNTIME_UARTS=2
|
CONFIG_SERIAL_8250_RUNTIME_UARTS=2
|
||||||
CONFIG_SERIAL_8250_DW=y
|
CONFIG_SERIAL_8250_DW=y
|
||||||
|
CONFIG_I2C=y
|
||||||
|
CONFIG_I2C_CHARDEV=y
|
||||||
|
CONFIG_I2C_DESIGNWARE_PLATFORM=y
|
||||||
CONFIG_GPIOLIB=y
|
CONFIG_GPIOLIB=y
|
||||||
CONFIG_GPIO_SYSFS=y
|
CONFIG_GPIO_SYSFS=y
|
||||||
CONFIG_GPIO_DWAPB=y
|
CONFIG_GPIO_DWAPB=y
|
||||||
# CONFIG_RTC_HCTOSYS is not set
|
CONFIG_PMBUS=y
|
||||||
|
CONFIG_SENSORS_LTC2978=y
|
||||||
|
CONFIG_SENSORS_LTC2978_REGULATOR=y
|
||||||
CONFIG_WATCHDOG=y
|
CONFIG_WATCHDOG=y
|
||||||
CONFIG_DW_WATCHDOG=y
|
CONFIG_DW_WATCHDOG=y
|
||||||
|
CONFIG_REGULATOR=y
|
||||||
|
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||||
|
CONFIG_USB=y
|
||||||
|
CONFIG_USB_DWC2=y
|
||||||
|
CONFIG_USB_DWC2_HOST=y
|
||||||
|
CONFIG_MMC=y
|
||||||
|
CONFIG_MMC_DW=y
|
||||||
CONFIG_EXT2_FS=y
|
CONFIG_EXT2_FS=y
|
||||||
CONFIG_EXT2_FS_XATTR=y
|
CONFIG_EXT2_FS_XATTR=y
|
||||||
CONFIG_EXT2_FS_POSIX_ACL=y
|
CONFIG_EXT2_FS_POSIX_ACL=y
|
||||||
CONFIG_EXT3_FS=y
|
CONFIG_EXT3_FS=y
|
||||||
CONFIG_NFS_FS=y
|
CONFIG_EXT4_FS=y
|
||||||
CONFIG_ROOT_NFS=y
|
|
||||||
# CONFIG_DNOTIFY is not set
|
|
||||||
# CONFIG_INOTIFY_USER is not set
|
|
||||||
CONFIG_FHANDLE=y
|
|
||||||
CONFIG_VFAT_FS=y
|
CONFIG_VFAT_FS=y
|
||||||
CONFIG_NTFS_FS=y
|
CONFIG_NTFS_FS=y
|
||||||
CONFIG_NTFS_RW=y
|
CONFIG_NTFS_RW=y
|
||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_JFFS2_FS=y
|
CONFIG_CONFIGFS_FS=y
|
||||||
|
CONFIG_NFS_FS=y
|
||||||
|
CONFIG_ROOT_NFS=y
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_ISO8859_1=y
|
CONFIG_NLS_ISO8859_1=y
|
||||||
|
CONFIG_PRINTK_TIME=y
|
||||||
|
CONFIG_DEBUG_INFO=y
|
||||||
CONFIG_MAGIC_SYSRQ=y
|
CONFIG_MAGIC_SYSRQ=y
|
||||||
CONFIG_DETECT_HUNG_TASK=y
|
CONFIG_DETECT_HUNG_TASK=y
|
||||||
# CONFIG_SCHED_DEBUG is not set
|
# CONFIG_SCHED_DEBUG is not set
|
||||||
CONFIG_DEBUG_INFO=y
|
|
||||||
CONFIG_ENABLE_DEFAULT_TRACERS=y
|
CONFIG_ENABLE_DEFAULT_TRACERS=y
|
||||||
CONFIG_DEBUG_USER=y
|
CONFIG_DEBUG_USER=y
|
||||||
CONFIG_XZ_DEC=y
|
CONFIG_XZ_DEC=y
|
||||||
CONFIG_I2C=y
|
|
||||||
CONFIG_I2C_DESIGNWARE_CORE=y
|
|
||||||
CONFIG_I2C_DESIGNWARE_PLATFORM=y
|
|
||||||
CONFIG_I2C_CHARDEV=y
|
|
||||||
CONFIG_MMC=y
|
|
||||||
CONFIG_MMC_DW=y
|
|
||||||
CONFIG_PM=y
|
|
||||||
CONFIG_SUSPEND=y
|
|
||||||
CONFIG_MMC_UNSAFE_RESUME=y
|
|
||||||
CONFIG_USB=y
|
|
||||||
CONFIG_USB_DWC2=y
|
|
||||||
CONFIG_USB_DWC2_HOST=y
|
|
||||||
CONFIG_USB_DWC2_PLATFORM=y
|
|
||||||
|
|
|
@ -412,6 +412,7 @@
|
||||||
#define __NR_seccomp (__NR_SYSCALL_BASE+383)
|
#define __NR_seccomp (__NR_SYSCALL_BASE+383)
|
||||||
#define __NR_getrandom (__NR_SYSCALL_BASE+384)
|
#define __NR_getrandom (__NR_SYSCALL_BASE+384)
|
||||||
#define __NR_memfd_create (__NR_SYSCALL_BASE+385)
|
#define __NR_memfd_create (__NR_SYSCALL_BASE+385)
|
||||||
|
#define __NR_bpf (__NR_SYSCALL_BASE+386)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The following SWIs are ARM private.
|
* The following SWIs are ARM private.
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
* it under the terms of the GNU General Public License version 2 as
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
* published by the Free Software Foundation.
|
* published by the Free Software Foundation.
|
||||||
*/
|
*/
|
||||||
|
#include <linux/compiler.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/dma-mapping.h>
|
#include <linux/dma-mapping.h>
|
||||||
|
@ -39,10 +40,19 @@
|
||||||
* GCC 3.2.x: miscompiles NEW_AUX_ENT in fs/binfmt_elf.c
|
* GCC 3.2.x: miscompiles NEW_AUX_ENT in fs/binfmt_elf.c
|
||||||
* (http://gcc.gnu.org/PR8896) and incorrect structure
|
* (http://gcc.gnu.org/PR8896) and incorrect structure
|
||||||
* initialisation in fs/jffs2/erase.c
|
* initialisation in fs/jffs2/erase.c
|
||||||
|
* GCC 4.8.0-4.8.2: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=58854
|
||||||
|
* miscompiles find_get_entry(), and can result in EXT3 and EXT4
|
||||||
|
* filesystem corruption (possibly other FS too).
|
||||||
*/
|
*/
|
||||||
|
#ifdef __GNUC__
|
||||||
#if (__GNUC__ == 3 && __GNUC_MINOR__ < 3)
|
#if (__GNUC__ == 3 && __GNUC_MINOR__ < 3)
|
||||||
#error Your compiler is too buggy; it is known to miscompile kernels.
|
#error Your compiler is too buggy; it is known to miscompile kernels.
|
||||||
#error Known good compilers: 3.3
|
#error Known good compilers: 3.3, 4.x
|
||||||
|
#endif
|
||||||
|
#if GCC_VERSION >= 40800 && GCC_VERSION < 40803
|
||||||
|
#error Your compiler is too buggy; it is known to miscompile kernels
|
||||||
|
#error and result in filesystem corruption and oopses.
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
|
|
|
@ -395,6 +395,7 @@
|
||||||
CALL(sys_seccomp)
|
CALL(sys_seccomp)
|
||||||
CALL(sys_getrandom)
|
CALL(sys_getrandom)
|
||||||
/* 385 */ CALL(sys_memfd_create)
|
/* 385 */ CALL(sys_memfd_create)
|
||||||
|
CALL(sys_bpf)
|
||||||
#ifndef syscalls_counted
|
#ifndef syscalls_counted
|
||||||
.equ syscalls_padding, ((NR_syscalls + 3) & ~3) - NR_syscalls
|
.equ syscalls_padding, ((NR_syscalls + 3) & ~3) - NR_syscalls
|
||||||
#define syscalls_counted
|
#define syscalls_counted
|
||||||
|
|
|
@ -58,8 +58,14 @@
|
||||||
#define PFD_PLL1_BASE (anatop_base + 0x2b0)
|
#define PFD_PLL1_BASE (anatop_base + 0x2b0)
|
||||||
#define PFD_PLL2_BASE (anatop_base + 0x100)
|
#define PFD_PLL2_BASE (anatop_base + 0x100)
|
||||||
#define PFD_PLL3_BASE (anatop_base + 0xf0)
|
#define PFD_PLL3_BASE (anatop_base + 0xf0)
|
||||||
|
#define PLL1_CTRL (anatop_base + 0x270)
|
||||||
|
#define PLL2_CTRL (anatop_base + 0x30)
|
||||||
#define PLL3_CTRL (anatop_base + 0x10)
|
#define PLL3_CTRL (anatop_base + 0x10)
|
||||||
|
#define PLL4_CTRL (anatop_base + 0x70)
|
||||||
|
#define PLL5_CTRL (anatop_base + 0xe0)
|
||||||
|
#define PLL6_CTRL (anatop_base + 0xa0)
|
||||||
#define PLL7_CTRL (anatop_base + 0x20)
|
#define PLL7_CTRL (anatop_base + 0x20)
|
||||||
|
#define ANA_MISC1 (anatop_base + 0x160)
|
||||||
|
|
||||||
static void __iomem *anatop_base;
|
static void __iomem *anatop_base;
|
||||||
static void __iomem *ccm_base;
|
static void __iomem *ccm_base;
|
||||||
|
@ -67,25 +73,34 @@ static void __iomem *ccm_base;
|
||||||
/* sources for multiplexer clocks, this is used multiple times */
|
/* sources for multiplexer clocks, this is used multiple times */
|
||||||
static const char *fast_sels[] = { "firc", "fxosc", };
|
static const char *fast_sels[] = { "firc", "fxosc", };
|
||||||
static const char *slow_sels[] = { "sirc_32k", "sxosc", };
|
static const char *slow_sels[] = { "sirc_32k", "sxosc", };
|
||||||
static const char *pll1_sels[] = { "pll1_main", "pll1_pfd1", "pll1_pfd2", "pll1_pfd3", "pll1_pfd4", };
|
static const char *pll1_sels[] = { "pll1_sys", "pll1_pfd1", "pll1_pfd2", "pll1_pfd3", "pll1_pfd4", };
|
||||||
static const char *pll2_sels[] = { "pll2_main", "pll2_pfd1", "pll2_pfd2", "pll2_pfd3", "pll2_pfd4", };
|
static const char *pll2_sels[] = { "pll2_bus", "pll2_pfd1", "pll2_pfd2", "pll2_pfd3", "pll2_pfd4", };
|
||||||
static const char *sys_sels[] = { "fast_clk_sel", "slow_clk_sel", "pll2_pfd_sel", "pll2_main", "pll1_pfd_sel", "pll3_main", };
|
static const char *pll_bypass_src_sels[] = { "fast_clk_sel", "lvds1_in", };
|
||||||
|
static const char *pll1_bypass_sels[] = { "pll1", "pll1_bypass_src", };
|
||||||
|
static const char *pll2_bypass_sels[] = { "pll2", "pll2_bypass_src", };
|
||||||
|
static const char *pll3_bypass_sels[] = { "pll3", "pll3_bypass_src", };
|
||||||
|
static const char *pll4_bypass_sels[] = { "pll4", "pll4_bypass_src", };
|
||||||
|
static const char *pll5_bypass_sels[] = { "pll5", "pll5_bypass_src", };
|
||||||
|
static const char *pll6_bypass_sels[] = { "pll6", "pll6_bypass_src", };
|
||||||
|
static const char *pll7_bypass_sels[] = { "pll7", "pll7_bypass_src", };
|
||||||
|
static const char *sys_sels[] = { "fast_clk_sel", "slow_clk_sel", "pll2_pfd_sel", "pll2_bus", "pll1_pfd_sel", "pll3_usb_otg", };
|
||||||
static const char *ddr_sels[] = { "pll2_pfd2", "sys_sel", };
|
static const char *ddr_sels[] = { "pll2_pfd2", "sys_sel", };
|
||||||
static const char *rmii_sels[] = { "enet_ext", "audio_ext", "enet_50m", "enet_25m", };
|
static const char *rmii_sels[] = { "enet_ext", "audio_ext", "enet_50m", "enet_25m", };
|
||||||
static const char *enet_ts_sels[] = { "enet_ext", "fxosc", "audio_ext", "usb", "enet_ts", "enet_25m", "enet_50m", };
|
static const char *enet_ts_sels[] = { "enet_ext", "fxosc", "audio_ext", "usb", "enet_ts", "enet_25m", "enet_50m", };
|
||||||
static const char *esai_sels[] = { "audio_ext", "mlb", "spdif_rx", "pll4_main_div", };
|
static const char *esai_sels[] = { "audio_ext", "mlb", "spdif_rx", "pll4_audio_div", };
|
||||||
static const char *sai_sels[] = { "audio_ext", "mlb", "spdif_rx", "pll4_main_div", };
|
static const char *sai_sels[] = { "audio_ext", "mlb", "spdif_rx", "pll4_audio_div", };
|
||||||
static const char *nfc_sels[] = { "platform_bus", "pll1_pfd1", "pll3_pfd1", "pll3_pfd3", };
|
static const char *nfc_sels[] = { "platform_bus", "pll1_pfd1", "pll3_pfd1", "pll3_pfd3", };
|
||||||
static const char *qspi_sels[] = { "pll3_main", "pll3_pfd4", "pll2_pfd4", "pll1_pfd4", };
|
static const char *qspi_sels[] = { "pll3_usb_otg", "pll3_pfd4", "pll2_pfd4", "pll1_pfd4", };
|
||||||
static const char *esdhc_sels[] = { "pll3_main", "pll3_pfd3", "pll1_pfd3", "platform_bus", };
|
static const char *esdhc_sels[] = { "pll3_usb_otg", "pll3_pfd3", "pll1_pfd3", "platform_bus", };
|
||||||
static const char *dcu_sels[] = { "pll1_pfd2", "pll3_main", };
|
static const char *dcu_sels[] = { "pll1_pfd2", "pll3_usb_otg", };
|
||||||
static const char *gpu_sels[] = { "pll2_pfd2", "pll3_pfd2", };
|
static const char *gpu_sels[] = { "pll2_pfd2", "pll3_pfd2", };
|
||||||
static const char *vadc_sels[] = { "pll6_main_div", "pll3_main_div", "pll3_main", };
|
static const char *vadc_sels[] = { "pll6_video_div", "pll3_usb_otg_div", "pll3_usb_otg", };
|
||||||
/* FTM counter clock source, not module clock */
|
/* FTM counter clock source, not module clock */
|
||||||
static const char *ftm_ext_sels[] = {"sirc_128k", "sxosc", "fxosc_half", "audio_ext", };
|
static const char *ftm_ext_sels[] = {"sirc_128k", "sxosc", "fxosc_half", "audio_ext", };
|
||||||
static const char *ftm_fix_sels[] = { "sxosc", "ipg_bus", };
|
static const char *ftm_fix_sels[] = { "sxosc", "ipg_bus", };
|
||||||
|
|
||||||
static struct clk_div_table pll4_main_div_table[] = {
|
|
||||||
|
static struct clk_div_table pll4_audio_div_table[] = {
|
||||||
{ .val = 0, .div = 1 },
|
{ .val = 0, .div = 1 },
|
||||||
{ .val = 1, .div = 2 },
|
{ .val = 1, .div = 2 },
|
||||||
{ .val = 2, .div = 6 },
|
{ .val = 2, .div = 6 },
|
||||||
|
@ -120,6 +135,9 @@ static void __init vf610_clocks_init(struct device_node *ccm_node)
|
||||||
clk[VF610_CLK_AUDIO_EXT] = imx_obtain_fixed_clock("audio_ext", 0);
|
clk[VF610_CLK_AUDIO_EXT] = imx_obtain_fixed_clock("audio_ext", 0);
|
||||||
clk[VF610_CLK_ENET_EXT] = imx_obtain_fixed_clock("enet_ext", 0);
|
clk[VF610_CLK_ENET_EXT] = imx_obtain_fixed_clock("enet_ext", 0);
|
||||||
|
|
||||||
|
/* Clock source from external clock via LVDs PAD */
|
||||||
|
clk[VF610_CLK_ANACLK1] = imx_obtain_fixed_clock("anaclk1", 0);
|
||||||
|
|
||||||
clk[VF610_CLK_FXOSC_HALF] = imx_clk_fixed_factor("fxosc_half", "fxosc", 1, 2);
|
clk[VF610_CLK_FXOSC_HALF] = imx_clk_fixed_factor("fxosc_half", "fxosc", 1, 2);
|
||||||
|
|
||||||
np = of_find_compatible_node(NULL, NULL, "fsl,vf610-anatop");
|
np = of_find_compatible_node(NULL, NULL, "fsl,vf610-anatop");
|
||||||
|
@ -133,31 +151,63 @@ static void __init vf610_clocks_init(struct device_node *ccm_node)
|
||||||
clk[VF610_CLK_SLOW_CLK_SEL] = imx_clk_mux("slow_clk_sel", CCM_CCSR, 4, 1, slow_sels, ARRAY_SIZE(slow_sels));
|
clk[VF610_CLK_SLOW_CLK_SEL] = imx_clk_mux("slow_clk_sel", CCM_CCSR, 4, 1, slow_sels, ARRAY_SIZE(slow_sels));
|
||||||
clk[VF610_CLK_FASK_CLK_SEL] = imx_clk_mux("fast_clk_sel", CCM_CCSR, 5, 1, fast_sels, ARRAY_SIZE(fast_sels));
|
clk[VF610_CLK_FASK_CLK_SEL] = imx_clk_mux("fast_clk_sel", CCM_CCSR, 5, 1, fast_sels, ARRAY_SIZE(fast_sels));
|
||||||
|
|
||||||
clk[VF610_CLK_PLL1_MAIN] = imx_clk_fixed_factor("pll1_main", "fast_clk_sel", 22, 1);
|
clk[VF610_CLK_PLL1_BYPASS_SRC] = imx_clk_mux("pll1_bypass_src", PLL1_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
clk[VF610_CLK_PLL1_PFD1] = imx_clk_pfd("pll1_pfd1", "pll1_main", PFD_PLL1_BASE, 0);
|
clk[VF610_CLK_PLL2_BYPASS_SRC] = imx_clk_mux("pll2_bypass_src", PLL2_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
clk[VF610_CLK_PLL1_PFD2] = imx_clk_pfd("pll1_pfd2", "pll1_main", PFD_PLL1_BASE, 1);
|
clk[VF610_CLK_PLL3_BYPASS_SRC] = imx_clk_mux("pll3_bypass_src", PLL3_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
clk[VF610_CLK_PLL1_PFD3] = imx_clk_pfd("pll1_pfd3", "pll1_main", PFD_PLL1_BASE, 2);
|
clk[VF610_CLK_PLL4_BYPASS_SRC] = imx_clk_mux("pll4_bypass_src", PLL4_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
clk[VF610_CLK_PLL1_PFD4] = imx_clk_pfd("pll1_pfd4", "pll1_main", PFD_PLL1_BASE, 3);
|
clk[VF610_CLK_PLL5_BYPASS_SRC] = imx_clk_mux("pll5_bypass_src", PLL5_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
|
clk[VF610_CLK_PLL6_BYPASS_SRC] = imx_clk_mux("pll6_bypass_src", PLL6_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
|
clk[VF610_CLK_PLL7_BYPASS_SRC] = imx_clk_mux("pll7_bypass_src", PLL7_CTRL, 14, 1, pll_bypass_src_sels, ARRAY_SIZE(pll_bypass_src_sels));
|
||||||
|
|
||||||
clk[VF610_CLK_PLL2_MAIN] = imx_clk_fixed_factor("pll2_main", "fast_clk_sel", 22, 1);
|
clk[VF610_CLK_PLL1] = imx_clk_pllv3(IMX_PLLV3_GENERIC, "pll1", "pll1_bypass_src", PLL1_CTRL, 0x1);
|
||||||
clk[VF610_CLK_PLL2_PFD1] = imx_clk_pfd("pll2_pfd1", "pll2_main", PFD_PLL2_BASE, 0);
|
clk[VF610_CLK_PLL2] = imx_clk_pllv3(IMX_PLLV3_GENERIC, "pll2", "pll2_bypass_src", PLL2_CTRL, 0x1);
|
||||||
clk[VF610_CLK_PLL2_PFD2] = imx_clk_pfd("pll2_pfd2", "pll2_main", PFD_PLL2_BASE, 1);
|
clk[VF610_CLK_PLL3] = imx_clk_pllv3(IMX_PLLV3_USB, "pll3", "pll3_bypass_src", PLL3_CTRL, 0x1);
|
||||||
clk[VF610_CLK_PLL2_PFD3] = imx_clk_pfd("pll2_pfd3", "pll2_main", PFD_PLL2_BASE, 2);
|
clk[VF610_CLK_PLL4] = imx_clk_pllv3(IMX_PLLV3_AV, "pll4", "pll4_bypass_src", PLL4_CTRL, 0x7f);
|
||||||
clk[VF610_CLK_PLL2_PFD4] = imx_clk_pfd("pll2_pfd4", "pll2_main", PFD_PLL2_BASE, 3);
|
clk[VF610_CLK_PLL5] = imx_clk_pllv3(IMX_PLLV3_ENET, "pll5", "pll5_bypass_src", PLL5_CTRL, 0x3);
|
||||||
|
clk[VF610_CLK_PLL6] = imx_clk_pllv3(IMX_PLLV3_AV, "pll6", "pll6_bypass_src", PLL6_CTRL, 0x7f);
|
||||||
|
clk[VF610_CLK_PLL7] = imx_clk_pllv3(IMX_PLLV3_USB, "pll7", "pll7_bypass_src", PLL7_CTRL, 0x1);
|
||||||
|
|
||||||
clk[VF610_CLK_PLL3_MAIN] = imx_clk_fixed_factor("pll3_main", "fast_clk_sel", 20, 1);
|
clk[VF610_PLL1_BYPASS] = imx_clk_mux_flags("pll1_bypass", PLL1_CTRL, 16, 1, pll1_bypass_sels, ARRAY_SIZE(pll1_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
clk[VF610_CLK_PLL3_PFD1] = imx_clk_pfd("pll3_pfd1", "pll3_main", PFD_PLL3_BASE, 0);
|
clk[VF610_PLL2_BYPASS] = imx_clk_mux_flags("pll2_bypass", PLL2_CTRL, 16, 1, pll2_bypass_sels, ARRAY_SIZE(pll2_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
clk[VF610_CLK_PLL3_PFD2] = imx_clk_pfd("pll3_pfd2", "pll3_main", PFD_PLL3_BASE, 1);
|
clk[VF610_PLL3_BYPASS] = imx_clk_mux_flags("pll3_bypass", PLL3_CTRL, 16, 1, pll3_bypass_sels, ARRAY_SIZE(pll3_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
clk[VF610_CLK_PLL3_PFD3] = imx_clk_pfd("pll3_pfd3", "pll3_main", PFD_PLL3_BASE, 2);
|
clk[VF610_PLL4_BYPASS] = imx_clk_mux_flags("pll4_bypass", PLL4_CTRL, 16, 1, pll4_bypass_sels, ARRAY_SIZE(pll4_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
clk[VF610_CLK_PLL3_PFD4] = imx_clk_pfd("pll3_pfd4", "pll3_main", PFD_PLL3_BASE, 3);
|
clk[VF610_PLL5_BYPASS] = imx_clk_mux_flags("pll5_bypass", PLL5_CTRL, 16, 1, pll5_bypass_sels, ARRAY_SIZE(pll5_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
|
clk[VF610_PLL6_BYPASS] = imx_clk_mux_flags("pll6_bypass", PLL6_CTRL, 16, 1, pll6_bypass_sels, ARRAY_SIZE(pll6_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
|
clk[VF610_PLL7_BYPASS] = imx_clk_mux_flags("pll7_bypass", PLL7_CTRL, 16, 1, pll7_bypass_sels, ARRAY_SIZE(pll7_bypass_sels), CLK_SET_RATE_PARENT);
|
||||||
|
|
||||||
clk[VF610_CLK_PLL4_MAIN] = imx_clk_fixed_factor("pll4_main", "fast_clk_sel", 25, 1);
|
/* Do not bypass PLLs initially */
|
||||||
/* Enet pll: fixed 50Mhz */
|
clk_set_parent(clk[VF610_PLL1_BYPASS], clk[VF610_CLK_PLL1]);
|
||||||
clk[VF610_CLK_PLL5_MAIN] = imx_clk_fixed_factor("pll5_main", "fast_clk_sel", 125, 6);
|
clk_set_parent(clk[VF610_PLL2_BYPASS], clk[VF610_CLK_PLL2]);
|
||||||
/* pll6: default 960Mhz */
|
clk_set_parent(clk[VF610_PLL3_BYPASS], clk[VF610_CLK_PLL3]);
|
||||||
clk[VF610_CLK_PLL6_MAIN] = imx_clk_fixed_factor("pll6_main", "fast_clk_sel", 40, 1);
|
clk_set_parent(clk[VF610_PLL4_BYPASS], clk[VF610_CLK_PLL4]);
|
||||||
/* pll7: USB1 PLL at 480MHz */
|
clk_set_parent(clk[VF610_PLL5_BYPASS], clk[VF610_CLK_PLL5]);
|
||||||
clk[VF610_CLK_PLL7_MAIN] = imx_clk_pllv3(IMX_PLLV3_USB, "pll7_main", "fast_clk_sel", PLL7_CTRL, 0x2);
|
clk_set_parent(clk[VF610_PLL6_BYPASS], clk[VF610_CLK_PLL6]);
|
||||||
|
clk_set_parent(clk[VF610_PLL7_BYPASS], clk[VF610_CLK_PLL7]);
|
||||||
|
|
||||||
|
clk[VF610_CLK_PLL1_SYS] = imx_clk_gate("pll1_sys", "pll1_bypass", PLL1_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL2_BUS] = imx_clk_gate("pll2_bus", "pll2_bypass", PLL2_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL3_USB_OTG] = imx_clk_gate("pll3_usb_otg", "pll3_bypass", PLL3_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL4_AUDIO] = imx_clk_gate("pll4_audio", "pll4_bypass", PLL4_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL5_ENET] = imx_clk_gate("pll5_enet", "pll5_bypass", PLL5_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL6_VIDEO] = imx_clk_gate("pll6_video", "pll6_bypass", PLL6_CTRL, 13);
|
||||||
|
clk[VF610_CLK_PLL7_USB_HOST] = imx_clk_gate("pll7_usb_host", "pll7_bypass", PLL7_CTRL, 13);
|
||||||
|
|
||||||
|
clk[VF610_CLK_LVDS1_IN] = imx_clk_gate_exclusive("lvds1_in", "anaclk1", ANA_MISC1, 12, BIT(10));
|
||||||
|
|
||||||
|
clk[VF610_CLK_PLL1_PFD1] = imx_clk_pfd("pll1_pfd1", "pll1_sys", PFD_PLL1_BASE, 0);
|
||||||
|
clk[VF610_CLK_PLL1_PFD2] = imx_clk_pfd("pll1_pfd2", "pll1_sys", PFD_PLL1_BASE, 1);
|
||||||
|
clk[VF610_CLK_PLL1_PFD3] = imx_clk_pfd("pll1_pfd3", "pll1_sys", PFD_PLL1_BASE, 2);
|
||||||
|
clk[VF610_CLK_PLL1_PFD4] = imx_clk_pfd("pll1_pfd4", "pll1_sys", PFD_PLL1_BASE, 3);
|
||||||
|
|
||||||
|
clk[VF610_CLK_PLL2_PFD1] = imx_clk_pfd("pll2_pfd1", "pll2_bus", PFD_PLL2_BASE, 0);
|
||||||
|
clk[VF610_CLK_PLL2_PFD2] = imx_clk_pfd("pll2_pfd2", "pll2_bus", PFD_PLL2_BASE, 1);
|
||||||
|
clk[VF610_CLK_PLL2_PFD3] = imx_clk_pfd("pll2_pfd3", "pll2_bus", PFD_PLL2_BASE, 2);
|
||||||
|
clk[VF610_CLK_PLL2_PFD4] = imx_clk_pfd("pll2_pfd4", "pll2_bus", PFD_PLL2_BASE, 3);
|
||||||
|
|
||||||
|
clk[VF610_CLK_PLL3_PFD1] = imx_clk_pfd("pll3_pfd1", "pll3_usb_otg", PFD_PLL3_BASE, 0);
|
||||||
|
clk[VF610_CLK_PLL3_PFD2] = imx_clk_pfd("pll3_pfd2", "pll3_usb_otg", PFD_PLL3_BASE, 1);
|
||||||
|
clk[VF610_CLK_PLL3_PFD3] = imx_clk_pfd("pll3_pfd3", "pll3_usb_otg", PFD_PLL3_BASE, 2);
|
||||||
|
clk[VF610_CLK_PLL3_PFD4] = imx_clk_pfd("pll3_pfd4", "pll3_usb_otg", PFD_PLL3_BASE, 3);
|
||||||
|
|
||||||
clk[VF610_CLK_PLL1_PFD_SEL] = imx_clk_mux("pll1_pfd_sel", CCM_CCSR, 16, 3, pll1_sels, 5);
|
clk[VF610_CLK_PLL1_PFD_SEL] = imx_clk_mux("pll1_pfd_sel", CCM_CCSR, 16, 3, pll1_sels, 5);
|
||||||
clk[VF610_CLK_PLL2_PFD_SEL] = imx_clk_mux("pll2_pfd_sel", CCM_CCSR, 19, 3, pll2_sels, 5);
|
clk[VF610_CLK_PLL2_PFD_SEL] = imx_clk_mux("pll2_pfd_sel", CCM_CCSR, 19, 3, pll2_sels, 5);
|
||||||
|
@ -167,12 +217,12 @@ static void __init vf610_clocks_init(struct device_node *ccm_node)
|
||||||
clk[VF610_CLK_PLATFORM_BUS] = imx_clk_divider("platform_bus", "sys_bus", CCM_CACRR, 3, 3);
|
clk[VF610_CLK_PLATFORM_BUS] = imx_clk_divider("platform_bus", "sys_bus", CCM_CACRR, 3, 3);
|
||||||
clk[VF610_CLK_IPG_BUS] = imx_clk_divider("ipg_bus", "platform_bus", CCM_CACRR, 11, 2);
|
clk[VF610_CLK_IPG_BUS] = imx_clk_divider("ipg_bus", "platform_bus", CCM_CACRR, 11, 2);
|
||||||
|
|
||||||
clk[VF610_CLK_PLL3_MAIN_DIV] = imx_clk_divider("pll3_main_div", "pll3_main", CCM_CACRR, 20, 1);
|
clk[VF610_CLK_PLL3_MAIN_DIV] = imx_clk_divider("pll3_usb_otg_div", "pll3_usb_otg", CCM_CACRR, 20, 1);
|
||||||
clk[VF610_CLK_PLL4_MAIN_DIV] = clk_register_divider_table(NULL, "pll4_main_div", "pll4_main", 0, CCM_CACRR, 6, 3, 0, pll4_main_div_table, &imx_ccm_lock);
|
clk[VF610_CLK_PLL4_MAIN_DIV] = clk_register_divider_table(NULL, "pll4_audio_div", "pll4_audio", 0, CCM_CACRR, 6, 3, 0, pll4_audio_div_table, &imx_ccm_lock);
|
||||||
clk[VF610_CLK_PLL6_MAIN_DIV] = imx_clk_divider("pll6_main_div", "pll6_main", CCM_CACRR, 21, 1);
|
clk[VF610_CLK_PLL6_MAIN_DIV] = imx_clk_divider("pll6_video_div", "pll6_video", CCM_CACRR, 21, 1);
|
||||||
|
|
||||||
clk[VF610_CLK_USBPHY0] = imx_clk_gate("usbphy0", "pll3_main", PLL3_CTRL, 6);
|
clk[VF610_CLK_USBPHY0] = imx_clk_gate("usbphy0", "pll3_usb_otg", PLL3_CTRL, 6);
|
||||||
clk[VF610_CLK_USBPHY1] = imx_clk_gate("usbphy1", "pll7_main", PLL7_CTRL, 6);
|
clk[VF610_CLK_USBPHY1] = imx_clk_gate("usbphy1", "pll7_usb_host", PLL7_CTRL, 6);
|
||||||
|
|
||||||
clk[VF610_CLK_USBC0] = imx_clk_gate2("usbc0", "ipg_bus", CCM_CCGR1, CCM_CCGRx_CGn(4));
|
clk[VF610_CLK_USBC0] = imx_clk_gate2("usbc0", "ipg_bus", CCM_CCGR1, CCM_CCGRx_CGn(4));
|
||||||
clk[VF610_CLK_USBC1] = imx_clk_gate2("usbc1", "ipg_bus", CCM_CCGR7, CCM_CCGRx_CGn(4));
|
clk[VF610_CLK_USBC1] = imx_clk_gate2("usbc1", "ipg_bus", CCM_CCGR7, CCM_CCGRx_CGn(4));
|
||||||
|
@ -191,8 +241,8 @@ static void __init vf610_clocks_init(struct device_node *ccm_node)
|
||||||
clk[VF610_CLK_QSPI1_X1_DIV] = imx_clk_divider("qspi1_x1", "qspi1_x2", CCM_CSCDR3, 11, 1);
|
clk[VF610_CLK_QSPI1_X1_DIV] = imx_clk_divider("qspi1_x1", "qspi1_x2", CCM_CSCDR3, 11, 1);
|
||||||
clk[VF610_CLK_QSPI1] = imx_clk_gate2("qspi1", "qspi1_x1", CCM_CCGR8, CCM_CCGRx_CGn(4));
|
clk[VF610_CLK_QSPI1] = imx_clk_gate2("qspi1", "qspi1_x1", CCM_CCGR8, CCM_CCGRx_CGn(4));
|
||||||
|
|
||||||
clk[VF610_CLK_ENET_50M] = imx_clk_fixed_factor("enet_50m", "pll5_main", 1, 10);
|
clk[VF610_CLK_ENET_50M] = imx_clk_fixed_factor("enet_50m", "pll5_enet", 1, 10);
|
||||||
clk[VF610_CLK_ENET_25M] = imx_clk_fixed_factor("enet_25m", "pll5_main", 1, 20);
|
clk[VF610_CLK_ENET_25M] = imx_clk_fixed_factor("enet_25m", "pll5_enet", 1, 20);
|
||||||
clk[VF610_CLK_ENET_SEL] = imx_clk_mux("enet_sel", CCM_CSCMR2, 4, 2, rmii_sels, 4);
|
clk[VF610_CLK_ENET_SEL] = imx_clk_mux("enet_sel", CCM_CSCMR2, 4, 2, rmii_sels, 4);
|
||||||
clk[VF610_CLK_ENET_TS_SEL] = imx_clk_mux("enet_ts_sel", CCM_CSCMR2, 0, 3, enet_ts_sels, 7);
|
clk[VF610_CLK_ENET_TS_SEL] = imx_clk_mux("enet_ts_sel", CCM_CSCMR2, 0, 3, enet_ts_sels, 7);
|
||||||
clk[VF610_CLK_ENET] = imx_clk_gate("enet", "enet_sel", CCM_CSCDR1, 24);
|
clk[VF610_CLK_ENET] = imx_clk_gate("enet", "enet_sel", CCM_CSCDR1, 24);
|
||||||
|
|
|
@ -76,7 +76,7 @@ static inline void __indirect_writeb(u8 value, volatile void __iomem *p)
|
||||||
u32 n, byte_enables, data;
|
u32 n, byte_enables, data;
|
||||||
|
|
||||||
if (!is_pci_memory(addr)) {
|
if (!is_pci_memory(addr)) {
|
||||||
__raw_writeb(value, addr);
|
__raw_writeb(value, p);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -141,7 +141,7 @@ static inline unsigned char __indirect_readb(const volatile void __iomem *p)
|
||||||
u32 n, byte_enables, data;
|
u32 n, byte_enables, data;
|
||||||
|
|
||||||
if (!is_pci_memory(addr))
|
if (!is_pci_memory(addr))
|
||||||
return __raw_readb(addr);
|
return __raw_readb(p);
|
||||||
|
|
||||||
n = addr % 4;
|
n = addr % 4;
|
||||||
byte_enables = (0xf & ~BIT(n)) << IXP4XX_PCI_NP_CBE_BESL;
|
byte_enables = (0xf & ~BIT(n)) << IXP4XX_PCI_NP_CBE_BESL;
|
||||||
|
|
|
@ -917,6 +917,10 @@ static int __init omap_device_late_idle(struct device *dev, void *data)
|
||||||
static int __init omap_device_late_init(void)
|
static int __init omap_device_late_init(void)
|
||||||
{
|
{
|
||||||
bus_for_each_dev(&platform_bus_type, NULL, NULL, omap_device_late_idle);
|
bus_for_each_dev(&platform_bus_type, NULL, NULL, omap_device_late_idle);
|
||||||
|
|
||||||
|
WARN(!of_have_populated_dt(),
|
||||||
|
"legacy booting deprecated, please update to boot with .dts\n");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
omap_late_initcall_sync(omap_device_late_init);
|
omap_late_initcall_sync(omap_device_late_init);
|
||||||
|
|
|
@ -252,9 +252,6 @@ static void __init nokia_n900_legacy_init(void)
|
||||||
platform_device_register(&omap3_rom_rng_device);
|
platform_device_register(&omap3_rom_rng_device);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Only on some development boards */
|
|
||||||
gpio_request_one(164, GPIOF_OUT_INIT_LOW, "smc91x reset");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init omap3_tao3530_legacy_init(void)
|
static void __init omap3_tao3530_legacy_init(void)
|
||||||
|
|
|
@ -38,6 +38,11 @@
|
||||||
#define DMEMC_VIRT IOMEM(0xf6100000)
|
#define DMEMC_VIRT IOMEM(0xf6100000)
|
||||||
#define DMEMC_SIZE 0x00100000
|
#define DMEMC_SIZE 0x00100000
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Reserved space for low level debug virtual addresses within
|
||||||
|
* 0xf6200000..0xf6201000
|
||||||
|
*/
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Internal Memory Controller (PXA27x and later)
|
* Internal Memory Controller (PXA27x and later)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -956,7 +956,7 @@ static u32 cache_id_part_number_from_dt;
|
||||||
* @associativity: variable to return the calculated associativity in
|
* @associativity: variable to return the calculated associativity in
|
||||||
* @max_way_size: the maximum size in bytes for the cache ways
|
* @max_way_size: the maximum size in bytes for the cache ways
|
||||||
*/
|
*/
|
||||||
static void __init l2x0_cache_size_of_parse(const struct device_node *np,
|
static int __init l2x0_cache_size_of_parse(const struct device_node *np,
|
||||||
u32 *aux_val, u32 *aux_mask,
|
u32 *aux_val, u32 *aux_mask,
|
||||||
u32 *associativity,
|
u32 *associativity,
|
||||||
u32 max_way_size)
|
u32 max_way_size)
|
||||||
|
@ -974,7 +974,7 @@ static void __init l2x0_cache_size_of_parse(const struct device_node *np,
|
||||||
of_property_read_u32(np, "cache-line-size", &line_size);
|
of_property_read_u32(np, "cache-line-size", &line_size);
|
||||||
|
|
||||||
if (!cache_size || !sets)
|
if (!cache_size || !sets)
|
||||||
return;
|
return -ENODEV;
|
||||||
|
|
||||||
/* All these l2 caches have the same line = block size actually */
|
/* All these l2 caches have the same line = block size actually */
|
||||||
if (!line_size) {
|
if (!line_size) {
|
||||||
|
@ -1009,7 +1009,7 @@ static void __init l2x0_cache_size_of_parse(const struct device_node *np,
|
||||||
|
|
||||||
if (way_size > max_way_size) {
|
if (way_size > max_way_size) {
|
||||||
pr_err("L2C OF: set size %dKB is too large\n", way_size);
|
pr_err("L2C OF: set size %dKB is too large\n", way_size);
|
||||||
return;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr_info("L2C OF: override cache size: %d bytes (%dKB)\n",
|
pr_info("L2C OF: override cache size: %d bytes (%dKB)\n",
|
||||||
|
@ -1027,7 +1027,7 @@ static void __init l2x0_cache_size_of_parse(const struct device_node *np,
|
||||||
if (way_size_bits < 1 || way_size_bits > 6) {
|
if (way_size_bits < 1 || way_size_bits > 6) {
|
||||||
pr_err("L2C OF: cache way size illegal: %dKB is not mapped\n",
|
pr_err("L2C OF: cache way size illegal: %dKB is not mapped\n",
|
||||||
way_size);
|
way_size);
|
||||||
return;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
mask |= L2C_AUX_CTRL_WAY_SIZE_MASK;
|
mask |= L2C_AUX_CTRL_WAY_SIZE_MASK;
|
||||||
|
@ -1036,6 +1036,8 @@ static void __init l2x0_cache_size_of_parse(const struct device_node *np,
|
||||||
*aux_val &= ~mask;
|
*aux_val &= ~mask;
|
||||||
*aux_val |= val;
|
*aux_val |= val;
|
||||||
*aux_mask &= ~mask;
|
*aux_mask &= ~mask;
|
||||||
|
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __init l2x0_of_parse(const struct device_node *np,
|
static void __init l2x0_of_parse(const struct device_node *np,
|
||||||
|
@ -1046,6 +1048,7 @@ static void __init l2x0_of_parse(const struct device_node *np,
|
||||||
u32 dirty = 0;
|
u32 dirty = 0;
|
||||||
u32 val = 0, mask = 0;
|
u32 val = 0, mask = 0;
|
||||||
u32 assoc;
|
u32 assoc;
|
||||||
|
int ret;
|
||||||
|
|
||||||
of_property_read_u32(np, "arm,tag-latency", &tag);
|
of_property_read_u32(np, "arm,tag-latency", &tag);
|
||||||
if (tag) {
|
if (tag) {
|
||||||
|
@ -1068,7 +1071,10 @@ static void __init l2x0_of_parse(const struct device_node *np,
|
||||||
val |= (dirty - 1) << L2X0_AUX_CTRL_DIRTY_LATENCY_SHIFT;
|
val |= (dirty - 1) << L2X0_AUX_CTRL_DIRTY_LATENCY_SHIFT;
|
||||||
}
|
}
|
||||||
|
|
||||||
l2x0_cache_size_of_parse(np, aux_val, aux_mask, &assoc, SZ_256K);
|
ret = l2x0_cache_size_of_parse(np, aux_val, aux_mask, &assoc, SZ_256K);
|
||||||
|
if (ret)
|
||||||
|
return;
|
||||||
|
|
||||||
if (assoc > 8) {
|
if (assoc > 8) {
|
||||||
pr_err("l2x0 of: cache setting yield too high associativity\n");
|
pr_err("l2x0 of: cache setting yield too high associativity\n");
|
||||||
pr_err("l2x0 of: %d calculated, max 8\n", assoc);
|
pr_err("l2x0 of: %d calculated, max 8\n", assoc);
|
||||||
|
@ -1125,6 +1131,7 @@ static void __init l2c310_of_parse(const struct device_node *np,
|
||||||
u32 tag[3] = { 0, 0, 0 };
|
u32 tag[3] = { 0, 0, 0 };
|
||||||
u32 filter[2] = { 0, 0 };
|
u32 filter[2] = { 0, 0 };
|
||||||
u32 assoc;
|
u32 assoc;
|
||||||
|
int ret;
|
||||||
|
|
||||||
of_property_read_u32_array(np, "arm,tag-latency", tag, ARRAY_SIZE(tag));
|
of_property_read_u32_array(np, "arm,tag-latency", tag, ARRAY_SIZE(tag));
|
||||||
if (tag[0] && tag[1] && tag[2])
|
if (tag[0] && tag[1] && tag[2])
|
||||||
|
@ -1152,7 +1159,10 @@ static void __init l2c310_of_parse(const struct device_node *np,
|
||||||
l2x0_base + L310_ADDR_FILTER_START);
|
l2x0_base + L310_ADDR_FILTER_START);
|
||||||
}
|
}
|
||||||
|
|
||||||
l2x0_cache_size_of_parse(np, aux_val, aux_mask, &assoc, SZ_512K);
|
ret = l2x0_cache_size_of_parse(np, aux_val, aux_mask, &assoc, SZ_512K);
|
||||||
|
if (ret)
|
||||||
|
return;
|
||||||
|
|
||||||
switch (assoc) {
|
switch (assoc) {
|
||||||
case 16:
|
case 16:
|
||||||
*aux_val &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
*aux_val &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
@ -1164,8 +1174,8 @@ static void __init l2c310_of_parse(const struct device_node *np,
|
||||||
*aux_mask &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
*aux_mask &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
pr_err("PL310 OF: cache setting yield illegal associativity\n");
|
pr_err("L2C-310 OF cache associativity %d invalid, only 8 or 16 permitted\n",
|
||||||
pr_err("PL310 OF: %d calculated, only 8 and 16 legal\n", assoc);
|
assoc);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1198,7 +1198,6 @@ __iommu_alloc_remap(struct page **pages, size_t size, gfp_t gfp, pgprot_t prot,
|
||||||
{
|
{
|
||||||
return dma_common_pages_remap(pages, size,
|
return dma_common_pages_remap(pages, size,
|
||||||
VM_ARM_DMA_CONSISTENT | VM_USERMAP, prot, caller);
|
VM_ARM_DMA_CONSISTENT | VM_USERMAP, prot, caller);
|
||||||
return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -127,8 +127,11 @@ void *kmap_atomic_pfn(unsigned long pfn)
|
||||||
{
|
{
|
||||||
unsigned long vaddr;
|
unsigned long vaddr;
|
||||||
int idx, type;
|
int idx, type;
|
||||||
|
struct page *page = pfn_to_page(pfn);
|
||||||
|
|
||||||
pagefault_disable();
|
pagefault_disable();
|
||||||
|
if (!PageHighMem(page))
|
||||||
|
return page_address(page);
|
||||||
|
|
||||||
type = kmap_atomic_idx_push();
|
type = kmap_atomic_idx_push();
|
||||||
idx = type + KM_TYPE_NR * smp_processor_id();
|
idx = type + KM_TYPE_NR * smp_processor_id();
|
||||||
|
|
|
@ -559,10 +559,10 @@ void __init mem_init(void)
|
||||||
#ifdef CONFIG_MODULES
|
#ifdef CONFIG_MODULES
|
||||||
" modules : 0x%08lx - 0x%08lx (%4ld MB)\n"
|
" modules : 0x%08lx - 0x%08lx (%4ld MB)\n"
|
||||||
#endif
|
#endif
|
||||||
" .text : 0x%p" " - 0x%p" " (%4d kB)\n"
|
" .text : 0x%p" " - 0x%p" " (%4td kB)\n"
|
||||||
" .init : 0x%p" " - 0x%p" " (%4d kB)\n"
|
" .init : 0x%p" " - 0x%p" " (%4td kB)\n"
|
||||||
" .data : 0x%p" " - 0x%p" " (%4d kB)\n"
|
" .data : 0x%p" " - 0x%p" " (%4td kB)\n"
|
||||||
" .bss : 0x%p" " - 0x%p" " (%4d kB)\n",
|
" .bss : 0x%p" " - 0x%p" " (%4td kB)\n",
|
||||||
|
|
||||||
MLK(UL(CONFIG_VECTORS_BASE), UL(CONFIG_VECTORS_BASE) +
|
MLK(UL(CONFIG_VECTORS_BASE), UL(CONFIG_VECTORS_BASE) +
|
||||||
(PAGE_SIZE)),
|
(PAGE_SIZE)),
|
||||||
|
|
|
@ -35,6 +35,9 @@ CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_ARCH_THUNDER=y
|
CONFIG_ARCH_THUNDER=y
|
||||||
CONFIG_ARCH_VEXPRESS=y
|
CONFIG_ARCH_VEXPRESS=y
|
||||||
CONFIG_ARCH_XGENE=y
|
CONFIG_ARCH_XGENE=y
|
||||||
|
CONFIG_PCI=y
|
||||||
|
CONFIG_PCI_MSI=y
|
||||||
|
CONFIG_PCI_XGENE=y
|
||||||
CONFIG_SMP=y
|
CONFIG_SMP=y
|
||||||
CONFIG_PREEMPT=y
|
CONFIG_PREEMPT=y
|
||||||
CONFIG_KSM=y
|
CONFIG_KSM=y
|
||||||
|
@ -52,6 +55,7 @@ CONFIG_IP_PNP_DHCP=y
|
||||||
CONFIG_IP_PNP_BOOTP=y
|
CONFIG_IP_PNP_BOOTP=y
|
||||||
# CONFIG_INET_LRO is not set
|
# CONFIG_INET_LRO is not set
|
||||||
# CONFIG_IPV6 is not set
|
# CONFIG_IPV6 is not set
|
||||||
|
CONFIG_BPF_JIT=y
|
||||||
# CONFIG_WIRELESS is not set
|
# CONFIG_WIRELESS is not set
|
||||||
CONFIG_NET_9P=y
|
CONFIG_NET_9P=y
|
||||||
CONFIG_NET_9P_VIRTIO=y
|
CONFIG_NET_9P_VIRTIO=y
|
||||||
|
@ -65,16 +69,17 @@ CONFIG_VIRTIO_BLK=y
|
||||||
CONFIG_BLK_DEV_SD=y
|
CONFIG_BLK_DEV_SD=y
|
||||||
# CONFIG_SCSI_LOWLEVEL is not set
|
# CONFIG_SCSI_LOWLEVEL is not set
|
||||||
CONFIG_ATA=y
|
CONFIG_ATA=y
|
||||||
|
CONFIG_SATA_AHCI=y
|
||||||
|
CONFIG_SATA_AHCI_PLATFORM=y
|
||||||
CONFIG_AHCI_XGENE=y
|
CONFIG_AHCI_XGENE=y
|
||||||
CONFIG_PHY_XGENE=y
|
|
||||||
CONFIG_PATA_PLATFORM=y
|
CONFIG_PATA_PLATFORM=y
|
||||||
CONFIG_PATA_OF_PLATFORM=y
|
CONFIG_PATA_OF_PLATFORM=y
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_TUN=y
|
CONFIG_TUN=y
|
||||||
CONFIG_VIRTIO_NET=y
|
CONFIG_VIRTIO_NET=y
|
||||||
|
CONFIG_NET_XGENE=y
|
||||||
CONFIG_SMC91X=y
|
CONFIG_SMC91X=y
|
||||||
CONFIG_SMSC911X=y
|
CONFIG_SMSC911X=y
|
||||||
CONFIG_NET_XGENE=y
|
|
||||||
# CONFIG_WLAN is not set
|
# CONFIG_WLAN is not set
|
||||||
CONFIG_INPUT_EVDEV=y
|
CONFIG_INPUT_EVDEV=y
|
||||||
# CONFIG_SERIO_SERPORT is not set
|
# CONFIG_SERIO_SERPORT is not set
|
||||||
|
@ -87,6 +92,11 @@ CONFIG_SERIAL_AMBA_PL011_CONSOLE=y
|
||||||
CONFIG_SERIAL_OF_PLATFORM=y
|
CONFIG_SERIAL_OF_PLATFORM=y
|
||||||
CONFIG_VIRTIO_CONSOLE=y
|
CONFIG_VIRTIO_CONSOLE=y
|
||||||
# CONFIG_HW_RANDOM is not set
|
# CONFIG_HW_RANDOM is not set
|
||||||
|
# CONFIG_HMC_DRV is not set
|
||||||
|
CONFIG_SPI=y
|
||||||
|
CONFIG_SPI_PL022=y
|
||||||
|
CONFIG_GPIO_PL061=y
|
||||||
|
CONFIG_GPIO_XGENE=y
|
||||||
# CONFIG_HWMON is not set
|
# CONFIG_HWMON is not set
|
||||||
CONFIG_REGULATOR=y
|
CONFIG_REGULATOR=y
|
||||||
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
CONFIG_REGULATOR_FIXED_VOLTAGE=y
|
||||||
|
@ -97,13 +107,25 @@ CONFIG_LOGO=y
|
||||||
# CONFIG_LOGO_LINUX_MONO is not set
|
# CONFIG_LOGO_LINUX_MONO is not set
|
||||||
# CONFIG_LOGO_LINUX_VGA16 is not set
|
# CONFIG_LOGO_LINUX_VGA16 is not set
|
||||||
CONFIG_USB=y
|
CONFIG_USB=y
|
||||||
|
CONFIG_USB_EHCI_HCD=y
|
||||||
|
CONFIG_USB_EHCI_HCD_PLATFORM=y
|
||||||
CONFIG_USB_ISP1760_HCD=y
|
CONFIG_USB_ISP1760_HCD=y
|
||||||
|
CONFIG_USB_OHCI_HCD=y
|
||||||
|
CONFIG_USB_OHCI_HCD_PLATFORM=y
|
||||||
CONFIG_USB_STORAGE=y
|
CONFIG_USB_STORAGE=y
|
||||||
|
CONFIG_USB_ULPI=y
|
||||||
CONFIG_MMC=y
|
CONFIG_MMC=y
|
||||||
CONFIG_MMC_ARMMMCI=y
|
CONFIG_MMC_ARMMMCI=y
|
||||||
|
CONFIG_MMC_SDHCI=y
|
||||||
|
CONFIG_MMC_SDHCI_PLTFM=y
|
||||||
|
CONFIG_MMC_SPI=y
|
||||||
|
CONFIG_RTC_CLASS=y
|
||||||
|
CONFIG_RTC_DRV_EFI=y
|
||||||
|
CONFIG_RTC_DRV_XGENE=y
|
||||||
CONFIG_VIRTIO_BALLOON=y
|
CONFIG_VIRTIO_BALLOON=y
|
||||||
CONFIG_VIRTIO_MMIO=y
|
CONFIG_VIRTIO_MMIO=y
|
||||||
# CONFIG_IOMMU_SUPPORT is not set
|
# CONFIG_IOMMU_SUPPORT is not set
|
||||||
|
CONFIG_PHY_XGENE=y
|
||||||
CONFIG_EXT2_FS=y
|
CONFIG_EXT2_FS=y
|
||||||
CONFIG_EXT3_FS=y
|
CONFIG_EXT3_FS=y
|
||||||
# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
|
# CONFIG_EXT3_DEFAULTS_TO_ORDERED is not set
|
||||||
|
|
|
@ -792,3 +792,5 @@ __SYSCALL(__NR_renameat2, sys_renameat2)
|
||||||
__SYSCALL(__NR_getrandom, sys_getrandom)
|
__SYSCALL(__NR_getrandom, sys_getrandom)
|
||||||
#define __NR_memfd_create 385
|
#define __NR_memfd_create 385
|
||||||
__SYSCALL(__NR_memfd_create, sys_memfd_create)
|
__SYSCALL(__NR_memfd_create, sys_memfd_create)
|
||||||
|
#define __NR_bpf 386
|
||||||
|
__SYSCALL(__NR_bpf, sys_bpf)
|
||||||
|
|
|
@ -528,7 +528,7 @@ static int __maybe_unused cpu_psci_cpu_suspend(unsigned long index)
|
||||||
if (WARN_ON_ONCE(!index))
|
if (WARN_ON_ONCE(!index))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (state->type == PSCI_POWER_STATE_TYPE_STANDBY)
|
if (state[index - 1].type == PSCI_POWER_STATE_TYPE_STANDBY)
|
||||||
ret = psci_ops.cpu_suspend(state[index - 1], 0);
|
ret = psci_ops.cpu_suspend(state[index - 1], 0);
|
||||||
else
|
else
|
||||||
ret = __cpu_suspend(index, psci_suspend_finisher);
|
ret = __cpu_suspend(index, psci_suspend_finisher);
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
#include <uapi/asm/unistd.h>
|
#include <uapi/asm/unistd.h>
|
||||||
|
|
||||||
|
|
||||||
#define NR_syscalls 354
|
#define NR_syscalls 355
|
||||||
|
|
||||||
#define __ARCH_WANT_OLD_READDIR
|
#define __ARCH_WANT_OLD_READDIR
|
||||||
#define __ARCH_WANT_OLD_STAT
|
#define __ARCH_WANT_OLD_STAT
|
||||||
|
|
|
@ -359,5 +359,6 @@
|
||||||
#define __NR_renameat2 351
|
#define __NR_renameat2 351
|
||||||
#define __NR_getrandom 352
|
#define __NR_getrandom 352
|
||||||
#define __NR_memfd_create 353
|
#define __NR_memfd_create 353
|
||||||
|
#define __NR_bpf 354
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_M68K_UNISTD_H_ */
|
#endif /* _UAPI_ASM_M68K_UNISTD_H_ */
|
||||||
|
|
|
@ -374,4 +374,5 @@ ENTRY(sys_call_table)
|
||||||
.long sys_renameat2
|
.long sys_renameat2
|
||||||
.long sys_getrandom
|
.long sys_getrandom
|
||||||
.long sys_memfd_create
|
.long sys_memfd_create
|
||||||
|
.long sys_bpf
|
||||||
|
|
||||||
|
|
|
@ -129,6 +129,10 @@ endmenu
|
||||||
|
|
||||||
menu "Kernel features"
|
menu "Kernel features"
|
||||||
|
|
||||||
|
config NR_CPUS
|
||||||
|
int
|
||||||
|
default "1"
|
||||||
|
|
||||||
config ADVANCED_OPTIONS
|
config ADVANCED_OPTIONS
|
||||||
bool "Prompt for advanced kernel configuration options"
|
bool "Prompt for advanced kernel configuration options"
|
||||||
help
|
help
|
||||||
|
|
|
@ -38,6 +38,6 @@
|
||||||
|
|
||||||
#endif /* __ASSEMBLY__ */
|
#endif /* __ASSEMBLY__ */
|
||||||
|
|
||||||
#define __NR_syscalls 387
|
#define __NR_syscalls 388
|
||||||
|
|
||||||
#endif /* _ASM_MICROBLAZE_UNISTD_H */
|
#endif /* _ASM_MICROBLAZE_UNISTD_H */
|
||||||
|
|
|
@ -402,5 +402,6 @@
|
||||||
#define __NR_seccomp 384
|
#define __NR_seccomp 384
|
||||||
#define __NR_getrandom 385
|
#define __NR_getrandom 385
|
||||||
#define __NR_memfd_create 386
|
#define __NR_memfd_create 386
|
||||||
|
#define __NR_bpf 387
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_MICROBLAZE_UNISTD_H */
|
#endif /* _UAPI_ASM_MICROBLAZE_UNISTD_H */
|
||||||
|
|
|
@ -387,3 +387,4 @@ ENTRY(sys_call_table)
|
||||||
.long sys_seccomp
|
.long sys_seccomp
|
||||||
.long sys_getrandom /* 385 */
|
.long sys_getrandom /* 385 */
|
||||||
.long sys_memfd_create
|
.long sys_memfd_create
|
||||||
|
.long sys_bpf
|
||||||
|
|
|
@ -660,8 +660,13 @@ void pci_process_bridge_OF_ranges(struct pci_controller *hose,
|
||||||
res = &hose->mem_resources[memno++];
|
res = &hose->mem_resources[memno++];
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (res != NULL)
|
if (res != NULL) {
|
||||||
of_pci_range_to_resource(&range, dev, res);
|
res->name = dev->full_name;
|
||||||
|
res->flags = range.flags;
|
||||||
|
res->start = range.cpu_addr;
|
||||||
|
res->end = range.cpu_addr + range.size - 1;
|
||||||
|
res->parent = res->child = res->sibling = NULL;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* If there's an ISA hole and the pci_mem_offset is -not- matching
|
/* If there's an ISA hole and the pci_mem_offset is -not- matching
|
||||||
|
|
|
@ -93,6 +93,15 @@ LDFLAGS_vmlinux += -G 0 -static -n -nostdlib
|
||||||
KBUILD_AFLAGS_MODULE += -mlong-calls
|
KBUILD_AFLAGS_MODULE += -mlong-calls
|
||||||
KBUILD_CFLAGS_MODULE += -mlong-calls
|
KBUILD_CFLAGS_MODULE += -mlong-calls
|
||||||
|
|
||||||
|
#
|
||||||
|
# pass -msoft-float to GAS if it supports it. However on newer binutils
|
||||||
|
# (specifically newer than 2.24.51.20140728) we then also need to explicitly
|
||||||
|
# set ".set hardfloat" in all files which manipulate floating point registers.
|
||||||
|
#
|
||||||
|
ifneq ($(call as-option,-Wa$(comma)-msoft-float,),)
|
||||||
|
cflags-y += -DGAS_HAS_SET_HARDFLOAT -Wa,-msoft-float
|
||||||
|
endif
|
||||||
|
|
||||||
cflags-y += -ffreestanding
|
cflags-y += -ffreestanding
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
|
@ -809,6 +809,7 @@ static struct irq_chip octeon_irq_chip_ciu_gpio_v2 = {
|
||||||
.irq_set_type = octeon_irq_ciu_gpio_set_type,
|
.irq_set_type = octeon_irq_ciu_gpio_set_type,
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
.irq_set_affinity = octeon_irq_ciu_set_affinity_v2,
|
.irq_set_affinity = octeon_irq_ciu_set_affinity_v2,
|
||||||
|
.irq_cpu_offline = octeon_irq_cpu_offline_ciu,
|
||||||
#endif
|
#endif
|
||||||
.flags = IRQCHIP_SET_TYPE_MASKED,
|
.flags = IRQCHIP_SET_TYPE_MASKED,
|
||||||
};
|
};
|
||||||
|
@ -823,6 +824,7 @@ static struct irq_chip octeon_irq_chip_ciu_gpio = {
|
||||||
.irq_set_type = octeon_irq_ciu_gpio_set_type,
|
.irq_set_type = octeon_irq_ciu_gpio_set_type,
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
.irq_set_affinity = octeon_irq_ciu_set_affinity,
|
.irq_set_affinity = octeon_irq_ciu_set_affinity,
|
||||||
|
.irq_cpu_offline = octeon_irq_cpu_offline_ciu,
|
||||||
#endif
|
#endif
|
||||||
.flags = IRQCHIP_SET_TYPE_MASKED,
|
.flags = IRQCHIP_SET_TYPE_MASKED,
|
||||||
};
|
};
|
||||||
|
|
|
@ -13,6 +13,8 @@
|
||||||
#include <asm/mipsregs.h>
|
#include <asm/mipsregs.h>
|
||||||
|
|
||||||
.macro fpu_save_single thread tmp=t0
|
.macro fpu_save_single thread tmp=t0
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 \tmp, fcr31
|
cfc1 \tmp, fcr31
|
||||||
swc1 $f0, THREAD_FPR0_LS64(\thread)
|
swc1 $f0, THREAD_FPR0_LS64(\thread)
|
||||||
swc1 $f1, THREAD_FPR1_LS64(\thread)
|
swc1 $f1, THREAD_FPR1_LS64(\thread)
|
||||||
|
@ -47,9 +49,12 @@
|
||||||
swc1 $f30, THREAD_FPR30_LS64(\thread)
|
swc1 $f30, THREAD_FPR30_LS64(\thread)
|
||||||
swc1 $f31, THREAD_FPR31_LS64(\thread)
|
swc1 $f31, THREAD_FPR31_LS64(\thread)
|
||||||
sw \tmp, THREAD_FCR31(\thread)
|
sw \tmp, THREAD_FCR31(\thread)
|
||||||
|
.set pop
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro fpu_restore_single thread tmp=t0
|
.macro fpu_restore_single thread tmp=t0
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
lw \tmp, THREAD_FCR31(\thread)
|
lw \tmp, THREAD_FCR31(\thread)
|
||||||
lwc1 $f0, THREAD_FPR0_LS64(\thread)
|
lwc1 $f0, THREAD_FPR0_LS64(\thread)
|
||||||
lwc1 $f1, THREAD_FPR1_LS64(\thread)
|
lwc1 $f1, THREAD_FPR1_LS64(\thread)
|
||||||
|
@ -84,6 +89,7 @@
|
||||||
lwc1 $f30, THREAD_FPR30_LS64(\thread)
|
lwc1 $f30, THREAD_FPR30_LS64(\thread)
|
||||||
lwc1 $f31, THREAD_FPR31_LS64(\thread)
|
lwc1 $f31, THREAD_FPR31_LS64(\thread)
|
||||||
ctc1 \tmp, fcr31
|
ctc1 \tmp, fcr31
|
||||||
|
.set pop
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro cpu_save_nonscratch thread
|
.macro cpu_save_nonscratch thread
|
||||||
|
|
|
@ -57,6 +57,8 @@
|
||||||
#endif /* CONFIG_CPU_MIPSR2 */
|
#endif /* CONFIG_CPU_MIPSR2 */
|
||||||
|
|
||||||
.macro fpu_save_16even thread tmp=t0
|
.macro fpu_save_16even thread tmp=t0
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 \tmp, fcr31
|
cfc1 \tmp, fcr31
|
||||||
sdc1 $f0, THREAD_FPR0_LS64(\thread)
|
sdc1 $f0, THREAD_FPR0_LS64(\thread)
|
||||||
sdc1 $f2, THREAD_FPR2_LS64(\thread)
|
sdc1 $f2, THREAD_FPR2_LS64(\thread)
|
||||||
|
@ -75,11 +77,13 @@
|
||||||
sdc1 $f28, THREAD_FPR28_LS64(\thread)
|
sdc1 $f28, THREAD_FPR28_LS64(\thread)
|
||||||
sdc1 $f30, THREAD_FPR30_LS64(\thread)
|
sdc1 $f30, THREAD_FPR30_LS64(\thread)
|
||||||
sw \tmp, THREAD_FCR31(\thread)
|
sw \tmp, THREAD_FCR31(\thread)
|
||||||
|
.set pop
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro fpu_save_16odd thread
|
.macro fpu_save_16odd thread
|
||||||
.set push
|
.set push
|
||||||
.set mips64r2
|
.set mips64r2
|
||||||
|
SET_HARDFLOAT
|
||||||
sdc1 $f1, THREAD_FPR1_LS64(\thread)
|
sdc1 $f1, THREAD_FPR1_LS64(\thread)
|
||||||
sdc1 $f3, THREAD_FPR3_LS64(\thread)
|
sdc1 $f3, THREAD_FPR3_LS64(\thread)
|
||||||
sdc1 $f5, THREAD_FPR5_LS64(\thread)
|
sdc1 $f5, THREAD_FPR5_LS64(\thread)
|
||||||
|
@ -110,6 +114,8 @@
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro fpu_restore_16even thread tmp=t0
|
.macro fpu_restore_16even thread tmp=t0
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
lw \tmp, THREAD_FCR31(\thread)
|
lw \tmp, THREAD_FCR31(\thread)
|
||||||
ldc1 $f0, THREAD_FPR0_LS64(\thread)
|
ldc1 $f0, THREAD_FPR0_LS64(\thread)
|
||||||
ldc1 $f2, THREAD_FPR2_LS64(\thread)
|
ldc1 $f2, THREAD_FPR2_LS64(\thread)
|
||||||
|
@ -133,6 +139,7 @@
|
||||||
.macro fpu_restore_16odd thread
|
.macro fpu_restore_16odd thread
|
||||||
.set push
|
.set push
|
||||||
.set mips64r2
|
.set mips64r2
|
||||||
|
SET_HARDFLOAT
|
||||||
ldc1 $f1, THREAD_FPR1_LS64(\thread)
|
ldc1 $f1, THREAD_FPR1_LS64(\thread)
|
||||||
ldc1 $f3, THREAD_FPR3_LS64(\thread)
|
ldc1 $f3, THREAD_FPR3_LS64(\thread)
|
||||||
ldc1 $f5, THREAD_FPR5_LS64(\thread)
|
ldc1 $f5, THREAD_FPR5_LS64(\thread)
|
||||||
|
@ -277,6 +284,7 @@
|
||||||
.macro cfcmsa rd, cs
|
.macro cfcmsa rd, cs
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
.insn
|
.insn
|
||||||
.word CFC_MSA_INSN | (\cs << 11)
|
.word CFC_MSA_INSN | (\cs << 11)
|
||||||
move \rd, $1
|
move \rd, $1
|
||||||
|
@ -286,6 +294,7 @@
|
||||||
.macro ctcmsa cd, rs
|
.macro ctcmsa cd, rs
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
move $1, \rs
|
move $1, \rs
|
||||||
.word CTC_MSA_INSN | (\cd << 6)
|
.word CTC_MSA_INSN | (\cd << 6)
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -294,6 +303,7 @@
|
||||||
.macro ld_d wd, off, base
|
.macro ld_d wd, off, base
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
add $1, \base, \off
|
add $1, \base, \off
|
||||||
.word LDD_MSA_INSN | (\wd << 6)
|
.word LDD_MSA_INSN | (\wd << 6)
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -302,6 +312,7 @@
|
||||||
.macro st_d wd, off, base
|
.macro st_d wd, off, base
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
add $1, \base, \off
|
add $1, \base, \off
|
||||||
.word STD_MSA_INSN | (\wd << 6)
|
.word STD_MSA_INSN | (\wd << 6)
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -310,6 +321,7 @@
|
||||||
.macro copy_u_w rd, ws, n
|
.macro copy_u_w rd, ws, n
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
.insn
|
.insn
|
||||||
.word COPY_UW_MSA_INSN | (\n << 16) | (\ws << 11)
|
.word COPY_UW_MSA_INSN | (\n << 16) | (\ws << 11)
|
||||||
/* move triggers an assembler bug... */
|
/* move triggers an assembler bug... */
|
||||||
|
@ -320,6 +332,7 @@
|
||||||
.macro copy_u_d rd, ws, n
|
.macro copy_u_d rd, ws, n
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
.insn
|
.insn
|
||||||
.word COPY_UD_MSA_INSN | (\n << 16) | (\ws << 11)
|
.word COPY_UD_MSA_INSN | (\n << 16) | (\ws << 11)
|
||||||
/* move triggers an assembler bug... */
|
/* move triggers an assembler bug... */
|
||||||
|
@ -330,6 +343,7 @@
|
||||||
.macro insert_w wd, n, rs
|
.macro insert_w wd, n, rs
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
/* move triggers an assembler bug... */
|
/* move triggers an assembler bug... */
|
||||||
or $1, \rs, zero
|
or $1, \rs, zero
|
||||||
.word INSERT_W_MSA_INSN | (\n << 16) | (\wd << 6)
|
.word INSERT_W_MSA_INSN | (\n << 16) | (\wd << 6)
|
||||||
|
@ -339,6 +353,7 @@
|
||||||
.macro insert_d wd, n, rs
|
.macro insert_d wd, n, rs
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
/* move triggers an assembler bug... */
|
/* move triggers an assembler bug... */
|
||||||
or $1, \rs, zero
|
or $1, \rs, zero
|
||||||
.word INSERT_D_MSA_INSN | (\n << 16) | (\wd << 6)
|
.word INSERT_D_MSA_INSN | (\n << 16) | (\wd << 6)
|
||||||
|
@ -381,6 +396,7 @@
|
||||||
st_d 31, THREAD_FPR31, \thread
|
st_d 31, THREAD_FPR31, \thread
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
cfcmsa $1, MSA_CSR
|
cfcmsa $1, MSA_CSR
|
||||||
sw $1, THREAD_MSA_CSR(\thread)
|
sw $1, THREAD_MSA_CSR(\thread)
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -389,6 +405,7 @@
|
||||||
.macro msa_restore_all thread
|
.macro msa_restore_all thread
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
lw $1, THREAD_MSA_CSR(\thread)
|
lw $1, THREAD_MSA_CSR(\thread)
|
||||||
ctcmsa MSA_CSR, $1
|
ctcmsa MSA_CSR, $1
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -441,6 +458,7 @@
|
||||||
.macro msa_init_all_upper
|
.macro msa_init_all_upper
|
||||||
.set push
|
.set push
|
||||||
.set noat
|
.set noat
|
||||||
|
SET_HARDFLOAT
|
||||||
not $1, zero
|
not $1, zero
|
||||||
msa_init_upper 0
|
msa_init_upper 0
|
||||||
.set pop
|
.set pop
|
||||||
|
|
|
@ -14,6 +14,20 @@
|
||||||
|
|
||||||
#include <asm/sgidefs.h>
|
#include <asm/sgidefs.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* starting with binutils 2.24.51.20140729, MIPS binutils warn about mixing
|
||||||
|
* hardfloat and softfloat object files. The kernel build uses soft-float by
|
||||||
|
* default, so we also need to pass -msoft-float along to GAS if it supports it.
|
||||||
|
* But this in turn causes assembler errors in files which access hardfloat
|
||||||
|
* registers. We detect if GAS supports "-msoft-float" in the Makefile and
|
||||||
|
* explicitly put ".set hardfloat" where floating point registers are touched.
|
||||||
|
*/
|
||||||
|
#ifdef GAS_HAS_SET_HARDFLOAT
|
||||||
|
#define SET_HARDFLOAT .set hardfloat
|
||||||
|
#else
|
||||||
|
#define SET_HARDFLOAT
|
||||||
|
#endif
|
||||||
|
|
||||||
#if _MIPS_SIM == _MIPS_SIM_ABI32
|
#if _MIPS_SIM == _MIPS_SIM_ABI32
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -145,8 +145,8 @@ static inline void lose_fpu(int save)
|
||||||
if (is_msa_enabled()) {
|
if (is_msa_enabled()) {
|
||||||
if (save) {
|
if (save) {
|
||||||
save_msa(current);
|
save_msa(current);
|
||||||
asm volatile("cfc1 %0, $31"
|
current->thread.fpu.fcr31 =
|
||||||
: "=r"(current->thread.fpu.fcr31));
|
read_32bit_cp1_register(CP1_STATUS);
|
||||||
}
|
}
|
||||||
disable_msa();
|
disable_msa();
|
||||||
clear_thread_flag(TIF_USEDMSA);
|
clear_thread_flag(TIF_USEDMSA);
|
||||||
|
|
|
@ -1324,7 +1324,7 @@ do { \
|
||||||
/*
|
/*
|
||||||
* Macros to access the floating point coprocessor control registers
|
* Macros to access the floating point coprocessor control registers
|
||||||
*/
|
*/
|
||||||
#define read_32bit_cp1_register(source) \
|
#define _read_32bit_cp1_register(source, gas_hardfloat) \
|
||||||
({ \
|
({ \
|
||||||
int __res; \
|
int __res; \
|
||||||
\
|
\
|
||||||
|
@ -1334,12 +1334,21 @@ do { \
|
||||||
" # gas fails to assemble cfc1 for some archs, \n" \
|
" # gas fails to assemble cfc1 for some archs, \n" \
|
||||||
" # like Octeon. \n" \
|
" # like Octeon. \n" \
|
||||||
" .set mips1 \n" \
|
" .set mips1 \n" \
|
||||||
|
" "STR(gas_hardfloat)" \n" \
|
||||||
" cfc1 %0,"STR(source)" \n" \
|
" cfc1 %0,"STR(source)" \n" \
|
||||||
" .set pop \n" \
|
" .set pop \n" \
|
||||||
: "=r" (__res)); \
|
: "=r" (__res)); \
|
||||||
__res; \
|
__res; \
|
||||||
})
|
})
|
||||||
|
|
||||||
|
#ifdef GAS_HAS_SET_HARDFLOAT
|
||||||
|
#define read_32bit_cp1_register(source) \
|
||||||
|
_read_32bit_cp1_register(source, .set hardfloat)
|
||||||
|
#else
|
||||||
|
#define read_32bit_cp1_register(source) \
|
||||||
|
_read_32bit_cp1_register(source, )
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef HAVE_AS_DSP
|
#ifdef HAVE_AS_DSP
|
||||||
#define rddsp(mask) \
|
#define rddsp(mask) \
|
||||||
({ \
|
({ \
|
||||||
|
|
|
@ -375,16 +375,17 @@
|
||||||
#define __NR_seccomp (__NR_Linux + 352)
|
#define __NR_seccomp (__NR_Linux + 352)
|
||||||
#define __NR_getrandom (__NR_Linux + 353)
|
#define __NR_getrandom (__NR_Linux + 353)
|
||||||
#define __NR_memfd_create (__NR_Linux + 354)
|
#define __NR_memfd_create (__NR_Linux + 354)
|
||||||
|
#define __NR_bpf (__NR_Linux + 355)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last Linux o32 flavoured syscall
|
* Offset of the last Linux o32 flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 354
|
#define __NR_Linux_syscalls 355
|
||||||
|
|
||||||
#endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */
|
#endif /* _MIPS_SIM == _MIPS_SIM_ABI32 */
|
||||||
|
|
||||||
#define __NR_O32_Linux 4000
|
#define __NR_O32_Linux 4000
|
||||||
#define __NR_O32_Linux_syscalls 354
|
#define __NR_O32_Linux_syscalls 355
|
||||||
|
|
||||||
#if _MIPS_SIM == _MIPS_SIM_ABI64
|
#if _MIPS_SIM == _MIPS_SIM_ABI64
|
||||||
|
|
||||||
|
@ -707,16 +708,17 @@
|
||||||
#define __NR_seccomp (__NR_Linux + 312)
|
#define __NR_seccomp (__NR_Linux + 312)
|
||||||
#define __NR_getrandom (__NR_Linux + 313)
|
#define __NR_getrandom (__NR_Linux + 313)
|
||||||
#define __NR_memfd_create (__NR_Linux + 314)
|
#define __NR_memfd_create (__NR_Linux + 314)
|
||||||
|
#define __NR_bpf (__NR_Linux + 315)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last Linux 64-bit flavoured syscall
|
* Offset of the last Linux 64-bit flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 314
|
#define __NR_Linux_syscalls 315
|
||||||
|
|
||||||
#endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */
|
#endif /* _MIPS_SIM == _MIPS_SIM_ABI64 */
|
||||||
|
|
||||||
#define __NR_64_Linux 5000
|
#define __NR_64_Linux 5000
|
||||||
#define __NR_64_Linux_syscalls 314
|
#define __NR_64_Linux_syscalls 315
|
||||||
|
|
||||||
#if _MIPS_SIM == _MIPS_SIM_NABI32
|
#if _MIPS_SIM == _MIPS_SIM_NABI32
|
||||||
|
|
||||||
|
@ -1043,15 +1045,16 @@
|
||||||
#define __NR_seccomp (__NR_Linux + 316)
|
#define __NR_seccomp (__NR_Linux + 316)
|
||||||
#define __NR_getrandom (__NR_Linux + 317)
|
#define __NR_getrandom (__NR_Linux + 317)
|
||||||
#define __NR_memfd_create (__NR_Linux + 318)
|
#define __NR_memfd_create (__NR_Linux + 318)
|
||||||
|
#define __NR_memfd_create (__NR_Linux + 319)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last N32 flavoured syscall
|
* Offset of the last N32 flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 318
|
#define __NR_Linux_syscalls 319
|
||||||
|
|
||||||
#endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */
|
#endif /* _MIPS_SIM == _MIPS_SIM_NABI32 */
|
||||||
|
|
||||||
#define __NR_N32_Linux 6000
|
#define __NR_N32_Linux 6000
|
||||||
#define __NR_N32_Linux_syscalls 318
|
#define __NR_N32_Linux_syscalls 319
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_UNISTD_H */
|
#endif /* _UAPI_ASM_UNISTD_H */
|
||||||
|
|
|
@ -144,7 +144,7 @@ int __mm_isBranchInstr(struct pt_regs *regs, struct mm_decoded_insn dec_insn,
|
||||||
case mm_bc1t_op:
|
case mm_bc1t_op:
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
if (is_fpu_owner())
|
if (is_fpu_owner())
|
||||||
asm volatile("cfc1\t%0,$31" : "=r" (fcr31));
|
fcr31 = read_32bit_cp1_register(CP1_STATUS);
|
||||||
else
|
else
|
||||||
fcr31 = current->thread.fpu.fcr31;
|
fcr31 = current->thread.fpu.fcr31;
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
|
@ -562,11 +562,7 @@ int __compute_return_epc_for_insn(struct pt_regs *regs,
|
||||||
case cop1_op:
|
case cop1_op:
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
if (is_fpu_owner())
|
if (is_fpu_owner())
|
||||||
asm volatile(
|
fcr31 = read_32bit_cp1_register(CP1_STATUS);
|
||||||
".set push\n"
|
|
||||||
"\t.set mips1\n"
|
|
||||||
"\tcfc1\t%0,$31\n"
|
|
||||||
"\t.set pop" : "=r" (fcr31));
|
|
||||||
else
|
else
|
||||||
fcr31 = current->thread.fpu.fcr31;
|
fcr31 = current->thread.fpu.fcr31;
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
|
|
|
@ -358,6 +358,7 @@ NESTED(nmi_handler, PT_SIZE, sp)
|
||||||
.set push
|
.set push
|
||||||
/* gas fails to assemble cfc1 for some archs (octeon).*/ \
|
/* gas fails to assemble cfc1 for some archs (octeon).*/ \
|
||||||
.set mips1
|
.set mips1
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 a1, fcr31
|
cfc1 a1, fcr31
|
||||||
li a2, ~(0x3f << 12)
|
li a2, ~(0x3f << 12)
|
||||||
and a2, a1
|
and a2, a1
|
||||||
|
|
|
@ -28,6 +28,8 @@
|
||||||
.set mips1
|
.set mips1
|
||||||
/* Save floating point context */
|
/* Save floating point context */
|
||||||
LEAF(_save_fp_context)
|
LEAF(_save_fp_context)
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
li v0, 0 # assume success
|
li v0, 0 # assume success
|
||||||
cfc1 t1,fcr31
|
cfc1 t1,fcr31
|
||||||
EX(swc1 $f0,(SC_FPREGS+0)(a0))
|
EX(swc1 $f0,(SC_FPREGS+0)(a0))
|
||||||
|
@ -65,6 +67,7 @@ LEAF(_save_fp_context)
|
||||||
EX(sw t1,(SC_FPC_CSR)(a0))
|
EX(sw t1,(SC_FPC_CSR)(a0))
|
||||||
cfc1 t0,$0 # implementation/version
|
cfc1 t0,$0 # implementation/version
|
||||||
jr ra
|
jr ra
|
||||||
|
.set pop
|
||||||
.set nomacro
|
.set nomacro
|
||||||
EX(sw t0,(SC_FPC_EIR)(a0))
|
EX(sw t0,(SC_FPC_EIR)(a0))
|
||||||
.set macro
|
.set macro
|
||||||
|
@ -80,6 +83,8 @@ LEAF(_save_fp_context)
|
||||||
* stack frame which might have been changed by the user.
|
* stack frame which might have been changed by the user.
|
||||||
*/
|
*/
|
||||||
LEAF(_restore_fp_context)
|
LEAF(_restore_fp_context)
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
li v0, 0 # assume success
|
li v0, 0 # assume success
|
||||||
EX(lw t0,(SC_FPC_CSR)(a0))
|
EX(lw t0,(SC_FPC_CSR)(a0))
|
||||||
EX(lwc1 $f0,(SC_FPREGS+0)(a0))
|
EX(lwc1 $f0,(SC_FPREGS+0)(a0))
|
||||||
|
@ -116,6 +121,7 @@ LEAF(_restore_fp_context)
|
||||||
EX(lwc1 $f31,(SC_FPREGS+248)(a0))
|
EX(lwc1 $f31,(SC_FPREGS+248)(a0))
|
||||||
jr ra
|
jr ra
|
||||||
ctc1 t0,fcr31
|
ctc1 t0,fcr31
|
||||||
|
.set pop
|
||||||
END(_restore_fp_context)
|
END(_restore_fp_context)
|
||||||
.set reorder
|
.set reorder
|
||||||
|
|
||||||
|
|
|
@ -120,6 +120,9 @@ LEAF(_restore_fp)
|
||||||
|
|
||||||
#define FPU_DEFAULT 0x00000000
|
#define FPU_DEFAULT 0x00000000
|
||||||
|
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
|
|
||||||
LEAF(_init_fpu)
|
LEAF(_init_fpu)
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
li t1, ST0_CU1
|
li t1, ST0_CU1
|
||||||
|
@ -165,3 +168,5 @@ LEAF(_init_fpu)
|
||||||
mtc1 t0, $f31
|
mtc1 t0, $f31
|
||||||
jr ra
|
jr ra
|
||||||
END(_init_fpu)
|
END(_init_fpu)
|
||||||
|
|
||||||
|
.set pop
|
||||||
|
|
|
@ -19,8 +19,12 @@
|
||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
#include <asm/regdef.h>
|
#include <asm/regdef.h>
|
||||||
|
|
||||||
|
/* preprocessor replaces the fp in ".set fp=64" with $30 otherwise */
|
||||||
|
#undef fp
|
||||||
|
|
||||||
.macro EX insn, reg, src
|
.macro EX insn, reg, src
|
||||||
.set push
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
.set nomacro
|
.set nomacro
|
||||||
.ex\@: \insn \reg, \src
|
.ex\@: \insn \reg, \src
|
||||||
.set pop
|
.set pop
|
||||||
|
@ -33,12 +37,17 @@
|
||||||
.set arch=r4000
|
.set arch=r4000
|
||||||
|
|
||||||
LEAF(_save_fp_context)
|
LEAF(_save_fp_context)
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 t1, fcr31
|
cfc1 t1, fcr31
|
||||||
|
.set pop
|
||||||
|
|
||||||
#if defined(CONFIG_64BIT) || defined(CONFIG_CPU_MIPS32_R2)
|
#if defined(CONFIG_64BIT) || defined(CONFIG_CPU_MIPS32_R2)
|
||||||
.set push
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
#ifdef CONFIG_CPU_MIPS32_R2
|
#ifdef CONFIG_CPU_MIPS32_R2
|
||||||
.set mips64r2
|
.set mips32r2
|
||||||
|
.set fp=64
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
sll t0, t0, 5
|
sll t0, t0, 5
|
||||||
bgez t0, 1f # skip storing odd if FR=0
|
bgez t0, 1f # skip storing odd if FR=0
|
||||||
|
@ -64,6 +73,8 @@ LEAF(_save_fp_context)
|
||||||
1: .set pop
|
1: .set pop
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
/* Store the 16 even double precision registers */
|
/* Store the 16 even double precision registers */
|
||||||
EX sdc1 $f0, SC_FPREGS+0(a0)
|
EX sdc1 $f0, SC_FPREGS+0(a0)
|
||||||
EX sdc1 $f2, SC_FPREGS+16(a0)
|
EX sdc1 $f2, SC_FPREGS+16(a0)
|
||||||
|
@ -84,11 +95,14 @@ LEAF(_save_fp_context)
|
||||||
EX sw t1, SC_FPC_CSR(a0)
|
EX sw t1, SC_FPC_CSR(a0)
|
||||||
jr ra
|
jr ra
|
||||||
li v0, 0 # success
|
li v0, 0 # success
|
||||||
|
.set pop
|
||||||
END(_save_fp_context)
|
END(_save_fp_context)
|
||||||
|
|
||||||
#ifdef CONFIG_MIPS32_COMPAT
|
#ifdef CONFIG_MIPS32_COMPAT
|
||||||
/* Save 32-bit process floating point context */
|
/* Save 32-bit process floating point context */
|
||||||
LEAF(_save_fp_context32)
|
LEAF(_save_fp_context32)
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 t1, fcr31
|
cfc1 t1, fcr31
|
||||||
|
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
|
@ -134,6 +148,7 @@ LEAF(_save_fp_context32)
|
||||||
EX sw t1, SC32_FPC_CSR(a0)
|
EX sw t1, SC32_FPC_CSR(a0)
|
||||||
cfc1 t0, $0 # implementation/version
|
cfc1 t0, $0 # implementation/version
|
||||||
EX sw t0, SC32_FPC_EIR(a0)
|
EX sw t0, SC32_FPC_EIR(a0)
|
||||||
|
.set pop
|
||||||
|
|
||||||
jr ra
|
jr ra
|
||||||
li v0, 0 # success
|
li v0, 0 # success
|
||||||
|
@ -150,8 +165,10 @@ LEAF(_restore_fp_context)
|
||||||
|
|
||||||
#if defined(CONFIG_64BIT) || defined(CONFIG_CPU_MIPS32_R2)
|
#if defined(CONFIG_64BIT) || defined(CONFIG_CPU_MIPS32_R2)
|
||||||
.set push
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
#ifdef CONFIG_CPU_MIPS32_R2
|
#ifdef CONFIG_CPU_MIPS32_R2
|
||||||
.set mips64r2
|
.set mips32r2
|
||||||
|
.set fp=64
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
sll t0, t0, 5
|
sll t0, t0, 5
|
||||||
bgez t0, 1f # skip loading odd if FR=0
|
bgez t0, 1f # skip loading odd if FR=0
|
||||||
|
@ -175,6 +192,8 @@ LEAF(_restore_fp_context)
|
||||||
EX ldc1 $f31, SC_FPREGS+248(a0)
|
EX ldc1 $f31, SC_FPREGS+248(a0)
|
||||||
1: .set pop
|
1: .set pop
|
||||||
#endif
|
#endif
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
EX ldc1 $f0, SC_FPREGS+0(a0)
|
EX ldc1 $f0, SC_FPREGS+0(a0)
|
||||||
EX ldc1 $f2, SC_FPREGS+16(a0)
|
EX ldc1 $f2, SC_FPREGS+16(a0)
|
||||||
EX ldc1 $f4, SC_FPREGS+32(a0)
|
EX ldc1 $f4, SC_FPREGS+32(a0)
|
||||||
|
@ -192,6 +211,7 @@ LEAF(_restore_fp_context)
|
||||||
EX ldc1 $f28, SC_FPREGS+224(a0)
|
EX ldc1 $f28, SC_FPREGS+224(a0)
|
||||||
EX ldc1 $f30, SC_FPREGS+240(a0)
|
EX ldc1 $f30, SC_FPREGS+240(a0)
|
||||||
ctc1 t1, fcr31
|
ctc1 t1, fcr31
|
||||||
|
.set pop
|
||||||
jr ra
|
jr ra
|
||||||
li v0, 0 # success
|
li v0, 0 # success
|
||||||
END(_restore_fp_context)
|
END(_restore_fp_context)
|
||||||
|
@ -199,6 +219,8 @@ LEAF(_restore_fp_context)
|
||||||
#ifdef CONFIG_MIPS32_COMPAT
|
#ifdef CONFIG_MIPS32_COMPAT
|
||||||
LEAF(_restore_fp_context32)
|
LEAF(_restore_fp_context32)
|
||||||
/* Restore an o32 sigcontext. */
|
/* Restore an o32 sigcontext. */
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
EX lw t1, SC32_FPC_CSR(a0)
|
EX lw t1, SC32_FPC_CSR(a0)
|
||||||
|
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
|
@ -242,6 +264,7 @@ LEAF(_restore_fp_context32)
|
||||||
ctc1 t1, fcr31
|
ctc1 t1, fcr31
|
||||||
jr ra
|
jr ra
|
||||||
li v0, 0 # success
|
li v0, 0 # success
|
||||||
|
.set pop
|
||||||
END(_restore_fp_context32)
|
END(_restore_fp_context32)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -22,6 +22,9 @@
|
||||||
|
|
||||||
#include <asm/asmmacro.h>
|
#include <asm/asmmacro.h>
|
||||||
|
|
||||||
|
/* preprocessor replaces the fp in ".set fp=64" with $30 otherwise */
|
||||||
|
#undef fp
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset to the current process status flags, the first 32 bytes of the
|
* Offset to the current process status flags, the first 32 bytes of the
|
||||||
* stack are not used.
|
* stack are not used.
|
||||||
|
@ -65,8 +68,12 @@
|
||||||
bgtz a3, 1f
|
bgtz a3, 1f
|
||||||
|
|
||||||
/* Save 128b MSA vector context + scalar FP control & status. */
|
/* Save 128b MSA vector context + scalar FP control & status. */
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
cfc1 t1, fcr31
|
cfc1 t1, fcr31
|
||||||
msa_save_all a0
|
msa_save_all a0
|
||||||
|
.set pop /* SET_HARDFLOAT */
|
||||||
|
|
||||||
sw t1, THREAD_FCR31(a0)
|
sw t1, THREAD_FCR31(a0)
|
||||||
b 2f
|
b 2f
|
||||||
|
|
||||||
|
@ -161,6 +168,9 @@ LEAF(_init_msa_upper)
|
||||||
|
|
||||||
#define FPU_DEFAULT 0x00000000
|
#define FPU_DEFAULT 0x00000000
|
||||||
|
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
|
|
||||||
LEAF(_init_fpu)
|
LEAF(_init_fpu)
|
||||||
mfc0 t0, CP0_STATUS
|
mfc0 t0, CP0_STATUS
|
||||||
li t1, ST0_CU1
|
li t1, ST0_CU1
|
||||||
|
@ -232,7 +242,8 @@ LEAF(_init_fpu)
|
||||||
|
|
||||||
#ifdef CONFIG_CPU_MIPS32_R2
|
#ifdef CONFIG_CPU_MIPS32_R2
|
||||||
.set push
|
.set push
|
||||||
.set mips64r2
|
.set mips32r2
|
||||||
|
.set fp=64
|
||||||
sll t0, t0, 5 # is Status.FR set?
|
sll t0, t0, 5 # is Status.FR set?
|
||||||
bgez t0, 1f # no: skip setting upper 32b
|
bgez t0, 1f # no: skip setting upper 32b
|
||||||
|
|
||||||
|
@ -291,3 +302,5 @@ LEAF(_init_fpu)
|
||||||
#endif
|
#endif
|
||||||
jr ra
|
jr ra
|
||||||
END(_init_fpu)
|
END(_init_fpu)
|
||||||
|
|
||||||
|
.set pop /* SET_HARDFLOAT */
|
||||||
|
|
|
@ -18,6 +18,9 @@
|
||||||
|
|
||||||
.set noreorder
|
.set noreorder
|
||||||
.set mips2
|
.set mips2
|
||||||
|
.set push
|
||||||
|
SET_HARDFLOAT
|
||||||
|
|
||||||
/* Save floating point context */
|
/* Save floating point context */
|
||||||
LEAF(_save_fp_context)
|
LEAF(_save_fp_context)
|
||||||
mfc0 t0,CP0_STATUS
|
mfc0 t0,CP0_STATUS
|
||||||
|
@ -85,3 +88,5 @@
|
||||||
1: jr ra
|
1: jr ra
|
||||||
nop
|
nop
|
||||||
END(_restore_fp_context)
|
END(_restore_fp_context)
|
||||||
|
|
||||||
|
.set pop /* SET_HARDFLOAT */
|
||||||
|
|
|
@ -579,3 +579,4 @@ EXPORT(sys_call_table)
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
PTR sys_getrandom
|
PTR sys_getrandom
|
||||||
PTR sys_memfd_create
|
PTR sys_memfd_create
|
||||||
|
PTR sys_bpf /* 4355 */
|
||||||
|
|
|
@ -434,4 +434,5 @@ EXPORT(sys_call_table)
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
PTR sys_getrandom
|
PTR sys_getrandom
|
||||||
PTR sys_memfd_create
|
PTR sys_memfd_create
|
||||||
|
PTR sys_bpf /* 5315 */
|
||||||
.size sys_call_table,.-sys_call_table
|
.size sys_call_table,.-sys_call_table
|
||||||
|
|
|
@ -427,4 +427,5 @@ EXPORT(sysn32_call_table)
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
PTR sys_getrandom
|
PTR sys_getrandom
|
||||||
PTR sys_memfd_create
|
PTR sys_memfd_create
|
||||||
|
PTR sys_bpf
|
||||||
.size sysn32_call_table,.-sysn32_call_table
|
.size sysn32_call_table,.-sysn32_call_table
|
||||||
|
|
|
@ -564,4 +564,5 @@ EXPORT(sys32_call_table)
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
PTR sys_getrandom
|
PTR sys_getrandom
|
||||||
PTR sys_memfd_create
|
PTR sys_memfd_create
|
||||||
|
PTR sys_bpf /* 4355 */
|
||||||
.size sys32_call_table,.-sys32_call_table
|
.size sys32_call_table,.-sys32_call_table
|
||||||
|
|
|
@ -683,6 +683,7 @@ static void __init arch_mem_init(char **cmdline_p)
|
||||||
dma_contiguous_reserve(PFN_PHYS(max_low_pfn));
|
dma_contiguous_reserve(PFN_PHYS(max_low_pfn));
|
||||||
/* Tell bootmem about cma reserved memblock section */
|
/* Tell bootmem about cma reserved memblock section */
|
||||||
for_each_memblock(reserved, reg)
|
for_each_memblock(reserved, reg)
|
||||||
|
if (reg->size != 0)
|
||||||
reserve_bootmem(reg->base, reg->size, BOOTMEM_DEFAULT);
|
reserve_bootmem(reg->base, reg->size, BOOTMEM_DEFAULT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,7 @@ static void dump_tlb(int first, int last)
|
||||||
entrylo0 = read_c0_entrylo0();
|
entrylo0 = read_c0_entrylo0();
|
||||||
|
|
||||||
/* Unused entries have a virtual address of KSEG0. */
|
/* Unused entries have a virtual address of KSEG0. */
|
||||||
if ((entryhi & 0xffffe000) != 0x80000000
|
if ((entryhi & 0xfffff000) != 0x80000000
|
||||||
&& (entryhi & 0xfc0) == asid) {
|
&& (entryhi & 0xfc0) == asid) {
|
||||||
/*
|
/*
|
||||||
* Only print entries in use
|
* Only print entries in use
|
||||||
|
@ -43,7 +43,7 @@ static void dump_tlb(int first, int last)
|
||||||
|
|
||||||
printk("va=%08lx asid=%08lx"
|
printk("va=%08lx asid=%08lx"
|
||||||
" [pa=%06lx n=%d d=%d v=%d g=%d]",
|
" [pa=%06lx n=%d d=%d v=%d g=%d]",
|
||||||
(entryhi & 0xffffe000),
|
(entryhi & 0xfffff000),
|
||||||
entryhi & 0xfc0,
|
entryhi & 0xfc0,
|
||||||
entrylo0 & PAGE_MASK,
|
entrylo0 & PAGE_MASK,
|
||||||
(entrylo0 & (1 << 11)) ? 1 : 0,
|
(entrylo0 & (1 << 11)) ? 1 : 0,
|
||||||
|
|
|
@ -40,9 +40,11 @@ FEXPORT(__strnlen_\func\()_nocheck_asm)
|
||||||
.else
|
.else
|
||||||
EX(lbe, t0, (v0), .Lfault\@)
|
EX(lbe, t0, (v0), .Lfault\@)
|
||||||
.endif
|
.endif
|
||||||
PTR_ADDIU v0, 1
|
.set noreorder
|
||||||
bnez t0, 1b
|
bnez t0, 1b
|
||||||
1: PTR_SUBU v0, a0
|
1: PTR_ADDIU v0, 1
|
||||||
|
.set reorder
|
||||||
|
PTR_SUBU v0, a0
|
||||||
jr ra
|
jr ra
|
||||||
END(__strnlen_\func\()_asm)
|
END(__strnlen_\func\()_asm)
|
||||||
|
|
||||||
|
|
|
@ -584,11 +584,7 @@ static int isBranchInstr(struct pt_regs *regs, struct mm_decoded_insn dec_insn,
|
||||||
if (insn.i_format.rs == bc_op) {
|
if (insn.i_format.rs == bc_op) {
|
||||||
preempt_disable();
|
preempt_disable();
|
||||||
if (is_fpu_owner())
|
if (is_fpu_owner())
|
||||||
asm volatile(
|
fcr31 = read_32bit_cp1_register(CP1_STATUS);
|
||||||
".set push\n"
|
|
||||||
"\t.set mips1\n"
|
|
||||||
"\tcfc1\t%0,$31\n"
|
|
||||||
"\t.set pop" : "=r" (fcr31));
|
|
||||||
else
|
else
|
||||||
fcr31 = current->thread.fpu.fcr31;
|
fcr31 = current->thread.fpu.fcr31;
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
|
|
|
@ -443,10 +443,8 @@ static int xlp_setup_msix(uint64_t lnkbase, int node, int link,
|
||||||
msg.data = 0xc00 | msixvec;
|
msg.data = 0xc00 | msixvec;
|
||||||
|
|
||||||
ret = irq_set_msi_desc(xirq, desc);
|
ret = irq_set_msi_desc(xirq, desc);
|
||||||
if (ret < 0) {
|
if (ret < 0)
|
||||||
destroy_irq(xirq);
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
|
||||||
|
|
||||||
write_msi_msg(xirq, &msg);
|
write_msi_msg(xirq, &msg);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -72,37 +72,37 @@
|
||||||
/* Utility macros */
|
/* Utility macros */
|
||||||
#define SKIP_TO_NEXT_CPU(reg_entry) \
|
#define SKIP_TO_NEXT_CPU(reg_entry) \
|
||||||
({ \
|
({ \
|
||||||
while (reg_entry->reg_id != REG_ID("CPUEND")) \
|
while (be64_to_cpu(reg_entry->reg_id) != REG_ID("CPUEND")) \
|
||||||
reg_entry++; \
|
reg_entry++; \
|
||||||
reg_entry++; \
|
reg_entry++; \
|
||||||
})
|
})
|
||||||
|
|
||||||
/* Kernel Dump section info */
|
/* Kernel Dump section info */
|
||||||
struct fadump_section {
|
struct fadump_section {
|
||||||
u32 request_flag;
|
__be32 request_flag;
|
||||||
u16 source_data_type;
|
__be16 source_data_type;
|
||||||
u16 error_flags;
|
__be16 error_flags;
|
||||||
u64 source_address;
|
__be64 source_address;
|
||||||
u64 source_len;
|
__be64 source_len;
|
||||||
u64 bytes_dumped;
|
__be64 bytes_dumped;
|
||||||
u64 destination_address;
|
__be64 destination_address;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* ibm,configure-kernel-dump header. */
|
/* ibm,configure-kernel-dump header. */
|
||||||
struct fadump_section_header {
|
struct fadump_section_header {
|
||||||
u32 dump_format_version;
|
__be32 dump_format_version;
|
||||||
u16 dump_num_sections;
|
__be16 dump_num_sections;
|
||||||
u16 dump_status_flag;
|
__be16 dump_status_flag;
|
||||||
u32 offset_first_dump_section;
|
__be32 offset_first_dump_section;
|
||||||
|
|
||||||
/* Fields for disk dump option. */
|
/* Fields for disk dump option. */
|
||||||
u32 dd_block_size;
|
__be32 dd_block_size;
|
||||||
u64 dd_block_offset;
|
__be64 dd_block_offset;
|
||||||
u64 dd_num_blocks;
|
__be64 dd_num_blocks;
|
||||||
u32 dd_offset_disk_path;
|
__be32 dd_offset_disk_path;
|
||||||
|
|
||||||
/* Maximum time allowed to prevent an automatic dump-reboot. */
|
/* Maximum time allowed to prevent an automatic dump-reboot. */
|
||||||
u32 max_time_auto;
|
__be32 max_time_auto;
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -174,15 +174,15 @@ static inline u64 str_to_u64(const char *str)
|
||||||
|
|
||||||
/* Register save area header. */
|
/* Register save area header. */
|
||||||
struct fadump_reg_save_area_header {
|
struct fadump_reg_save_area_header {
|
||||||
u64 magic_number;
|
__be64 magic_number;
|
||||||
u32 version;
|
__be32 version;
|
||||||
u32 num_cpu_offset;
|
__be32 num_cpu_offset;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Register entry. */
|
/* Register entry. */
|
||||||
struct fadump_reg_entry {
|
struct fadump_reg_entry {
|
||||||
u64 reg_id;
|
__be64 reg_id;
|
||||||
u64 reg_value;
|
__be64 reg_value;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* fadump crash info structure */
|
/* fadump crash info structure */
|
||||||
|
|
|
@ -71,7 +71,7 @@ pte_t *huge_pte_offset_and_shift(struct mm_struct *mm,
|
||||||
|
|
||||||
void flush_dcache_icache_hugepage(struct page *page);
|
void flush_dcache_icache_hugepage(struct page *page);
|
||||||
|
|
||||||
#if defined(CONFIG_PPC_MM_SLICES) || defined(CONFIG_PPC_SUBPAGE_PROT)
|
#if defined(CONFIG_PPC_MM_SLICES)
|
||||||
int is_hugepage_only_range(struct mm_struct *mm, unsigned long addr,
|
int is_hugepage_only_range(struct mm_struct *mm, unsigned long addr,
|
||||||
unsigned long len);
|
unsigned long len);
|
||||||
#else
|
#else
|
||||||
|
|
|
@ -365,3 +365,4 @@ SYSCALL_SPU(renameat2)
|
||||||
SYSCALL_SPU(seccomp)
|
SYSCALL_SPU(seccomp)
|
||||||
SYSCALL_SPU(getrandom)
|
SYSCALL_SPU(getrandom)
|
||||||
SYSCALL_SPU(memfd_create)
|
SYSCALL_SPU(memfd_create)
|
||||||
|
SYSCALL_SPU(bpf)
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
#include <uapi/asm/unistd.h>
|
#include <uapi/asm/unistd.h>
|
||||||
|
|
||||||
|
|
||||||
#define __NR_syscalls 361
|
#define __NR_syscalls 362
|
||||||
|
|
||||||
#define __NR__exit __NR_exit
|
#define __NR__exit __NR_exit
|
||||||
#define NR_syscalls __NR_syscalls
|
#define NR_syscalls __NR_syscalls
|
||||||
|
|
|
@ -383,5 +383,6 @@
|
||||||
#define __NR_seccomp 358
|
#define __NR_seccomp 358
|
||||||
#define __NR_getrandom 359
|
#define __NR_getrandom 359
|
||||||
#define __NR_memfd_create 360
|
#define __NR_memfd_create 360
|
||||||
|
#define __NR_bpf 361
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_POWERPC_UNISTD_H_ */
|
#endif /* _UAPI_ASM_POWERPC_UNISTD_H_ */
|
||||||
|
|
|
@ -659,7 +659,13 @@ _GLOBAL(ret_from_except_lite)
|
||||||
3:
|
3:
|
||||||
#endif
|
#endif
|
||||||
bl save_nvgprs
|
bl save_nvgprs
|
||||||
|
/*
|
||||||
|
* Use a non volatile GPR to save and restore our thread_info flags
|
||||||
|
* across the call to restore_interrupts.
|
||||||
|
*/
|
||||||
|
mr r30,r4
|
||||||
bl restore_interrupts
|
bl restore_interrupts
|
||||||
|
mr r4,r30
|
||||||
addi r3,r1,STACK_FRAME_OVERHEAD
|
addi r3,r1,STACK_FRAME_OVERHEAD
|
||||||
bl do_notify_resume
|
bl do_notify_resume
|
||||||
b ret_from_except
|
b ret_from_except
|
||||||
|
|
|
@ -58,7 +58,7 @@ int __init early_init_dt_scan_fw_dump(unsigned long node,
|
||||||
const __be32 *sections;
|
const __be32 *sections;
|
||||||
int i, num_sections;
|
int i, num_sections;
|
||||||
int size;
|
int size;
|
||||||
const int *token;
|
const __be32 *token;
|
||||||
|
|
||||||
if (depth != 1 || strcmp(uname, "rtas") != 0)
|
if (depth != 1 || strcmp(uname, "rtas") != 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -72,7 +72,7 @@ int __init early_init_dt_scan_fw_dump(unsigned long node,
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
fw_dump.fadump_supported = 1;
|
fw_dump.fadump_supported = 1;
|
||||||
fw_dump.ibm_configure_kernel_dump = *token;
|
fw_dump.ibm_configure_kernel_dump = be32_to_cpu(*token);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The 'ibm,kernel-dump' rtas node is present only if there is
|
* The 'ibm,kernel-dump' rtas node is present only if there is
|
||||||
|
@ -147,11 +147,11 @@ static unsigned long init_fadump_mem_struct(struct fadump_mem_struct *fdm,
|
||||||
memset(fdm, 0, sizeof(struct fadump_mem_struct));
|
memset(fdm, 0, sizeof(struct fadump_mem_struct));
|
||||||
addr = addr & PAGE_MASK;
|
addr = addr & PAGE_MASK;
|
||||||
|
|
||||||
fdm->header.dump_format_version = 0x00000001;
|
fdm->header.dump_format_version = cpu_to_be32(0x00000001);
|
||||||
fdm->header.dump_num_sections = 3;
|
fdm->header.dump_num_sections = cpu_to_be16(3);
|
||||||
fdm->header.dump_status_flag = 0;
|
fdm->header.dump_status_flag = 0;
|
||||||
fdm->header.offset_first_dump_section =
|
fdm->header.offset_first_dump_section =
|
||||||
(u32)offsetof(struct fadump_mem_struct, cpu_state_data);
|
cpu_to_be32((u32)offsetof(struct fadump_mem_struct, cpu_state_data));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fields for disk dump option.
|
* Fields for disk dump option.
|
||||||
|
@ -167,27 +167,27 @@ static unsigned long init_fadump_mem_struct(struct fadump_mem_struct *fdm,
|
||||||
|
|
||||||
/* Kernel dump sections */
|
/* Kernel dump sections */
|
||||||
/* cpu state data section. */
|
/* cpu state data section. */
|
||||||
fdm->cpu_state_data.request_flag = FADUMP_REQUEST_FLAG;
|
fdm->cpu_state_data.request_flag = cpu_to_be32(FADUMP_REQUEST_FLAG);
|
||||||
fdm->cpu_state_data.source_data_type = FADUMP_CPU_STATE_DATA;
|
fdm->cpu_state_data.source_data_type = cpu_to_be16(FADUMP_CPU_STATE_DATA);
|
||||||
fdm->cpu_state_data.source_address = 0;
|
fdm->cpu_state_data.source_address = 0;
|
||||||
fdm->cpu_state_data.source_len = fw_dump.cpu_state_data_size;
|
fdm->cpu_state_data.source_len = cpu_to_be64(fw_dump.cpu_state_data_size);
|
||||||
fdm->cpu_state_data.destination_address = addr;
|
fdm->cpu_state_data.destination_address = cpu_to_be64(addr);
|
||||||
addr += fw_dump.cpu_state_data_size;
|
addr += fw_dump.cpu_state_data_size;
|
||||||
|
|
||||||
/* hpte region section */
|
/* hpte region section */
|
||||||
fdm->hpte_region.request_flag = FADUMP_REQUEST_FLAG;
|
fdm->hpte_region.request_flag = cpu_to_be32(FADUMP_REQUEST_FLAG);
|
||||||
fdm->hpte_region.source_data_type = FADUMP_HPTE_REGION;
|
fdm->hpte_region.source_data_type = cpu_to_be16(FADUMP_HPTE_REGION);
|
||||||
fdm->hpte_region.source_address = 0;
|
fdm->hpte_region.source_address = 0;
|
||||||
fdm->hpte_region.source_len = fw_dump.hpte_region_size;
|
fdm->hpte_region.source_len = cpu_to_be64(fw_dump.hpte_region_size);
|
||||||
fdm->hpte_region.destination_address = addr;
|
fdm->hpte_region.destination_address = cpu_to_be64(addr);
|
||||||
addr += fw_dump.hpte_region_size;
|
addr += fw_dump.hpte_region_size;
|
||||||
|
|
||||||
/* RMA region section */
|
/* RMA region section */
|
||||||
fdm->rmr_region.request_flag = FADUMP_REQUEST_FLAG;
|
fdm->rmr_region.request_flag = cpu_to_be32(FADUMP_REQUEST_FLAG);
|
||||||
fdm->rmr_region.source_data_type = FADUMP_REAL_MODE_REGION;
|
fdm->rmr_region.source_data_type = cpu_to_be16(FADUMP_REAL_MODE_REGION);
|
||||||
fdm->rmr_region.source_address = RMA_START;
|
fdm->rmr_region.source_address = cpu_to_be64(RMA_START);
|
||||||
fdm->rmr_region.source_len = fw_dump.boot_memory_size;
|
fdm->rmr_region.source_len = cpu_to_be64(fw_dump.boot_memory_size);
|
||||||
fdm->rmr_region.destination_address = addr;
|
fdm->rmr_region.destination_address = cpu_to_be64(addr);
|
||||||
addr += fw_dump.boot_memory_size;
|
addr += fw_dump.boot_memory_size;
|
||||||
|
|
||||||
return addr;
|
return addr;
|
||||||
|
@ -272,7 +272,7 @@ int __init fadump_reserve_mem(void)
|
||||||
* first kernel.
|
* first kernel.
|
||||||
*/
|
*/
|
||||||
if (fdm_active)
|
if (fdm_active)
|
||||||
fw_dump.boot_memory_size = fdm_active->rmr_region.source_len;
|
fw_dump.boot_memory_size = be64_to_cpu(fdm_active->rmr_region.source_len);
|
||||||
else
|
else
|
||||||
fw_dump.boot_memory_size = fadump_calculate_reserve_size();
|
fw_dump.boot_memory_size = fadump_calculate_reserve_size();
|
||||||
|
|
||||||
|
@ -314,8 +314,8 @@ int __init fadump_reserve_mem(void)
|
||||||
(unsigned long)(base >> 20));
|
(unsigned long)(base >> 20));
|
||||||
|
|
||||||
fw_dump.fadumphdr_addr =
|
fw_dump.fadumphdr_addr =
|
||||||
fdm_active->rmr_region.destination_address +
|
be64_to_cpu(fdm_active->rmr_region.destination_address) +
|
||||||
fdm_active->rmr_region.source_len;
|
be64_to_cpu(fdm_active->rmr_region.source_len);
|
||||||
pr_debug("fadumphdr_addr = %p\n",
|
pr_debug("fadumphdr_addr = %p\n",
|
||||||
(void *) fw_dump.fadumphdr_addr);
|
(void *) fw_dump.fadumphdr_addr);
|
||||||
} else {
|
} else {
|
||||||
|
@ -472,9 +472,9 @@ fadump_read_registers(struct fadump_reg_entry *reg_entry, struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
memset(regs, 0, sizeof(struct pt_regs));
|
memset(regs, 0, sizeof(struct pt_regs));
|
||||||
|
|
||||||
while (reg_entry->reg_id != REG_ID("CPUEND")) {
|
while (be64_to_cpu(reg_entry->reg_id) != REG_ID("CPUEND")) {
|
||||||
fadump_set_regval(regs, reg_entry->reg_id,
|
fadump_set_regval(regs, be64_to_cpu(reg_entry->reg_id),
|
||||||
reg_entry->reg_value);
|
be64_to_cpu(reg_entry->reg_value));
|
||||||
reg_entry++;
|
reg_entry++;
|
||||||
}
|
}
|
||||||
reg_entry++;
|
reg_entry++;
|
||||||
|
@ -603,20 +603,20 @@ static int __init fadump_build_cpu_notes(const struct fadump_mem_struct *fdm)
|
||||||
if (!fdm->cpu_state_data.bytes_dumped)
|
if (!fdm->cpu_state_data.bytes_dumped)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
addr = fdm->cpu_state_data.destination_address;
|
addr = be64_to_cpu(fdm->cpu_state_data.destination_address);
|
||||||
vaddr = __va(addr);
|
vaddr = __va(addr);
|
||||||
|
|
||||||
reg_header = vaddr;
|
reg_header = vaddr;
|
||||||
if (reg_header->magic_number != REGSAVE_AREA_MAGIC) {
|
if (be64_to_cpu(reg_header->magic_number) != REGSAVE_AREA_MAGIC) {
|
||||||
printk(KERN_ERR "Unable to read register save area.\n");
|
printk(KERN_ERR "Unable to read register save area.\n");
|
||||||
return -ENOENT;
|
return -ENOENT;
|
||||||
}
|
}
|
||||||
pr_debug("--------CPU State Data------------\n");
|
pr_debug("--------CPU State Data------------\n");
|
||||||
pr_debug("Magic Number: %llx\n", reg_header->magic_number);
|
pr_debug("Magic Number: %llx\n", be64_to_cpu(reg_header->magic_number));
|
||||||
pr_debug("NumCpuOffset: %x\n", reg_header->num_cpu_offset);
|
pr_debug("NumCpuOffset: %x\n", be32_to_cpu(reg_header->num_cpu_offset));
|
||||||
|
|
||||||
vaddr += reg_header->num_cpu_offset;
|
vaddr += be32_to_cpu(reg_header->num_cpu_offset);
|
||||||
num_cpus = *((u32 *)(vaddr));
|
num_cpus = be32_to_cpu(*((__be32 *)(vaddr)));
|
||||||
pr_debug("NumCpus : %u\n", num_cpus);
|
pr_debug("NumCpus : %u\n", num_cpus);
|
||||||
vaddr += sizeof(u32);
|
vaddr += sizeof(u32);
|
||||||
reg_entry = (struct fadump_reg_entry *)vaddr;
|
reg_entry = (struct fadump_reg_entry *)vaddr;
|
||||||
|
@ -639,13 +639,13 @@ static int __init fadump_build_cpu_notes(const struct fadump_mem_struct *fdm)
|
||||||
fdh = __va(fw_dump.fadumphdr_addr);
|
fdh = __va(fw_dump.fadumphdr_addr);
|
||||||
|
|
||||||
for (i = 0; i < num_cpus; i++) {
|
for (i = 0; i < num_cpus; i++) {
|
||||||
if (reg_entry->reg_id != REG_ID("CPUSTRT")) {
|
if (be64_to_cpu(reg_entry->reg_id) != REG_ID("CPUSTRT")) {
|
||||||
printk(KERN_ERR "Unable to read CPU state data\n");
|
printk(KERN_ERR "Unable to read CPU state data\n");
|
||||||
rc = -ENOENT;
|
rc = -ENOENT;
|
||||||
goto error_out;
|
goto error_out;
|
||||||
}
|
}
|
||||||
/* Lower 4 bytes of reg_value contains logical cpu id */
|
/* Lower 4 bytes of reg_value contains logical cpu id */
|
||||||
cpu = reg_entry->reg_value & FADUMP_CPU_ID_MASK;
|
cpu = be64_to_cpu(reg_entry->reg_value) & FADUMP_CPU_ID_MASK;
|
||||||
if (fdh && !cpumask_test_cpu(cpu, &fdh->cpu_online_mask)) {
|
if (fdh && !cpumask_test_cpu(cpu, &fdh->cpu_online_mask)) {
|
||||||
SKIP_TO_NEXT_CPU(reg_entry);
|
SKIP_TO_NEXT_CPU(reg_entry);
|
||||||
continue;
|
continue;
|
||||||
|
@ -692,7 +692,7 @@ static int __init process_fadump(const struct fadump_mem_struct *fdm_active)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
/* Check if the dump data is valid. */
|
/* Check if the dump data is valid. */
|
||||||
if ((fdm_active->header.dump_status_flag == FADUMP_ERROR_FLAG) ||
|
if ((be16_to_cpu(fdm_active->header.dump_status_flag) == FADUMP_ERROR_FLAG) ||
|
||||||
(fdm_active->cpu_state_data.error_flags != 0) ||
|
(fdm_active->cpu_state_data.error_flags != 0) ||
|
||||||
(fdm_active->rmr_region.error_flags != 0)) {
|
(fdm_active->rmr_region.error_flags != 0)) {
|
||||||
printk(KERN_ERR "Dump taken by platform is not valid\n");
|
printk(KERN_ERR "Dump taken by platform is not valid\n");
|
||||||
|
@ -828,7 +828,7 @@ static void fadump_setup_crash_memory_ranges(void)
|
||||||
static inline unsigned long fadump_relocate(unsigned long paddr)
|
static inline unsigned long fadump_relocate(unsigned long paddr)
|
||||||
{
|
{
|
||||||
if (paddr > RMA_START && paddr < fw_dump.boot_memory_size)
|
if (paddr > RMA_START && paddr < fw_dump.boot_memory_size)
|
||||||
return fdm.rmr_region.destination_address + paddr;
|
return be64_to_cpu(fdm.rmr_region.destination_address) + paddr;
|
||||||
else
|
else
|
||||||
return paddr;
|
return paddr;
|
||||||
}
|
}
|
||||||
|
@ -902,7 +902,7 @@ static int fadump_create_elfcore_headers(char *bufp)
|
||||||
* to the specified destination_address. Hence set
|
* to the specified destination_address. Hence set
|
||||||
* the correct offset.
|
* the correct offset.
|
||||||
*/
|
*/
|
||||||
phdr->p_offset = fdm.rmr_region.destination_address;
|
phdr->p_offset = be64_to_cpu(fdm.rmr_region.destination_address);
|
||||||
}
|
}
|
||||||
|
|
||||||
phdr->p_paddr = mbase;
|
phdr->p_paddr = mbase;
|
||||||
|
@ -951,7 +951,7 @@ static void register_fadump(void)
|
||||||
|
|
||||||
fadump_setup_crash_memory_ranges();
|
fadump_setup_crash_memory_ranges();
|
||||||
|
|
||||||
addr = fdm.rmr_region.destination_address + fdm.rmr_region.source_len;
|
addr = be64_to_cpu(fdm.rmr_region.destination_address) + be64_to_cpu(fdm.rmr_region.source_len);
|
||||||
/* Initialize fadump crash info header. */
|
/* Initialize fadump crash info header. */
|
||||||
addr = init_fadump_header(addr);
|
addr = init_fadump_header(addr);
|
||||||
vaddr = __va(addr);
|
vaddr = __va(addr);
|
||||||
|
@ -1023,7 +1023,7 @@ void fadump_cleanup(void)
|
||||||
/* Invalidate the registration only if dump is active. */
|
/* Invalidate the registration only if dump is active. */
|
||||||
if (fw_dump.dump_active) {
|
if (fw_dump.dump_active) {
|
||||||
init_fadump_mem_struct(&fdm,
|
init_fadump_mem_struct(&fdm,
|
||||||
fdm_active->cpu_state_data.destination_address);
|
be64_to_cpu(fdm_active->cpu_state_data.destination_address));
|
||||||
fadump_invalidate_dump(&fdm);
|
fadump_invalidate_dump(&fdm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1063,7 +1063,7 @@ static void fadump_invalidate_release_mem(void)
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
destination_address = fdm_active->cpu_state_data.destination_address;
|
destination_address = be64_to_cpu(fdm_active->cpu_state_data.destination_address);
|
||||||
fadump_cleanup();
|
fadump_cleanup();
|
||||||
mutex_unlock(&fadump_mutex);
|
mutex_unlock(&fadump_mutex);
|
||||||
|
|
||||||
|
@ -1183,31 +1183,31 @@ static int fadump_region_show(struct seq_file *m, void *private)
|
||||||
seq_printf(m,
|
seq_printf(m,
|
||||||
"CPU : [%#016llx-%#016llx] %#llx bytes, "
|
"CPU : [%#016llx-%#016llx] %#llx bytes, "
|
||||||
"Dumped: %#llx\n",
|
"Dumped: %#llx\n",
|
||||||
fdm_ptr->cpu_state_data.destination_address,
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address),
|
||||||
fdm_ptr->cpu_state_data.destination_address +
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address) +
|
||||||
fdm_ptr->cpu_state_data.source_len - 1,
|
be64_to_cpu(fdm_ptr->cpu_state_data.source_len) - 1,
|
||||||
fdm_ptr->cpu_state_data.source_len,
|
be64_to_cpu(fdm_ptr->cpu_state_data.source_len),
|
||||||
fdm_ptr->cpu_state_data.bytes_dumped);
|
be64_to_cpu(fdm_ptr->cpu_state_data.bytes_dumped));
|
||||||
seq_printf(m,
|
seq_printf(m,
|
||||||
"HPTE: [%#016llx-%#016llx] %#llx bytes, "
|
"HPTE: [%#016llx-%#016llx] %#llx bytes, "
|
||||||
"Dumped: %#llx\n",
|
"Dumped: %#llx\n",
|
||||||
fdm_ptr->hpte_region.destination_address,
|
be64_to_cpu(fdm_ptr->hpte_region.destination_address),
|
||||||
fdm_ptr->hpte_region.destination_address +
|
be64_to_cpu(fdm_ptr->hpte_region.destination_address) +
|
||||||
fdm_ptr->hpte_region.source_len - 1,
|
be64_to_cpu(fdm_ptr->hpte_region.source_len) - 1,
|
||||||
fdm_ptr->hpte_region.source_len,
|
be64_to_cpu(fdm_ptr->hpte_region.source_len),
|
||||||
fdm_ptr->hpte_region.bytes_dumped);
|
be64_to_cpu(fdm_ptr->hpte_region.bytes_dumped));
|
||||||
seq_printf(m,
|
seq_printf(m,
|
||||||
"DUMP: [%#016llx-%#016llx] %#llx bytes, "
|
"DUMP: [%#016llx-%#016llx] %#llx bytes, "
|
||||||
"Dumped: %#llx\n",
|
"Dumped: %#llx\n",
|
||||||
fdm_ptr->rmr_region.destination_address,
|
be64_to_cpu(fdm_ptr->rmr_region.destination_address),
|
||||||
fdm_ptr->rmr_region.destination_address +
|
be64_to_cpu(fdm_ptr->rmr_region.destination_address) +
|
||||||
fdm_ptr->rmr_region.source_len - 1,
|
be64_to_cpu(fdm_ptr->rmr_region.source_len) - 1,
|
||||||
fdm_ptr->rmr_region.source_len,
|
be64_to_cpu(fdm_ptr->rmr_region.source_len),
|
||||||
fdm_ptr->rmr_region.bytes_dumped);
|
be64_to_cpu(fdm_ptr->rmr_region.bytes_dumped));
|
||||||
|
|
||||||
if (!fdm_active ||
|
if (!fdm_active ||
|
||||||
(fw_dump.reserve_dump_area_start ==
|
(fw_dump.reserve_dump_area_start ==
|
||||||
fdm_ptr->cpu_state_data.destination_address))
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address)))
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
/* Dump is active. Show reserved memory region. */
|
/* Dump is active. Show reserved memory region. */
|
||||||
|
@ -1215,10 +1215,10 @@ static int fadump_region_show(struct seq_file *m, void *private)
|
||||||
" : [%#016llx-%#016llx] %#llx bytes, "
|
" : [%#016llx-%#016llx] %#llx bytes, "
|
||||||
"Dumped: %#llx\n",
|
"Dumped: %#llx\n",
|
||||||
(unsigned long long)fw_dump.reserve_dump_area_start,
|
(unsigned long long)fw_dump.reserve_dump_area_start,
|
||||||
fdm_ptr->cpu_state_data.destination_address - 1,
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address) - 1,
|
||||||
fdm_ptr->cpu_state_data.destination_address -
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address) -
|
||||||
fw_dump.reserve_dump_area_start,
|
fw_dump.reserve_dump_area_start,
|
||||||
fdm_ptr->cpu_state_data.destination_address -
|
be64_to_cpu(fdm_ptr->cpu_state_data.destination_address) -
|
||||||
fw_dump.reserve_dump_area_start);
|
fw_dump.reserve_dump_area_start);
|
||||||
out:
|
out:
|
||||||
if (fdm_active)
|
if (fdm_active)
|
||||||
|
|
|
@ -99,8 +99,6 @@ int copro_calculate_slb(struct mm_struct *mm, u64 ea, struct copro_slb *slb)
|
||||||
u64 vsid;
|
u64 vsid;
|
||||||
int psize, ssize;
|
int psize, ssize;
|
||||||
|
|
||||||
slb->esid = (ea & ESID_MASK) | SLB_ESID_V;
|
|
||||||
|
|
||||||
switch (REGION_ID(ea)) {
|
switch (REGION_ID(ea)) {
|
||||||
case USER_REGION_ID:
|
case USER_REGION_ID:
|
||||||
pr_devel("%s: 0x%llx -- USER_REGION_ID\n", __func__, ea);
|
pr_devel("%s: 0x%llx -- USER_REGION_ID\n", __func__, ea);
|
||||||
|
@ -133,6 +131,7 @@ int copro_calculate_slb(struct mm_struct *mm, u64 ea, struct copro_slb *slb)
|
||||||
vsid |= mmu_psize_defs[psize].sllp |
|
vsid |= mmu_psize_defs[psize].sllp |
|
||||||
((ssize == MMU_SEGSIZE_1T) ? SLB_VSID_B_1T : 0);
|
((ssize == MMU_SEGSIZE_1T) ? SLB_VSID_B_1T : 0);
|
||||||
|
|
||||||
|
slb->esid = (ea & (ssize == MMU_SEGSIZE_1T ? ESID_MASK_1T : ESID_MASK)) | SLB_ESID_V;
|
||||||
slb->vsid = vsid;
|
slb->vsid = vsid;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -103,7 +103,7 @@ unsigned long __max_low_memory = MAX_LOW_MEM;
|
||||||
/*
|
/*
|
||||||
* Check for command-line options that affect what MMU_init will do.
|
* Check for command-line options that affect what MMU_init will do.
|
||||||
*/
|
*/
|
||||||
void MMU_setup(void)
|
void __init MMU_setup(void)
|
||||||
{
|
{
|
||||||
/* Check for nobats option (used in mapin_ram). */
|
/* Check for nobats option (used in mapin_ram). */
|
||||||
if (strstr(boot_command_line, "nobats")) {
|
if (strstr(boot_command_line, "nobats")) {
|
||||||
|
|
|
@ -1509,11 +1509,14 @@ static int update_cpu_topology(void *data)
|
||||||
cpu = smp_processor_id();
|
cpu = smp_processor_id();
|
||||||
|
|
||||||
for (update = data; update; update = update->next) {
|
for (update = data; update; update = update->next) {
|
||||||
|
int new_nid = update->new_nid;
|
||||||
if (cpu != update->cpu)
|
if (cpu != update->cpu)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
unmap_cpu_from_node(update->cpu);
|
unmap_cpu_from_node(cpu);
|
||||||
map_cpu_to_node(update->cpu, update->new_nid);
|
map_cpu_to_node(cpu, new_nid);
|
||||||
|
set_cpu_numa_node(cpu, new_nid);
|
||||||
|
set_cpu_numa_mem(cpu, local_memory_node(new_nid));
|
||||||
vdso_getcpu_init();
|
vdso_getcpu_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -682,6 +682,7 @@ void slice_set_range_psize(struct mm_struct *mm, unsigned long start,
|
||||||
slice_convert(mm, mask, psize);
|
slice_convert(mm, mask, psize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_HUGETLB_PAGE
|
||||||
/*
|
/*
|
||||||
* is_hugepage_only_range() is used by generic code to verify whether
|
* is_hugepage_only_range() is used by generic code to verify whether
|
||||||
* a normal mmap mapping (non hugetlbfs) is valid on a given area.
|
* a normal mmap mapping (non hugetlbfs) is valid on a given area.
|
||||||
|
@ -726,4 +727,4 @@ int is_hugepage_only_range(struct mm_struct *mm, unsigned long addr,
|
||||||
#endif
|
#endif
|
||||||
return !slice_check_fit(mask, available);
|
return !slice_check_fit(mask, available);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
|
@ -417,11 +417,6 @@ static int h_24x7_event_add(struct perf_event *event, int flags)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int h_24x7_event_idx(struct perf_event *event)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct pmu h_24x7_pmu = {
|
static struct pmu h_24x7_pmu = {
|
||||||
.task_ctx_nr = perf_invalid_context,
|
.task_ctx_nr = perf_invalid_context,
|
||||||
|
|
||||||
|
@ -433,7 +428,6 @@ static struct pmu h_24x7_pmu = {
|
||||||
.start = h_24x7_event_start,
|
.start = h_24x7_event_start,
|
||||||
.stop = h_24x7_event_stop,
|
.stop = h_24x7_event_stop,
|
||||||
.read = h_24x7_event_update,
|
.read = h_24x7_event_update,
|
||||||
.event_idx = h_24x7_event_idx,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int hv_24x7_init(void)
|
static int hv_24x7_init(void)
|
||||||
|
|
|
@ -246,11 +246,6 @@ static int h_gpci_event_init(struct perf_event *event)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int h_gpci_event_idx(struct perf_event *event)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct pmu h_gpci_pmu = {
|
static struct pmu h_gpci_pmu = {
|
||||||
.task_ctx_nr = perf_invalid_context,
|
.task_ctx_nr = perf_invalid_context,
|
||||||
|
|
||||||
|
@ -262,7 +257,6 @@ static struct pmu h_gpci_pmu = {
|
||||||
.start = h_gpci_event_start,
|
.start = h_gpci_event_start,
|
||||||
.stop = h_gpci_event_stop,
|
.stop = h_gpci_event_stop,
|
||||||
.read = h_gpci_event_update,
|
.read = h_gpci_event_update,
|
||||||
.event_idx = h_gpci_event_idx,
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static int hv_gpci_init(void)
|
static int hv_gpci_init(void)
|
||||||
|
|
|
@ -191,7 +191,6 @@ static ssize_t lpc_debug_read(struct file *filp, char __user *ubuf,
|
||||||
{
|
{
|
||||||
struct lpc_debugfs_entry *lpc = filp->private_data;
|
struct lpc_debugfs_entry *lpc = filp->private_data;
|
||||||
u32 data, pos, len, todo;
|
u32 data, pos, len, todo;
|
||||||
__be32 bedata;
|
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (!access_ok(VERIFY_WRITE, ubuf, count))
|
if (!access_ok(VERIFY_WRITE, ubuf, count))
|
||||||
|
@ -214,18 +213,57 @@ static ssize_t lpc_debug_read(struct file *filp, char __user *ubuf,
|
||||||
len = 2;
|
len = 2;
|
||||||
}
|
}
|
||||||
rc = opal_lpc_read(opal_lpc_chip_id, lpc->lpc_type, pos,
|
rc = opal_lpc_read(opal_lpc_chip_id, lpc->lpc_type, pos,
|
||||||
&bedata, len);
|
&data, len);
|
||||||
if (rc)
|
if (rc)
|
||||||
return -ENXIO;
|
return -ENXIO;
|
||||||
data = be32_to_cpu(bedata);
|
|
||||||
|
/*
|
||||||
|
* Now there is some trickery with the data returned by OPAL
|
||||||
|
* as it's the desired data right justified in a 32-bit BE
|
||||||
|
* word.
|
||||||
|
*
|
||||||
|
* This is a very bad interface and I'm to blame for it :-(
|
||||||
|
*
|
||||||
|
* So we can't just apply a 32-bit swap to what comes from OPAL,
|
||||||
|
* because user space expects the *bytes* to be in their proper
|
||||||
|
* respective positions (ie, LPC position).
|
||||||
|
*
|
||||||
|
* So what we really want to do here is to shift data right
|
||||||
|
* appropriately on a LE kernel.
|
||||||
|
*
|
||||||
|
* IE. If the LPC transaction has bytes B0, B1, B2 and B3 in that
|
||||||
|
* order, we have in memory written to by OPAL at the "data"
|
||||||
|
* pointer:
|
||||||
|
*
|
||||||
|
* Bytes: OPAL "data" LE "data"
|
||||||
|
* 32-bit: B0 B1 B2 B3 B0B1B2B3 B3B2B1B0
|
||||||
|
* 16-bit: B0 B1 0000B0B1 B1B00000
|
||||||
|
* 8-bit: B0 000000B0 B0000000
|
||||||
|
*
|
||||||
|
* So a BE kernel will have the leftmost of the above in the MSB
|
||||||
|
* and rightmost in the LSB and can just then "cast" the u32 "data"
|
||||||
|
* down to the appropriate quantity and write it.
|
||||||
|
*
|
||||||
|
* However, an LE kernel can't. It doesn't need to swap because a
|
||||||
|
* load from data followed by a store to user are going to preserve
|
||||||
|
* the byte ordering which is the wire byte order which is what the
|
||||||
|
* user wants, but in order to "crop" to the right size, we need to
|
||||||
|
* shift right first.
|
||||||
|
*/
|
||||||
switch(len) {
|
switch(len) {
|
||||||
case 4:
|
case 4:
|
||||||
rc = __put_user((u32)data, (u32 __user *)ubuf);
|
rc = __put_user((u32)data, (u32 __user *)ubuf);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
data >>= 16;
|
||||||
|
#endif
|
||||||
rc = __put_user((u16)data, (u16 __user *)ubuf);
|
rc = __put_user((u16)data, (u16 __user *)ubuf);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
#ifdef __LITTLE_ENDIAN__
|
||||||
|
data >>= 24;
|
||||||
|
#endif
|
||||||
rc = __put_user((u8)data, (u8 __user *)ubuf);
|
rc = __put_user((u8)data, (u8 __user *)ubuf);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -265,12 +303,31 @@ static ssize_t lpc_debug_write(struct file *filp, const char __user *ubuf,
|
||||||
else if (todo > 1 && (pos & 1) == 0)
|
else if (todo > 1 && (pos & 1) == 0)
|
||||||
len = 2;
|
len = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Similarly to the read case, we have some trickery here but
|
||||||
|
* it's different to handle. We need to pass the value to OPAL in
|
||||||
|
* a register whose layout depends on the access size. We want
|
||||||
|
* to reproduce the memory layout of the user, however we aren't
|
||||||
|
* doing a load from user and a store to another memory location
|
||||||
|
* which would achieve that. Here we pass the value to OPAL via
|
||||||
|
* a register which is expected to contain the "BE" interpretation
|
||||||
|
* of the byte sequence. IE: for a 32-bit access, byte 0 should be
|
||||||
|
* in the MSB. So here we *do* need to byteswap on LE.
|
||||||
|
*
|
||||||
|
* User bytes: LE "data" OPAL "data"
|
||||||
|
* 32-bit: B0 B1 B2 B3 B3B2B1B0 B0B1B2B3
|
||||||
|
* 16-bit: B0 B1 0000B1B0 0000B0B1
|
||||||
|
* 8-bit: B0 000000B0 000000B0
|
||||||
|
*/
|
||||||
switch(len) {
|
switch(len) {
|
||||||
case 4:
|
case 4:
|
||||||
rc = __get_user(data, (u32 __user *)ubuf);
|
rc = __get_user(data, (u32 __user *)ubuf);
|
||||||
|
data = cpu_to_be32(data);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
rc = __get_user(data, (u16 __user *)ubuf);
|
rc = __get_user(data, (u16 __user *)ubuf);
|
||||||
|
data = cpu_to_be16(data);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
rc = __get_user(data, (u8 __user *)ubuf);
|
rc = __get_user(data, (u8 __user *)ubuf);
|
||||||
|
|
|
@ -58,7 +58,7 @@ END_FTR_SECTION(0, 1); \
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define OPAL_CALL(name, token) \
|
#define OPAL_CALL(name, token) \
|
||||||
_GLOBAL(name); \
|
_GLOBAL_TOC(name); \
|
||||||
mflr r0; \
|
mflr r0; \
|
||||||
std r0,16(r1); \
|
std r0,16(r1); \
|
||||||
li r0,token; \
|
li r0,token; \
|
||||||
|
|
|
@ -382,7 +382,7 @@ static int dlpar_online_cpu(struct device_node *dn)
|
||||||
BUG_ON(get_cpu_current_state(cpu)
|
BUG_ON(get_cpu_current_state(cpu)
|
||||||
!= CPU_STATE_OFFLINE);
|
!= CPU_STATE_OFFLINE);
|
||||||
cpu_maps_update_done();
|
cpu_maps_update_done();
|
||||||
rc = cpu_up(cpu);
|
rc = device_online(get_cpu_device(cpu));
|
||||||
if (rc)
|
if (rc)
|
||||||
goto out;
|
goto out;
|
||||||
cpu_maps_update_begin();
|
cpu_maps_update_begin();
|
||||||
|
@ -467,7 +467,7 @@ static int dlpar_offline_cpu(struct device_node *dn)
|
||||||
if (get_cpu_current_state(cpu) == CPU_STATE_ONLINE) {
|
if (get_cpu_current_state(cpu) == CPU_STATE_ONLINE) {
|
||||||
set_preferred_offline_state(cpu, CPU_STATE_OFFLINE);
|
set_preferred_offline_state(cpu, CPU_STATE_OFFLINE);
|
||||||
cpu_maps_update_done();
|
cpu_maps_update_done();
|
||||||
rc = cpu_down(cpu);
|
rc = device_offline(get_cpu_device(cpu));
|
||||||
if (rc)
|
if (rc)
|
||||||
goto out;
|
goto out;
|
||||||
cpu_maps_update_begin();
|
cpu_maps_update_begin();
|
||||||
|
|
|
@ -43,6 +43,7 @@
|
||||||
#include <asm/trace.h>
|
#include <asm/trace.h>
|
||||||
#include <asm/firmware.h>
|
#include <asm/firmware.h>
|
||||||
#include <asm/plpar_wrappers.h>
|
#include <asm/plpar_wrappers.h>
|
||||||
|
#include <asm/fadump.h>
|
||||||
|
|
||||||
#include "pseries.h"
|
#include "pseries.h"
|
||||||
|
|
||||||
|
@ -247,8 +248,17 @@ static void pSeries_lpar_hptab_clear(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __LITTLE_ENDIAN__
|
#ifdef __LITTLE_ENDIAN__
|
||||||
/* Reset exceptions to big endian */
|
/*
|
||||||
if (firmware_has_feature(FW_FEATURE_SET_MODE)) {
|
* Reset exceptions to big endian.
|
||||||
|
*
|
||||||
|
* FIXME this is a hack for kexec, we need to reset the exception
|
||||||
|
* endian before starting the new kernel and this is a convenient place
|
||||||
|
* to do it.
|
||||||
|
*
|
||||||
|
* This is also called on boot when a fadump happens. In that case we
|
||||||
|
* must not change the exception endian mode.
|
||||||
|
*/
|
||||||
|
if (firmware_has_feature(FW_FEATURE_SET_MODE) && !is_fadump_active()) {
|
||||||
long rc;
|
long rc;
|
||||||
|
|
||||||
rc = pseries_big_endian_exceptions();
|
rc = pseries_big_endian_exceptions();
|
||||||
|
|
|
@ -35,7 +35,6 @@ CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODULE_FORCE_UNLOAD=y
|
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_BLK_DEV_INTEGRITY=y
|
|
||||||
CONFIG_BLK_DEV_THROTTLING=y
|
CONFIG_BLK_DEV_THROTTLING=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
CONFIG_IBM_PARTITION=y
|
CONFIG_IBM_PARTITION=y
|
||||||
|
@ -245,6 +244,7 @@ CONFIG_NF_TABLES_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
||||||
CONFIG_NF_TABLES_ARP=m
|
CONFIG_NF_TABLES_ARP=m
|
||||||
|
CONFIG_NF_NAT_IPV4=m
|
||||||
CONFIG_IP_NF_IPTABLES=m
|
CONFIG_IP_NF_IPTABLES=m
|
||||||
CONFIG_IP_NF_MATCH_AH=m
|
CONFIG_IP_NF_MATCH_AH=m
|
||||||
CONFIG_IP_NF_MATCH_ECN=m
|
CONFIG_IP_NF_MATCH_ECN=m
|
||||||
|
@ -252,11 +252,6 @@ CONFIG_IP_NF_MATCH_RPFILTER=m
|
||||||
CONFIG_IP_NF_MATCH_TTL=m
|
CONFIG_IP_NF_MATCH_TTL=m
|
||||||
CONFIG_IP_NF_FILTER=m
|
CONFIG_IP_NF_FILTER=m
|
||||||
CONFIG_IP_NF_TARGET_REJECT=m
|
CONFIG_IP_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP_NF_TARGET_ULOG=m
|
|
||||||
CONFIG_NF_NAT_IPV4=m
|
|
||||||
CONFIG_IP_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP_NF_TARGET_NETMAP=m
|
|
||||||
CONFIG_IP_NF_TARGET_REDIRECT=m
|
|
||||||
CONFIG_IP_NF_MANGLE=m
|
CONFIG_IP_NF_MANGLE=m
|
||||||
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
||||||
CONFIG_IP_NF_TARGET_ECN=m
|
CONFIG_IP_NF_TARGET_ECN=m
|
||||||
|
@ -270,6 +265,7 @@ CONFIG_NF_CONNTRACK_IPV6=m
|
||||||
CONFIG_NF_TABLES_IPV6=m
|
CONFIG_NF_TABLES_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
||||||
|
CONFIG_NF_NAT_IPV6=m
|
||||||
CONFIG_IP6_NF_IPTABLES=m
|
CONFIG_IP6_NF_IPTABLES=m
|
||||||
CONFIG_IP6_NF_MATCH_AH=m
|
CONFIG_IP6_NF_MATCH_AH=m
|
||||||
CONFIG_IP6_NF_MATCH_EUI64=m
|
CONFIG_IP6_NF_MATCH_EUI64=m
|
||||||
|
@ -286,9 +282,6 @@ CONFIG_IP6_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP6_NF_MANGLE=m
|
CONFIG_IP6_NF_MANGLE=m
|
||||||
CONFIG_IP6_NF_RAW=m
|
CONFIG_IP6_NF_RAW=m
|
||||||
CONFIG_IP6_NF_SECURITY=m
|
CONFIG_IP6_NF_SECURITY=m
|
||||||
CONFIG_NF_NAT_IPV6=m
|
|
||||||
CONFIG_IP6_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP6_NF_TARGET_NPT=m
|
|
||||||
CONFIG_NF_TABLES_BRIDGE=m
|
CONFIG_NF_TABLES_BRIDGE=m
|
||||||
CONFIG_NET_SCTPPROBE=m
|
CONFIG_NET_SCTPPROBE=m
|
||||||
CONFIG_RDS=m
|
CONFIG_RDS=m
|
||||||
|
@ -374,14 +367,13 @@ CONFIG_BLK_DEV_SR=m
|
||||||
CONFIG_CHR_DEV_SG=y
|
CONFIG_CHR_DEV_SG=y
|
||||||
CONFIG_CHR_DEV_SCH=m
|
CONFIG_CHR_DEV_SCH=m
|
||||||
CONFIG_SCSI_ENCLOSURE=m
|
CONFIG_SCSI_ENCLOSURE=m
|
||||||
CONFIG_SCSI_MULTI_LUN=y
|
|
||||||
CONFIG_SCSI_CONSTANTS=y
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
CONFIG_SCSI_LOGGING=y
|
CONFIG_SCSI_LOGGING=y
|
||||||
CONFIG_SCSI_SPI_ATTRS=m
|
CONFIG_SCSI_SPI_ATTRS=m
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SAS_LIBSAS=m
|
CONFIG_SCSI_SAS_LIBSAS=m
|
||||||
CONFIG_SCSI_SRP_ATTRS=m
|
CONFIG_SCSI_SRP_ATTRS=m
|
||||||
CONFIG_ISCSI_TCP=m
|
CONFIG_ISCSI_TCP=m
|
||||||
CONFIG_LIBFCOE=m
|
|
||||||
CONFIG_SCSI_DEBUG=m
|
CONFIG_SCSI_DEBUG=m
|
||||||
CONFIG_ZFCP=y
|
CONFIG_ZFCP=y
|
||||||
CONFIG_SCSI_VIRTIO=m
|
CONFIG_SCSI_VIRTIO=m
|
||||||
|
@ -427,7 +419,6 @@ CONFIG_VIRTIO_NET=m
|
||||||
CONFIG_NLMON=m
|
CONFIG_NLMON=m
|
||||||
CONFIG_VHOST_NET=m
|
CONFIG_VHOST_NET=m
|
||||||
# CONFIG_NET_VENDOR_ARC is not set
|
# CONFIG_NET_VENDOR_ARC is not set
|
||||||
# CONFIG_NET_CADENCE is not set
|
|
||||||
# CONFIG_NET_VENDOR_CHELSIO is not set
|
# CONFIG_NET_VENDOR_CHELSIO is not set
|
||||||
# CONFIG_NET_VENDOR_INTEL is not set
|
# CONFIG_NET_VENDOR_INTEL is not set
|
||||||
# CONFIG_NET_VENDOR_MARVELL is not set
|
# CONFIG_NET_VENDOR_MARVELL is not set
|
||||||
|
@ -481,14 +472,14 @@ CONFIG_JFS_FS=m
|
||||||
CONFIG_JFS_POSIX_ACL=y
|
CONFIG_JFS_POSIX_ACL=y
|
||||||
CONFIG_JFS_SECURITY=y
|
CONFIG_JFS_SECURITY=y
|
||||||
CONFIG_JFS_STATISTICS=y
|
CONFIG_JFS_STATISTICS=y
|
||||||
CONFIG_XFS_FS=m
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_XFS_QUOTA=y
|
CONFIG_XFS_QUOTA=y
|
||||||
CONFIG_XFS_POSIX_ACL=y
|
CONFIG_XFS_POSIX_ACL=y
|
||||||
CONFIG_XFS_RT=y
|
CONFIG_XFS_RT=y
|
||||||
CONFIG_XFS_DEBUG=y
|
CONFIG_XFS_DEBUG=y
|
||||||
CONFIG_GFS2_FS=m
|
CONFIG_GFS2_FS=m
|
||||||
CONFIG_OCFS2_FS=m
|
CONFIG_OCFS2_FS=m
|
||||||
CONFIG_BTRFS_FS=m
|
CONFIG_BTRFS_FS=y
|
||||||
CONFIG_BTRFS_FS_POSIX_ACL=y
|
CONFIG_BTRFS_FS_POSIX_ACL=y
|
||||||
CONFIG_NILFS2_FS=m
|
CONFIG_NILFS2_FS=m
|
||||||
CONFIG_FANOTIFY=y
|
CONFIG_FANOTIFY=y
|
||||||
|
@ -574,7 +565,6 @@ CONFIG_DEBUG_SHIRQ=y
|
||||||
CONFIG_DETECT_HUNG_TASK=y
|
CONFIG_DETECT_HUNG_TASK=y
|
||||||
CONFIG_TIMER_STATS=y
|
CONFIG_TIMER_STATS=y
|
||||||
CONFIG_DEBUG_RT_MUTEXES=y
|
CONFIG_DEBUG_RT_MUTEXES=y
|
||||||
CONFIG_RT_MUTEX_TESTER=y
|
|
||||||
CONFIG_DEBUG_WW_MUTEX_SLOWPATH=y
|
CONFIG_DEBUG_WW_MUTEX_SLOWPATH=y
|
||||||
CONFIG_PROVE_LOCKING=y
|
CONFIG_PROVE_LOCKING=y
|
||||||
CONFIG_LOCK_STAT=y
|
CONFIG_LOCK_STAT=y
|
||||||
|
@ -600,8 +590,13 @@ CONFIG_FAULT_INJECTION_DEBUG_FS=y
|
||||||
CONFIG_FAULT_INJECTION_STACKTRACE_FILTER=y
|
CONFIG_FAULT_INJECTION_STACKTRACE_FILTER=y
|
||||||
CONFIG_LATENCYTOP=y
|
CONFIG_LATENCYTOP=y
|
||||||
CONFIG_DEBUG_STRICT_USER_COPY_CHECKS=y
|
CONFIG_DEBUG_STRICT_USER_COPY_CHECKS=y
|
||||||
|
CONFIG_IRQSOFF_TRACER=y
|
||||||
|
CONFIG_PREEMPT_TRACER=y
|
||||||
|
CONFIG_SCHED_TRACER=y
|
||||||
|
CONFIG_FTRACE_SYSCALLS=y
|
||||||
|
CONFIG_STACK_TRACER=y
|
||||||
CONFIG_BLK_DEV_IO_TRACE=y
|
CONFIG_BLK_DEV_IO_TRACE=y
|
||||||
# CONFIG_KPROBE_EVENT is not set
|
CONFIG_UPROBE_EVENT=y
|
||||||
CONFIG_LKDTM=m
|
CONFIG_LKDTM=m
|
||||||
CONFIG_TEST_LIST_SORT=y
|
CONFIG_TEST_LIST_SORT=y
|
||||||
CONFIG_KPROBES_SANITY_TEST=y
|
CONFIG_KPROBES_SANITY_TEST=y
|
||||||
|
@ -609,7 +604,10 @@ CONFIG_RBTREE_TEST=y
|
||||||
CONFIG_INTERVAL_TREE_TEST=m
|
CONFIG_INTERVAL_TREE_TEST=m
|
||||||
CONFIG_PERCPU_TEST=m
|
CONFIG_PERCPU_TEST=m
|
||||||
CONFIG_ATOMIC64_SELFTEST=y
|
CONFIG_ATOMIC64_SELFTEST=y
|
||||||
|
CONFIG_TEST_STRING_HELPERS=y
|
||||||
|
CONFIG_TEST_KSTRTOX=y
|
||||||
CONFIG_DMA_API_DEBUG=y
|
CONFIG_DMA_API_DEBUG=y
|
||||||
|
CONFIG_TEST_BPF=m
|
||||||
# CONFIG_STRICT_DEVMEM is not set
|
# CONFIG_STRICT_DEVMEM is not set
|
||||||
CONFIG_S390_PTDUMP=y
|
CONFIG_S390_PTDUMP=y
|
||||||
CONFIG_ENCRYPTED_KEYS=m
|
CONFIG_ENCRYPTED_KEYS=m
|
||||||
|
@ -673,12 +671,6 @@ CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=m
|
||||||
CONFIG_X509_CERTIFICATE_PARSER=m
|
CONFIG_X509_CERTIFICATE_PARSER=m
|
||||||
CONFIG_CRC7=m
|
CONFIG_CRC7=m
|
||||||
CONFIG_CRC8=m
|
CONFIG_CRC8=m
|
||||||
CONFIG_XZ_DEC_X86=y
|
|
||||||
CONFIG_XZ_DEC_POWERPC=y
|
|
||||||
CONFIG_XZ_DEC_IA64=y
|
|
||||||
CONFIG_XZ_DEC_ARM=y
|
|
||||||
CONFIG_XZ_DEC_ARMTHUMB=y
|
|
||||||
CONFIG_XZ_DEC_SPARC=y
|
|
||||||
CONFIG_CORDIC=m
|
CONFIG_CORDIC=m
|
||||||
CONFIG_CMM=m
|
CONFIG_CMM=m
|
||||||
CONFIG_APPLDATA_BASE=y
|
CONFIG_APPLDATA_BASE=y
|
||||||
|
|
|
@ -35,7 +35,6 @@ CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODULE_FORCE_UNLOAD=y
|
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_BLK_DEV_INTEGRITY=y
|
|
||||||
CONFIG_BLK_DEV_THROTTLING=y
|
CONFIG_BLK_DEV_THROTTLING=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
CONFIG_IBM_PARTITION=y
|
CONFIG_IBM_PARTITION=y
|
||||||
|
@ -243,6 +242,7 @@ CONFIG_NF_TABLES_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
||||||
CONFIG_NF_TABLES_ARP=m
|
CONFIG_NF_TABLES_ARP=m
|
||||||
|
CONFIG_NF_NAT_IPV4=m
|
||||||
CONFIG_IP_NF_IPTABLES=m
|
CONFIG_IP_NF_IPTABLES=m
|
||||||
CONFIG_IP_NF_MATCH_AH=m
|
CONFIG_IP_NF_MATCH_AH=m
|
||||||
CONFIG_IP_NF_MATCH_ECN=m
|
CONFIG_IP_NF_MATCH_ECN=m
|
||||||
|
@ -250,11 +250,6 @@ CONFIG_IP_NF_MATCH_RPFILTER=m
|
||||||
CONFIG_IP_NF_MATCH_TTL=m
|
CONFIG_IP_NF_MATCH_TTL=m
|
||||||
CONFIG_IP_NF_FILTER=m
|
CONFIG_IP_NF_FILTER=m
|
||||||
CONFIG_IP_NF_TARGET_REJECT=m
|
CONFIG_IP_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP_NF_TARGET_ULOG=m
|
|
||||||
CONFIG_NF_NAT_IPV4=m
|
|
||||||
CONFIG_IP_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP_NF_TARGET_NETMAP=m
|
|
||||||
CONFIG_IP_NF_TARGET_REDIRECT=m
|
|
||||||
CONFIG_IP_NF_MANGLE=m
|
CONFIG_IP_NF_MANGLE=m
|
||||||
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
||||||
CONFIG_IP_NF_TARGET_ECN=m
|
CONFIG_IP_NF_TARGET_ECN=m
|
||||||
|
@ -268,6 +263,7 @@ CONFIG_NF_CONNTRACK_IPV6=m
|
||||||
CONFIG_NF_TABLES_IPV6=m
|
CONFIG_NF_TABLES_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
||||||
|
CONFIG_NF_NAT_IPV6=m
|
||||||
CONFIG_IP6_NF_IPTABLES=m
|
CONFIG_IP6_NF_IPTABLES=m
|
||||||
CONFIG_IP6_NF_MATCH_AH=m
|
CONFIG_IP6_NF_MATCH_AH=m
|
||||||
CONFIG_IP6_NF_MATCH_EUI64=m
|
CONFIG_IP6_NF_MATCH_EUI64=m
|
||||||
|
@ -284,9 +280,6 @@ CONFIG_IP6_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP6_NF_MANGLE=m
|
CONFIG_IP6_NF_MANGLE=m
|
||||||
CONFIG_IP6_NF_RAW=m
|
CONFIG_IP6_NF_RAW=m
|
||||||
CONFIG_IP6_NF_SECURITY=m
|
CONFIG_IP6_NF_SECURITY=m
|
||||||
CONFIG_NF_NAT_IPV6=m
|
|
||||||
CONFIG_IP6_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP6_NF_TARGET_NPT=m
|
|
||||||
CONFIG_NF_TABLES_BRIDGE=m
|
CONFIG_NF_TABLES_BRIDGE=m
|
||||||
CONFIG_NET_SCTPPROBE=m
|
CONFIG_NET_SCTPPROBE=m
|
||||||
CONFIG_RDS=m
|
CONFIG_RDS=m
|
||||||
|
@ -371,14 +364,13 @@ CONFIG_BLK_DEV_SR=m
|
||||||
CONFIG_CHR_DEV_SG=y
|
CONFIG_CHR_DEV_SG=y
|
||||||
CONFIG_CHR_DEV_SCH=m
|
CONFIG_CHR_DEV_SCH=m
|
||||||
CONFIG_SCSI_ENCLOSURE=m
|
CONFIG_SCSI_ENCLOSURE=m
|
||||||
CONFIG_SCSI_MULTI_LUN=y
|
|
||||||
CONFIG_SCSI_CONSTANTS=y
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
CONFIG_SCSI_LOGGING=y
|
CONFIG_SCSI_LOGGING=y
|
||||||
CONFIG_SCSI_SPI_ATTRS=m
|
CONFIG_SCSI_SPI_ATTRS=m
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SAS_LIBSAS=m
|
CONFIG_SCSI_SAS_LIBSAS=m
|
||||||
CONFIG_SCSI_SRP_ATTRS=m
|
CONFIG_SCSI_SRP_ATTRS=m
|
||||||
CONFIG_ISCSI_TCP=m
|
CONFIG_ISCSI_TCP=m
|
||||||
CONFIG_LIBFCOE=m
|
|
||||||
CONFIG_SCSI_DEBUG=m
|
CONFIG_SCSI_DEBUG=m
|
||||||
CONFIG_ZFCP=y
|
CONFIG_ZFCP=y
|
||||||
CONFIG_SCSI_VIRTIO=m
|
CONFIG_SCSI_VIRTIO=m
|
||||||
|
@ -424,7 +416,6 @@ CONFIG_VIRTIO_NET=m
|
||||||
CONFIG_NLMON=m
|
CONFIG_NLMON=m
|
||||||
CONFIG_VHOST_NET=m
|
CONFIG_VHOST_NET=m
|
||||||
# CONFIG_NET_VENDOR_ARC is not set
|
# CONFIG_NET_VENDOR_ARC is not set
|
||||||
# CONFIG_NET_CADENCE is not set
|
|
||||||
# CONFIG_NET_VENDOR_CHELSIO is not set
|
# CONFIG_NET_VENDOR_CHELSIO is not set
|
||||||
# CONFIG_NET_VENDOR_INTEL is not set
|
# CONFIG_NET_VENDOR_INTEL is not set
|
||||||
# CONFIG_NET_VENDOR_MARVELL is not set
|
# CONFIG_NET_VENDOR_MARVELL is not set
|
||||||
|
@ -478,13 +469,13 @@ CONFIG_JFS_FS=m
|
||||||
CONFIG_JFS_POSIX_ACL=y
|
CONFIG_JFS_POSIX_ACL=y
|
||||||
CONFIG_JFS_SECURITY=y
|
CONFIG_JFS_SECURITY=y
|
||||||
CONFIG_JFS_STATISTICS=y
|
CONFIG_JFS_STATISTICS=y
|
||||||
CONFIG_XFS_FS=m
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_XFS_QUOTA=y
|
CONFIG_XFS_QUOTA=y
|
||||||
CONFIG_XFS_POSIX_ACL=y
|
CONFIG_XFS_POSIX_ACL=y
|
||||||
CONFIG_XFS_RT=y
|
CONFIG_XFS_RT=y
|
||||||
CONFIG_GFS2_FS=m
|
CONFIG_GFS2_FS=m
|
||||||
CONFIG_OCFS2_FS=m
|
CONFIG_OCFS2_FS=m
|
||||||
CONFIG_BTRFS_FS=m
|
CONFIG_BTRFS_FS=y
|
||||||
CONFIG_BTRFS_FS_POSIX_ACL=y
|
CONFIG_BTRFS_FS_POSIX_ACL=y
|
||||||
CONFIG_NILFS2_FS=m
|
CONFIG_NILFS2_FS=m
|
||||||
CONFIG_FANOTIFY=y
|
CONFIG_FANOTIFY=y
|
||||||
|
@ -626,12 +617,6 @@ CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=m
|
||||||
CONFIG_X509_CERTIFICATE_PARSER=m
|
CONFIG_X509_CERTIFICATE_PARSER=m
|
||||||
CONFIG_CRC7=m
|
CONFIG_CRC7=m
|
||||||
CONFIG_CRC8=m
|
CONFIG_CRC8=m
|
||||||
CONFIG_XZ_DEC_X86=y
|
|
||||||
CONFIG_XZ_DEC_POWERPC=y
|
|
||||||
CONFIG_XZ_DEC_IA64=y
|
|
||||||
CONFIG_XZ_DEC_ARM=y
|
|
||||||
CONFIG_XZ_DEC_ARMTHUMB=y
|
|
||||||
CONFIG_XZ_DEC_SPARC=y
|
|
||||||
CONFIG_CORDIC=m
|
CONFIG_CORDIC=m
|
||||||
CONFIG_CMM=m
|
CONFIG_CMM=m
|
||||||
CONFIG_APPLDATA_BASE=y
|
CONFIG_APPLDATA_BASE=y
|
||||||
|
|
|
@ -33,7 +33,6 @@ CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODULE_FORCE_UNLOAD=y
|
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_BLK_DEV_INTEGRITY=y
|
|
||||||
CONFIG_BLK_DEV_THROTTLING=y
|
CONFIG_BLK_DEV_THROTTLING=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
CONFIG_IBM_PARTITION=y
|
CONFIG_IBM_PARTITION=y
|
||||||
|
@ -241,6 +240,7 @@ CONFIG_NF_TABLES_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV4=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
CONFIG_NFT_CHAIN_NAT_IPV4=m
|
||||||
CONFIG_NF_TABLES_ARP=m
|
CONFIG_NF_TABLES_ARP=m
|
||||||
|
CONFIG_NF_NAT_IPV4=m
|
||||||
CONFIG_IP_NF_IPTABLES=m
|
CONFIG_IP_NF_IPTABLES=m
|
||||||
CONFIG_IP_NF_MATCH_AH=m
|
CONFIG_IP_NF_MATCH_AH=m
|
||||||
CONFIG_IP_NF_MATCH_ECN=m
|
CONFIG_IP_NF_MATCH_ECN=m
|
||||||
|
@ -248,11 +248,6 @@ CONFIG_IP_NF_MATCH_RPFILTER=m
|
||||||
CONFIG_IP_NF_MATCH_TTL=m
|
CONFIG_IP_NF_MATCH_TTL=m
|
||||||
CONFIG_IP_NF_FILTER=m
|
CONFIG_IP_NF_FILTER=m
|
||||||
CONFIG_IP_NF_TARGET_REJECT=m
|
CONFIG_IP_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP_NF_TARGET_ULOG=m
|
|
||||||
CONFIG_NF_NAT_IPV4=m
|
|
||||||
CONFIG_IP_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP_NF_TARGET_NETMAP=m
|
|
||||||
CONFIG_IP_NF_TARGET_REDIRECT=m
|
|
||||||
CONFIG_IP_NF_MANGLE=m
|
CONFIG_IP_NF_MANGLE=m
|
||||||
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
CONFIG_IP_NF_TARGET_CLUSTERIP=m
|
||||||
CONFIG_IP_NF_TARGET_ECN=m
|
CONFIG_IP_NF_TARGET_ECN=m
|
||||||
|
@ -266,6 +261,7 @@ CONFIG_NF_CONNTRACK_IPV6=m
|
||||||
CONFIG_NF_TABLES_IPV6=m
|
CONFIG_NF_TABLES_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
CONFIG_NFT_CHAIN_ROUTE_IPV6=m
|
||||||
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
CONFIG_NFT_CHAIN_NAT_IPV6=m
|
||||||
|
CONFIG_NF_NAT_IPV6=m
|
||||||
CONFIG_IP6_NF_IPTABLES=m
|
CONFIG_IP6_NF_IPTABLES=m
|
||||||
CONFIG_IP6_NF_MATCH_AH=m
|
CONFIG_IP6_NF_MATCH_AH=m
|
||||||
CONFIG_IP6_NF_MATCH_EUI64=m
|
CONFIG_IP6_NF_MATCH_EUI64=m
|
||||||
|
@ -282,9 +278,6 @@ CONFIG_IP6_NF_TARGET_REJECT=m
|
||||||
CONFIG_IP6_NF_MANGLE=m
|
CONFIG_IP6_NF_MANGLE=m
|
||||||
CONFIG_IP6_NF_RAW=m
|
CONFIG_IP6_NF_RAW=m
|
||||||
CONFIG_IP6_NF_SECURITY=m
|
CONFIG_IP6_NF_SECURITY=m
|
||||||
CONFIG_NF_NAT_IPV6=m
|
|
||||||
CONFIG_IP6_NF_TARGET_MASQUERADE=m
|
|
||||||
CONFIG_IP6_NF_TARGET_NPT=m
|
|
||||||
CONFIG_NF_TABLES_BRIDGE=m
|
CONFIG_NF_TABLES_BRIDGE=m
|
||||||
CONFIG_NET_SCTPPROBE=m
|
CONFIG_NET_SCTPPROBE=m
|
||||||
CONFIG_RDS=m
|
CONFIG_RDS=m
|
||||||
|
@ -369,14 +362,13 @@ CONFIG_BLK_DEV_SR=m
|
||||||
CONFIG_CHR_DEV_SG=y
|
CONFIG_CHR_DEV_SG=y
|
||||||
CONFIG_CHR_DEV_SCH=m
|
CONFIG_CHR_DEV_SCH=m
|
||||||
CONFIG_SCSI_ENCLOSURE=m
|
CONFIG_SCSI_ENCLOSURE=m
|
||||||
CONFIG_SCSI_MULTI_LUN=y
|
|
||||||
CONFIG_SCSI_CONSTANTS=y
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
CONFIG_SCSI_LOGGING=y
|
CONFIG_SCSI_LOGGING=y
|
||||||
CONFIG_SCSI_SPI_ATTRS=m
|
CONFIG_SCSI_SPI_ATTRS=m
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SAS_LIBSAS=m
|
CONFIG_SCSI_SAS_LIBSAS=m
|
||||||
CONFIG_SCSI_SRP_ATTRS=m
|
CONFIG_SCSI_SRP_ATTRS=m
|
||||||
CONFIG_ISCSI_TCP=m
|
CONFIG_ISCSI_TCP=m
|
||||||
CONFIG_LIBFCOE=m
|
|
||||||
CONFIG_SCSI_DEBUG=m
|
CONFIG_SCSI_DEBUG=m
|
||||||
CONFIG_ZFCP=y
|
CONFIG_ZFCP=y
|
||||||
CONFIG_SCSI_VIRTIO=m
|
CONFIG_SCSI_VIRTIO=m
|
||||||
|
@ -422,7 +414,6 @@ CONFIG_VIRTIO_NET=m
|
||||||
CONFIG_NLMON=m
|
CONFIG_NLMON=m
|
||||||
CONFIG_VHOST_NET=m
|
CONFIG_VHOST_NET=m
|
||||||
# CONFIG_NET_VENDOR_ARC is not set
|
# CONFIG_NET_VENDOR_ARC is not set
|
||||||
# CONFIG_NET_CADENCE is not set
|
|
||||||
# CONFIG_NET_VENDOR_CHELSIO is not set
|
# CONFIG_NET_VENDOR_CHELSIO is not set
|
||||||
# CONFIG_NET_VENDOR_INTEL is not set
|
# CONFIG_NET_VENDOR_INTEL is not set
|
||||||
# CONFIG_NET_VENDOR_MARVELL is not set
|
# CONFIG_NET_VENDOR_MARVELL is not set
|
||||||
|
@ -476,13 +467,13 @@ CONFIG_JFS_FS=m
|
||||||
CONFIG_JFS_POSIX_ACL=y
|
CONFIG_JFS_POSIX_ACL=y
|
||||||
CONFIG_JFS_SECURITY=y
|
CONFIG_JFS_SECURITY=y
|
||||||
CONFIG_JFS_STATISTICS=y
|
CONFIG_JFS_STATISTICS=y
|
||||||
CONFIG_XFS_FS=m
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_XFS_QUOTA=y
|
CONFIG_XFS_QUOTA=y
|
||||||
CONFIG_XFS_POSIX_ACL=y
|
CONFIG_XFS_POSIX_ACL=y
|
||||||
CONFIG_XFS_RT=y
|
CONFIG_XFS_RT=y
|
||||||
CONFIG_GFS2_FS=m
|
CONFIG_GFS2_FS=m
|
||||||
CONFIG_OCFS2_FS=m
|
CONFIG_OCFS2_FS=m
|
||||||
CONFIG_BTRFS_FS=m
|
CONFIG_BTRFS_FS=y
|
||||||
CONFIG_BTRFS_FS_POSIX_ACL=y
|
CONFIG_BTRFS_FS_POSIX_ACL=y
|
||||||
CONFIG_NILFS2_FS=m
|
CONFIG_NILFS2_FS=m
|
||||||
CONFIG_FANOTIFY=y
|
CONFIG_FANOTIFY=y
|
||||||
|
@ -550,8 +541,11 @@ CONFIG_TIMER_STATS=y
|
||||||
CONFIG_RCU_TORTURE_TEST=m
|
CONFIG_RCU_TORTURE_TEST=m
|
||||||
CONFIG_RCU_CPU_STALL_TIMEOUT=60
|
CONFIG_RCU_CPU_STALL_TIMEOUT=60
|
||||||
CONFIG_LATENCYTOP=y
|
CONFIG_LATENCYTOP=y
|
||||||
|
CONFIG_SCHED_TRACER=y
|
||||||
|
CONFIG_FTRACE_SYSCALLS=y
|
||||||
|
CONFIG_STACK_TRACER=y
|
||||||
CONFIG_BLK_DEV_IO_TRACE=y
|
CONFIG_BLK_DEV_IO_TRACE=y
|
||||||
# CONFIG_KPROBE_EVENT is not set
|
CONFIG_UPROBE_EVENT=y
|
||||||
CONFIG_LKDTM=m
|
CONFIG_LKDTM=m
|
||||||
CONFIG_PERCPU_TEST=m
|
CONFIG_PERCPU_TEST=m
|
||||||
CONFIG_ATOMIC64_SELFTEST=y
|
CONFIG_ATOMIC64_SELFTEST=y
|
||||||
|
@ -618,12 +612,6 @@ CONFIG_ASYMMETRIC_PUBLIC_KEY_SUBTYPE=m
|
||||||
CONFIG_X509_CERTIFICATE_PARSER=m
|
CONFIG_X509_CERTIFICATE_PARSER=m
|
||||||
CONFIG_CRC7=m
|
CONFIG_CRC7=m
|
||||||
CONFIG_CRC8=m
|
CONFIG_CRC8=m
|
||||||
CONFIG_XZ_DEC_X86=y
|
|
||||||
CONFIG_XZ_DEC_POWERPC=y
|
|
||||||
CONFIG_XZ_DEC_IA64=y
|
|
||||||
CONFIG_XZ_DEC_ARM=y
|
|
||||||
CONFIG_XZ_DEC_ARMTHUMB=y
|
|
||||||
CONFIG_XZ_DEC_SPARC=y
|
|
||||||
CONFIG_CORDIC=m
|
CONFIG_CORDIC=m
|
||||||
CONFIG_CMM=m
|
CONFIG_CMM=m
|
||||||
CONFIG_APPLDATA_BASE=y
|
CONFIG_APPLDATA_BASE=y
|
||||||
|
|
|
@ -22,8 +22,8 @@ CONFIG_HZ_100=y
|
||||||
CONFIG_CRASH_DUMP=y
|
CONFIG_CRASH_DUMP=y
|
||||||
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
# CONFIG_CORE_DUMP_DEFAULT_ELF_HEADERS is not set
|
||||||
# CONFIG_SECCOMP is not set
|
# CONFIG_SECCOMP is not set
|
||||||
# CONFIG_IUCV is not set
|
|
||||||
CONFIG_NET=y
|
CONFIG_NET=y
|
||||||
|
# CONFIG_IUCV is not set
|
||||||
CONFIG_ATM=y
|
CONFIG_ATM=y
|
||||||
CONFIG_ATM_LANE=y
|
CONFIG_ATM_LANE=y
|
||||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||||
|
@ -36,9 +36,9 @@ CONFIG_ENCLOSURE_SERVICES=y
|
||||||
CONFIG_SCSI=y
|
CONFIG_SCSI=y
|
||||||
CONFIG_BLK_DEV_SD=y
|
CONFIG_BLK_DEV_SD=y
|
||||||
CONFIG_SCSI_ENCLOSURE=y
|
CONFIG_SCSI_ENCLOSURE=y
|
||||||
CONFIG_SCSI_MULTI_LUN=y
|
|
||||||
CONFIG_SCSI_CONSTANTS=y
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
CONFIG_SCSI_LOGGING=y
|
CONFIG_SCSI_LOGGING=y
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SRP_ATTRS=y
|
CONFIG_SCSI_SRP_ATTRS=y
|
||||||
CONFIG_ZFCP=y
|
CONFIG_ZFCP=y
|
||||||
# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
|
# CONFIG_INPUT_MOUSEDEV_PSAUX is not set
|
||||||
|
@ -75,12 +75,6 @@ CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_RCU_CPU_STALL_TIMEOUT=60
|
CONFIG_RCU_CPU_STALL_TIMEOUT=60
|
||||||
# CONFIG_FTRACE is not set
|
# CONFIG_FTRACE is not set
|
||||||
# CONFIG_STRICT_DEVMEM is not set
|
# CONFIG_STRICT_DEVMEM is not set
|
||||||
CONFIG_XZ_DEC_X86=y
|
|
||||||
CONFIG_XZ_DEC_POWERPC=y
|
|
||||||
CONFIG_XZ_DEC_IA64=y
|
|
||||||
CONFIG_XZ_DEC_ARM=y
|
|
||||||
CONFIG_XZ_DEC_ARMTHUMB=y
|
|
||||||
CONFIG_XZ_DEC_SPARC=y
|
|
||||||
# CONFIG_PFAULT is not set
|
# CONFIG_PFAULT is not set
|
||||||
# CONFIG_S390_HYPFS_FS is not set
|
# CONFIG_S390_HYPFS_FS is not set
|
||||||
# CONFIG_VIRTUALIZATION is not set
|
# CONFIG_VIRTUALIZATION is not set
|
||||||
|
|
|
@ -92,10 +92,10 @@ CONFIG_CHR_DEV_ST=y
|
||||||
CONFIG_BLK_DEV_SR=y
|
CONFIG_BLK_DEV_SR=y
|
||||||
CONFIG_BLK_DEV_SR_VENDOR=y
|
CONFIG_BLK_DEV_SR_VENDOR=y
|
||||||
CONFIG_CHR_DEV_SG=y
|
CONFIG_CHR_DEV_SG=y
|
||||||
CONFIG_SCSI_MULTI_LUN=y
|
|
||||||
CONFIG_SCSI_CONSTANTS=y
|
CONFIG_SCSI_CONSTANTS=y
|
||||||
CONFIG_SCSI_LOGGING=y
|
CONFIG_SCSI_LOGGING=y
|
||||||
CONFIG_SCSI_SCAN_ASYNC=y
|
CONFIG_SCSI_SCAN_ASYNC=y
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_ZFCP=y
|
CONFIG_ZFCP=y
|
||||||
CONFIG_SCSI_VIRTIO=y
|
CONFIG_SCSI_VIRTIO=y
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
|
@ -164,14 +164,13 @@ CONFIG_CRYPTO_CMAC=m
|
||||||
CONFIG_CRYPTO_XCBC=m
|
CONFIG_CRYPTO_XCBC=m
|
||||||
CONFIG_CRYPTO_VMAC=m
|
CONFIG_CRYPTO_VMAC=m
|
||||||
CONFIG_CRYPTO_CRC32=m
|
CONFIG_CRYPTO_CRC32=m
|
||||||
CONFIG_CRYPTO_CRCT10DIF=m
|
|
||||||
CONFIG_CRYPTO_MD4=m
|
CONFIG_CRYPTO_MD4=m
|
||||||
CONFIG_CRYPTO_MICHAEL_MIC=m
|
CONFIG_CRYPTO_MICHAEL_MIC=m
|
||||||
CONFIG_CRYPTO_RMD128=m
|
CONFIG_CRYPTO_RMD128=m
|
||||||
CONFIG_CRYPTO_RMD160=m
|
CONFIG_CRYPTO_RMD160=m
|
||||||
CONFIG_CRYPTO_RMD256=m
|
CONFIG_CRYPTO_RMD256=m
|
||||||
CONFIG_CRYPTO_RMD320=m
|
CONFIG_CRYPTO_RMD320=m
|
||||||
CONFIG_CRYPTO_SHA256=m
|
CONFIG_CRYPTO_SHA256=y
|
||||||
CONFIG_CRYPTO_SHA512=m
|
CONFIG_CRYPTO_SHA512=m
|
||||||
CONFIG_CRYPTO_TGR192=m
|
CONFIG_CRYPTO_TGR192=m
|
||||||
CONFIG_CRYPTO_WP512=m
|
CONFIG_CRYPTO_WP512=m
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue