mirror of
https://github.com/edk2-porting/linux-next.git
synced 2024-12-17 09:43:59 +08:00
Merge branches 'fiq' (early part), 'fixes', 'l2c' (early part) and 'misc' into for-next
This commit is contained in:
commit
d5d1689224
@ -2545,6 +2545,30 @@ fields changed from _s32 to _u32.
|
|||||||
</orderedlist>
|
</orderedlist>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
|
<section>
|
||||||
|
<title>V4L2 in Linux 3.16</title>
|
||||||
|
<orderedlist>
|
||||||
|
<listitem>
|
||||||
|
<para>Added event V4L2_EVENT_SOURCE_CHANGE.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
</orderedlist>
|
||||||
|
</section>
|
||||||
|
|
||||||
|
<section>
|
||||||
|
<title>V4L2 in Linux 3.17</title>
|
||||||
|
<orderedlist>
|
||||||
|
<listitem>
|
||||||
|
<para>Extended &v4l2-pix-format;. Added format flags.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
<listitem>
|
||||||
|
<para>Added compound control types and &VIDIOC-QUERY-EXT-CTRL;.
|
||||||
|
</para>
|
||||||
|
</listitem>
|
||||||
|
</orderedlist>
|
||||||
|
</section>
|
||||||
|
|
||||||
<section id="other">
|
<section id="other">
|
||||||
<title>Relation of V4L2 to other Linux multimedia APIs</title>
|
<title>Relation of V4L2 to other Linux multimedia APIs</title>
|
||||||
|
|
||||||
|
@ -29,9 +29,12 @@ can suspend execution until the driver has captured data or is ready
|
|||||||
to accept data for output.</para>
|
to accept data for output.</para>
|
||||||
|
|
||||||
<para>When streaming I/O has been negotiated this function waits
|
<para>When streaming I/O has been negotiated this function waits
|
||||||
until a buffer has been filled or displayed and can be dequeued with
|
until a buffer has been filled by the capture device and can be dequeued
|
||||||
the &VIDIOC-DQBUF; ioctl. When buffers are already in the outgoing
|
with the &VIDIOC-DQBUF; ioctl. For output devices this function waits
|
||||||
queue of the driver the function returns immediately.</para>
|
until the device is ready to accept a new buffer to be queued up with
|
||||||
|
the &VIDIOC-QBUF; ioctl for display. When buffers are already in the outgoing
|
||||||
|
queue of the driver (capture) or the incoming queue isn't full (display)
|
||||||
|
the function returns immediately.</para>
|
||||||
|
|
||||||
<para>On success <function>poll()</function> returns the number of
|
<para>On success <function>poll()</function> returns the number of
|
||||||
file descriptors that have been selected (that is, file descriptors
|
file descriptors that have been selected (that is, file descriptors
|
||||||
@ -44,10 +47,22 @@ Capture devices set the <constant>POLLIN</constant> and
|
|||||||
flags. When the function timed out it returns a value of zero, on
|
flags. When the function timed out it returns a value of zero, on
|
||||||
failure it returns <returnvalue>-1</returnvalue> and the
|
failure it returns <returnvalue>-1</returnvalue> and the
|
||||||
<varname>errno</varname> variable is set appropriately. When the
|
<varname>errno</varname> variable is set appropriately. When the
|
||||||
application did not call &VIDIOC-QBUF; or &VIDIOC-STREAMON; yet the
|
application did not call &VIDIOC-STREAMON; the
|
||||||
<function>poll()</function> function succeeds, but sets the
|
<function>poll()</function> function succeeds, but sets the
|
||||||
<constant>POLLERR</constant> flag in the
|
<constant>POLLERR</constant> flag in the
|
||||||
<structfield>revents</structfield> field.</para>
|
<structfield>revents</structfield> field. When the
|
||||||
|
application has called &VIDIOC-STREAMON; for a capture device but hasn't
|
||||||
|
yet called &VIDIOC-QBUF;, the <function>poll()</function> function
|
||||||
|
succeeds and sets the <constant>POLLERR</constant> flag in the
|
||||||
|
<structfield>revents</structfield> field. For output devices this
|
||||||
|
same situation will cause <function>poll()</function> to succeed
|
||||||
|
as well, but it sets the <constant>POLLOUT</constant> and
|
||||||
|
<constant>POLLWRNORM</constant> flags in the <structfield>revents</structfield>
|
||||||
|
field.</para>
|
||||||
|
|
||||||
|
<para>If an event occurred (see &VIDIOC-DQEVENT;) then
|
||||||
|
<constant>POLLPRI</constant> will be set in the <structfield>revents</structfield>
|
||||||
|
field and <function>poll()</function> will return.</para>
|
||||||
|
|
||||||
<para>When use of the <function>read()</function> function has
|
<para>When use of the <function>read()</function> function has
|
||||||
been negotiated and the driver does not capture yet, the
|
been negotiated and the driver does not capture yet, the
|
||||||
@ -58,10 +73,18 @@ continuously (as opposed to, for example, still images) the function
|
|||||||
may return immediately.</para>
|
may return immediately.</para>
|
||||||
|
|
||||||
<para>When use of the <function>write()</function> function has
|
<para>When use of the <function>write()</function> function has
|
||||||
been negotiated the <function>poll</function> function just waits
|
been negotiated and the driver does not stream yet, the
|
||||||
|
<function>poll</function> function starts streaming. When that fails
|
||||||
|
it returns a <constant>POLLERR</constant> as above. Otherwise it waits
|
||||||
until the driver is ready for a non-blocking
|
until the driver is ready for a non-blocking
|
||||||
<function>write()</function> call.</para>
|
<function>write()</function> call.</para>
|
||||||
|
|
||||||
|
<para>If the caller is only interested in events (just
|
||||||
|
<constant>POLLPRI</constant> is set in the <structfield>events</structfield>
|
||||||
|
field), then <function>poll()</function> will <emphasis>not</emphasis>
|
||||||
|
start streaming if the driver does not stream yet. This makes it
|
||||||
|
possible to just poll for events and not for buffers.</para>
|
||||||
|
|
||||||
<para>All drivers implementing the <function>read()</function> or
|
<para>All drivers implementing the <function>read()</function> or
|
||||||
<function>write()</function> function or streaming I/O must also
|
<function>write()</function> function or streaming I/O must also
|
||||||
support the <function>poll()</function> function.</para>
|
support the <function>poll()</function> function.</para>
|
||||||
|
@ -152,10 +152,11 @@ structs, ioctls) must be noted in more detail in the history chapter
|
|||||||
applications. -->
|
applications. -->
|
||||||
|
|
||||||
<revision>
|
<revision>
|
||||||
<revnumber>3.16</revnumber>
|
<revnumber>3.17</revnumber>
|
||||||
<date>2014-05-27</date>
|
<date>2014-08-04</date>
|
||||||
<authorinitials>lp</authorinitials>
|
<authorinitials>lp, hv</authorinitials>
|
||||||
<revremark>Extended &v4l2-pix-format;. Added format flags.
|
<revremark>Extended &v4l2-pix-format;. Added format flags. Added compound control types
|
||||||
|
and VIDIOC_QUERY_EXT_CTRL.
|
||||||
</revremark>
|
</revremark>
|
||||||
</revision>
|
</revision>
|
||||||
|
|
||||||
@ -538,7 +539,7 @@ and discussions on the V4L mailing list.</revremark>
|
|||||||
</partinfo>
|
</partinfo>
|
||||||
|
|
||||||
<title>Video for Linux Two API Specification</title>
|
<title>Video for Linux Two API Specification</title>
|
||||||
<subtitle>Revision 3.14</subtitle>
|
<subtitle>Revision 3.17</subtitle>
|
||||||
|
|
||||||
<chapter id="common">
|
<chapter id="common">
|
||||||
&sub-common;
|
&sub-common;
|
||||||
|
@ -119,7 +119,7 @@
|
|||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
<entry>&v4l2-rect;</entry>
|
<entry>&v4l2-rect;</entry>
|
||||||
<entry><structfield>rect</structfield></entry>
|
<entry><structfield>r</structfield></entry>
|
||||||
<entry>Selection rectangle, in pixels.</entry>
|
<entry>Selection rectangle, in pixels.</entry>
|
||||||
</row>
|
</row>
|
||||||
<row>
|
<row>
|
||||||
|
@ -345,14 +345,14 @@ the named feature on.
|
|||||||
The implementation is simple.
|
The implementation is simple.
|
||||||
|
|
||||||
Setting the flag 'cpuset.memory_spread_page' turns on a per-process flag
|
Setting the flag 'cpuset.memory_spread_page' turns on a per-process flag
|
||||||
PF_SPREAD_PAGE for each task that is in that cpuset or subsequently
|
PFA_SPREAD_PAGE for each task that is in that cpuset or subsequently
|
||||||
joins that cpuset. The page allocation calls for the page cache
|
joins that cpuset. The page allocation calls for the page cache
|
||||||
is modified to perform an inline check for this PF_SPREAD_PAGE task
|
is modified to perform an inline check for this PFA_SPREAD_PAGE task
|
||||||
flag, and if set, a call to a new routine cpuset_mem_spread_node()
|
flag, and if set, a call to a new routine cpuset_mem_spread_node()
|
||||||
returns the node to prefer for the allocation.
|
returns the node to prefer for the allocation.
|
||||||
|
|
||||||
Similarly, setting 'cpuset.memory_spread_slab' turns on the flag
|
Similarly, setting 'cpuset.memory_spread_slab' turns on the flag
|
||||||
PF_SPREAD_SLAB, and appropriately marked slab caches will allocate
|
PFA_SPREAD_SLAB, and appropriately marked slab caches will allocate
|
||||||
pages from the node returned by cpuset_mem_spread_node().
|
pages from the node returned by cpuset_mem_spread_node().
|
||||||
|
|
||||||
The cpuset_mem_spread_node() routine is also simple. It uses the
|
The cpuset_mem_spread_node() routine is also simple. It uses the
|
||||||
|
@ -2,6 +2,10 @@
|
|||||||
|
|
||||||
ARM cores often have a separate level 2 cache controller. There are various
|
ARM cores often have a separate level 2 cache controller. There are various
|
||||||
implementations of the L2 cache controller with compatible programming models.
|
implementations of the L2 cache controller with compatible programming models.
|
||||||
|
Some of the properties that are just prefixed "cache-*" are taken from section
|
||||||
|
3.7.3 of the ePAPR v1.1 specification which can be found at:
|
||||||
|
https://www.power.org/wp-content/uploads/2012/06/Power_ePAPR_APPROVED_v1.1.pdf
|
||||||
|
|
||||||
The ARM L2 cache representation in the device tree should be done as follows:
|
The ARM L2 cache representation in the device tree should be done as follows:
|
||||||
|
|
||||||
Required properties:
|
Required properties:
|
||||||
@ -44,6 +48,12 @@ Optional properties:
|
|||||||
I/O coherent mode. Valid only when the arm,pl310-cache compatible
|
I/O coherent mode. Valid only when the arm,pl310-cache compatible
|
||||||
string is used.
|
string is used.
|
||||||
- interrupts : 1 combined interrupt.
|
- interrupts : 1 combined interrupt.
|
||||||
|
- cache-size : specifies the size in bytes of the cache
|
||||||
|
- cache-sets : specifies the number of associativity sets of the cache
|
||||||
|
- cache-block-size : specifies the size in bytes of a cache block
|
||||||
|
- cache-line-size : specifies the size in bytes of a line in the cache,
|
||||||
|
if this is not specified, the line size is assumed to be equal to the
|
||||||
|
cache block size
|
||||||
- cache-id-part: cache id part number to be used if it is not present
|
- cache-id-part: cache id part number to be used if it is not present
|
||||||
on hardware
|
on hardware
|
||||||
- wt-override: If present then L2 is forced to Write through mode
|
- wt-override: If present then L2 is forced to Write through mode
|
||||||
|
@ -11,10 +11,6 @@ Required properties:
|
|||||||
|
|
||||||
Optional properties for main touchpad device:
|
Optional properties for main touchpad device:
|
||||||
|
|
||||||
- linux,gpio-keymap: An array of up to 4 entries indicating the Linux
|
|
||||||
keycode generated by each GPIO. Linux keycodes are defined in
|
|
||||||
<dt-bindings/input/input.h>.
|
|
||||||
|
|
||||||
- linux,gpio-keymap: When enabled, the SPT_GPIOPWN_T19 object sends messages
|
- linux,gpio-keymap: When enabled, the SPT_GPIOPWN_T19 object sends messages
|
||||||
on GPIO bit changes. An array of up to 8 entries can be provided
|
on GPIO bit changes. An array of up to 8 entries can be provided
|
||||||
indicating the Linux keycode mapped to each bit of the status byte,
|
indicating the Linux keycode mapped to each bit of the status byte,
|
||||||
|
@ -31,7 +31,7 @@ i2s@ff890000 {
|
|||||||
#address-cells = <1>;
|
#address-cells = <1>;
|
||||||
#size-cells = <0>;
|
#size-cells = <0>;
|
||||||
dmas = <&pdma1 0>, <&pdma1 1>;
|
dmas = <&pdma1 0>, <&pdma1 1>;
|
||||||
dma-names = "rx", "tx";
|
dma-names = "tx", "rx";
|
||||||
clock-names = "i2s_hclk", "i2s_clk";
|
clock-names = "i2s_hclk", "i2s_clk";
|
||||||
clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
|
clocks = <&cru HCLK_I2S0>, <&cru SCLK_I2S0>;
|
||||||
};
|
};
|
||||||
|
@ -16,11 +16,15 @@ Required Properties:
|
|||||||
- clocks: Must contain an entry for each entry in clock-names.
|
- clocks: Must contain an entry for each entry in clock-names.
|
||||||
- clock-names: Shall be "spiclk" for the transfer-clock, and "apb_pclk" for
|
- clock-names: Shall be "spiclk" for the transfer-clock, and "apb_pclk" for
|
||||||
the peripheral clock.
|
the peripheral clock.
|
||||||
|
- #address-cells: should be 1.
|
||||||
|
- #size-cells: should be 0.
|
||||||
|
|
||||||
|
Optional Properties:
|
||||||
|
|
||||||
- dmas: DMA specifiers for tx and rx dma. See the DMA client binding,
|
- dmas: DMA specifiers for tx and rx dma. See the DMA client binding,
|
||||||
Documentation/devicetree/bindings/dma/dma.txt
|
Documentation/devicetree/bindings/dma/dma.txt
|
||||||
- dma-names: DMA request names should include "tx" and "rx" if present.
|
- dma-names: DMA request names should include "tx" and "rx" if present.
|
||||||
- #address-cells: should be 1.
|
|
||||||
- #size-cells: should be 0.
|
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
|
@ -56,6 +56,9 @@ Required properties:
|
|||||||
- fsl,data-width : should be <18> or <24>
|
- fsl,data-width : should be <18> or <24>
|
||||||
- port: A port node with endpoint definitions as defined in
|
- port: A port node with endpoint definitions as defined in
|
||||||
Documentation/devicetree/bindings/media/video-interfaces.txt.
|
Documentation/devicetree/bindings/media/video-interfaces.txt.
|
||||||
|
On i.MX5, the internal two-input-multiplexer is used.
|
||||||
|
Due to hardware limitations, only one port (port@[0,1])
|
||||||
|
can be used for each channel (lvds-channel@[0,1], respectively)
|
||||||
On i.MX6, there should be four ports (port@[0-3]) that correspond
|
On i.MX6, there should be four ports (port@[0-3]) that correspond
|
||||||
to the four LVDS multiplexer inputs.
|
to the four LVDS multiplexer inputs.
|
||||||
|
|
||||||
@ -78,6 +81,8 @@ ldb: ldb@53fa8008 {
|
|||||||
"di0", "di1";
|
"di0", "di1";
|
||||||
|
|
||||||
lvds-channel@0 {
|
lvds-channel@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
fsl,data-mapping = "spwg";
|
fsl,data-mapping = "spwg";
|
||||||
fsl,data-width = <24>;
|
fsl,data-width = <24>;
|
||||||
@ -86,7 +91,9 @@ ldb: ldb@53fa8008 {
|
|||||||
/* ... */
|
/* ... */
|
||||||
};
|
};
|
||||||
|
|
||||||
port {
|
port@0 {
|
||||||
|
reg = <0>;
|
||||||
|
|
||||||
lvds0_in: endpoint {
|
lvds0_in: endpoint {
|
||||||
remote-endpoint = <&ipu_di0_lvds0>;
|
remote-endpoint = <&ipu_di0_lvds0>;
|
||||||
};
|
};
|
||||||
@ -94,6 +101,8 @@ ldb: ldb@53fa8008 {
|
|||||||
};
|
};
|
||||||
|
|
||||||
lvds-channel@1 {
|
lvds-channel@1 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
reg = <1>;
|
reg = <1>;
|
||||||
fsl,data-mapping = "spwg";
|
fsl,data-mapping = "spwg";
|
||||||
fsl,data-width = <24>;
|
fsl,data-width = <24>;
|
||||||
@ -102,7 +111,9 @@ ldb: ldb@53fa8008 {
|
|||||||
/* ... */
|
/* ... */
|
||||||
};
|
};
|
||||||
|
|
||||||
port {
|
port@1 {
|
||||||
|
reg = <1>;
|
||||||
|
|
||||||
lvds1_in: endpoint {
|
lvds1_in: endpoint {
|
||||||
remote-endpoint = <&ipu_di1_lvds1>;
|
remote-endpoint = <&ipu_di1_lvds1>;
|
||||||
};
|
};
|
||||||
|
211
Documentation/devicetree/of_selftest.txt
Normal file
211
Documentation/devicetree/of_selftest.txt
Normal file
@ -0,0 +1,211 @@
|
|||||||
|
Open Firmware Device Tree Selftest
|
||||||
|
----------------------------------
|
||||||
|
|
||||||
|
Author: Gaurav Minocha <gaurav.minocha.os@gmail.com>
|
||||||
|
|
||||||
|
1. Introduction
|
||||||
|
|
||||||
|
This document explains how the test data required for executing OF selftest
|
||||||
|
is attached to the live tree dynamically, independent of the machine's
|
||||||
|
architecture.
|
||||||
|
|
||||||
|
It is recommended to read the following documents before moving ahead.
|
||||||
|
|
||||||
|
[1] Documentation/devicetree/usage-model.txt
|
||||||
|
[2] http://www.devicetree.org/Device_Tree_Usage
|
||||||
|
|
||||||
|
OF Selftest has been designed to test the interface (include/linux/of.h)
|
||||||
|
provided to device driver developers to fetch the device information..etc.
|
||||||
|
from the unflattened device tree data structure. This interface is used by
|
||||||
|
most of the device drivers in various use cases.
|
||||||
|
|
||||||
|
|
||||||
|
2. Test-data
|
||||||
|
|
||||||
|
The Device Tree Source file (drivers/of/testcase-data/testcases.dts) contains
|
||||||
|
the test data required for executing the unit tests automated in
|
||||||
|
drivers/of/selftests.c. Currently, following Device Tree Source Include files
|
||||||
|
(.dtsi) are included in testcase.dts:
|
||||||
|
|
||||||
|
drivers/of/testcase-data/tests-interrupts.dtsi
|
||||||
|
drivers/of/testcase-data/tests-platform.dtsi
|
||||||
|
drivers/of/testcase-data/tests-phandle.dtsi
|
||||||
|
drivers/of/testcase-data/tests-match.dtsi
|
||||||
|
|
||||||
|
When the kernel is build with OF_SELFTEST enabled, then the following make rule
|
||||||
|
|
||||||
|
$(obj)/%.dtb: $(src)/%.dts FORCE
|
||||||
|
$(call if_changed_dep, dtc)
|
||||||
|
|
||||||
|
is used to compile the DT source file (testcase.dts) into a binary blob
|
||||||
|
(testcase.dtb), also referred as flattened DT.
|
||||||
|
|
||||||
|
After that, using the following rule the binary blob above is wrapped as an
|
||||||
|
assembly file (testcase.dtb.S).
|
||||||
|
|
||||||
|
$(obj)/%.dtb.S: $(obj)/%.dtb
|
||||||
|
$(call cmd, dt_S_dtb)
|
||||||
|
|
||||||
|
The assembly file is compiled into an object file (testcase.dtb.o), and is
|
||||||
|
linked into the kernel image.
|
||||||
|
|
||||||
|
|
||||||
|
2.1. Adding the test data
|
||||||
|
|
||||||
|
Un-flattened device tree structure:
|
||||||
|
|
||||||
|
Un-flattened device tree consists of connected device_node(s) in form of a tree
|
||||||
|
structure described below.
|
||||||
|
|
||||||
|
// following struct members are used to construct the tree
|
||||||
|
struct device_node {
|
||||||
|
...
|
||||||
|
struct device_node *parent;
|
||||||
|
struct device_node *child;
|
||||||
|
struct device_node *sibling;
|
||||||
|
struct device_node *allnext; /* next in list of all nodes */
|
||||||
|
...
|
||||||
|
};
|
||||||
|
|
||||||
|
Figure 1, describes a generic structure of machine’s un-flattened device tree
|
||||||
|
considering only child and sibling pointers. There exists another pointer,
|
||||||
|
*parent, that is used to traverse the tree in the reverse direction. So, at
|
||||||
|
a particular level the child node and all the sibling nodes will have a parent
|
||||||
|
pointer pointing to a common node (e.g. child1, sibling2, sibling3, sibling4’s
|
||||||
|
parent points to root node)
|
||||||
|
|
||||||
|
root (‘/’)
|
||||||
|
|
|
||||||
|
child1 -> sibling2 -> sibling3 -> sibling4 -> null
|
||||||
|
| | | |
|
||||||
|
| | | null
|
||||||
|
| | |
|
||||||
|
| | child31 -> sibling32 -> null
|
||||||
|
| | | |
|
||||||
|
| | null null
|
||||||
|
| |
|
||||||
|
| child21 -> sibling22 -> sibling23 -> null
|
||||||
|
| | | |
|
||||||
|
| null null null
|
||||||
|
|
|
||||||
|
child11 -> sibling12 -> sibling13 -> sibling14 -> null
|
||||||
|
| | | |
|
||||||
|
| | | null
|
||||||
|
| | |
|
||||||
|
null null child131 -> null
|
||||||
|
|
|
||||||
|
null
|
||||||
|
|
||||||
|
Figure 1: Generic structure of un-flattened device tree
|
||||||
|
|
||||||
|
|
||||||
|
*allnext: it is used to link all the nodes of DT into a list. So, for the
|
||||||
|
above tree the list would be as follows:
|
||||||
|
|
||||||
|
root->child1->child11->sibling12->sibling13->child131->sibling14->sibling2->
|
||||||
|
child21->sibling22->sibling23->sibling3->child31->sibling32->sibling4->null
|
||||||
|
|
||||||
|
Before executing OF selftest, it is required to attach the test data to
|
||||||
|
machine's device tree (if present). So, when selftest_data_add() is called,
|
||||||
|
at first it reads the flattened device tree data linked into the kernel image
|
||||||
|
via the following kernel symbols:
|
||||||
|
|
||||||
|
__dtb_testcases_begin - address marking the start of test data blob
|
||||||
|
__dtb_testcases_end - address marking the end of test data blob
|
||||||
|
|
||||||
|
Secondly, it calls of_fdt_unflatten_device_tree() to unflatten the flattened
|
||||||
|
blob. And finally, if the machine’s device tree (i.e live tree) is present,
|
||||||
|
then it attaches the unflattened test data tree to the live tree, else it
|
||||||
|
attaches itself as a live device tree.
|
||||||
|
|
||||||
|
attach_node_and_children() uses of_attach_node() to attach the nodes into the
|
||||||
|
live tree as explained below. To explain the same, the test data tree described
|
||||||
|
in Figure 2 is attached to the live tree described in Figure 1.
|
||||||
|
|
||||||
|
root (‘/’)
|
||||||
|
|
|
||||||
|
testcase-data
|
||||||
|
|
|
||||||
|
test-child0 -> test-sibling1 -> test-sibling2 -> test-sibling3 -> null
|
||||||
|
| | | |
|
||||||
|
test-child01 null null null
|
||||||
|
|
||||||
|
|
||||||
|
allnext list:
|
||||||
|
|
||||||
|
root->testcase-data->test-child0->test-child01->test-sibling1->test-sibling2
|
||||||
|
->test-sibling3->null
|
||||||
|
|
||||||
|
Figure 2: Example test data tree to be attached to live tree.
|
||||||
|
|
||||||
|
According to the scenario above, the live tree is already present so it isn’t
|
||||||
|
required to attach the root(‘/’) node. All other nodes are attached by calling
|
||||||
|
of_attach_node() on each node.
|
||||||
|
|
||||||
|
In the function of_attach_node(), the new node is attached as the child of the
|
||||||
|
given parent in live tree. But, if parent already has a child then the new node
|
||||||
|
replaces the current child and turns it into its sibling. So, when the testcase
|
||||||
|
data node is attached to the live tree above (Figure 1), the final structure is
|
||||||
|
as shown in Figure 3.
|
||||||
|
|
||||||
|
root (‘/’)
|
||||||
|
|
|
||||||
|
testcase-data -> child1 -> sibling2 -> sibling3 -> sibling4 -> null
|
||||||
|
| | | | |
|
||||||
|
(...) | | | null
|
||||||
|
| | child31 -> sibling32 -> null
|
||||||
|
| | | |
|
||||||
|
| | null null
|
||||||
|
| |
|
||||||
|
| child21 -> sibling22 -> sibling23 -> null
|
||||||
|
| | | |
|
||||||
|
| null null null
|
||||||
|
|
|
||||||
|
child11 -> sibling12 -> sibling13 -> sibling14 -> null
|
||||||
|
| | | |
|
||||||
|
null null | null
|
||||||
|
|
|
||||||
|
child131 -> null
|
||||||
|
|
|
||||||
|
null
|
||||||
|
-----------------------------------------------------------------------
|
||||||
|
|
||||||
|
root (‘/’)
|
||||||
|
|
|
||||||
|
testcase-data -> child1 -> sibling2 -> sibling3 -> sibling4 -> null
|
||||||
|
| | | | |
|
||||||
|
| (...) (...) (...) null
|
||||||
|
|
|
||||||
|
test-sibling3 -> test-sibling2 -> test-sibling1 -> test-child0 -> null
|
||||||
|
| | | |
|
||||||
|
null null null test-child01
|
||||||
|
|
||||||
|
|
||||||
|
Figure 3: Live device tree structure after attaching the testcase-data.
|
||||||
|
|
||||||
|
|
||||||
|
Astute readers would have noticed that test-child0 node becomes the last
|
||||||
|
sibling compared to the earlier structure (Figure 2). After attaching first
|
||||||
|
test-child0 the test-sibling1 is attached that pushes the child node
|
||||||
|
(i.e. test-child0) to become a sibling and makes itself a child node,
|
||||||
|
as mentioned above.
|
||||||
|
|
||||||
|
If a duplicate node is found (i.e. if a node with same full_name property is
|
||||||
|
already present in the live tree), then the node isn’t attached rather its
|
||||||
|
properties are updated to the live tree’s node by calling the function
|
||||||
|
update_node_properties().
|
||||||
|
|
||||||
|
|
||||||
|
2.2. Removing the test data
|
||||||
|
|
||||||
|
Once the test case execution is complete, selftest_data_remove is called in
|
||||||
|
order to remove the device nodes attached initially (first the leaf nodes are
|
||||||
|
detached and then moving up the parent nodes are removed, and eventually the
|
||||||
|
whole tree). selftest_data_remove() calls detach_node_and_children() that uses
|
||||||
|
of_detach_node() to detach the nodes from the live device tree.
|
||||||
|
|
||||||
|
To detach a node, of_detach_node() first updates all_next linked list, by
|
||||||
|
attaching the previous node’s allnext to current node’s allnext pointer. And
|
||||||
|
then, it either updates the child pointer of given node’s parent to its
|
||||||
|
sibling or attaches the previous sibling to the given node’s sibling, as
|
||||||
|
appropriate. That is it :)
|
@ -462,9 +462,9 @@ JIT compiler
|
|||||||
------------
|
------------
|
||||||
|
|
||||||
The Linux kernel has a built-in BPF JIT compiler for x86_64, SPARC, PowerPC,
|
The Linux kernel has a built-in BPF JIT compiler for x86_64, SPARC, PowerPC,
|
||||||
ARM and s390 and can be enabled through CONFIG_BPF_JIT. The JIT compiler is
|
ARM, MIPS and s390 and can be enabled through CONFIG_BPF_JIT. The JIT compiler
|
||||||
transparently invoked for each attached filter from user space or for internal
|
is transparently invoked for each attached filter from user space or for
|
||||||
kernel users if it has been previously enabled by root:
|
internal kernel users if it has been previously enabled by root:
|
||||||
|
|
||||||
echo 1 > /proc/sys/net/core/bpf_jit_enable
|
echo 1 > /proc/sys/net/core/bpf_jit_enable
|
||||||
|
|
||||||
|
@ -3012,9 +3012,8 @@ S: Supported
|
|||||||
F: drivers/acpi/dock.c
|
F: drivers/acpi/dock.c
|
||||||
|
|
||||||
DOCUMENTATION
|
DOCUMENTATION
|
||||||
M: Randy Dunlap <rdunlap@infradead.org>
|
M: Jiri Kosina <jkosina@suse.cz>
|
||||||
L: linux-doc@vger.kernel.org
|
L: linux-doc@vger.kernel.org
|
||||||
T: quilt http://www.infradead.org/~rdunlap/Doc/patches/
|
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/
|
F: Documentation/
|
||||||
X: Documentation/ABI/
|
X: Documentation/ABI/
|
||||||
@ -4477,7 +4476,6 @@ M: Mika Westerberg <mika.westerberg@linux.intel.com>
|
|||||||
L: linux-i2c@vger.kernel.org
|
L: linux-i2c@vger.kernel.org
|
||||||
L: linux-acpi@vger.kernel.org
|
L: linux-acpi@vger.kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: drivers/i2c/i2c-acpi.c
|
|
||||||
|
|
||||||
I2C-TAOS-EVM DRIVER
|
I2C-TAOS-EVM DRIVER
|
||||||
M: Jean Delvare <jdelvare@suse.de>
|
M: Jean Delvare <jdelvare@suse.de>
|
||||||
@ -6876,7 +6874,7 @@ F: arch/x86/kernel/quirks.c
|
|||||||
|
|
||||||
PCI DRIVER FOR IMX6
|
PCI DRIVER FOR IMX6
|
||||||
M: Richard Zhu <r65037@freescale.com>
|
M: Richard Zhu <r65037@freescale.com>
|
||||||
M: Shawn Guo <shawn.guo@freescale.com>
|
M: Lucas Stach <l.stach@pengutronix.de>
|
||||||
L: linux-pci@vger.kernel.org
|
L: linux-pci@vger.kernel.org
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
VERSION = 3
|
VERSION = 3
|
||||||
PATCHLEVEL = 17
|
PATCHLEVEL = 17
|
||||||
SUBLEVEL = 0
|
SUBLEVEL = 0
|
||||||
EXTRAVERSION = -rc5
|
EXTRAVERSION = -rc7
|
||||||
NAME = Shuffling Zombie Juror
|
NAME = Shuffling Zombie Juror
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -157,6 +157,7 @@ machine-$(CONFIG_ARCH_EBSA110) += ebsa110
|
|||||||
machine-$(CONFIG_ARCH_EFM32) += efm32
|
machine-$(CONFIG_ARCH_EFM32) += efm32
|
||||||
machine-$(CONFIG_ARCH_EP93XX) += ep93xx
|
machine-$(CONFIG_ARCH_EP93XX) += ep93xx
|
||||||
machine-$(CONFIG_ARCH_EXYNOS) += exynos
|
machine-$(CONFIG_ARCH_EXYNOS) += exynos
|
||||||
|
machine-$(CONFIG_ARCH_FOOTBRIDGE) += footbridge
|
||||||
machine-$(CONFIG_ARCH_GEMINI) += gemini
|
machine-$(CONFIG_ARCH_GEMINI) += gemini
|
||||||
machine-$(CONFIG_ARCH_HIGHBANK) += highbank
|
machine-$(CONFIG_ARCH_HIGHBANK) += highbank
|
||||||
machine-$(CONFIG_ARCH_HISI) += hisi
|
machine-$(CONFIG_ARCH_HISI) += hisi
|
||||||
@ -205,7 +206,6 @@ machine-$(CONFIG_ARCH_VEXPRESS) += vexpress
|
|||||||
machine-$(CONFIG_ARCH_VT8500) += vt8500
|
machine-$(CONFIG_ARCH_VT8500) += vt8500
|
||||||
machine-$(CONFIG_ARCH_W90X900) += w90x900
|
machine-$(CONFIG_ARCH_W90X900) += w90x900
|
||||||
machine-$(CONFIG_ARCH_ZYNQ) += zynq
|
machine-$(CONFIG_ARCH_ZYNQ) += zynq
|
||||||
machine-$(CONFIG_FOOTBRIDGE) += footbridge
|
|
||||||
machine-$(CONFIG_PLAT_SPEAR) += spear
|
machine-$(CONFIG_PLAT_SPEAR) += spear
|
||||||
|
|
||||||
# Platform directory name. This list is sorted alphanumerically
|
# Platform directory name. This list is sorted alphanumerically
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
# architecture-specific flags and dependencies.
|
# architecture-specific flags and dependencies.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
GCOV_PROFILE := n
|
||||||
|
|
||||||
LDFLAGS_bootp :=-p --no-undefined -X \
|
LDFLAGS_bootp :=-p --no-undefined -X \
|
||||||
--defsym initrd_phys=$(INITRD_PHYS) \
|
--defsym initrd_phys=$(INITRD_PHYS) \
|
||||||
--defsym params_phys=$(PARAMS_PHYS) -T
|
--defsym params_phys=$(PARAMS_PHYS) -T
|
||||||
|
@ -37,6 +37,8 @@ ifeq ($(CONFIG_ARM_VIRT_EXT),y)
|
|||||||
OBJS += hyp-stub.o
|
OBJS += hyp-stub.o
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
GCOV_PROFILE := n
|
||||||
|
|
||||||
#
|
#
|
||||||
# Architecture dependencies
|
# Architecture dependencies
|
||||||
#
|
#
|
||||||
|
@ -447,22 +447,19 @@
|
|||||||
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>;
|
||||||
gpmc,cs-rd-off-ns = <40>;
|
gpmc,cs-rd-off-ns = <80>;
|
||||||
gpmc,cs-wr-off-ns = <40>;
|
gpmc,cs-wr-off-ns = <80>;
|
||||||
gpmc,adv-on-ns = <0>;
|
gpmc,adv-on-ns = <0>;
|
||||||
gpmc,adv-rd-off-ns = <30>;
|
gpmc,adv-rd-off-ns = <60>;
|
||||||
gpmc,adv-wr-off-ns = <30>;
|
gpmc,adv-wr-off-ns = <60>;
|
||||||
gpmc,we-on-ns = <5>;
|
gpmc,we-on-ns = <10>;
|
||||||
gpmc,we-off-ns = <25>;
|
gpmc,we-off-ns = <50>;
|
||||||
gpmc,oe-on-ns = <2>;
|
gpmc,oe-on-ns = <4>;
|
||||||
gpmc,oe-off-ns = <20>;
|
gpmc,oe-off-ns = <40>;
|
||||||
gpmc,access-ns = <20>;
|
gpmc,access-ns = <40>;
|
||||||
gpmc,wr-access-ns = <40>;
|
gpmc,wr-access-ns = <80>;
|
||||||
gpmc,rd-cycle-ns = <40>;
|
gpmc,rd-cycle-ns = <80>;
|
||||||
gpmc,wr-cycle-ns = <40>;
|
gpmc,wr-cycle-ns = <80>;
|
||||||
gpmc,wait-pin = <0>;
|
|
||||||
gpmc,wait-on-read;
|
|
||||||
gpmc,wait-on-write;
|
|
||||||
gpmc,bus-turnaround-ns = <0>;
|
gpmc,bus-turnaround-ns = <0>;
|
||||||
gpmc,cycle2cycle-delay-ns = <0>;
|
gpmc,cycle2cycle-delay-ns = <0>;
|
||||||
gpmc,clk-activation-ns = <0>;
|
gpmc,clk-activation-ns = <0>;
|
||||||
|
@ -423,10 +423,14 @@
|
|||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
||||||
lvds-channel@0 {
|
lvds-channel@0 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
reg = <0>;
|
reg = <0>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
||||||
port {
|
port@0 {
|
||||||
|
reg = <0>;
|
||||||
|
|
||||||
lvds0_in: endpoint {
|
lvds0_in: endpoint {
|
||||||
remote-endpoint = <&ipu_di0_lvds0>;
|
remote-endpoint = <&ipu_di0_lvds0>;
|
||||||
};
|
};
|
||||||
@ -434,10 +438,14 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
lvds-channel@1 {
|
lvds-channel@1 {
|
||||||
|
#address-cells = <1>;
|
||||||
|
#size-cells = <0>;
|
||||||
reg = <1>;
|
reg = <1>;
|
||||||
status = "disabled";
|
status = "disabled";
|
||||||
|
|
||||||
port {
|
port@1 {
|
||||||
|
reg = <1>;
|
||||||
|
|
||||||
lvds1_in: endpoint {
|
lvds1_in: endpoint {
|
||||||
remote-endpoint = <&ipu_di1_lvds1>;
|
remote-endpoint = <&ipu_di1_lvds1>;
|
||||||
};
|
};
|
||||||
|
@ -40,7 +40,7 @@ clocks {
|
|||||||
#clock-cells = <0>;
|
#clock-cells = <0>;
|
||||||
compatible = "ti,keystone,psc-clock";
|
compatible = "ti,keystone,psc-clock";
|
||||||
clocks = <&chipclk16>;
|
clocks = <&chipclk16>;
|
||||||
clock-output-names = "usb";
|
clock-output-names = "usb1";
|
||||||
reg = <0x02350004 0xb00>, <0x02350000 0x400>;
|
reg = <0x02350004 0xb00>, <0x02350000 0x400>;
|
||||||
reg-names = "control", "domain";
|
reg-names = "control", "domain";
|
||||||
domain-id = <0>;
|
domain-id = <0>;
|
||||||
@ -60,8 +60,8 @@ clocks {
|
|||||||
#clock-cells = <0>;
|
#clock-cells = <0>;
|
||||||
compatible = "ti,keystone,psc-clock";
|
compatible = "ti,keystone,psc-clock";
|
||||||
clocks = <&chipclk12>;
|
clocks = <&chipclk12>;
|
||||||
clock-output-names = "pcie";
|
clock-output-names = "pcie1";
|
||||||
reg = <0x0235006c 0xb00>, <0x02350000 0x400>;
|
reg = <0x0235006c 0xb00>, <0x02350048 0x400>;
|
||||||
reg-names = "control", "domain";
|
reg-names = "control", "domain";
|
||||||
domain-id = <18>;
|
domain-id = <18>;
|
||||||
};
|
};
|
||||||
|
@ -353,13 +353,12 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
ldo8_reg: ldo8 {
|
ldo8_reg: ldo8 {
|
||||||
/* VDD_3v0: Does not go anywhere */
|
/* VDD_3V_GP: act led/serial console */
|
||||||
regulator-name = "ldo8";
|
regulator-name = "ldo8";
|
||||||
regulator-min-microvolt = <3000000>;
|
regulator-min-microvolt = <3000000>;
|
||||||
regulator-max-microvolt = <3000000>;
|
regulator-max-microvolt = <3000000>;
|
||||||
|
regulator-always-on;
|
||||||
regulator-boot-on;
|
regulator-boot-on;
|
||||||
/* Unused */
|
|
||||||
status = "disabled";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
ldo9_reg: ldo9 {
|
ldo9_reg: ldo9 {
|
||||||
|
@ -107,5 +107,6 @@ CONFIG_DEBUG_SPINLOCK=y
|
|||||||
CONFIG_DEBUG_MUTEXES=y
|
CONFIG_DEBUG_MUTEXES=y
|
||||||
CONFIG_DEBUG_USER=y
|
CONFIG_DEBUG_USER=y
|
||||||
CONFIG_DEBUG_LL=y
|
CONFIG_DEBUG_LL=y
|
||||||
|
CONFIG_DEBUG_LL_UART_PL01X=y
|
||||||
# CONFIG_CRYPTO_ANSI_CPRNG is not set
|
# CONFIG_CRYPTO_ANSI_CPRNG is not set
|
||||||
CONFIG_LIBCRC32C=y
|
CONFIG_LIBCRC32C=y
|
||||||
|
@ -82,5 +82,6 @@ CONFIG_MAGIC_SYSRQ=y
|
|||||||
CONFIG_DEBUG_KERNEL=y
|
CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_DEBUG_USER=y
|
CONFIG_DEBUG_USER=y
|
||||||
CONFIG_DEBUG_LL=y
|
CONFIG_DEBUG_LL=y
|
||||||
|
CONFIG_DEBUG_LL_UART_PL01X=y
|
||||||
CONFIG_FONTS=y
|
CONFIG_FONTS=y
|
||||||
CONFIG_FONT_ACORN_8x8=y
|
CONFIG_FONT_ACORN_8x8=y
|
||||||
|
@ -9,7 +9,7 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
|
#include <asm/assembler.h>
|
||||||
|
|
||||||
.syntax unified
|
.syntax unified
|
||||||
.code 32
|
.code 32
|
||||||
@ -61,13 +61,13 @@
|
|||||||
#define RT3 r12
|
#define RT3 r12
|
||||||
|
|
||||||
#define W0 q0
|
#define W0 q0
|
||||||
#define W1 q1
|
#define W1 q7
|
||||||
#define W2 q2
|
#define W2 q2
|
||||||
#define W3 q3
|
#define W3 q3
|
||||||
#define W4 q4
|
#define W4 q4
|
||||||
#define W5 q5
|
#define W5 q6
|
||||||
#define W6 q6
|
#define W6 q5
|
||||||
#define W7 q7
|
#define W7 q1
|
||||||
|
|
||||||
#define tmp0 q8
|
#define tmp0 q8
|
||||||
#define tmp1 q9
|
#define tmp1 q9
|
||||||
@ -79,6 +79,11 @@
|
|||||||
#define qK3 q14
|
#define qK3 q14
|
||||||
#define qK4 q15
|
#define qK4 q15
|
||||||
|
|
||||||
|
#ifdef CONFIG_CPU_BIG_ENDIAN
|
||||||
|
#define ARM_LE(code...)
|
||||||
|
#else
|
||||||
|
#define ARM_LE(code...) code
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Round function macros. */
|
/* Round function macros. */
|
||||||
|
|
||||||
@ -150,45 +155,45 @@
|
|||||||
#define W_PRECALC_00_15() \
|
#define W_PRECALC_00_15() \
|
||||||
add RWK, sp, #(WK_offs(0)); \
|
add RWK, sp, #(WK_offs(0)); \
|
||||||
\
|
\
|
||||||
vld1.32 {tmp0, tmp1}, [RDATA]!; \
|
vld1.32 {W0, W7}, [RDATA]!; \
|
||||||
vrev32.8 W0, tmp0; /* big => little */ \
|
ARM_LE(vrev32.8 W0, W0; ) /* big => little */ \
|
||||||
vld1.32 {tmp2, tmp3}, [RDATA]!; \
|
vld1.32 {W6, W5}, [RDATA]!; \
|
||||||
vadd.u32 tmp0, W0, curK; \
|
vadd.u32 tmp0, W0, curK; \
|
||||||
vrev32.8 W7, tmp1; /* big => little */ \
|
ARM_LE(vrev32.8 W7, W7; ) /* big => little */ \
|
||||||
vrev32.8 W6, tmp2; /* big => little */ \
|
ARM_LE(vrev32.8 W6, W6; ) /* big => little */ \
|
||||||
vadd.u32 tmp1, W7, curK; \
|
vadd.u32 tmp1, W7, curK; \
|
||||||
vrev32.8 W5, tmp3; /* big => little */ \
|
ARM_LE(vrev32.8 W5, W5; ) /* big => little */ \
|
||||||
vadd.u32 tmp2, W6, curK; \
|
vadd.u32 tmp2, W6, curK; \
|
||||||
vst1.32 {tmp0, tmp1}, [RWK]!; \
|
vst1.32 {tmp0, tmp1}, [RWK]!; \
|
||||||
vadd.u32 tmp3, W5, curK; \
|
vadd.u32 tmp3, W5, curK; \
|
||||||
vst1.32 {tmp2, tmp3}, [RWK]; \
|
vst1.32 {tmp2, tmp3}, [RWK]; \
|
||||||
|
|
||||||
#define WPRECALC_00_15_0(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_0(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vld1.32 {tmp0, tmp1}, [RDATA]!; \
|
vld1.32 {W0, W7}, [RDATA]!; \
|
||||||
|
|
||||||
#define WPRECALC_00_15_1(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_1(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
add RWK, sp, #(WK_offs(0)); \
|
add RWK, sp, #(WK_offs(0)); \
|
||||||
|
|
||||||
#define WPRECALC_00_15_2(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_2(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vrev32.8 W0, tmp0; /* big => little */ \
|
ARM_LE(vrev32.8 W0, W0; ) /* big => little */ \
|
||||||
|
|
||||||
#define WPRECALC_00_15_3(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_3(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vld1.32 {tmp2, tmp3}, [RDATA]!; \
|
vld1.32 {W6, W5}, [RDATA]!; \
|
||||||
|
|
||||||
#define WPRECALC_00_15_4(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_4(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vadd.u32 tmp0, W0, curK; \
|
vadd.u32 tmp0, W0, curK; \
|
||||||
|
|
||||||
#define WPRECALC_00_15_5(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_5(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vrev32.8 W7, tmp1; /* big => little */ \
|
ARM_LE(vrev32.8 W7, W7; ) /* big => little */ \
|
||||||
|
|
||||||
#define WPRECALC_00_15_6(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_6(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vrev32.8 W6, tmp2; /* big => little */ \
|
ARM_LE(vrev32.8 W6, W6; ) /* big => little */ \
|
||||||
|
|
||||||
#define WPRECALC_00_15_7(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_7(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vadd.u32 tmp1, W7, curK; \
|
vadd.u32 tmp1, W7, curK; \
|
||||||
|
|
||||||
#define WPRECALC_00_15_8(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_8(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vrev32.8 W5, tmp3; /* big => little */ \
|
ARM_LE(vrev32.8 W5, W5; ) /* big => little */ \
|
||||||
|
|
||||||
#define WPRECALC_00_15_9(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
#define WPRECALC_00_15_9(i,W,W_m04,W_m08,W_m12,W_m16,W_m20,W_m24,W_m28) \
|
||||||
vadd.u32 tmp2, W6, curK; \
|
vadd.u32 tmp2, W6, curK; \
|
||||||
|
@ -466,6 +466,7 @@ static inline void __sync_cache_range_r(volatile void *p, size_t size)
|
|||||||
*/
|
*/
|
||||||
#define v7_exit_coherency_flush(level) \
|
#define v7_exit_coherency_flush(level) \
|
||||||
asm volatile( \
|
asm volatile( \
|
||||||
|
".arch armv7-a \n\t" \
|
||||||
"stmfd sp!, {fp, ip} \n\t" \
|
"stmfd sp!, {fp, ip} \n\t" \
|
||||||
"mrc p15, 0, r0, c1, c0, 0 @ get SCTLR \n\t" \
|
"mrc p15, 0, r0, c1, c0, 0 @ get SCTLR \n\t" \
|
||||||
"bic r0, r0, #"__stringify(CR_C)" \n\t" \
|
"bic r0, r0, #"__stringify(CR_C)" \n\t" \
|
||||||
|
@ -45,7 +45,7 @@ void *return_address(unsigned int);
|
|||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
extern inline void *return_address(unsigned int level)
|
static inline void *return_address(unsigned int level)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -48,12 +48,6 @@ extern void smp_init_cpus(void);
|
|||||||
*/
|
*/
|
||||||
extern void set_smp_cross_call(void (*)(const struct cpumask *, unsigned int));
|
extern void set_smp_cross_call(void (*)(const struct cpumask *, unsigned int));
|
||||||
|
|
||||||
/*
|
|
||||||
* Boot a secondary CPU, and assign it the specified idle task.
|
|
||||||
* This also gives us the initial stack to use for this CPU.
|
|
||||||
*/
|
|
||||||
extern int boot_secondary(unsigned int cpu, struct task_struct *);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Called from platform specific assembly code, this is the
|
* Called from platform specific assembly code, this is the
|
||||||
* secondary CPU entry point.
|
* secondary CPU entry point.
|
||||||
|
@ -63,8 +63,8 @@ static inline void syscall_get_arguments(struct task_struct *task,
|
|||||||
if (i + n > SYSCALL_MAX_ARGS) {
|
if (i + n > SYSCALL_MAX_ARGS) {
|
||||||
unsigned long *args_bad = args + SYSCALL_MAX_ARGS - i;
|
unsigned long *args_bad = args + SYSCALL_MAX_ARGS - i;
|
||||||
unsigned int n_bad = n + i - SYSCALL_MAX_ARGS;
|
unsigned int n_bad = n + i - SYSCALL_MAX_ARGS;
|
||||||
pr_warning("%s called with max args %d, handling only %d\n",
|
pr_warn("%s called with max args %d, handling only %d\n",
|
||||||
__func__, i + n, SYSCALL_MAX_ARGS);
|
__func__, i + n, SYSCALL_MAX_ARGS);
|
||||||
memset(args_bad, 0, n_bad * sizeof(args[0]));
|
memset(args_bad, 0, n_bad * sizeof(args[0]));
|
||||||
n = SYSCALL_MAX_ARGS - i;
|
n = SYSCALL_MAX_ARGS - i;
|
||||||
}
|
}
|
||||||
@ -88,8 +88,8 @@ static inline void syscall_set_arguments(struct task_struct *task,
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (i + n > SYSCALL_MAX_ARGS) {
|
if (i + n > SYSCALL_MAX_ARGS) {
|
||||||
pr_warning("%s called with max args %d, handling only %d\n",
|
pr_warn("%s called with max args %d, handling only %d\n",
|
||||||
__func__, i + n, SYSCALL_MAX_ARGS);
|
__func__, i + n, SYSCALL_MAX_ARGS);
|
||||||
n = SYSCALL_MAX_ARGS - i;
|
n = SYSCALL_MAX_ARGS - i;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,9 @@
|
|||||||
#ifndef __ASMARM_TLS_H
|
#ifndef __ASMARM_TLS_H
|
||||||
#define __ASMARM_TLS_H
|
#define __ASMARM_TLS_H
|
||||||
|
|
||||||
|
#include <linux/compiler.h>
|
||||||
|
#include <asm/thread_info.h>
|
||||||
|
|
||||||
#ifdef __ASSEMBLY__
|
#ifdef __ASSEMBLY__
|
||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
.macro switch_tls_none, base, tp, tpuser, tmp1, tmp2
|
.macro switch_tls_none, base, tp, tpuser, tmp1, tmp2
|
||||||
@ -50,6 +53,49 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __ASSEMBLY__
|
#ifndef __ASSEMBLY__
|
||||||
|
|
||||||
|
static inline void set_tls(unsigned long val)
|
||||||
|
{
|
||||||
|
struct thread_info *thread;
|
||||||
|
|
||||||
|
thread = current_thread_info();
|
||||||
|
|
||||||
|
thread->tp_value[0] = val;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This code runs with preemption enabled and therefore must
|
||||||
|
* be reentrant with respect to switch_tls.
|
||||||
|
*
|
||||||
|
* We need to ensure ordering between the shadow state and the
|
||||||
|
* hardware state, so that we don't corrupt the hardware state
|
||||||
|
* with a stale shadow state during context switch.
|
||||||
|
*
|
||||||
|
* If we're preempted here, switch_tls will load TPIDRURO from
|
||||||
|
* thread_info upon resuming execution and the following mcr
|
||||||
|
* is merely redundant.
|
||||||
|
*/
|
||||||
|
barrier();
|
||||||
|
|
||||||
|
if (!tls_emu) {
|
||||||
|
if (has_tls_reg) {
|
||||||
|
asm("mcr p15, 0, %0, c13, c0, 3"
|
||||||
|
: : "r" (val));
|
||||||
|
} else {
|
||||||
|
#ifdef CONFIG_KUSER_HELPERS
|
||||||
|
/*
|
||||||
|
* User space must never try to access this
|
||||||
|
* directly. Expect your app to break
|
||||||
|
* eventually if you do so. The user helper
|
||||||
|
* at 0xffff0fe0 must be used instead. (see
|
||||||
|
* entry-armv.S for details)
|
||||||
|
*/
|
||||||
|
*((unsigned int *)0xffff0ff0) = val;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static inline unsigned long get_tpuser(void)
|
static inline unsigned long get_tpuser(void)
|
||||||
{
|
{
|
||||||
unsigned long reg = 0;
|
unsigned long reg = 0;
|
||||||
@ -59,5 +105,23 @@ static inline unsigned long get_tpuser(void)
|
|||||||
|
|
||||||
return reg;
|
return reg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static inline void set_tpuser(unsigned long val)
|
||||||
|
{
|
||||||
|
/* Since TPIDRURW is fully context-switched (unlike TPIDRURO),
|
||||||
|
* we need not update thread_info.
|
||||||
|
*/
|
||||||
|
if (has_tls_reg && !tls_emu) {
|
||||||
|
asm("mcr p15, 0, %0, c13, c0, 2"
|
||||||
|
: : "r" (val));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static inline void flush_tls(void)
|
||||||
|
{
|
||||||
|
set_tls(0);
|
||||||
|
set_tpuser(0);
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
#endif /* __ASMARM_TLS_H */
|
#endif /* __ASMARM_TLS_H */
|
||||||
|
@ -107,8 +107,11 @@ static inline void set_fs(mm_segment_t fs)
|
|||||||
extern int __get_user_1(void *);
|
extern int __get_user_1(void *);
|
||||||
extern int __get_user_2(void *);
|
extern int __get_user_2(void *);
|
||||||
extern int __get_user_4(void *);
|
extern int __get_user_4(void *);
|
||||||
extern int __get_user_lo8(void *);
|
extern int __get_user_32t_8(void *);
|
||||||
extern int __get_user_8(void *);
|
extern int __get_user_8(void *);
|
||||||
|
extern int __get_user_64t_1(void *);
|
||||||
|
extern int __get_user_64t_2(void *);
|
||||||
|
extern int __get_user_64t_4(void *);
|
||||||
|
|
||||||
#define __GUP_CLOBBER_1 "lr", "cc"
|
#define __GUP_CLOBBER_1 "lr", "cc"
|
||||||
#ifdef CONFIG_CPU_USE_DOMAINS
|
#ifdef CONFIG_CPU_USE_DOMAINS
|
||||||
@ -117,7 +120,7 @@ extern int __get_user_8(void *);
|
|||||||
#define __GUP_CLOBBER_2 "lr", "cc"
|
#define __GUP_CLOBBER_2 "lr", "cc"
|
||||||
#endif
|
#endif
|
||||||
#define __GUP_CLOBBER_4 "lr", "cc"
|
#define __GUP_CLOBBER_4 "lr", "cc"
|
||||||
#define __GUP_CLOBBER_lo8 "lr", "cc"
|
#define __GUP_CLOBBER_32t_8 "lr", "cc"
|
||||||
#define __GUP_CLOBBER_8 "lr", "cc"
|
#define __GUP_CLOBBER_8 "lr", "cc"
|
||||||
|
|
||||||
#define __get_user_x(__r2,__p,__e,__l,__s) \
|
#define __get_user_x(__r2,__p,__e,__l,__s) \
|
||||||
@ -131,12 +134,30 @@ extern int __get_user_8(void *);
|
|||||||
|
|
||||||
/* narrowing a double-word get into a single 32bit word register: */
|
/* narrowing a double-word get into a single 32bit word register: */
|
||||||
#ifdef __ARMEB__
|
#ifdef __ARMEB__
|
||||||
#define __get_user_xb(__r2, __p, __e, __l, __s) \
|
#define __get_user_x_32t(__r2, __p, __e, __l, __s) \
|
||||||
__get_user_x(__r2, __p, __e, __l, lo8)
|
__get_user_x(__r2, __p, __e, __l, 32t_8)
|
||||||
#else
|
#else
|
||||||
#define __get_user_xb __get_user_x
|
#define __get_user_x_32t __get_user_x
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* storing result into proper least significant word of 64bit target var,
|
||||||
|
* different only for big endian case where 64 bit __r2 lsw is r3:
|
||||||
|
*/
|
||||||
|
#ifdef __ARMEB__
|
||||||
|
#define __get_user_x_64t(__r2, __p, __e, __l, __s) \
|
||||||
|
__asm__ __volatile__ ( \
|
||||||
|
__asmeq("%0", "r0") __asmeq("%1", "r2") \
|
||||||
|
__asmeq("%3", "r1") \
|
||||||
|
"bl __get_user_64t_" #__s \
|
||||||
|
: "=&r" (__e), "=r" (__r2) \
|
||||||
|
: "0" (__p), "r" (__l) \
|
||||||
|
: __GUP_CLOBBER_##__s)
|
||||||
|
#else
|
||||||
|
#define __get_user_x_64t __get_user_x
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#define __get_user_check(x,p) \
|
#define __get_user_check(x,p) \
|
||||||
({ \
|
({ \
|
||||||
unsigned long __limit = current_thread_info()->addr_limit - 1; \
|
unsigned long __limit = current_thread_info()->addr_limit - 1; \
|
||||||
@ -146,17 +167,26 @@ extern int __get_user_8(void *);
|
|||||||
register int __e asm("r0"); \
|
register int __e asm("r0"); \
|
||||||
switch (sizeof(*(__p))) { \
|
switch (sizeof(*(__p))) { \
|
||||||
case 1: \
|
case 1: \
|
||||||
__get_user_x(__r2, __p, __e, __l, 1); \
|
if (sizeof((x)) >= 8) \
|
||||||
|
__get_user_x_64t(__r2, __p, __e, __l, 1); \
|
||||||
|
else \
|
||||||
|
__get_user_x(__r2, __p, __e, __l, 1); \
|
||||||
break; \
|
break; \
|
||||||
case 2: \
|
case 2: \
|
||||||
__get_user_x(__r2, __p, __e, __l, 2); \
|
if (sizeof((x)) >= 8) \
|
||||||
|
__get_user_x_64t(__r2, __p, __e, __l, 2); \
|
||||||
|
else \
|
||||||
|
__get_user_x(__r2, __p, __e, __l, 2); \
|
||||||
break; \
|
break; \
|
||||||
case 4: \
|
case 4: \
|
||||||
__get_user_x(__r2, __p, __e, __l, 4); \
|
if (sizeof((x)) >= 8) \
|
||||||
|
__get_user_x_64t(__r2, __p, __e, __l, 4); \
|
||||||
|
else \
|
||||||
|
__get_user_x(__r2, __p, __e, __l, 4); \
|
||||||
break; \
|
break; \
|
||||||
case 8: \
|
case 8: \
|
||||||
if (sizeof((x)) < 8) \
|
if (sizeof((x)) < 8) \
|
||||||
__get_user_xb(__r2, __p, __e, __l, 4); \
|
__get_user_x_32t(__r2, __p, __e, __l, 4); \
|
||||||
else \
|
else \
|
||||||
__get_user_x(__r2, __p, __e, __l, 8); \
|
__get_user_x(__r2, __p, __e, __l, 8); \
|
||||||
break; \
|
break; \
|
||||||
|
@ -98,6 +98,14 @@ EXPORT_SYMBOL(__clear_user);
|
|||||||
EXPORT_SYMBOL(__get_user_1);
|
EXPORT_SYMBOL(__get_user_1);
|
||||||
EXPORT_SYMBOL(__get_user_2);
|
EXPORT_SYMBOL(__get_user_2);
|
||||||
EXPORT_SYMBOL(__get_user_4);
|
EXPORT_SYMBOL(__get_user_4);
|
||||||
|
EXPORT_SYMBOL(__get_user_8);
|
||||||
|
|
||||||
|
#ifdef __ARMEB__
|
||||||
|
EXPORT_SYMBOL(__get_user_64t_1);
|
||||||
|
EXPORT_SYMBOL(__get_user_64t_2);
|
||||||
|
EXPORT_SYMBOL(__get_user_64t_4);
|
||||||
|
EXPORT_SYMBOL(__get_user_32t_8);
|
||||||
|
#endif
|
||||||
|
|
||||||
EXPORT_SYMBOL(__put_user_1);
|
EXPORT_SYMBOL(__put_user_1);
|
||||||
EXPORT_SYMBOL(__put_user_2);
|
EXPORT_SYMBOL(__put_user_2);
|
||||||
|
@ -130,7 +130,7 @@ static int __init parse_tag_cmdline(const struct tag *tag)
|
|||||||
strlcat(default_command_line, tag->u.cmdline.cmdline,
|
strlcat(default_command_line, tag->u.cmdline.cmdline,
|
||||||
COMMAND_LINE_SIZE);
|
COMMAND_LINE_SIZE);
|
||||||
#elif defined(CONFIG_CMDLINE_FORCE)
|
#elif defined(CONFIG_CMDLINE_FORCE)
|
||||||
pr_warning("Ignoring tag cmdline (using the default kernel command line)\n");
|
pr_warn("Ignoring tag cmdline (using the default kernel command line)\n");
|
||||||
#else
|
#else
|
||||||
strlcpy(default_command_line, tag->u.cmdline.cmdline,
|
strlcpy(default_command_line, tag->u.cmdline.cmdline,
|
||||||
COMMAND_LINE_SIZE);
|
COMMAND_LINE_SIZE);
|
||||||
|
@ -372,6 +372,9 @@ ENDPROC(__fiq_abt)
|
|||||||
ARM( stmib sp, {r1 - r12} )
|
ARM( stmib sp, {r1 - r12} )
|
||||||
THUMB( stmia sp, {r0 - r12} )
|
THUMB( stmia sp, {r0 - r12} )
|
||||||
|
|
||||||
|
ATRAP( mrc p15, 0, r7, c1, c0, 0)
|
||||||
|
ATRAP( ldr r8, .LCcralign)
|
||||||
|
|
||||||
ldmia r0, {r3 - r5}
|
ldmia r0, {r3 - r5}
|
||||||
add r0, sp, #S_PC @ here for interlock avoidance
|
add r0, sp, #S_PC @ here for interlock avoidance
|
||||||
mov r6, #-1 @ "" "" "" ""
|
mov r6, #-1 @ "" "" "" ""
|
||||||
@ -379,6 +382,8 @@ ENDPROC(__fiq_abt)
|
|||||||
str r3, [sp] @ save the "real" r0 copied
|
str r3, [sp] @ save the "real" r0 copied
|
||||||
@ from the exception stack
|
@ from the exception stack
|
||||||
|
|
||||||
|
ATRAP( ldr r8, [r8, #0])
|
||||||
|
|
||||||
@
|
@
|
||||||
@ We are now ready to fill in the remaining blanks on the stack:
|
@ We are now ready to fill in the remaining blanks on the stack:
|
||||||
@
|
@
|
||||||
@ -392,10 +397,9 @@ ENDPROC(__fiq_abt)
|
|||||||
ARM( stmdb r0, {sp, lr}^ )
|
ARM( stmdb r0, {sp, lr}^ )
|
||||||
THUMB( store_user_sp_lr r0, r1, S_SP - S_PC )
|
THUMB( store_user_sp_lr r0, r1, S_SP - S_PC )
|
||||||
|
|
||||||
@
|
|
||||||
@ Enable the alignment trap while in kernel mode
|
@ Enable the alignment trap while in kernel mode
|
||||||
@
|
ATRAP( teq r8, r7)
|
||||||
alignment_trap r0, .LCcralign
|
ATRAP( mcrne p15, 0, r8, c1, c0, 0)
|
||||||
|
|
||||||
@
|
@
|
||||||
@ Clear FP to mark the first stack frame
|
@ Clear FP to mark the first stack frame
|
||||||
|
@ -366,7 +366,7 @@ ENTRY(vector_swi)
|
|||||||
str r0, [sp, #S_OLD_R0] @ Save OLD_R0
|
str r0, [sp, #S_OLD_R0] @ Save OLD_R0
|
||||||
#endif
|
#endif
|
||||||
zero_fp
|
zero_fp
|
||||||
alignment_trap ip, __cr_alignment
|
alignment_trap r10, ip, __cr_alignment
|
||||||
enable_irq
|
enable_irq
|
||||||
ct_user_exit
|
ct_user_exit
|
||||||
get_thread_info tsk
|
get_thread_info tsk
|
||||||
|
@ -37,11 +37,19 @@
|
|||||||
#endif
|
#endif
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
.macro alignment_trap, rtemp, label
|
|
||||||
#ifdef CONFIG_ALIGNMENT_TRAP
|
#ifdef CONFIG_ALIGNMENT_TRAP
|
||||||
ldr \rtemp, \label
|
#define ATRAP(x...) x
|
||||||
ldr \rtemp, [\rtemp]
|
#else
|
||||||
mcr p15, 0, \rtemp, c1, c0
|
#define ATRAP(x...)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
.macro alignment_trap, rtmp1, rtmp2, label
|
||||||
|
#ifdef CONFIG_ALIGNMENT_TRAP
|
||||||
|
mrc p15, 0, \rtmp2, c1, c0, 0
|
||||||
|
ldr \rtmp1, \label
|
||||||
|
ldr \rtmp1, [\rtmp1]
|
||||||
|
teq \rtmp1, \rtmp2
|
||||||
|
mcrne p15, 0, \rtmp1, c1, c0, 0
|
||||||
#endif
|
#endif
|
||||||
.endm
|
.endm
|
||||||
|
|
||||||
|
@ -113,8 +113,8 @@ static u32 read_wb_reg(int n)
|
|||||||
GEN_READ_WB_REG_CASES(ARM_OP2_WVR, val);
|
GEN_READ_WB_REG_CASES(ARM_OP2_WVR, val);
|
||||||
GEN_READ_WB_REG_CASES(ARM_OP2_WCR, val);
|
GEN_READ_WB_REG_CASES(ARM_OP2_WCR, val);
|
||||||
default:
|
default:
|
||||||
pr_warning("attempt to read from unknown breakpoint "
|
pr_warn("attempt to read from unknown breakpoint register %d\n",
|
||||||
"register %d\n", n);
|
n);
|
||||||
}
|
}
|
||||||
|
|
||||||
return val;
|
return val;
|
||||||
@ -128,8 +128,8 @@ static void write_wb_reg(int n, u32 val)
|
|||||||
GEN_WRITE_WB_REG_CASES(ARM_OP2_WVR, val);
|
GEN_WRITE_WB_REG_CASES(ARM_OP2_WVR, val);
|
||||||
GEN_WRITE_WB_REG_CASES(ARM_OP2_WCR, val);
|
GEN_WRITE_WB_REG_CASES(ARM_OP2_WCR, val);
|
||||||
default:
|
default:
|
||||||
pr_warning("attempt to write to unknown breakpoint "
|
pr_warn("attempt to write to unknown breakpoint register %d\n",
|
||||||
"register %d\n", n);
|
n);
|
||||||
}
|
}
|
||||||
isb();
|
isb();
|
||||||
}
|
}
|
||||||
@ -292,7 +292,7 @@ int hw_breakpoint_slots(int type)
|
|||||||
case TYPE_DATA:
|
case TYPE_DATA:
|
||||||
return get_num_wrps();
|
return get_num_wrps();
|
||||||
default:
|
default:
|
||||||
pr_warning("unknown slot type: %d\n", type);
|
pr_warn("unknown slot type: %d\n", type);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -365,7 +365,7 @@ int arch_install_hw_breakpoint(struct perf_event *bp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i == max_slots) {
|
if (i == max_slots) {
|
||||||
pr_warning("Can't find any breakpoint slot\n");
|
pr_warn("Can't find any breakpoint slot\n");
|
||||||
return -EBUSY;
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -417,7 +417,7 @@ void arch_uninstall_hw_breakpoint(struct perf_event *bp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (i == max_slots) {
|
if (i == max_slots) {
|
||||||
pr_warning("Can't find any breakpoint slot\n");
|
pr_warn("Can't find any breakpoint slot\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -894,8 +894,8 @@ static int debug_reg_trap(struct pt_regs *regs, unsigned int instr)
|
|||||||
{
|
{
|
||||||
int cpu = smp_processor_id();
|
int cpu = smp_processor_id();
|
||||||
|
|
||||||
pr_warning("Debug register access (0x%x) caused undefined instruction on CPU %d\n",
|
pr_warn("Debug register access (0x%x) caused undefined instruction on CPU %d\n",
|
||||||
instr, cpu);
|
instr, cpu);
|
||||||
|
|
||||||
/* Set the error flag for this CPU and skip the faulting instruction. */
|
/* Set the error flag for this CPU and skip the faulting instruction. */
|
||||||
cpumask_set_cpu(cpu, &debug_err_mask);
|
cpumask_set_cpu(cpu, &debug_err_mask);
|
||||||
|
@ -175,7 +175,7 @@ static bool migrate_one_irq(struct irq_desc *desc)
|
|||||||
c = irq_data_get_irq_chip(d);
|
c = irq_data_get_irq_chip(d);
|
||||||
if (!c->irq_set_affinity)
|
if (!c->irq_set_affinity)
|
||||||
pr_debug("IRQ%u: unable to set affinity\n", d->irq);
|
pr_debug("IRQ%u: unable to set affinity\n", d->irq);
|
||||||
else if (c->irq_set_affinity(d, affinity, true) == IRQ_SET_MASK_OK && ret)
|
else if (c->irq_set_affinity(d, affinity, false) == IRQ_SET_MASK_OK && ret)
|
||||||
cpumask_copy(d->affinity, affinity);
|
cpumask_copy(d->affinity, affinity);
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
@ -205,8 +205,8 @@ void migrate_irqs(void)
|
|||||||
raw_spin_unlock(&desc->lock);
|
raw_spin_unlock(&desc->lock);
|
||||||
|
|
||||||
if (affinity_broken && printk_ratelimit())
|
if (affinity_broken && printk_ratelimit())
|
||||||
pr_warning("IRQ%u no longer affine to CPU%u\n", i,
|
pr_warn("IRQ%u no longer affine to CPU%u\n",
|
||||||
smp_processor_id());
|
i, smp_processor_id());
|
||||||
}
|
}
|
||||||
|
|
||||||
local_irq_restore(flags);
|
local_irq_restore(flags);
|
||||||
|
@ -110,10 +110,13 @@
|
|||||||
*
|
*
|
||||||
* @ TESTCASE_START
|
* @ TESTCASE_START
|
||||||
* bl __kprobes_test_case_start
|
* bl __kprobes_test_case_start
|
||||||
* @ start of inline data...
|
* .pushsection .rodata
|
||||||
|
* "10:
|
||||||
* .ascii "mov r0, r7" @ text title for test case
|
* .ascii "mov r0, r7" @ text title for test case
|
||||||
* .byte 0
|
* .byte 0
|
||||||
* .align 2, 0
|
* .popsection
|
||||||
|
* @ start of inline data...
|
||||||
|
* .word 10b @ pointer to title in .rodata section
|
||||||
*
|
*
|
||||||
* @ TEST_ARG_REG
|
* @ TEST_ARG_REG
|
||||||
* .byte ARG_TYPE_REG
|
* .byte ARG_TYPE_REG
|
||||||
@ -971,7 +974,7 @@ void __naked __kprobes_test_case_start(void)
|
|||||||
__asm__ __volatile__ (
|
__asm__ __volatile__ (
|
||||||
"stmdb sp!, {r4-r11} \n\t"
|
"stmdb sp!, {r4-r11} \n\t"
|
||||||
"sub sp, sp, #"__stringify(TEST_MEMORY_SIZE)"\n\t"
|
"sub sp, sp, #"__stringify(TEST_MEMORY_SIZE)"\n\t"
|
||||||
"bic r0, lr, #1 @ r0 = inline title string \n\t"
|
"bic r0, lr, #1 @ r0 = inline data \n\t"
|
||||||
"mov r1, sp \n\t"
|
"mov r1, sp \n\t"
|
||||||
"bl kprobes_test_case_start \n\t"
|
"bl kprobes_test_case_start \n\t"
|
||||||
"bx r0 \n\t"
|
"bx r0 \n\t"
|
||||||
@ -1349,15 +1352,14 @@ static unsigned long next_instruction(unsigned long pc)
|
|||||||
return pc + 4;
|
return pc + 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
static uintptr_t __used kprobes_test_case_start(const char *title, void *stack)
|
static uintptr_t __used kprobes_test_case_start(const char **title, void *stack)
|
||||||
{
|
{
|
||||||
struct test_arg *args;
|
struct test_arg *args;
|
||||||
struct test_arg_end *end_arg;
|
struct test_arg_end *end_arg;
|
||||||
unsigned long test_code;
|
unsigned long test_code;
|
||||||
|
|
||||||
args = (struct test_arg *)PTR_ALIGN(title + strlen(title) + 1, 4);
|
current_title = *title++;
|
||||||
|
args = (struct test_arg *)title;
|
||||||
current_title = title;
|
|
||||||
current_args = args;
|
current_args = args;
|
||||||
current_stack = stack;
|
current_stack = stack;
|
||||||
|
|
||||||
|
@ -111,11 +111,14 @@ struct test_arg_end {
|
|||||||
#define TESTCASE_START(title) \
|
#define TESTCASE_START(title) \
|
||||||
__asm__ __volatile__ ( \
|
__asm__ __volatile__ ( \
|
||||||
"bl __kprobes_test_case_start \n\t" \
|
"bl __kprobes_test_case_start \n\t" \
|
||||||
|
".pushsection .rodata \n\t" \
|
||||||
|
"10: \n\t" \
|
||||||
/* don't use .asciz here as 'title' may be */ \
|
/* don't use .asciz here as 'title' may be */ \
|
||||||
/* multiple strings to be concatenated. */ \
|
/* multiple strings to be concatenated. */ \
|
||||||
".ascii "#title" \n\t" \
|
".ascii "#title" \n\t" \
|
||||||
".byte 0 \n\t" \
|
".byte 0 \n\t" \
|
||||||
".align 2, 0 \n\t"
|
".popsection \n\t" \
|
||||||
|
".word 10b \n\t"
|
||||||
|
|
||||||
#define TEST_ARG_REG(reg, val) \
|
#define TEST_ARG_REG(reg, val) \
|
||||||
".byte "__stringify(ARG_TYPE_REG)" \n\t" \
|
".byte "__stringify(ARG_TYPE_REG)" \n\t" \
|
||||||
|
@ -76,21 +76,15 @@ static struct pmu_hw_events *cpu_pmu_get_cpu_events(void)
|
|||||||
|
|
||||||
static void cpu_pmu_enable_percpu_irq(void *data)
|
static void cpu_pmu_enable_percpu_irq(void *data)
|
||||||
{
|
{
|
||||||
struct arm_pmu *cpu_pmu = data;
|
int irq = *(int *)data;
|
||||||
struct platform_device *pmu_device = cpu_pmu->plat_device;
|
|
||||||
int irq = platform_get_irq(pmu_device, 0);
|
|
||||||
|
|
||||||
enable_percpu_irq(irq, IRQ_TYPE_NONE);
|
enable_percpu_irq(irq, IRQ_TYPE_NONE);
|
||||||
cpumask_set_cpu(smp_processor_id(), &cpu_pmu->active_irqs);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void cpu_pmu_disable_percpu_irq(void *data)
|
static void cpu_pmu_disable_percpu_irq(void *data)
|
||||||
{
|
{
|
||||||
struct arm_pmu *cpu_pmu = data;
|
int irq = *(int *)data;
|
||||||
struct platform_device *pmu_device = cpu_pmu->plat_device;
|
|
||||||
int irq = platform_get_irq(pmu_device, 0);
|
|
||||||
|
|
||||||
cpumask_clear_cpu(smp_processor_id(), &cpu_pmu->active_irqs);
|
|
||||||
disable_percpu_irq(irq);
|
disable_percpu_irq(irq);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,7 +97,7 @@ static void cpu_pmu_free_irq(struct arm_pmu *cpu_pmu)
|
|||||||
|
|
||||||
irq = platform_get_irq(pmu_device, 0);
|
irq = platform_get_irq(pmu_device, 0);
|
||||||
if (irq >= 0 && irq_is_percpu(irq)) {
|
if (irq >= 0 && irq_is_percpu(irq)) {
|
||||||
on_each_cpu(cpu_pmu_disable_percpu_irq, cpu_pmu, 1);
|
on_each_cpu(cpu_pmu_disable_percpu_irq, &irq, 1);
|
||||||
free_percpu_irq(irq, &percpu_pmu);
|
free_percpu_irq(irq, &percpu_pmu);
|
||||||
} else {
|
} else {
|
||||||
for (i = 0; i < irqs; ++i) {
|
for (i = 0; i < irqs; ++i) {
|
||||||
@ -138,7 +132,7 @@ static int cpu_pmu_request_irq(struct arm_pmu *cpu_pmu, irq_handler_t handler)
|
|||||||
irq);
|
irq);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
on_each_cpu(cpu_pmu_enable_percpu_irq, cpu_pmu, 1);
|
on_each_cpu(cpu_pmu_enable_percpu_irq, &irq, 1);
|
||||||
} else {
|
} else {
|
||||||
for (i = 0; i < irqs; ++i) {
|
for (i = 0; i < irqs; ++i) {
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -152,8 +146,8 @@ static int cpu_pmu_request_irq(struct arm_pmu *cpu_pmu, irq_handler_t handler)
|
|||||||
* continue. Otherwise, continue without this interrupt.
|
* continue. Otherwise, continue without this interrupt.
|
||||||
*/
|
*/
|
||||||
if (irq_set_affinity(irq, cpumask_of(i)) && irqs > 1) {
|
if (irq_set_affinity(irq, cpumask_of(i)) && irqs > 1) {
|
||||||
pr_warning("unable to set irq affinity (irq=%d, cpu=%u)\n",
|
pr_warn("unable to set irq affinity (irq=%d, cpu=%u)\n",
|
||||||
irq, i);
|
irq, i);
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -333,6 +333,8 @@ void flush_thread(void)
|
|||||||
memset(&tsk->thread.debug, 0, sizeof(struct debug_info));
|
memset(&tsk->thread.debug, 0, sizeof(struct debug_info));
|
||||||
memset(&thread->fpstate, 0, sizeof(union fp_state));
|
memset(&thread->fpstate, 0, sizeof(union fp_state));
|
||||||
|
|
||||||
|
flush_tls();
|
||||||
|
|
||||||
thread_notify(THREAD_NOTIFY_FLUSH, thread);
|
thread_notify(THREAD_NOTIFY_FLUSH, thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -471,19 +473,57 @@ int in_gate_area_no_mm(unsigned long addr)
|
|||||||
|
|
||||||
const char *arch_vma_name(struct vm_area_struct *vma)
|
const char *arch_vma_name(struct vm_area_struct *vma)
|
||||||
{
|
{
|
||||||
return is_gate_vma(vma) ? "[vectors]" :
|
return is_gate_vma(vma) ? "[vectors]" : NULL;
|
||||||
(vma->vm_mm && vma->vm_start == vma->vm_mm->context.sigpage) ?
|
}
|
||||||
"[sigpage]" : NULL;
|
|
||||||
|
/* If possible, provide a placement hint at a random offset from the
|
||||||
|
* stack for the signal page.
|
||||||
|
*/
|
||||||
|
static unsigned long sigpage_addr(const struct mm_struct *mm,
|
||||||
|
unsigned int npages)
|
||||||
|
{
|
||||||
|
unsigned long offset;
|
||||||
|
unsigned long first;
|
||||||
|
unsigned long last;
|
||||||
|
unsigned long addr;
|
||||||
|
unsigned int slots;
|
||||||
|
|
||||||
|
first = PAGE_ALIGN(mm->start_stack);
|
||||||
|
|
||||||
|
last = TASK_SIZE - (npages << PAGE_SHIFT);
|
||||||
|
|
||||||
|
/* No room after stack? */
|
||||||
|
if (first > last)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* Just enough room? */
|
||||||
|
if (first == last)
|
||||||
|
return first;
|
||||||
|
|
||||||
|
slots = ((last - first) >> PAGE_SHIFT) + 1;
|
||||||
|
|
||||||
|
offset = get_random_int() % slots;
|
||||||
|
|
||||||
|
addr = first + (offset << PAGE_SHIFT);
|
||||||
|
|
||||||
|
return addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct page *signal_page;
|
static struct page *signal_page;
|
||||||
extern struct page *get_signal_page(void);
|
extern struct page *get_signal_page(void);
|
||||||
|
|
||||||
|
static const struct vm_special_mapping sigpage_mapping = {
|
||||||
|
.name = "[sigpage]",
|
||||||
|
.pages = &signal_page,
|
||||||
|
};
|
||||||
|
|
||||||
int arch_setup_additional_pages(struct linux_binprm *bprm, int uses_interp)
|
int arch_setup_additional_pages(struct linux_binprm *bprm, int uses_interp)
|
||||||
{
|
{
|
||||||
struct mm_struct *mm = current->mm;
|
struct mm_struct *mm = current->mm;
|
||||||
|
struct vm_area_struct *vma;
|
||||||
unsigned long addr;
|
unsigned long addr;
|
||||||
int ret;
|
unsigned long hint;
|
||||||
|
int ret = 0;
|
||||||
|
|
||||||
if (!signal_page)
|
if (!signal_page)
|
||||||
signal_page = get_signal_page();
|
signal_page = get_signal_page();
|
||||||
@ -491,18 +531,23 @@ int arch_setup_additional_pages(struct linux_binprm *bprm, int uses_interp)
|
|||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
down_write(&mm->mmap_sem);
|
down_write(&mm->mmap_sem);
|
||||||
addr = get_unmapped_area(NULL, 0, PAGE_SIZE, 0, 0);
|
hint = sigpage_addr(mm, 1);
|
||||||
|
addr = get_unmapped_area(NULL, hint, PAGE_SIZE, 0, 0);
|
||||||
if (IS_ERR_VALUE(addr)) {
|
if (IS_ERR_VALUE(addr)) {
|
||||||
ret = addr;
|
ret = addr;
|
||||||
goto up_fail;
|
goto up_fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = install_special_mapping(mm, addr, PAGE_SIZE,
|
vma = _install_special_mapping(mm, addr, PAGE_SIZE,
|
||||||
VM_READ | VM_EXEC | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC,
|
VM_READ | VM_EXEC | VM_MAYREAD | VM_MAYWRITE | VM_MAYEXEC,
|
||||||
&signal_page);
|
&sigpage_mapping);
|
||||||
|
|
||||||
if (ret == 0)
|
if (IS_ERR(vma)) {
|
||||||
mm->context.sigpage = addr;
|
ret = PTR_ERR(vma);
|
||||||
|
goto up_fail;
|
||||||
|
}
|
||||||
|
|
||||||
|
mm->context.sigpage = addr;
|
||||||
|
|
||||||
up_fail:
|
up_fail:
|
||||||
up_write(&mm->mmap_sem);
|
up_write(&mm->mmap_sem);
|
||||||
|
@ -59,15 +59,6 @@ void *return_address(unsigned int level)
|
|||||||
|
|
||||||
#else /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) */
|
#else /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) */
|
||||||
|
|
||||||
#if defined(CONFIG_ARM_UNWIND)
|
|
||||||
#warning "TODO: return_address should use unwind tables"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void *return_address(unsigned int level)
|
|
||||||
{
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) / else */
|
#endif /* if defined(CONFIG_FRAME_POINTER) && !defined(CONFIG_ARM_UNWIND) / else */
|
||||||
|
|
||||||
EXPORT_SYMBOL_GPL(return_address);
|
EXPORT_SYMBOL_GPL(return_address);
|
||||||
|
@ -95,6 +95,9 @@ int __cpu_up(unsigned int cpu, struct task_struct *idle)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
if (!smp_ops.smp_boot_secondary)
|
||||||
|
return -ENOSYS;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We need to tell the secondary core where to find
|
* We need to tell the secondary core where to find
|
||||||
* its stack and the page tables.
|
* its stack and the page tables.
|
||||||
@ -113,7 +116,7 @@ int __cpu_up(unsigned int cpu, struct task_struct *idle)
|
|||||||
/*
|
/*
|
||||||
* Now bring the CPU into our world.
|
* Now bring the CPU into our world.
|
||||||
*/
|
*/
|
||||||
ret = boot_secondary(cpu, idle);
|
ret = smp_ops.smp_boot_secondary(cpu, idle);
|
||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
/*
|
/*
|
||||||
* CPU was successfully started, wait for it
|
* CPU was successfully started, wait for it
|
||||||
@ -142,13 +145,6 @@ void __init smp_init_cpus(void)
|
|||||||
smp_ops.smp_init_cpus();
|
smp_ops.smp_init_cpus();
|
||||||
}
|
}
|
||||||
|
|
||||||
int boot_secondary(unsigned int cpu, struct task_struct *idle)
|
|
||||||
{
|
|
||||||
if (smp_ops.smp_boot_secondary)
|
|
||||||
return smp_ops.smp_boot_secondary(cpu, idle);
|
|
||||||
return -ENOSYS;
|
|
||||||
}
|
|
||||||
|
|
||||||
int platform_can_cpu_hotplug(void)
|
int platform_can_cpu_hotplug(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
@ -650,7 +646,7 @@ void smp_send_stop(void)
|
|||||||
udelay(1);
|
udelay(1);
|
||||||
|
|
||||||
if (num_online_cpus() > 1)
|
if (num_online_cpus() > 1)
|
||||||
pr_warning("SMP: failed to stop secondary CPUs\n");
|
pr_warn("SMP: failed to stop secondary CPUs\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -142,14 +142,6 @@ static int emulate_swpX(unsigned int address, unsigned int *data,
|
|||||||
while (1) {
|
while (1) {
|
||||||
unsigned long temp;
|
unsigned long temp;
|
||||||
|
|
||||||
/*
|
|
||||||
* Barrier required between accessing protected resource and
|
|
||||||
* releasing a lock for it. Legacy code might not have done
|
|
||||||
* this, and we cannot determine that this is not the case
|
|
||||||
* being emulated, so insert always.
|
|
||||||
*/
|
|
||||||
smp_mb();
|
|
||||||
|
|
||||||
if (type == TYPE_SWPB)
|
if (type == TYPE_SWPB)
|
||||||
__user_swpb_asm(*data, address, res, temp);
|
__user_swpb_asm(*data, address, res, temp);
|
||||||
else
|
else
|
||||||
@ -162,13 +154,6 @@ static int emulate_swpX(unsigned int address, unsigned int *data,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (res == 0) {
|
if (res == 0) {
|
||||||
/*
|
|
||||||
* Barrier also required between acquiring a lock for a
|
|
||||||
* protected resource and accessing the resource. Inserted for
|
|
||||||
* same reason as above.
|
|
||||||
*/
|
|
||||||
smp_mb();
|
|
||||||
|
|
||||||
if (type == TYPE_SWPB)
|
if (type == TYPE_SWPB)
|
||||||
swpbcounter++;
|
swpbcounter++;
|
||||||
else
|
else
|
||||||
|
@ -45,7 +45,7 @@ static int thumbee_notifier(struct notifier_block *self, unsigned long cmd, void
|
|||||||
|
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case THREAD_NOTIFY_FLUSH:
|
case THREAD_NOTIFY_FLUSH:
|
||||||
thread->thumbee_state = 0;
|
teehbr_write(0);
|
||||||
break;
|
break;
|
||||||
case THREAD_NOTIFY_SWITCH:
|
case THREAD_NOTIFY_SWITCH:
|
||||||
current_thread_info()->thumbee_state = teehbr_read();
|
current_thread_info()->thumbee_state = teehbr_read();
|
||||||
|
@ -601,7 +601,6 @@ do_cache_op(unsigned long start, unsigned long end, int flags)
|
|||||||
#define NR(x) ((__ARM_NR_##x) - __ARM_NR_BASE)
|
#define NR(x) ((__ARM_NR_##x) - __ARM_NR_BASE)
|
||||||
asmlinkage int arm_syscall(int no, struct pt_regs *regs)
|
asmlinkage int arm_syscall(int no, struct pt_regs *regs)
|
||||||
{
|
{
|
||||||
struct thread_info *thread = current_thread_info();
|
|
||||||
siginfo_t info;
|
siginfo_t info;
|
||||||
|
|
||||||
if ((no >> 16) != (__ARM_NR_BASE>> 16))
|
if ((no >> 16) != (__ARM_NR_BASE>> 16))
|
||||||
@ -652,21 +651,7 @@ asmlinkage int arm_syscall(int no, struct pt_regs *regs)
|
|||||||
return regs->ARM_r0;
|
return regs->ARM_r0;
|
||||||
|
|
||||||
case NR(set_tls):
|
case NR(set_tls):
|
||||||
thread->tp_value[0] = regs->ARM_r0;
|
set_tls(regs->ARM_r0);
|
||||||
if (tls_emu)
|
|
||||||
return 0;
|
|
||||||
if (has_tls_reg) {
|
|
||||||
asm ("mcr p15, 0, %0, c13, c0, 3"
|
|
||||||
: : "r" (regs->ARM_r0));
|
|
||||||
} else {
|
|
||||||
/*
|
|
||||||
* User space must never try to access this directly.
|
|
||||||
* Expect your app to break eventually if you do so.
|
|
||||||
* The user helper at 0xffff0fe0 must be used instead.
|
|
||||||
* (see entry-armv.S for details)
|
|
||||||
*/
|
|
||||||
*((unsigned int *)0xffff0ff0) = regs->ARM_r0;
|
|
||||||
}
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
#ifdef CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG
|
#ifdef CONFIG_NEEDS_SYSCALL_FOR_CMPXCHG
|
||||||
|
@ -157,7 +157,7 @@ static const struct unwind_idx *search_index(unsigned long addr,
|
|||||||
if (likely(start->addr_offset <= addr_prel31))
|
if (likely(start->addr_offset <= addr_prel31))
|
||||||
return start;
|
return start;
|
||||||
else {
|
else {
|
||||||
pr_warning("unwind: Unknown symbol address %08lx\n", addr);
|
pr_warn("unwind: Unknown symbol address %08lx\n", addr);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -225,7 +225,7 @@ static unsigned long unwind_get_byte(struct unwind_ctrl_block *ctrl)
|
|||||||
unsigned long ret;
|
unsigned long ret;
|
||||||
|
|
||||||
if (ctrl->entries <= 0) {
|
if (ctrl->entries <= 0) {
|
||||||
pr_warning("unwind: Corrupt unwind table\n");
|
pr_warn("unwind: Corrupt unwind table\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -333,8 +333,8 @@ static int unwind_exec_insn(struct unwind_ctrl_block *ctrl)
|
|||||||
insn = (insn << 8) | unwind_get_byte(ctrl);
|
insn = (insn << 8) | unwind_get_byte(ctrl);
|
||||||
mask = insn & 0x0fff;
|
mask = insn & 0x0fff;
|
||||||
if (mask == 0) {
|
if (mask == 0) {
|
||||||
pr_warning("unwind: 'Refuse to unwind' instruction %04lx\n",
|
pr_warn("unwind: 'Refuse to unwind' instruction %04lx\n",
|
||||||
insn);
|
insn);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -357,8 +357,8 @@ static int unwind_exec_insn(struct unwind_ctrl_block *ctrl)
|
|||||||
unsigned long mask = unwind_get_byte(ctrl);
|
unsigned long mask = unwind_get_byte(ctrl);
|
||||||
|
|
||||||
if (mask == 0 || mask & 0xf0) {
|
if (mask == 0 || mask & 0xf0) {
|
||||||
pr_warning("unwind: Spare encoding %04lx\n",
|
pr_warn("unwind: Spare encoding %04lx\n",
|
||||||
(insn << 8) | mask);
|
(insn << 8) | mask);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -370,7 +370,7 @@ static int unwind_exec_insn(struct unwind_ctrl_block *ctrl)
|
|||||||
|
|
||||||
ctrl->vrs[SP] += 0x204 + (uleb128 << 2);
|
ctrl->vrs[SP] += 0x204 + (uleb128 << 2);
|
||||||
} else {
|
} else {
|
||||||
pr_warning("unwind: Unhandled instruction %02lx\n", insn);
|
pr_warn("unwind: Unhandled instruction %02lx\n", insn);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,7 +403,7 @@ int unwind_frame(struct stackframe *frame)
|
|||||||
|
|
||||||
idx = unwind_find_idx(frame->pc);
|
idx = unwind_find_idx(frame->pc);
|
||||||
if (!idx) {
|
if (!idx) {
|
||||||
pr_warning("unwind: Index not found %08lx\n", frame->pc);
|
pr_warn("unwind: Index not found %08lx\n", frame->pc);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -422,8 +422,8 @@ int unwind_frame(struct stackframe *frame)
|
|||||||
/* only personality routine 0 supported in the index */
|
/* only personality routine 0 supported in the index */
|
||||||
ctrl.insn = &idx->insn;
|
ctrl.insn = &idx->insn;
|
||||||
else {
|
else {
|
||||||
pr_warning("unwind: Unsupported personality routine %08lx in the index at %p\n",
|
pr_warn("unwind: Unsupported personality routine %08lx in the index at %p\n",
|
||||||
idx->insn, idx);
|
idx->insn, idx);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -435,8 +435,8 @@ int unwind_frame(struct stackframe *frame)
|
|||||||
ctrl.byte = 1;
|
ctrl.byte = 1;
|
||||||
ctrl.entries = 1 + ((*ctrl.insn & 0x00ff0000) >> 16);
|
ctrl.entries = 1 + ((*ctrl.insn & 0x00ff0000) >> 16);
|
||||||
} else {
|
} else {
|
||||||
pr_warning("unwind: Unsupported personality routine %08lx at %p\n",
|
pr_warn("unwind: Unsupported personality routine %08lx at %p\n",
|
||||||
*ctrl.insn, ctrl.insn);
|
*ctrl.insn, ctrl.insn);
|
||||||
return -URC_FAILURE;
|
return -URC_FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -219,8 +219,8 @@ SECTIONS
|
|||||||
__data_loc = ALIGN(4); /* location in binary */
|
__data_loc = ALIGN(4); /* location in binary */
|
||||||
. = PAGE_OFFSET + TEXT_OFFSET;
|
. = PAGE_OFFSET + TEXT_OFFSET;
|
||||||
#else
|
#else
|
||||||
__init_end = .;
|
|
||||||
. = ALIGN(THREAD_SIZE);
|
. = ALIGN(THREAD_SIZE);
|
||||||
|
__init_end = .;
|
||||||
__data_loc = .;
|
__data_loc = .;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -80,7 +80,7 @@ ENTRY(__get_user_8)
|
|||||||
ENDPROC(__get_user_8)
|
ENDPROC(__get_user_8)
|
||||||
|
|
||||||
#ifdef __ARMEB__
|
#ifdef __ARMEB__
|
||||||
ENTRY(__get_user_lo8)
|
ENTRY(__get_user_32t_8)
|
||||||
check_uaccess r0, 8, r1, r2, __get_user_bad
|
check_uaccess r0, 8, r1, r2, __get_user_bad
|
||||||
#ifdef CONFIG_CPU_USE_DOMAINS
|
#ifdef CONFIG_CPU_USE_DOMAINS
|
||||||
add r0, r0, #4
|
add r0, r0, #4
|
||||||
@ -90,7 +90,37 @@ ENTRY(__get_user_lo8)
|
|||||||
#endif
|
#endif
|
||||||
mov r0, #0
|
mov r0, #0
|
||||||
ret lr
|
ret lr
|
||||||
ENDPROC(__get_user_lo8)
|
ENDPROC(__get_user_32t_8)
|
||||||
|
|
||||||
|
ENTRY(__get_user_64t_1)
|
||||||
|
check_uaccess r0, 1, r1, r2, __get_user_bad8
|
||||||
|
8: TUSER(ldrb) r3, [r0]
|
||||||
|
mov r0, #0
|
||||||
|
ret lr
|
||||||
|
ENDPROC(__get_user_64t_1)
|
||||||
|
|
||||||
|
ENTRY(__get_user_64t_2)
|
||||||
|
check_uaccess r0, 2, r1, r2, __get_user_bad8
|
||||||
|
#ifdef CONFIG_CPU_USE_DOMAINS
|
||||||
|
rb .req ip
|
||||||
|
9: ldrbt r3, [r0], #1
|
||||||
|
10: ldrbt rb, [r0], #0
|
||||||
|
#else
|
||||||
|
rb .req r0
|
||||||
|
9: ldrb r3, [r0]
|
||||||
|
10: ldrb rb, [r0, #1]
|
||||||
|
#endif
|
||||||
|
orr r3, rb, r3, lsl #8
|
||||||
|
mov r0, #0
|
||||||
|
ret lr
|
||||||
|
ENDPROC(__get_user_64t_2)
|
||||||
|
|
||||||
|
ENTRY(__get_user_64t_4)
|
||||||
|
check_uaccess r0, 4, r1, r2, __get_user_bad8
|
||||||
|
11: TUSER(ldr) r3, [r0]
|
||||||
|
mov r0, #0
|
||||||
|
ret lr
|
||||||
|
ENDPROC(__get_user_64t_4)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
__get_user_bad8:
|
__get_user_bad8:
|
||||||
@ -111,5 +141,9 @@ ENDPROC(__get_user_bad8)
|
|||||||
.long 6b, __get_user_bad8
|
.long 6b, __get_user_bad8
|
||||||
#ifdef __ARMEB__
|
#ifdef __ARMEB__
|
||||||
.long 7b, __get_user_bad
|
.long 7b, __get_user_bad
|
||||||
|
.long 8b, __get_user_bad8
|
||||||
|
.long 9b, __get_user_bad8
|
||||||
|
.long 10b, __get_user_bad8
|
||||||
|
.long 11b, __get_user_bad8
|
||||||
#endif
|
#endif
|
||||||
.popsection
|
.popsection
|
||||||
|
@ -97,7 +97,7 @@ static int clk_gate2_is_enabled(struct clk_hw *hw)
|
|||||||
struct clk_gate2 *gate = to_clk_gate2(hw);
|
struct clk_gate2 *gate = to_clk_gate2(hw);
|
||||||
|
|
||||||
if (gate->share_count)
|
if (gate->share_count)
|
||||||
return !!(*gate->share_count);
|
return !!__clk_get_enable_count(hw->clk);
|
||||||
else
|
else
|
||||||
return clk_gate2_reg_is_enabled(gate->reg, gate->bit_idx);
|
return clk_gate2_reg_is_enabled(gate->reg, gate->bit_idx);
|
||||||
}
|
}
|
||||||
@ -127,10 +127,6 @@ struct clk *clk_register_gate2(struct device *dev, const char *name,
|
|||||||
gate->bit_idx = bit_idx;
|
gate->bit_idx = bit_idx;
|
||||||
gate->flags = clk_gate2_flags;
|
gate->flags = clk_gate2_flags;
|
||||||
gate->lock = lock;
|
gate->lock = lock;
|
||||||
|
|
||||||
/* Initialize share_count per hardware state */
|
|
||||||
if (share_count)
|
|
||||||
*share_count = clk_gate2_reg_is_enabled(reg, bit_idx) ? 1 : 0;
|
|
||||||
gate->share_count = share_count;
|
gate->share_count = share_count;
|
||||||
|
|
||||||
init.name = name;
|
init.name = name;
|
||||||
|
@ -1,9 +1,6 @@
|
|||||||
menu "TI OMAP/AM/DM/DRA Family"
|
menu "TI OMAP/AM/DM/DRA Family"
|
||||||
depends on ARCH_MULTI_V6 || ARCH_MULTI_V7
|
depends on ARCH_MULTI_V6 || ARCH_MULTI_V7
|
||||||
|
|
||||||
config ARCH_OMAP
|
|
||||||
bool
|
|
||||||
|
|
||||||
config ARCH_OMAP2
|
config ARCH_OMAP2
|
||||||
bool "TI OMAP2"
|
bool "TI OMAP2"
|
||||||
depends on ARCH_MULTI_V6
|
depends on ARCH_MULTI_V6
|
||||||
|
@ -2065,7 +2065,7 @@ static void _reconfigure_io_chain(void)
|
|||||||
|
|
||||||
spin_lock_irqsave(&io_chain_lock, flags);
|
spin_lock_irqsave(&io_chain_lock, flags);
|
||||||
|
|
||||||
if (cpu_is_omap34xx() && omap3_has_io_chain_ctrl())
|
if (cpu_is_omap34xx())
|
||||||
omap3xxx_prm_reconfigure_io_chain();
|
omap3xxx_prm_reconfigure_io_chain();
|
||||||
else if (cpu_is_omap44xx())
|
else if (cpu_is_omap44xx())
|
||||||
omap44xx_prm_reconfigure_io_chain();
|
omap44xx_prm_reconfigure_io_chain();
|
||||||
|
@ -45,7 +45,7 @@ static struct omap_prcm_irq_setup omap3_prcm_irq_setup = {
|
|||||||
.ocp_barrier = &omap3xxx_prm_ocp_barrier,
|
.ocp_barrier = &omap3xxx_prm_ocp_barrier,
|
||||||
.save_and_clear_irqen = &omap3xxx_prm_save_and_clear_irqen,
|
.save_and_clear_irqen = &omap3xxx_prm_save_and_clear_irqen,
|
||||||
.restore_irqen = &omap3xxx_prm_restore_irqen,
|
.restore_irqen = &omap3xxx_prm_restore_irqen,
|
||||||
.reconfigure_io_chain = &omap3xxx_prm_reconfigure_io_chain,
|
.reconfigure_io_chain = NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -369,15 +369,30 @@ void __init omap3_prm_init_pm(bool has_uart4, bool has_iva)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* omap3xxx_prm_reconfigure_io_chain - clear latches and reconfigure I/O chain
|
* omap3430_pre_es3_1_reconfigure_io_chain - restart wake-up daisy chain
|
||||||
|
*
|
||||||
|
* The ST_IO_CHAIN bit does not exist in 3430 before es3.1. The only
|
||||||
|
* thing we can do is toggle EN_IO bit for earlier omaps.
|
||||||
|
*/
|
||||||
|
void omap3430_pre_es3_1_reconfigure_io_chain(void)
|
||||||
|
{
|
||||||
|
omap2_prm_clear_mod_reg_bits(OMAP3430_EN_IO_MASK, WKUP_MOD,
|
||||||
|
PM_WKEN);
|
||||||
|
omap2_prm_set_mod_reg_bits(OMAP3430_EN_IO_MASK, WKUP_MOD,
|
||||||
|
PM_WKEN);
|
||||||
|
omap2_prm_read_mod_reg(WKUP_MOD, PM_WKEN);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* omap3_prm_reconfigure_io_chain - clear latches and reconfigure I/O chain
|
||||||
*
|
*
|
||||||
* Clear any previously-latched I/O wakeup events and ensure that the
|
* Clear any previously-latched I/O wakeup events and ensure that the
|
||||||
* I/O wakeup gates are aligned with the current mux settings. Works
|
* I/O wakeup gates are aligned with the current mux settings. Works
|
||||||
* by asserting WUCLKIN, waiting for WUCLKOUT to be asserted, and then
|
* by asserting WUCLKIN, waiting for WUCLKOUT to be asserted, and then
|
||||||
* deasserting WUCLKIN and clearing the ST_IO_CHAIN WKST bit. No
|
* deasserting WUCLKIN and clearing the ST_IO_CHAIN WKST bit. No
|
||||||
* return value.
|
* return value. These registers are only available in 3430 es3.1 and later.
|
||||||
*/
|
*/
|
||||||
void omap3xxx_prm_reconfigure_io_chain(void)
|
void omap3_prm_reconfigure_io_chain(void)
|
||||||
{
|
{
|
||||||
int i = 0;
|
int i = 0;
|
||||||
|
|
||||||
@ -399,6 +414,15 @@ void omap3xxx_prm_reconfigure_io_chain(void)
|
|||||||
omap2_prm_read_mod_reg(WKUP_MOD, PM_WKST);
|
omap2_prm_read_mod_reg(WKUP_MOD, PM_WKST);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* omap3xxx_prm_reconfigure_io_chain - reconfigure I/O chain
|
||||||
|
*/
|
||||||
|
void omap3xxx_prm_reconfigure_io_chain(void)
|
||||||
|
{
|
||||||
|
if (omap3_prcm_irq_setup.reconfigure_io_chain)
|
||||||
|
omap3_prcm_irq_setup.reconfigure_io_chain();
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* omap3xxx_prm_enable_io_wakeup - enable wakeup events from I/O wakeup latches
|
* omap3xxx_prm_enable_io_wakeup - enable wakeup events from I/O wakeup latches
|
||||||
*
|
*
|
||||||
@ -656,6 +680,13 @@ static int omap3xxx_prm_late_init(void)
|
|||||||
if (!(prm_features & PRM_HAS_IO_WAKEUP))
|
if (!(prm_features & PRM_HAS_IO_WAKEUP))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (omap3_has_io_chain_ctrl())
|
||||||
|
omap3_prcm_irq_setup.reconfigure_io_chain =
|
||||||
|
omap3_prm_reconfigure_io_chain;
|
||||||
|
else
|
||||||
|
omap3_prcm_irq_setup.reconfigure_io_chain =
|
||||||
|
omap3430_pre_es3_1_reconfigure_io_chain;
|
||||||
|
|
||||||
omap3xxx_prm_enable_io_wakeup();
|
omap3xxx_prm_enable_io_wakeup();
|
||||||
ret = omap_prcm_register_chain_handler(&omap3_prcm_irq_setup);
|
ret = omap_prcm_register_chain_handler(&omap3_prcm_irq_setup);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
|
@ -61,7 +61,7 @@ EXPORT_SYMBOL(get_clock_tick_rate);
|
|||||||
/*
|
/*
|
||||||
* For non device-tree builds, keep legacy timer init
|
* For non device-tree builds, keep legacy timer init
|
||||||
*/
|
*/
|
||||||
void pxa_timer_init(void)
|
void __init pxa_timer_init(void)
|
||||||
{
|
{
|
||||||
pxa_timer_nodt_init(IRQ_OST0, io_p2v(0x40a00000),
|
pxa_timer_nodt_init(IRQ_OST0, io_p2v(0x40a00000),
|
||||||
get_clock_tick_rate());
|
get_clock_tick_rate());
|
||||||
|
@ -58,6 +58,7 @@ config SA1100_H3100
|
|||||||
bool "Compaq iPAQ H3100"
|
bool "Compaq iPAQ H3100"
|
||||||
select ARM_SA1110_CPUFREQ
|
select ARM_SA1110_CPUFREQ
|
||||||
select HTC_EGPIO
|
select HTC_EGPIO
|
||||||
|
select MFD_IPAQ_MICRO
|
||||||
help
|
help
|
||||||
Say Y here if you intend to run this kernel on the Compaq iPAQ
|
Say Y here if you intend to run this kernel on the Compaq iPAQ
|
||||||
H3100 handheld computer. Information about this machine and the
|
H3100 handheld computer. Information about this machine and the
|
||||||
@ -69,6 +70,7 @@ config SA1100_H3600
|
|||||||
bool "Compaq iPAQ H3600/H3700"
|
bool "Compaq iPAQ H3600/H3700"
|
||||||
select ARM_SA1110_CPUFREQ
|
select ARM_SA1110_CPUFREQ
|
||||||
select HTC_EGPIO
|
select HTC_EGPIO
|
||||||
|
select MFD_IPAQ_MICRO
|
||||||
help
|
help
|
||||||
Say Y here if you intend to run this kernel on the Compaq iPAQ
|
Say Y here if you intend to run this kernel on the Compaq iPAQ
|
||||||
H3600 handheld computer. Information about this machine and the
|
H3600 handheld computer. Information about this machine and the
|
||||||
|
@ -25,6 +25,7 @@
|
|||||||
#include <asm/mach/map.h>
|
#include <asm/mach/map.h>
|
||||||
|
|
||||||
#include <mach/h3xxx.h>
|
#include <mach/h3xxx.h>
|
||||||
|
#include <mach/irqs.h>
|
||||||
|
|
||||||
#include "generic.h"
|
#include "generic.h"
|
||||||
|
|
||||||
@ -244,9 +245,23 @@ static struct platform_device h3xxx_keys = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct resource h3xxx_micro_resources[] = {
|
||||||
|
DEFINE_RES_MEM(0x80010000, SZ_4K),
|
||||||
|
DEFINE_RES_MEM(0x80020000, SZ_4K),
|
||||||
|
DEFINE_RES_IRQ(IRQ_Ser1UART),
|
||||||
|
};
|
||||||
|
|
||||||
|
struct platform_device h3xxx_micro_asic = {
|
||||||
|
.name = "ipaq-h3xxx-micro",
|
||||||
|
.id = -1,
|
||||||
|
.resource = h3xxx_micro_resources,
|
||||||
|
.num_resources = ARRAY_SIZE(h3xxx_micro_resources),
|
||||||
|
};
|
||||||
|
|
||||||
static struct platform_device *h3xxx_devices[] = {
|
static struct platform_device *h3xxx_devices[] = {
|
||||||
&h3xxx_egpio,
|
&h3xxx_egpio,
|
||||||
&h3xxx_keys,
|
&h3xxx_keys,
|
||||||
|
&h3xxx_micro_asic,
|
||||||
};
|
};
|
||||||
|
|
||||||
void __init h3xxx_mach_init(void)
|
void __init h3xxx_mach_init(void)
|
||||||
|
@ -41,6 +41,7 @@
|
|||||||
* This code is not portable to processors with late data abort handling.
|
* This code is not portable to processors with late data abort handling.
|
||||||
*/
|
*/
|
||||||
#define CODING_BITS(i) (i & 0x0e000000)
|
#define CODING_BITS(i) (i & 0x0e000000)
|
||||||
|
#define COND_BITS(i) (i & 0xf0000000)
|
||||||
|
|
||||||
#define LDST_I_BIT(i) (i & (1 << 26)) /* Immediate constant */
|
#define LDST_I_BIT(i) (i & (1 << 26)) /* Immediate constant */
|
||||||
#define LDST_P_BIT(i) (i & (1 << 24)) /* Preindex */
|
#define LDST_P_BIT(i) (i & (1 << 24)) /* Preindex */
|
||||||
@ -821,6 +822,8 @@ do_alignment(unsigned long addr, unsigned int fsr, struct pt_regs *regs)
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x04000000: /* ldr or str immediate */
|
case 0x04000000: /* ldr or str immediate */
|
||||||
|
if (COND_BITS(instr) == 0xf0000000) /* NEON VLDn, VSTn */
|
||||||
|
goto bad;
|
||||||
offset.un = OFFSET_BITS(instr);
|
offset.un = OFFSET_BITS(instr);
|
||||||
handler = do_alignment_ldrstr;
|
handler = do_alignment_ldrstr;
|
||||||
break;
|
break;
|
||||||
|
@ -21,6 +21,7 @@
|
|||||||
#include <linux/init.h>
|
#include <linux/init.h>
|
||||||
#include <linux/smp.h>
|
#include <linux/smp.h>
|
||||||
#include <linux/spinlock.h>
|
#include <linux/spinlock.h>
|
||||||
|
#include <linux/log2.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/of.h>
|
#include <linux/of.h>
|
||||||
#include <linux/of_address.h>
|
#include <linux/of_address.h>
|
||||||
@ -945,6 +946,98 @@ static int l2_wt_override;
|
|||||||
* pass it though the device tree */
|
* pass it though the device tree */
|
||||||
static u32 cache_id_part_number_from_dt;
|
static u32 cache_id_part_number_from_dt;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* l2x0_cache_size_of_parse() - read cache size parameters from DT
|
||||||
|
* @np: the device tree node for the l2 cache
|
||||||
|
* @aux_val: pointer to machine-supplied auxilary register value, to
|
||||||
|
* be augmented by the call (bits to be set to 1)
|
||||||
|
* @aux_mask: pointer to machine-supplied auxilary register mask, to
|
||||||
|
* be augmented by the call (bits to be set to 0)
|
||||||
|
* @associativity: variable to return the calculated associativity in
|
||||||
|
* @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,
|
||||||
|
u32 *aux_val, u32 *aux_mask,
|
||||||
|
u32 *associativity,
|
||||||
|
u32 max_way_size)
|
||||||
|
{
|
||||||
|
u32 mask = 0, val = 0;
|
||||||
|
u32 cache_size = 0, sets = 0;
|
||||||
|
u32 way_size_bits = 1;
|
||||||
|
u32 way_size = 0;
|
||||||
|
u32 block_size = 0;
|
||||||
|
u32 line_size = 0;
|
||||||
|
|
||||||
|
of_property_read_u32(np, "cache-size", &cache_size);
|
||||||
|
of_property_read_u32(np, "cache-sets", &sets);
|
||||||
|
of_property_read_u32(np, "cache-block-size", &block_size);
|
||||||
|
of_property_read_u32(np, "cache-line-size", &line_size);
|
||||||
|
|
||||||
|
if (!cache_size || !sets)
|
||||||
|
return;
|
||||||
|
|
||||||
|
/* All these l2 caches have the same line = block size actually */
|
||||||
|
if (!line_size) {
|
||||||
|
if (block_size) {
|
||||||
|
/* If linesize if not given, it is equal to blocksize */
|
||||||
|
line_size = block_size;
|
||||||
|
} else {
|
||||||
|
/* Fall back to known size */
|
||||||
|
pr_warn("L2C OF: no cache block/line size given: "
|
||||||
|
"falling back to default size %d bytes\n",
|
||||||
|
CACHE_LINE_SIZE);
|
||||||
|
line_size = CACHE_LINE_SIZE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (line_size != CACHE_LINE_SIZE)
|
||||||
|
pr_warn("L2C OF: DT supplied line size %d bytes does "
|
||||||
|
"not match hardware line size of %d bytes\n",
|
||||||
|
line_size,
|
||||||
|
CACHE_LINE_SIZE);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Since:
|
||||||
|
* set size = cache size / sets
|
||||||
|
* ways = cache size / (sets * line size)
|
||||||
|
* way size = cache size / (cache size / (sets * line size))
|
||||||
|
* way size = sets * line size
|
||||||
|
* associativity = ways = cache size / way size
|
||||||
|
*/
|
||||||
|
way_size = sets * line_size;
|
||||||
|
*associativity = cache_size / way_size;
|
||||||
|
|
||||||
|
if (way_size > max_way_size) {
|
||||||
|
pr_err("L2C OF: set size %dKB is too large\n", way_size);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
pr_info("L2C OF: override cache size: %d bytes (%dKB)\n",
|
||||||
|
cache_size, cache_size >> 10);
|
||||||
|
pr_info("L2C OF: override line size: %d bytes\n", line_size);
|
||||||
|
pr_info("L2C OF: override way size: %d bytes (%dKB)\n",
|
||||||
|
way_size, way_size >> 10);
|
||||||
|
pr_info("L2C OF: override associativity: %d\n", *associativity);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Calculates the bits 17:19 to set for way size:
|
||||||
|
* 512KB -> 6, 256KB -> 5, ... 16KB -> 1
|
||||||
|
*/
|
||||||
|
way_size_bits = ilog2(way_size >> 10) - 3;
|
||||||
|
if (way_size_bits < 1 || way_size_bits > 6) {
|
||||||
|
pr_err("L2C OF: cache way size illegal: %dKB is not mapped\n",
|
||||||
|
way_size);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
mask |= L2C_AUX_CTRL_WAY_SIZE_MASK;
|
||||||
|
val |= (way_size_bits << L2C_AUX_CTRL_WAY_SIZE_SHIFT);
|
||||||
|
|
||||||
|
*aux_val &= ~mask;
|
||||||
|
*aux_val |= val;
|
||||||
|
*aux_mask &= ~mask;
|
||||||
|
}
|
||||||
|
|
||||||
static void __init l2x0_of_parse(const struct device_node *np,
|
static void __init l2x0_of_parse(const struct device_node *np,
|
||||||
u32 *aux_val, u32 *aux_mask)
|
u32 *aux_val, u32 *aux_mask)
|
||||||
{
|
{
|
||||||
@ -952,6 +1045,7 @@ static void __init l2x0_of_parse(const struct device_node *np,
|
|||||||
u32 tag = 0;
|
u32 tag = 0;
|
||||||
u32 dirty = 0;
|
u32 dirty = 0;
|
||||||
u32 val = 0, mask = 0;
|
u32 val = 0, mask = 0;
|
||||||
|
u32 assoc;
|
||||||
|
|
||||||
of_property_read_u32(np, "arm,tag-latency", &tag);
|
of_property_read_u32(np, "arm,tag-latency", &tag);
|
||||||
if (tag) {
|
if (tag) {
|
||||||
@ -974,6 +1068,15 @@ 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);
|
||||||
|
if (assoc > 8) {
|
||||||
|
pr_err("l2x0 of: cache setting yield too high associativity\n");
|
||||||
|
pr_err("l2x0 of: %d calculated, max 8\n", assoc);
|
||||||
|
} else {
|
||||||
|
mask |= L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
val |= (assoc << L2X0_AUX_CTRL_ASSOC_SHIFT);
|
||||||
|
}
|
||||||
|
|
||||||
*aux_val &= ~mask;
|
*aux_val &= ~mask;
|
||||||
*aux_val |= val;
|
*aux_val |= val;
|
||||||
*aux_mask &= ~mask;
|
*aux_mask &= ~mask;
|
||||||
@ -1021,6 +1124,7 @@ static void __init l2c310_of_parse(const struct device_node *np,
|
|||||||
u32 data[3] = { 0, 0, 0 };
|
u32 data[3] = { 0, 0, 0 };
|
||||||
u32 tag[3] = { 0, 0, 0 };
|
u32 tag[3] = { 0, 0, 0 };
|
||||||
u32 filter[2] = { 0, 0 };
|
u32 filter[2] = { 0, 0 };
|
||||||
|
u32 assoc;
|
||||||
|
|
||||||
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])
|
||||||
@ -1047,6 +1151,23 @@ static void __init l2c310_of_parse(const struct device_node *np,
|
|||||||
writel_relaxed((filter[0] & ~(SZ_1M - 1)) | L310_ADDR_FILTER_EN,
|
writel_relaxed((filter[0] & ~(SZ_1M - 1)) | L310_ADDR_FILTER_EN,
|
||||||
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);
|
||||||
|
switch (assoc) {
|
||||||
|
case 16:
|
||||||
|
*aux_val &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
*aux_val |= L310_AUX_CTRL_ASSOCIATIVITY_16;
|
||||||
|
*aux_mask &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
break;
|
||||||
|
case 8:
|
||||||
|
*aux_val &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
*aux_mask &= ~L2X0_AUX_CTRL_ASSOC_MASK;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
pr_err("PL310 OF: cache setting yield illegal associativity\n");
|
||||||
|
pr_err("PL310 OF: %d calculated, only 8 and 16 legal\n", assoc);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct l2c_init_data of_l2c310_data __initconst = {
|
static const struct l2c_init_data of_l2c310_data __initconst = {
|
||||||
|
@ -27,7 +27,7 @@ static void idmap_add_pmd(pud_t *pud, unsigned long addr, unsigned long end,
|
|||||||
if (pud_none_or_clear_bad(pud) || (pud_val(*pud) & L_PGD_SWAPPER)) {
|
if (pud_none_or_clear_bad(pud) || (pud_val(*pud) & L_PGD_SWAPPER)) {
|
||||||
pmd = pmd_alloc_one(&init_mm, addr);
|
pmd = pmd_alloc_one(&init_mm, addr);
|
||||||
if (!pmd) {
|
if (!pmd) {
|
||||||
pr_warning("Failed to allocate identity pmd.\n");
|
pr_warn("Failed to allocate identity pmd.\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
|
@ -636,6 +636,11 @@ static int keep_initrd;
|
|||||||
void free_initrd_mem(unsigned long start, unsigned long end)
|
void free_initrd_mem(unsigned long start, unsigned long end)
|
||||||
{
|
{
|
||||||
if (!keep_initrd) {
|
if (!keep_initrd) {
|
||||||
|
if (start == initrd_start)
|
||||||
|
start = round_down(start, PAGE_SIZE);
|
||||||
|
if (end == initrd_end)
|
||||||
|
end = round_up(end, PAGE_SIZE);
|
||||||
|
|
||||||
poison_init_mem((void *)start, PAGE_ALIGN(end) - start);
|
poison_init_mem((void *)start, PAGE_ALIGN(end) - start);
|
||||||
free_reserved_area((void *)start, (void *)end, -1, "initrd");
|
free_reserved_area((void *)start, (void *)end, -1, "initrd");
|
||||||
}
|
}
|
||||||
|
@ -223,13 +223,13 @@ early_param("ecc", early_ecc);
|
|||||||
|
|
||||||
static int __init early_cachepolicy(char *p)
|
static int __init early_cachepolicy(char *p)
|
||||||
{
|
{
|
||||||
pr_warning("cachepolicy kernel parameter not supported without cp15\n");
|
pr_warn("cachepolicy kernel parameter not supported without cp15\n");
|
||||||
}
|
}
|
||||||
early_param("cachepolicy", early_cachepolicy);
|
early_param("cachepolicy", early_cachepolicy);
|
||||||
|
|
||||||
static int __init noalign_setup(char *__unused)
|
static int __init noalign_setup(char *__unused)
|
||||||
{
|
{
|
||||||
pr_warning("noalign kernel parameter not supported without cp15\n");
|
pr_warn("noalign kernel parameter not supported without cp15\n");
|
||||||
}
|
}
|
||||||
__setup("noalign", noalign_setup);
|
__setup("noalign", noalign_setup);
|
||||||
|
|
||||||
|
@ -146,7 +146,6 @@ ENDPROC(cpu_v7_set_pte_ext)
|
|||||||
mov \tmp, \ttbr1, lsr #(32 - ARCH_PGD_SHIFT) @ upper bits
|
mov \tmp, \ttbr1, lsr #(32 - ARCH_PGD_SHIFT) @ upper bits
|
||||||
mov \ttbr1, \ttbr1, lsl #ARCH_PGD_SHIFT @ lower bits
|
mov \ttbr1, \ttbr1, lsl #ARCH_PGD_SHIFT @ lower bits
|
||||||
addls \ttbr1, \ttbr1, #TTBR1_OFFSET
|
addls \ttbr1, \ttbr1, #TTBR1_OFFSET
|
||||||
adcls \tmp, \tmp, #0
|
|
||||||
mcrr p15, 1, \ttbr1, \tmp, c2 @ load TTBR1
|
mcrr p15, 1, \ttbr1, \tmp, c2 @ load TTBR1
|
||||||
mov \tmp, \ttbr0, lsr #(32 - ARCH_PGD_SHIFT) @ upper bits
|
mov \tmp, \ttbr0, lsr #(32 - ARCH_PGD_SHIFT) @ upper bits
|
||||||
mov \ttbr0, \ttbr0, lsl #ARCH_PGD_SHIFT @ lower bits
|
mov \ttbr0, \ttbr0, lsl #ARCH_PGD_SHIFT @ lower bits
|
||||||
@ -158,9 +157,9 @@ ENDPROC(cpu_v7_set_pte_ext)
|
|||||||
* TFR EV X F IHD LR S
|
* TFR EV X F IHD LR S
|
||||||
* .EEE ..EE PUI. .TAT 4RVI ZWRS BLDP WCAM
|
* .EEE ..EE PUI. .TAT 4RVI ZWRS BLDP WCAM
|
||||||
* rxxx rrxx xxx0 0101 xxxx xxxx x111 xxxx < forced
|
* rxxx rrxx xxx0 0101 xxxx xxxx x111 xxxx < forced
|
||||||
* 11 0 110 1 0011 1100 .111 1101 < we want
|
* 11 0 110 0 0011 1100 .111 1101 < we want
|
||||||
*/
|
*/
|
||||||
.align 2
|
.align 2
|
||||||
.type v7_crval, #object
|
.type v7_crval, #object
|
||||||
v7_crval:
|
v7_crval:
|
||||||
crval clear=0x0120c302, mmuset=0x30c23c7d, ucset=0x00c01c7c
|
crval clear=0x0122c302, mmuset=0x30c03c7d, ucset=0x00c01c7c
|
||||||
|
@ -570,7 +570,7 @@ __v7_ca15mp_proc_info:
|
|||||||
__v7_b15mp_proc_info:
|
__v7_b15mp_proc_info:
|
||||||
.long 0x420f00f0
|
.long 0x420f00f0
|
||||||
.long 0xff0ffff0
|
.long 0xff0ffff0
|
||||||
__v7_proc __v7_b15mp_setup, hwcaps = HWCAP_IDIV
|
__v7_proc __v7_b15mp_setup
|
||||||
.size __v7_b15mp_proc_info, . - __v7_b15mp_proc_info
|
.size __v7_b15mp_proc_info, . - __v7_b15mp_proc_info
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1,3 +1,6 @@
|
|||||||
|
config ARCH_OMAP
|
||||||
|
bool
|
||||||
|
|
||||||
if ARCH_OMAP
|
if ARCH_OMAP
|
||||||
|
|
||||||
menu "TI OMAP Common Features"
|
menu "TI OMAP Common Features"
|
||||||
|
@ -97,9 +97,9 @@ SECTIONS
|
|||||||
|
|
||||||
PERCPU_SECTION(64)
|
PERCPU_SECTION(64)
|
||||||
|
|
||||||
|
. = ALIGN(PAGE_SIZE);
|
||||||
__init_end = .;
|
__init_end = .;
|
||||||
|
|
||||||
. = ALIGN(PAGE_SIZE);
|
|
||||||
_data = .;
|
_data = .;
|
||||||
_sdata = .;
|
_sdata = .;
|
||||||
RW_DATA_SECTION(64, PAGE_SIZE, THREAD_SIZE)
|
RW_DATA_SECTION(64, PAGE_SIZE, THREAD_SIZE)
|
||||||
|
@ -149,8 +149,7 @@ void __init arm64_memblock_init(void)
|
|||||||
memblock_reserve(__virt_to_phys(initrd_start), initrd_end - initrd_start);
|
memblock_reserve(__virt_to_phys(initrd_start), initrd_end - initrd_start);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (!efi_enabled(EFI_MEMMAP))
|
early_init_fdt_scan_reserved_mem();
|
||||||
early_init_fdt_scan_reserved_mem();
|
|
||||||
|
|
||||||
/* 4GB maximum for 32-bit only capable devices */
|
/* 4GB maximum for 32-bit only capable devices */
|
||||||
if (IS_ENABLED(CONFIG_ZONE_DMA))
|
if (IS_ENABLED(CONFIG_ZONE_DMA))
|
||||||
@ -334,8 +333,14 @@ static int keep_initrd;
|
|||||||
|
|
||||||
void free_initrd_mem(unsigned long start, unsigned long end)
|
void free_initrd_mem(unsigned long start, unsigned long end)
|
||||||
{
|
{
|
||||||
if (!keep_initrd)
|
if (!keep_initrd) {
|
||||||
|
if (start == initrd_start)
|
||||||
|
start = round_down(start, PAGE_SIZE);
|
||||||
|
if (end == initrd_end)
|
||||||
|
end = round_up(end, PAGE_SIZE);
|
||||||
|
|
||||||
free_reserved_area((void *)start, (void *)end, 0, "initrd");
|
free_reserved_area((void *)start, (void *)end, 0, "initrd");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init keepinitrd_setup(char *__unused)
|
static int __init keepinitrd_setup(char *__unused)
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_POSIX_MQUEUE=y
|
CONFIG_POSIX_MQUEUE=y
|
||||||
CONFIG_LOG_BUF_SHIFT=16
|
CONFIG_LOG_BUF_SHIFT=16
|
||||||
@ -6,6 +5,8 @@ CONFIG_PROFILING=y
|
|||||||
CONFIG_OPROFILE=y
|
CONFIG_OPROFILE=y
|
||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
CONFIG_MODULE_UNLOAD=y
|
CONFIG_MODULE_UNLOAD=y
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
|
CONFIG_SGI_PARTITION=y
|
||||||
CONFIG_IA64_DIG=y
|
CONFIG_IA64_DIG=y
|
||||||
CONFIG_SMP=y
|
CONFIG_SMP=y
|
||||||
CONFIG_NR_CPUS=2
|
CONFIG_NR_CPUS=2
|
||||||
@ -51,9 +52,6 @@ CONFIG_DM_MIRROR=m
|
|||||||
CONFIG_DM_ZERO=m
|
CONFIG_DM_ZERO=m
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_DUMMY=y
|
CONFIG_DUMMY=y
|
||||||
CONFIG_NET_ETHERNET=y
|
|
||||||
CONFIG_MII=y
|
|
||||||
CONFIG_NET_PCI=y
|
|
||||||
CONFIG_INPUT_EVDEV=y
|
CONFIG_INPUT_EVDEV=y
|
||||||
CONFIG_SERIAL_8250=y
|
CONFIG_SERIAL_8250=y
|
||||||
CONFIG_SERIAL_8250_CONSOLE=y
|
CONFIG_SERIAL_8250_CONSOLE=y
|
||||||
@ -85,7 +83,6 @@ CONFIG_EXT3_FS=y
|
|||||||
CONFIG_XFS_FS=y
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_XFS_QUOTA=y
|
CONFIG_XFS_QUOTA=y
|
||||||
CONFIG_XFS_POSIX_ACL=y
|
CONFIG_XFS_POSIX_ACL=y
|
||||||
CONFIG_AUTOFS_FS=m
|
|
||||||
CONFIG_AUTOFS4_FS=m
|
CONFIG_AUTOFS4_FS=m
|
||||||
CONFIG_ISO9660_FS=m
|
CONFIG_ISO9660_FS=m
|
||||||
CONFIG_JOLIET=y
|
CONFIG_JOLIET=y
|
||||||
@ -95,17 +92,13 @@ CONFIG_PROC_KCORE=y
|
|||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_HUGETLBFS=y
|
CONFIG_HUGETLBFS=y
|
||||||
CONFIG_NFS_FS=m
|
CONFIG_NFS_FS=m
|
||||||
CONFIG_NFS_V3=y
|
CONFIG_NFS_V4=m
|
||||||
CONFIG_NFS_V4=y
|
|
||||||
CONFIG_NFSD=m
|
CONFIG_NFSD=m
|
||||||
CONFIG_NFSD_V4=y
|
CONFIG_NFSD_V4=y
|
||||||
CONFIG_CIFS=m
|
CONFIG_CIFS=m
|
||||||
CONFIG_CIFS_STATS=y
|
CONFIG_CIFS_STATS=y
|
||||||
CONFIG_CIFS_XATTR=y
|
CONFIG_CIFS_XATTR=y
|
||||||
CONFIG_CIFS_POSIX=y
|
CONFIG_CIFS_POSIX=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
|
||||||
CONFIG_SGI_PARTITION=y
|
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_ISO8859_1=y
|
CONFIG_NLS_ISO8859_1=y
|
||||||
CONFIG_NLS_UTF8=m
|
CONFIG_NLS_UTF8=m
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_POSIX_MQUEUE=y
|
CONFIG_POSIX_MQUEUE=y
|
||||||
CONFIG_IKCONFIG=y
|
CONFIG_IKCONFIG=y
|
||||||
@ -6,13 +5,13 @@ CONFIG_IKCONFIG_PROC=y
|
|||||||
CONFIG_LOG_BUF_SHIFT=20
|
CONFIG_LOG_BUF_SHIFT=20
|
||||||
CONFIG_CGROUPS=y
|
CONFIG_CGROUPS=y
|
||||||
CONFIG_CPUSETS=y
|
CONFIG_CPUSETS=y
|
||||||
CONFIG_SYSFS_DEPRECATED_V2=y
|
|
||||||
CONFIG_BLK_DEV_INITRD=y
|
CONFIG_BLK_DEV_INITRD=y
|
||||||
CONFIG_KALLSYMS_ALL=y
|
CONFIG_KALLSYMS_ALL=y
|
||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
CONFIG_MODULE_UNLOAD=y
|
CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
# CONFIG_BLK_DEV_BSG is not set
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
|
CONFIG_SGI_PARTITION=y
|
||||||
CONFIG_MCKINLEY=y
|
CONFIG_MCKINLEY=y
|
||||||
CONFIG_IA64_PAGE_SIZE_64KB=y
|
CONFIG_IA64_PAGE_SIZE_64KB=y
|
||||||
CONFIG_IA64_CYCLONE=y
|
CONFIG_IA64_CYCLONE=y
|
||||||
@ -29,14 +28,13 @@ CONFIG_ACPI_BUTTON=m
|
|||||||
CONFIG_ACPI_FAN=m
|
CONFIG_ACPI_FAN=m
|
||||||
CONFIG_ACPI_DOCK=y
|
CONFIG_ACPI_DOCK=y
|
||||||
CONFIG_ACPI_PROCESSOR=m
|
CONFIG_ACPI_PROCESSOR=m
|
||||||
CONFIG_ACPI_CONTAINER=y
|
|
||||||
CONFIG_HOTPLUG_PCI=y
|
CONFIG_HOTPLUG_PCI=y
|
||||||
CONFIG_HOTPLUG_PCI_ACPI=y
|
CONFIG_HOTPLUG_PCI_ACPI=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_INET=y
|
CONFIG_INET=y
|
||||||
CONFIG_IP_MULTICAST=y
|
CONFIG_IP_MULTICAST=y
|
||||||
CONFIG_ARPD=y
|
|
||||||
CONFIG_SYN_COOKIES=y
|
CONFIG_SYN_COOKIES=y
|
||||||
# CONFIG_IPV6 is not set
|
# CONFIG_IPV6 is not set
|
||||||
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
CONFIG_UEVENT_HELPER_PATH="/sbin/hotplug"
|
||||||
@ -82,16 +80,13 @@ CONFIG_FUSION_FC=m
|
|||||||
CONFIG_FUSION_SAS=y
|
CONFIG_FUSION_SAS=y
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_DUMMY=m
|
CONFIG_DUMMY=m
|
||||||
CONFIG_NET_ETHERNET=y
|
CONFIG_NETCONSOLE=y
|
||||||
|
CONFIG_TIGON3=y
|
||||||
CONFIG_NET_TULIP=y
|
CONFIG_NET_TULIP=y
|
||||||
CONFIG_TULIP=m
|
CONFIG_TULIP=m
|
||||||
CONFIG_NET_PCI=y
|
|
||||||
CONFIG_NET_VENDOR_INTEL=y
|
|
||||||
CONFIG_E100=m
|
CONFIG_E100=m
|
||||||
CONFIG_E1000=y
|
CONFIG_E1000=y
|
||||||
CONFIG_IGB=y
|
CONFIG_IGB=y
|
||||||
CONFIG_TIGON3=y
|
|
||||||
CONFIG_NETCONSOLE=y
|
|
||||||
# CONFIG_SERIO_SERPORT is not set
|
# CONFIG_SERIO_SERPORT is not set
|
||||||
CONFIG_GAMEPORT=m
|
CONFIG_GAMEPORT=m
|
||||||
CONFIG_SERIAL_NONSTANDARD=y
|
CONFIG_SERIAL_NONSTANDARD=y
|
||||||
@ -151,6 +146,7 @@ CONFIG_USB_STORAGE=m
|
|||||||
CONFIG_INFINIBAND=m
|
CONFIG_INFINIBAND=m
|
||||||
CONFIG_INFINIBAND_MTHCA=m
|
CONFIG_INFINIBAND_MTHCA=m
|
||||||
CONFIG_INFINIBAND_IPOIB=m
|
CONFIG_INFINIBAND_IPOIB=m
|
||||||
|
CONFIG_INTEL_IOMMU=y
|
||||||
CONFIG_MSPEC=m
|
CONFIG_MSPEC=m
|
||||||
CONFIG_EXT2_FS=y
|
CONFIG_EXT2_FS=y
|
||||||
CONFIG_EXT2_FS_XATTR=y
|
CONFIG_EXT2_FS_XATTR=y
|
||||||
@ -164,7 +160,6 @@ CONFIG_REISERFS_FS_XATTR=y
|
|||||||
CONFIG_REISERFS_FS_POSIX_ACL=y
|
CONFIG_REISERFS_FS_POSIX_ACL=y
|
||||||
CONFIG_REISERFS_FS_SECURITY=y
|
CONFIG_REISERFS_FS_SECURITY=y
|
||||||
CONFIG_XFS_FS=y
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_AUTOFS_FS=m
|
|
||||||
CONFIG_AUTOFS4_FS=m
|
CONFIG_AUTOFS4_FS=m
|
||||||
CONFIG_ISO9660_FS=m
|
CONFIG_ISO9660_FS=m
|
||||||
CONFIG_JOLIET=y
|
CONFIG_JOLIET=y
|
||||||
@ -175,16 +170,10 @@ CONFIG_PROC_KCORE=y
|
|||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_HUGETLBFS=y
|
CONFIG_HUGETLBFS=y
|
||||||
CONFIG_NFS_FS=m
|
CONFIG_NFS_FS=m
|
||||||
CONFIG_NFS_V3=y
|
CONFIG_NFS_V4=m
|
||||||
CONFIG_NFS_V4=y
|
|
||||||
CONFIG_NFSD=m
|
CONFIG_NFSD=m
|
||||||
CONFIG_NFSD_V4=y
|
CONFIG_NFSD_V4=y
|
||||||
CONFIG_SMB_FS=m
|
|
||||||
CONFIG_SMB_NLS_DEFAULT=y
|
|
||||||
CONFIG_CIFS=m
|
CONFIG_CIFS=m
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
|
||||||
CONFIG_SGI_PARTITION=y
|
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_CODEPAGE_737=m
|
CONFIG_NLS_CODEPAGE_737=m
|
||||||
CONFIG_NLS_CODEPAGE_775=m
|
CONFIG_NLS_CODEPAGE_775=m
|
||||||
@ -225,11 +214,7 @@ CONFIG_NLS_UTF8=m
|
|||||||
CONFIG_MAGIC_SYSRQ=y
|
CONFIG_MAGIC_SYSRQ=y
|
||||||
CONFIG_DEBUG_KERNEL=y
|
CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_DEBUG_MUTEXES=y
|
CONFIG_DEBUG_MUTEXES=y
|
||||||
# CONFIG_RCU_CPU_STALL_DETECTOR is not set
|
|
||||||
CONFIG_SYSCTL_SYSCALL_CHECK=y
|
|
||||||
CONFIG_CRYPTO_ECB=m
|
|
||||||
CONFIG_CRYPTO_PCBC=m
|
CONFIG_CRYPTO_PCBC=m
|
||||||
CONFIG_CRYPTO_MD5=y
|
CONFIG_CRYPTO_MD5=y
|
||||||
# CONFIG_CRYPTO_ANSI_CPRNG is not set
|
# CONFIG_CRYPTO_ANSI_CPRNG is not set
|
||||||
CONFIG_CRC_T10DIF=y
|
CONFIG_CRC_T10DIF=y
|
||||||
CONFIG_INTEL_IOMMU=y
|
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_POSIX_MQUEUE=y
|
CONFIG_POSIX_MQUEUE=y
|
||||||
CONFIG_IKCONFIG=y
|
CONFIG_IKCONFIG=y
|
||||||
@ -9,6 +8,8 @@ CONFIG_KALLSYMS_ALL=y
|
|||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
CONFIG_MODULE_UNLOAD=y
|
CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
|
CONFIG_SGI_PARTITION=y
|
||||||
CONFIG_MCKINLEY=y
|
CONFIG_MCKINLEY=y
|
||||||
CONFIG_IA64_CYCLONE=y
|
CONFIG_IA64_CYCLONE=y
|
||||||
CONFIG_SMP=y
|
CONFIG_SMP=y
|
||||||
@ -24,14 +25,12 @@ CONFIG_BINFMT_MISC=m
|
|||||||
CONFIG_ACPI_BUTTON=m
|
CONFIG_ACPI_BUTTON=m
|
||||||
CONFIG_ACPI_FAN=m
|
CONFIG_ACPI_FAN=m
|
||||||
CONFIG_ACPI_PROCESSOR=m
|
CONFIG_ACPI_PROCESSOR=m
|
||||||
CONFIG_ACPI_CONTAINER=m
|
|
||||||
CONFIG_HOTPLUG_PCI=y
|
CONFIG_HOTPLUG_PCI=y
|
||||||
CONFIG_HOTPLUG_PCI_ACPI=m
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_INET=y
|
CONFIG_INET=y
|
||||||
CONFIG_IP_MULTICAST=y
|
CONFIG_IP_MULTICAST=y
|
||||||
CONFIG_ARPD=y
|
|
||||||
CONFIG_SYN_COOKIES=y
|
CONFIG_SYN_COOKIES=y
|
||||||
# CONFIG_IPV6 is not set
|
# CONFIG_IPV6 is not set
|
||||||
CONFIG_BLK_DEV_LOOP=m
|
CONFIG_BLK_DEV_LOOP=m
|
||||||
@ -71,15 +70,12 @@ CONFIG_FUSION_SPI=y
|
|||||||
CONFIG_FUSION_FC=m
|
CONFIG_FUSION_FC=m
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_DUMMY=m
|
CONFIG_DUMMY=m
|
||||||
CONFIG_NET_ETHERNET=y
|
CONFIG_NETCONSOLE=y
|
||||||
|
CONFIG_TIGON3=y
|
||||||
CONFIG_NET_TULIP=y
|
CONFIG_NET_TULIP=y
|
||||||
CONFIG_TULIP=m
|
CONFIG_TULIP=m
|
||||||
CONFIG_NET_PCI=y
|
|
||||||
CONFIG_NET_VENDOR_INTEL=y
|
|
||||||
CONFIG_E100=m
|
CONFIG_E100=m
|
||||||
CONFIG_E1000=y
|
CONFIG_E1000=y
|
||||||
CONFIG_TIGON3=y
|
|
||||||
CONFIG_NETCONSOLE=y
|
|
||||||
# CONFIG_SERIO_SERPORT is not set
|
# CONFIG_SERIO_SERPORT is not set
|
||||||
CONFIG_GAMEPORT=m
|
CONFIG_GAMEPORT=m
|
||||||
CONFIG_SERIAL_NONSTANDARD=y
|
CONFIG_SERIAL_NONSTANDARD=y
|
||||||
@ -146,7 +142,6 @@ CONFIG_REISERFS_FS_XATTR=y
|
|||||||
CONFIG_REISERFS_FS_POSIX_ACL=y
|
CONFIG_REISERFS_FS_POSIX_ACL=y
|
||||||
CONFIG_REISERFS_FS_SECURITY=y
|
CONFIG_REISERFS_FS_SECURITY=y
|
||||||
CONFIG_XFS_FS=y
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_AUTOFS_FS=y
|
|
||||||
CONFIG_AUTOFS4_FS=y
|
CONFIG_AUTOFS4_FS=y
|
||||||
CONFIG_ISO9660_FS=m
|
CONFIG_ISO9660_FS=m
|
||||||
CONFIG_JOLIET=y
|
CONFIG_JOLIET=y
|
||||||
@ -157,16 +152,10 @@ CONFIG_PROC_KCORE=y
|
|||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_HUGETLBFS=y
|
CONFIG_HUGETLBFS=y
|
||||||
CONFIG_NFS_FS=m
|
CONFIG_NFS_FS=m
|
||||||
CONFIG_NFS_V3=y
|
CONFIG_NFS_V4=m
|
||||||
CONFIG_NFS_V4=y
|
|
||||||
CONFIG_NFSD=m
|
CONFIG_NFSD=m
|
||||||
CONFIG_NFSD_V4=y
|
CONFIG_NFSD_V4=y
|
||||||
CONFIG_SMB_FS=m
|
|
||||||
CONFIG_SMB_NLS_DEFAULT=y
|
|
||||||
CONFIG_CIFS=m
|
CONFIG_CIFS=m
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
|
||||||
CONFIG_SGI_PARTITION=y
|
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_CODEPAGE_737=m
|
CONFIG_NLS_CODEPAGE_737=m
|
||||||
CONFIG_NLS_CODEPAGE_775=m
|
CONFIG_NLS_CODEPAGE_775=m
|
||||||
|
@ -1,13 +1,12 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_IKCONFIG=y
|
CONFIG_IKCONFIG=y
|
||||||
CONFIG_IKCONFIG_PROC=y
|
CONFIG_IKCONFIG_PROC=y
|
||||||
CONFIG_LOG_BUF_SHIFT=16
|
CONFIG_LOG_BUF_SHIFT=16
|
||||||
# CONFIG_CC_OPTIMIZE_FOR_SIZE is not set
|
|
||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
CONFIG_MODULE_UNLOAD=y
|
CONFIG_MODULE_UNLOAD=y
|
||||||
CONFIG_MODULE_FORCE_UNLOAD=y
|
CONFIG_MODULE_FORCE_UNLOAD=y
|
||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
CONFIG_IA64_HP_SIM=y
|
CONFIG_IA64_HP_SIM=y
|
||||||
CONFIG_MCKINLEY=y
|
CONFIG_MCKINLEY=y
|
||||||
CONFIG_IA64_PAGE_SIZE_64KB=y
|
CONFIG_IA64_PAGE_SIZE_64KB=y
|
||||||
@ -27,7 +26,6 @@ CONFIG_BLK_DEV_LOOP=y
|
|||||||
CONFIG_BLK_DEV_RAM=y
|
CONFIG_BLK_DEV_RAM=y
|
||||||
CONFIG_SCSI=y
|
CONFIG_SCSI=y
|
||||||
CONFIG_BLK_DEV_SD=y
|
CONFIG_BLK_DEV_SD=y
|
||||||
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=y
|
CONFIG_SCSI_SPI_ATTRS=y
|
||||||
@ -49,8 +47,6 @@ CONFIG_HUGETLBFS=y
|
|||||||
CONFIG_NFS_FS=y
|
CONFIG_NFS_FS=y
|
||||||
CONFIG_NFSD=y
|
CONFIG_NFSD=y
|
||||||
CONFIG_NFSD_V3=y
|
CONFIG_NFSD_V3=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
CONFIG_DEBUG_INFO=y
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_DEBUG_KERNEL=y
|
CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_DEBUG_MUTEXES=y
|
CONFIG_DEBUG_MUTEXES=y
|
||||||
CONFIG_DEBUG_INFO=y
|
|
||||||
|
@ -1,4 +1,3 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_POSIX_MQUEUE=y
|
CONFIG_POSIX_MQUEUE=y
|
||||||
CONFIG_IKCONFIG=y
|
CONFIG_IKCONFIG=y
|
||||||
@ -11,6 +10,8 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
# CONFIG_BLK_DEV_BSG is not set
|
# CONFIG_BLK_DEV_BSG is not set
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
|
CONFIG_SGI_PARTITION=y
|
||||||
CONFIG_IA64_DIG=y
|
CONFIG_IA64_DIG=y
|
||||||
CONFIG_MCKINLEY=y
|
CONFIG_MCKINLEY=y
|
||||||
CONFIG_IA64_PAGE_SIZE_64KB=y
|
CONFIG_IA64_PAGE_SIZE_64KB=y
|
||||||
@ -29,14 +30,12 @@ CONFIG_BINFMT_MISC=m
|
|||||||
CONFIG_ACPI_BUTTON=m
|
CONFIG_ACPI_BUTTON=m
|
||||||
CONFIG_ACPI_FAN=m
|
CONFIG_ACPI_FAN=m
|
||||||
CONFIG_ACPI_PROCESSOR=m
|
CONFIG_ACPI_PROCESSOR=m
|
||||||
CONFIG_ACPI_CONTAINER=m
|
|
||||||
CONFIG_HOTPLUG_PCI=y
|
CONFIG_HOTPLUG_PCI=y
|
||||||
CONFIG_HOTPLUG_PCI_ACPI=m
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_INET=y
|
CONFIG_INET=y
|
||||||
CONFIG_IP_MULTICAST=y
|
CONFIG_IP_MULTICAST=y
|
||||||
CONFIG_ARPD=y
|
|
||||||
CONFIG_SYN_COOKIES=y
|
CONFIG_SYN_COOKIES=y
|
||||||
# CONFIG_IPV6 is not set
|
# CONFIG_IPV6 is not set
|
||||||
CONFIG_BLK_DEV_LOOP=m
|
CONFIG_BLK_DEV_LOOP=m
|
||||||
@ -53,6 +52,7 @@ CONFIG_BLK_DEV_SD=y
|
|||||||
CONFIG_CHR_DEV_ST=m
|
CONFIG_CHR_DEV_ST=m
|
||||||
CONFIG_BLK_DEV_SR=m
|
CONFIG_BLK_DEV_SR=m
|
||||||
CONFIG_CHR_DEV_SG=m
|
CONFIG_CHR_DEV_SG=m
|
||||||
|
CONFIG_SCSI_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SYM53C8XX_2=y
|
CONFIG_SCSI_SYM53C8XX_2=y
|
||||||
CONFIG_SCSI_QLOGIC_1280=y
|
CONFIG_SCSI_QLOGIC_1280=y
|
||||||
CONFIG_MD=y
|
CONFIG_MD=y
|
||||||
@ -72,15 +72,12 @@ CONFIG_FUSION_FC=y
|
|||||||
CONFIG_FUSION_CTL=y
|
CONFIG_FUSION_CTL=y
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_DUMMY=m
|
CONFIG_DUMMY=m
|
||||||
CONFIG_NET_ETHERNET=y
|
CONFIG_NETCONSOLE=y
|
||||||
|
CONFIG_TIGON3=y
|
||||||
CONFIG_NET_TULIP=y
|
CONFIG_NET_TULIP=y
|
||||||
CONFIG_TULIP=m
|
CONFIG_TULIP=m
|
||||||
CONFIG_NET_PCI=y
|
|
||||||
CONFIG_NET_VENDOR_INTEL=y
|
|
||||||
CONFIG_E100=m
|
CONFIG_E100=m
|
||||||
CONFIG_E1000=y
|
CONFIG_E1000=y
|
||||||
CONFIG_TIGON3=y
|
|
||||||
CONFIG_NETCONSOLE=y
|
|
||||||
# CONFIG_SERIO_SERPORT is not set
|
# CONFIG_SERIO_SERPORT is not set
|
||||||
CONFIG_GAMEPORT=m
|
CONFIG_GAMEPORT=m
|
||||||
CONFIG_SERIAL_NONSTANDARD=y
|
CONFIG_SERIAL_NONSTANDARD=y
|
||||||
@ -118,7 +115,6 @@ CONFIG_REISERFS_FS_XATTR=y
|
|||||||
CONFIG_REISERFS_FS_POSIX_ACL=y
|
CONFIG_REISERFS_FS_POSIX_ACL=y
|
||||||
CONFIG_REISERFS_FS_SECURITY=y
|
CONFIG_REISERFS_FS_SECURITY=y
|
||||||
CONFIG_XFS_FS=y
|
CONFIG_XFS_FS=y
|
||||||
CONFIG_AUTOFS_FS=y
|
|
||||||
CONFIG_AUTOFS4_FS=y
|
CONFIG_AUTOFS4_FS=y
|
||||||
CONFIG_ISO9660_FS=m
|
CONFIG_ISO9660_FS=m
|
||||||
CONFIG_JOLIET=y
|
CONFIG_JOLIET=y
|
||||||
@ -129,16 +125,10 @@ CONFIG_PROC_KCORE=y
|
|||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_HUGETLBFS=y
|
CONFIG_HUGETLBFS=y
|
||||||
CONFIG_NFS_FS=m
|
CONFIG_NFS_FS=m
|
||||||
CONFIG_NFS_V3=y
|
CONFIG_NFS_V4=m
|
||||||
CONFIG_NFS_V4=y
|
|
||||||
CONFIG_NFSD=m
|
CONFIG_NFSD=m
|
||||||
CONFIG_NFSD_V4=y
|
CONFIG_NFSD_V4=y
|
||||||
CONFIG_SMB_FS=m
|
|
||||||
CONFIG_SMB_NLS_DEFAULT=y
|
|
||||||
CONFIG_CIFS=m
|
CONFIG_CIFS=m
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
|
||||||
CONFIG_SGI_PARTITION=y
|
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_CODEPAGE_737=m
|
CONFIG_NLS_CODEPAGE_737=m
|
||||||
CONFIG_NLS_CODEPAGE_775=m
|
CONFIG_NLS_CODEPAGE_775=m
|
||||||
@ -180,6 +170,5 @@ CONFIG_MAGIC_SYSRQ=y
|
|||||||
CONFIG_DEBUG_KERNEL=y
|
CONFIG_DEBUG_KERNEL=y
|
||||||
CONFIG_DEBUG_MUTEXES=y
|
CONFIG_DEBUG_MUTEXES=y
|
||||||
CONFIG_IA64_GRANULE_16MB=y
|
CONFIG_IA64_GRANULE_16MB=y
|
||||||
CONFIG_CRYPTO_ECB=m
|
|
||||||
CONFIG_CRYPTO_PCBC=m
|
CONFIG_CRYPTO_PCBC=m
|
||||||
CONFIG_CRYPTO_MD5=y
|
CONFIG_CRYPTO_MD5=y
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
CONFIG_EXPERIMENTAL=y
|
|
||||||
CONFIG_SYSVIPC=y
|
CONFIG_SYSVIPC=y
|
||||||
CONFIG_BSD_PROCESS_ACCT=y
|
CONFIG_BSD_PROCESS_ACCT=y
|
||||||
CONFIG_BLK_DEV_INITRD=y
|
CONFIG_BLK_DEV_INITRD=y
|
||||||
CONFIG_KPROBES=y
|
CONFIG_KPROBES=y
|
||||||
CONFIG_MODULES=y
|
CONFIG_MODULES=y
|
||||||
|
CONFIG_PARTITION_ADVANCED=y
|
||||||
CONFIG_IA64_HP_ZX1=y
|
CONFIG_IA64_HP_ZX1=y
|
||||||
CONFIG_MCKINLEY=y
|
CONFIG_MCKINLEY=y
|
||||||
CONFIG_SMP=y
|
CONFIG_SMP=y
|
||||||
@ -18,6 +18,7 @@ CONFIG_EFI_VARS=y
|
|||||||
CONFIG_BINFMT_MISC=y
|
CONFIG_BINFMT_MISC=y
|
||||||
CONFIG_HOTPLUG_PCI=y
|
CONFIG_HOTPLUG_PCI=y
|
||||||
CONFIG_HOTPLUG_PCI_ACPI=y
|
CONFIG_HOTPLUG_PCI_ACPI=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_INET=y
|
CONFIG_INET=y
|
||||||
@ -37,9 +38,9 @@ CONFIG_CHR_DEV_OSST=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_FC_ATTRS=y
|
||||||
CONFIG_SCSI_SYM53C8XX_2=y
|
CONFIG_SCSI_SYM53C8XX_2=y
|
||||||
CONFIG_SCSI_QLOGIC_1280=y
|
CONFIG_SCSI_QLOGIC_1280=y
|
||||||
CONFIG_FUSION=y
|
CONFIG_FUSION=y
|
||||||
@ -48,18 +49,15 @@ CONFIG_FUSION_FC=y
|
|||||||
CONFIG_FUSION_CTL=m
|
CONFIG_FUSION_CTL=m
|
||||||
CONFIG_NETDEVICES=y
|
CONFIG_NETDEVICES=y
|
||||||
CONFIG_DUMMY=y
|
CONFIG_DUMMY=y
|
||||||
CONFIG_NET_ETHERNET=y
|
CONFIG_TIGON3=y
|
||||||
CONFIG_NET_TULIP=y
|
CONFIG_NET_TULIP=y
|
||||||
CONFIG_TULIP=y
|
CONFIG_TULIP=y
|
||||||
CONFIG_TULIP_MWI=y
|
CONFIG_TULIP_MWI=y
|
||||||
CONFIG_TULIP_MMIO=y
|
CONFIG_TULIP_MMIO=y
|
||||||
CONFIG_TULIP_NAPI=y
|
CONFIG_TULIP_NAPI=y
|
||||||
CONFIG_TULIP_NAPI_HW_MITIGATION=y
|
CONFIG_TULIP_NAPI_HW_MITIGATION=y
|
||||||
CONFIG_NET_PCI=y
|
|
||||||
CONFIG_NET_VENDOR_INTEL=y
|
|
||||||
CONFIG_E100=y
|
CONFIG_E100=y
|
||||||
CONFIG_E1000=y
|
CONFIG_E1000=y
|
||||||
CONFIG_TIGON3=y
|
|
||||||
CONFIG_INPUT_JOYDEV=y
|
CONFIG_INPUT_JOYDEV=y
|
||||||
CONFIG_INPUT_EVDEV=y
|
CONFIG_INPUT_EVDEV=y
|
||||||
# CONFIG_INPUT_KEYBOARD is not set
|
# CONFIG_INPUT_KEYBOARD is not set
|
||||||
@ -100,7 +98,6 @@ CONFIG_USB_STORAGE=y
|
|||||||
CONFIG_EXT2_FS=y
|
CONFIG_EXT2_FS=y
|
||||||
CONFIG_EXT2_FS_XATTR=y
|
CONFIG_EXT2_FS_XATTR=y
|
||||||
CONFIG_EXT3_FS=y
|
CONFIG_EXT3_FS=y
|
||||||
CONFIG_AUTOFS_FS=y
|
|
||||||
CONFIG_ISO9660_FS=y
|
CONFIG_ISO9660_FS=y
|
||||||
CONFIG_JOLIET=y
|
CONFIG_JOLIET=y
|
||||||
CONFIG_UDF_FS=y
|
CONFIG_UDF_FS=y
|
||||||
@ -110,12 +107,9 @@ CONFIG_PROC_KCORE=y
|
|||||||
CONFIG_TMPFS=y
|
CONFIG_TMPFS=y
|
||||||
CONFIG_HUGETLBFS=y
|
CONFIG_HUGETLBFS=y
|
||||||
CONFIG_NFS_FS=y
|
CONFIG_NFS_FS=y
|
||||||
CONFIG_NFS_V3=y
|
|
||||||
CONFIG_NFS_V4=y
|
CONFIG_NFS_V4=y
|
||||||
CONFIG_NFSD=y
|
CONFIG_NFSD=y
|
||||||
CONFIG_NFSD_V3=y
|
CONFIG_NFSD_V3=y
|
||||||
CONFIG_PARTITION_ADVANCED=y
|
|
||||||
CONFIG_EFI_PARTITION=y
|
|
||||||
CONFIG_NLS_CODEPAGE_437=y
|
CONFIG_NLS_CODEPAGE_437=y
|
||||||
CONFIG_NLS_CODEPAGE_737=y
|
CONFIG_NLS_CODEPAGE_737=y
|
||||||
CONFIG_NLS_CODEPAGE_775=y
|
CONFIG_NLS_CODEPAGE_775=y
|
||||||
|
@ -329,6 +329,6 @@
|
|||||||
#define __NR_sched_getattr 1337
|
#define __NR_sched_getattr 1337
|
||||||
#define __NR_renameat2 1338
|
#define __NR_renameat2 1338
|
||||||
#define __NR_getrandom 1339
|
#define __NR_getrandom 1339
|
||||||
#define __NR_memfd_create 1339
|
#define __NR_memfd_create 1340
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_IA64_UNISTD_H */
|
#endif /* _UAPI_ASM_IA64_UNISTD_H */
|
||||||
|
@ -38,27 +38,6 @@ static void pci_fixup_video(struct pci_dev *pdev)
|
|||||||
return;
|
return;
|
||||||
/* Maybe, this machine supports legacy memory map. */
|
/* Maybe, this machine supports legacy memory map. */
|
||||||
|
|
||||||
if (!vga_default_device()) {
|
|
||||||
resource_size_t start, end;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
/* Does firmware framebuffer belong to us? */
|
|
||||||
for (i = 0; i < DEVICE_COUNT_RESOURCE; i++) {
|
|
||||||
if (!(pci_resource_flags(pdev, i) & IORESOURCE_MEM))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
start = pci_resource_start(pdev, i);
|
|
||||||
end = pci_resource_end(pdev, i);
|
|
||||||
|
|
||||||
if (!start || !end)
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (screen_info.lfb_base >= start &&
|
|
||||||
(screen_info.lfb_base + screen_info.lfb_size) < end)
|
|
||||||
vga_set_default_device(pdev);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Is VGA routed to us? */
|
/* Is VGA routed to us? */
|
||||||
bus = pdev->bus;
|
bus = pdev->bus;
|
||||||
while (bus) {
|
while (bus) {
|
||||||
@ -83,8 +62,7 @@ static void pci_fixup_video(struct pci_dev *pdev)
|
|||||||
pci_read_config_word(pdev, PCI_COMMAND, &config);
|
pci_read_config_word(pdev, PCI_COMMAND, &config);
|
||||||
if (config & (PCI_COMMAND_IO | PCI_COMMAND_MEMORY)) {
|
if (config & (PCI_COMMAND_IO | PCI_COMMAND_MEMORY)) {
|
||||||
pdev->resource[PCI_ROM_RESOURCE].flags |= IORESOURCE_ROM_SHADOW;
|
pdev->resource[PCI_ROM_RESOURCE].flags |= IORESOURCE_ROM_SHADOW;
|
||||||
dev_printk(KERN_DEBUG, &pdev->dev, "Boot video device\n");
|
dev_printk(KERN_DEBUG, &pdev->dev, "Video device with shadowed ROM\n");
|
||||||
vga_set_default_device(pdev);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -546,6 +546,7 @@ config SGI_IP28
|
|||||||
# select SYS_HAS_EARLY_PRINTK
|
# select SYS_HAS_EARLY_PRINTK
|
||||||
select SYS_SUPPORTS_64BIT_KERNEL
|
select SYS_SUPPORTS_64BIT_KERNEL
|
||||||
select SYS_SUPPORTS_BIG_ENDIAN
|
select SYS_SUPPORTS_BIG_ENDIAN
|
||||||
|
select MIPS_L1_CACHE_SHIFT_7
|
||||||
help
|
help
|
||||||
This is the SGI Indigo2 with R10000 processor. To compile a Linux
|
This is the SGI Indigo2 with R10000 processor. To compile a Linux
|
||||||
kernel that runs on these, say Y here.
|
kernel that runs on these, say Y here.
|
||||||
@ -2029,7 +2030,9 @@ config MIPS_CMP
|
|||||||
bool "MIPS CMP framework support (DEPRECATED)"
|
bool "MIPS CMP framework support (DEPRECATED)"
|
||||||
depends on SYS_SUPPORTS_MIPS_CMP
|
depends on SYS_SUPPORTS_MIPS_CMP
|
||||||
select MIPS_GIC_IPI
|
select MIPS_GIC_IPI
|
||||||
|
select SMP
|
||||||
select SYNC_R4K
|
select SYNC_R4K
|
||||||
|
select SYS_SUPPORTS_SMP
|
||||||
select WEAK_ORDERING
|
select WEAK_ORDERING
|
||||||
default n
|
default n
|
||||||
help
|
help
|
||||||
|
@ -113,7 +113,16 @@ predef-le += -DMIPSEL -D_MIPSEL -D__MIPSEL -D__MIPSEL__
|
|||||||
cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' && echo -EB $(undef-all) $(predef-be))
|
cflags-$(CONFIG_CPU_BIG_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' && echo -EB $(undef-all) $(predef-be))
|
||||||
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' || echo -EL $(undef-all) $(predef-le))
|
cflags-$(CONFIG_CPU_LITTLE_ENDIAN) += $(shell $(CC) -dumpmachine |grep -q 'mips.*el-.*' || echo -EL $(undef-all) $(predef-le))
|
||||||
|
|
||||||
cflags-$(CONFIG_CPU_HAS_SMARTMIPS) += $(call cc-option,-msmartmips)
|
# For smartmips configurations, there are hundreds of warnings due to ISA overrides
|
||||||
|
# in assembly and header files. smartmips is only supported for MIPS32r1 onwards
|
||||||
|
# and there is no support for 64-bit. Various '.set mips2' or '.set mips3' or
|
||||||
|
# similar directives in the kernel will spam the build logs with the following warnings:
|
||||||
|
# Warning: the `smartmips' extension requires MIPS32 revision 1 or greater
|
||||||
|
# or
|
||||||
|
# Warning: the 64-bit MIPS architecture does not support the `smartmips' extension
|
||||||
|
# Pass -Wa,--no-warn to disable all assembler warnings until the kernel code has
|
||||||
|
# been fixed properly.
|
||||||
|
cflags-$(CONFIG_CPU_HAS_SMARTMIPS) += $(call cc-option,-msmartmips) -Wa,--no-warn
|
||||||
cflags-$(CONFIG_CPU_MICROMIPS) += $(call cc-option,-mmicromips)
|
cflags-$(CONFIG_CPU_MICROMIPS) += $(call cc-option,-mmicromips)
|
||||||
|
|
||||||
cflags-$(CONFIG_SB1XXX_CORELIS) += $(call cc-option,-mno-sched-prolog) \
|
cflags-$(CONFIG_SB1XXX_CORELIS) += $(call cc-option,-mno-sched-prolog) \
|
||||||
|
@ -434,7 +434,7 @@ static void bcm63xx_init_irq(void)
|
|||||||
irq_stat_addr[0] += PERF_IRQSTAT_3368_REG;
|
irq_stat_addr[0] += PERF_IRQSTAT_3368_REG;
|
||||||
irq_mask_addr[0] += PERF_IRQMASK_3368_REG;
|
irq_mask_addr[0] += PERF_IRQMASK_3368_REG;
|
||||||
irq_stat_addr[1] = 0;
|
irq_stat_addr[1] = 0;
|
||||||
irq_stat_addr[1] = 0;
|
irq_mask_addr[1] = 0;
|
||||||
irq_bits = 32;
|
irq_bits = 32;
|
||||||
ext_irq_count = 4;
|
ext_irq_count = 4;
|
||||||
ext_irq_cfg_reg1 = PERF_EXTIRQ_CFG_REG_3368;
|
ext_irq_cfg_reg1 = PERF_EXTIRQ_CFG_REG_3368;
|
||||||
@ -443,7 +443,7 @@ static void bcm63xx_init_irq(void)
|
|||||||
irq_stat_addr[0] += PERF_IRQSTAT_6328_REG(0);
|
irq_stat_addr[0] += PERF_IRQSTAT_6328_REG(0);
|
||||||
irq_mask_addr[0] += PERF_IRQMASK_6328_REG(0);
|
irq_mask_addr[0] += PERF_IRQMASK_6328_REG(0);
|
||||||
irq_stat_addr[1] += PERF_IRQSTAT_6328_REG(1);
|
irq_stat_addr[1] += PERF_IRQSTAT_6328_REG(1);
|
||||||
irq_stat_addr[1] += PERF_IRQMASK_6328_REG(1);
|
irq_mask_addr[1] += PERF_IRQMASK_6328_REG(1);
|
||||||
irq_bits = 64;
|
irq_bits = 64;
|
||||||
ext_irq_count = 4;
|
ext_irq_count = 4;
|
||||||
is_ext_irq_cascaded = 1;
|
is_ext_irq_cascaded = 1;
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include <linux/types.h>
|
#include <linux/types.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/string.h>
|
||||||
|
|
||||||
#include <asm/addrspace.h>
|
#include <asm/addrspace.h>
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
# CONFIG_BLK_DEV_BSG is not set
|
# CONFIG_BLK_DEV_BSG is not set
|
||||||
CONFIG_PCI=y
|
CONFIG_PCI=y
|
||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_INET=y
|
CONFIG_INET=y
|
||||||
|
@ -28,6 +28,7 @@ CONFIG_MIPS32_COMPAT=y
|
|||||||
CONFIG_MIPS32_O32=y
|
CONFIG_MIPS32_O32=y
|
||||||
CONFIG_MIPS32_N32=y
|
CONFIG_MIPS32_N32=y
|
||||||
CONFIG_PM=y
|
CONFIG_PM=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -18,6 +18,7 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
CONFIG_PM=y
|
CONFIG_PM=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=m
|
CONFIG_PACKET=m
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_NET_KEY=m
|
CONFIG_NET_KEY=m
|
||||||
|
@ -59,6 +59,7 @@ CONFIG_MIPS32_COMPAT=y
|
|||||||
CONFIG_MIPS32_O32=y
|
CONFIG_MIPS32_O32=y
|
||||||
CONFIG_MIPS32_N32=y
|
CONFIG_MIPS32_N32=y
|
||||||
CONFIG_PM_RUNTIME=y
|
CONFIG_PM_RUNTIME=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=y
|
CONFIG_XFRM_USER=y
|
||||||
|
@ -19,6 +19,7 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_PCI=y
|
CONFIG_PCI=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -20,6 +20,7 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_PCI=y
|
CONFIG_PCI=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -19,6 +19,7 @@ CONFIG_MODULE_UNLOAD=y
|
|||||||
CONFIG_MODVERSIONS=y
|
CONFIG_MODVERSIONS=y
|
||||||
CONFIG_MODULE_SRCVERSION_ALL=y
|
CONFIG_MODULE_SRCVERSION_ALL=y
|
||||||
CONFIG_PCI=y
|
CONFIG_PCI=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -27,6 +27,7 @@ CONFIG_PD6729=m
|
|||||||
CONFIG_I82092=m
|
CONFIG_I82092=m
|
||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
CONFIG_PM=y
|
CONFIG_PM=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=m
|
CONFIG_PACKET=m
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -63,6 +63,7 @@ CONFIG_MIPS32_O32=y
|
|||||||
CONFIG_MIPS32_N32=y
|
CONFIG_MIPS32_N32=y
|
||||||
CONFIG_PM_RUNTIME=y
|
CONFIG_PM_RUNTIME=y
|
||||||
CONFIG_PM_DEBUG=y
|
CONFIG_PM_DEBUG=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -43,6 +43,7 @@ CONFIG_PCI_DEBUG=y
|
|||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
CONFIG_PM_RUNTIME=y
|
CONFIG_PM_RUNTIME=y
|
||||||
CONFIG_PM_DEBUG=y
|
CONFIG_PM_DEBUG=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=y
|
CONFIG_PACKET=y
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_XFRM_USER=m
|
CONFIG_XFRM_USER=m
|
||||||
|
@ -20,6 +20,7 @@ CONFIG_MODVERSIONS=y
|
|||||||
CONFIG_PCI=y
|
CONFIG_PCI=y
|
||||||
CONFIG_BINFMT_MISC=m
|
CONFIG_BINFMT_MISC=m
|
||||||
CONFIG_PM=y
|
CONFIG_PM=y
|
||||||
|
CONFIG_NET=y
|
||||||
CONFIG_PACKET=m
|
CONFIG_PACKET=m
|
||||||
CONFIG_UNIX=y
|
CONFIG_UNIX=y
|
||||||
CONFIG_NET_KEY=m
|
CONFIG_NET_KEY=m
|
||||||
|
@ -16,8 +16,8 @@
|
|||||||
extern void octeon_cop2_save(struct octeon_cop2_state *);
|
extern void octeon_cop2_save(struct octeon_cop2_state *);
|
||||||
extern void octeon_cop2_restore(struct octeon_cop2_state *);
|
extern void octeon_cop2_restore(struct octeon_cop2_state *);
|
||||||
|
|
||||||
#define cop2_save(r) octeon_cop2_save(r)
|
#define cop2_save(r) octeon_cop2_save(&(r)->thread.cp2)
|
||||||
#define cop2_restore(r) octeon_cop2_restore(r)
|
#define cop2_restore(r) octeon_cop2_restore(&(r)->thread.cp2)
|
||||||
|
|
||||||
#define cop2_present 1
|
#define cop2_present 1
|
||||||
#define cop2_lazy_restore 1
|
#define cop2_lazy_restore 1
|
||||||
@ -26,26 +26,26 @@ extern void octeon_cop2_restore(struct octeon_cop2_state *);
|
|||||||
|
|
||||||
extern void nlm_cop2_save(struct nlm_cop2_state *);
|
extern void nlm_cop2_save(struct nlm_cop2_state *);
|
||||||
extern void nlm_cop2_restore(struct nlm_cop2_state *);
|
extern void nlm_cop2_restore(struct nlm_cop2_state *);
|
||||||
#define cop2_save(r) nlm_cop2_save(r)
|
|
||||||
#define cop2_restore(r) nlm_cop2_restore(r)
|
#define cop2_save(r) nlm_cop2_save(&(r)->thread.cp2)
|
||||||
|
#define cop2_restore(r) nlm_cop2_restore(&(r)->thread.cp2)
|
||||||
|
|
||||||
#define cop2_present 1
|
#define cop2_present 1
|
||||||
#define cop2_lazy_restore 0
|
#define cop2_lazy_restore 0
|
||||||
|
|
||||||
#elif defined(CONFIG_CPU_LOONGSON3)
|
#elif defined(CONFIG_CPU_LOONGSON3)
|
||||||
|
|
||||||
#define cop2_save(r)
|
|
||||||
#define cop2_restore(r)
|
|
||||||
|
|
||||||
#define cop2_present 1
|
#define cop2_present 1
|
||||||
#define cop2_lazy_restore 1
|
#define cop2_lazy_restore 1
|
||||||
|
#define cop2_save(r) do { (r); } while (0)
|
||||||
|
#define cop2_restore(r) do { (r); } while (0)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#define cop2_present 0
|
#define cop2_present 0
|
||||||
#define cop2_lazy_restore 0
|
#define cop2_lazy_restore 0
|
||||||
#define cop2_save(r)
|
#define cop2_save(r) do { (r); } while (0)
|
||||||
#define cop2_restore(r)
|
#define cop2_restore(r) do { (r); } while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
enum cu2_ops {
|
enum cu2_ops {
|
||||||
|
@ -11,15 +11,8 @@
|
|||||||
#ifndef _ASM_MACH_IP28_SPACES_H
|
#ifndef _ASM_MACH_IP28_SPACES_H
|
||||||
#define _ASM_MACH_IP28_SPACES_H
|
#define _ASM_MACH_IP28_SPACES_H
|
||||||
|
|
||||||
#define CAC_BASE _AC(0xa800000000000000, UL)
|
|
||||||
|
|
||||||
#define HIGHMEM_START (~0UL)
|
|
||||||
|
|
||||||
#define PHYS_OFFSET _AC(0x20000000, UL)
|
#define PHYS_OFFSET _AC(0x20000000, UL)
|
||||||
|
|
||||||
#define UNCAC_BASE _AC(0xc0000000, UL) /* 0xa0000000 + PHYS_OFFSET */
|
|
||||||
#define IO_BASE UNCAC_BASE
|
|
||||||
|
|
||||||
#include <asm/mach-generic/spaces.h>
|
#include <asm/mach-generic/spaces.h>
|
||||||
|
|
||||||
#endif /* _ASM_MACH_IP28_SPACES_H */
|
#endif /* _ASM_MACH_IP28_SPACES_H */
|
||||||
|
@ -37,7 +37,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* This is used for calculating the real page sizes
|
* This is used for calculating the real page sizes
|
||||||
* for FTLB or VTLB + FTLB confugrations.
|
* for FTLB or VTLB + FTLB configurations.
|
||||||
*/
|
*/
|
||||||
static inline unsigned int page_size_ftlb(unsigned int mmuextdef)
|
static inline unsigned int page_size_ftlb(unsigned int mmuextdef)
|
||||||
{
|
{
|
||||||
@ -223,7 +223,8 @@ static inline int pfn_valid(unsigned long pfn)
|
|||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define virt_to_page(kaddr) pfn_to_page(PFN_DOWN(virt_to_phys(kaddr)))
|
#define virt_to_page(kaddr) pfn_to_page(PFN_DOWN(virt_to_phys((void *) \
|
||||||
|
(kaddr))))
|
||||||
|
|
||||||
extern int __virt_addr_valid(const volatile void *kaddr);
|
extern int __virt_addr_valid(const volatile void *kaddr);
|
||||||
#define virt_addr_valid(kaddr) \
|
#define virt_addr_valid(kaddr) \
|
||||||
|
@ -37,11 +37,6 @@ extern int __cpu_logical_map[NR_CPUS];
|
|||||||
|
|
||||||
#define NO_PROC_ID (-1)
|
#define NO_PROC_ID (-1)
|
||||||
|
|
||||||
#define topology_physical_package_id(cpu) (cpu_data[cpu].package)
|
|
||||||
#define topology_core_id(cpu) (cpu_data[cpu].core)
|
|
||||||
#define topology_core_cpumask(cpu) (&cpu_core_map[cpu])
|
|
||||||
#define topology_thread_cpumask(cpu) (&cpu_sibling_map[cpu])
|
|
||||||
|
|
||||||
#define SMP_RESCHEDULE_YOURSELF 0x1 /* XXX braindead */
|
#define SMP_RESCHEDULE_YOURSELF 0x1 /* XXX braindead */
|
||||||
#define SMP_CALL_FUNCTION 0x2
|
#define SMP_CALL_FUNCTION 0x2
|
||||||
/* Octeon - Tell another core to flush its icache */
|
/* Octeon - Tell another core to flush its icache */
|
||||||
|
@ -92,7 +92,7 @@ do { \
|
|||||||
KSTK_STATUS(prev) &= ~ST0_CU2; \
|
KSTK_STATUS(prev) &= ~ST0_CU2; \
|
||||||
__c0_stat = read_c0_status(); \
|
__c0_stat = read_c0_status(); \
|
||||||
write_c0_status(__c0_stat | ST0_CU2); \
|
write_c0_status(__c0_stat | ST0_CU2); \
|
||||||
cop2_save(&prev->thread.cp2); \
|
cop2_save(prev); \
|
||||||
write_c0_status(__c0_stat & ~ST0_CU2); \
|
write_c0_status(__c0_stat & ~ST0_CU2); \
|
||||||
} \
|
} \
|
||||||
__clear_software_ll_bit(); \
|
__clear_software_ll_bit(); \
|
||||||
@ -111,7 +111,7 @@ do { \
|
|||||||
(KSTK_STATUS(current) & ST0_CU2)) { \
|
(KSTK_STATUS(current) & ST0_CU2)) { \
|
||||||
__c0_stat = read_c0_status(); \
|
__c0_stat = read_c0_status(); \
|
||||||
write_c0_status(__c0_stat | ST0_CU2); \
|
write_c0_status(__c0_stat | ST0_CU2); \
|
||||||
cop2_restore(¤t->thread.cp2); \
|
cop2_restore(current); \
|
||||||
write_c0_status(__c0_stat & ~ST0_CU2); \
|
write_c0_status(__c0_stat & ~ST0_CU2); \
|
||||||
} \
|
} \
|
||||||
if (cpu_has_dsp) \
|
if (cpu_has_dsp) \
|
||||||
|
@ -9,5 +9,13 @@
|
|||||||
#define __ASM_TOPOLOGY_H
|
#define __ASM_TOPOLOGY_H
|
||||||
|
|
||||||
#include <topology.h>
|
#include <topology.h>
|
||||||
|
#include <linux/smp.h>
|
||||||
|
|
||||||
|
#ifdef CONFIG_SMP
|
||||||
|
#define topology_physical_package_id(cpu) (cpu_data[cpu].package)
|
||||||
|
#define topology_core_id(cpu) (cpu_data[cpu].core)
|
||||||
|
#define topology_core_cpumask(cpu) (&cpu_core_map[cpu])
|
||||||
|
#define topology_thread_cpumask(cpu) (&cpu_sibling_map[cpu])
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* __ASM_TOPOLOGY_H */
|
#endif /* __ASM_TOPOLOGY_H */
|
||||||
|
@ -373,16 +373,18 @@
|
|||||||
#define __NR_sched_getattr (__NR_Linux + 350)
|
#define __NR_sched_getattr (__NR_Linux + 350)
|
||||||
#define __NR_renameat2 (__NR_Linux + 351)
|
#define __NR_renameat2 (__NR_Linux + 351)
|
||||||
#define __NR_seccomp (__NR_Linux + 352)
|
#define __NR_seccomp (__NR_Linux + 352)
|
||||||
|
#define __NR_getrandom (__NR_Linux + 353)
|
||||||
|
#define __NR_memfd_create (__NR_Linux + 354)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last Linux o32 flavoured syscall
|
* Offset of the last Linux o32 flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 352
|
#define __NR_Linux_syscalls 354
|
||||||
|
|
||||||
#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 352
|
#define __NR_O32_Linux_syscalls 354
|
||||||
|
|
||||||
#if _MIPS_SIM == _MIPS_SIM_ABI64
|
#if _MIPS_SIM == _MIPS_SIM_ABI64
|
||||||
|
|
||||||
@ -703,16 +705,18 @@
|
|||||||
#define __NR_sched_getattr (__NR_Linux + 310)
|
#define __NR_sched_getattr (__NR_Linux + 310)
|
||||||
#define __NR_renameat2 (__NR_Linux + 311)
|
#define __NR_renameat2 (__NR_Linux + 311)
|
||||||
#define __NR_seccomp (__NR_Linux + 312)
|
#define __NR_seccomp (__NR_Linux + 312)
|
||||||
|
#define __NR_getrandom (__NR_Linux + 313)
|
||||||
|
#define __NR_memfd_create (__NR_Linux + 314)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last Linux 64-bit flavoured syscall
|
* Offset of the last Linux 64-bit flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 312
|
#define __NR_Linux_syscalls 314
|
||||||
|
|
||||||
#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 312
|
#define __NR_64_Linux_syscalls 314
|
||||||
|
|
||||||
#if _MIPS_SIM == _MIPS_SIM_NABI32
|
#if _MIPS_SIM == _MIPS_SIM_NABI32
|
||||||
|
|
||||||
@ -1037,15 +1041,17 @@
|
|||||||
#define __NR_sched_getattr (__NR_Linux + 314)
|
#define __NR_sched_getattr (__NR_Linux + 314)
|
||||||
#define __NR_renameat2 (__NR_Linux + 315)
|
#define __NR_renameat2 (__NR_Linux + 315)
|
||||||
#define __NR_seccomp (__NR_Linux + 316)
|
#define __NR_seccomp (__NR_Linux + 316)
|
||||||
|
#define __NR_getrandom (__NR_Linux + 317)
|
||||||
|
#define __NR_memfd_create (__NR_Linux + 318)
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Offset of the last N32 flavoured syscall
|
* Offset of the last N32 flavoured syscall
|
||||||
*/
|
*/
|
||||||
#define __NR_Linux_syscalls 316
|
#define __NR_Linux_syscalls 318
|
||||||
|
|
||||||
#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 316
|
#define __NR_N32_Linux_syscalls 318
|
||||||
|
|
||||||
#endif /* _UAPI_ASM_UNISTD_H */
|
#endif /* _UAPI_ASM_UNISTD_H */
|
||||||
|
@ -71,8 +71,12 @@ machine_kexec(struct kimage *image)
|
|||||||
kexec_start_address =
|
kexec_start_address =
|
||||||
(unsigned long) phys_to_virt(image->start);
|
(unsigned long) phys_to_virt(image->start);
|
||||||
|
|
||||||
kexec_indirection_page =
|
if (image->type == KEXEC_TYPE_DEFAULT) {
|
||||||
(unsigned long) phys_to_virt(image->head & PAGE_MASK);
|
kexec_indirection_page =
|
||||||
|
(unsigned long) phys_to_virt(image->head & PAGE_MASK);
|
||||||
|
} else {
|
||||||
|
kexec_indirection_page = (unsigned long)&image->head;
|
||||||
|
}
|
||||||
|
|
||||||
memcpy((void*)reboot_code_buffer, relocate_new_kernel,
|
memcpy((void*)reboot_code_buffer, relocate_new_kernel,
|
||||||
relocate_new_kernel_size);
|
relocate_new_kernel_size);
|
||||||
|
@ -129,7 +129,11 @@ NESTED(_mcount, PT_SIZE, ra)
|
|||||||
nop
|
nop
|
||||||
#endif
|
#endif
|
||||||
b ftrace_stub
|
b ftrace_stub
|
||||||
|
#ifdef CONFIG_32BIT
|
||||||
|
addiu sp, sp, 8
|
||||||
|
#else
|
||||||
nop
|
nop
|
||||||
|
#endif
|
||||||
|
|
||||||
static_trace:
|
static_trace:
|
||||||
MCOUNT_SAVE_REGS
|
MCOUNT_SAVE_REGS
|
||||||
@ -139,6 +143,9 @@ static_trace:
|
|||||||
move a1, AT /* arg2: parent's return address */
|
move a1, AT /* arg2: parent's return address */
|
||||||
|
|
||||||
MCOUNT_RESTORE_REGS
|
MCOUNT_RESTORE_REGS
|
||||||
|
#ifdef CONFIG_32BIT
|
||||||
|
addiu sp, sp, 8
|
||||||
|
#endif
|
||||||
.globl ftrace_stub
|
.globl ftrace_stub
|
||||||
ftrace_stub:
|
ftrace_stub:
|
||||||
RETURN_BACK
|
RETURN_BACK
|
||||||
@ -183,6 +190,11 @@ NESTED(ftrace_graph_caller, PT_SIZE, ra)
|
|||||||
jal prepare_ftrace_return
|
jal prepare_ftrace_return
|
||||||
nop
|
nop
|
||||||
MCOUNT_RESTORE_REGS
|
MCOUNT_RESTORE_REGS
|
||||||
|
#ifndef CONFIG_DYNAMIC_FTRACE
|
||||||
|
#ifdef CONFIG_32BIT
|
||||||
|
addiu sp, sp, 8
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
RETURN_BACK
|
RETURN_BACK
|
||||||
END(ftrace_graph_caller)
|
END(ftrace_graph_caller)
|
||||||
|
|
||||||
|
@ -577,3 +577,5 @@ EXPORT(sys_call_table)
|
|||||||
PTR sys_sched_getattr /* 4350 */
|
PTR sys_sched_getattr /* 4350 */
|
||||||
PTR sys_renameat2
|
PTR sys_renameat2
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
|
PTR sys_getrandom
|
||||||
|
PTR sys_memfd_create
|
||||||
|
@ -432,4 +432,6 @@ EXPORT(sys_call_table)
|
|||||||
PTR sys_sched_getattr /* 5310 */
|
PTR sys_sched_getattr /* 5310 */
|
||||||
PTR sys_renameat2
|
PTR sys_renameat2
|
||||||
PTR sys_seccomp
|
PTR sys_seccomp
|
||||||
|
PTR sys_getrandom
|
||||||
|
PTR sys_memfd_create
|
||||||
.size sys_call_table,.-sys_call_table
|
.size sys_call_table,.-sys_call_table
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user