mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-13 09:20:17 +00:00
Merge branch 'davinci-fixes' of git://gitorious.org/linux-davinci/linux-davinci into fixes
This commit is contained in:
commit
167f829752
@ -387,26 +387,6 @@ Who: Tejun Heo <tj@kernel.org>
|
|||||||
|
|
||||||
----------------------------
|
----------------------------
|
||||||
|
|
||||||
What: Support for lcd_switch and display_get in asus-laptop driver
|
|
||||||
When: March 2010
|
|
||||||
Why: These two features use non-standard interfaces. There are the
|
|
||||||
only features that really need multiple path to guess what's
|
|
||||||
the right method name on a specific laptop.
|
|
||||||
|
|
||||||
Removing them will allow to remove a lot of code an significantly
|
|
||||||
clean the drivers.
|
|
||||||
|
|
||||||
This will affect the backlight code which won't be able to know
|
|
||||||
if the backlight is on or off. The platform display file will also be
|
|
||||||
write only (like the one in eeepc-laptop).
|
|
||||||
|
|
||||||
This should'nt affect a lot of user because they usually know
|
|
||||||
when their display is on or off.
|
|
||||||
|
|
||||||
Who: Corentin Chary <corentin.chary@gmail.com>
|
|
||||||
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
What: sysfs-class-rfkill state file
|
What: sysfs-class-rfkill state file
|
||||||
When: Feb 2014
|
When: Feb 2014
|
||||||
Files: net/rfkill/core.c
|
Files: net/rfkill/core.c
|
||||||
|
262
Documentation/input/event-codes.txt
Normal file
262
Documentation/input/event-codes.txt
Normal file
@ -0,0 +1,262 @@
|
|||||||
|
The input protocol uses a map of types and codes to express input device values
|
||||||
|
to userspace. This document describes the types and codes and how and when they
|
||||||
|
may be used.
|
||||||
|
|
||||||
|
A single hardware event generates multiple input events. Each input event
|
||||||
|
contains the new value of a single data item. A special event type, EV_SYN, is
|
||||||
|
used to separate input events into packets of input data changes occurring at
|
||||||
|
the same moment in time. In the following, the term "event" refers to a single
|
||||||
|
input event encompassing a type, code, and value.
|
||||||
|
|
||||||
|
The input protocol is a stateful protocol. Events are emitted only when values
|
||||||
|
of event codes have changed. However, the state is maintained within the Linux
|
||||||
|
input subsystem; drivers do not need to maintain the state and may attempt to
|
||||||
|
emit unchanged values without harm. Userspace may obtain the current state of
|
||||||
|
event code values using the EVIOCG* ioctls defined in linux/input.h. The event
|
||||||
|
reports supported by a device are also provided by sysfs in
|
||||||
|
class/input/event*/device/capabilities/, and the properties of a device are
|
||||||
|
provided in class/input/event*/device/properties.
|
||||||
|
|
||||||
|
Types:
|
||||||
|
==========
|
||||||
|
Types are groupings of codes under a logical input construct. Each type has a
|
||||||
|
set of applicable codes to be used in generating events. See the Codes section
|
||||||
|
for details on valid codes for each type.
|
||||||
|
|
||||||
|
* EV_SYN:
|
||||||
|
- Used as markers to separate events. Events may be separated in time or in
|
||||||
|
space, such as with the multitouch protocol.
|
||||||
|
|
||||||
|
* EV_KEY:
|
||||||
|
- Used to describe state changes of keyboards, buttons, or other key-like
|
||||||
|
devices.
|
||||||
|
|
||||||
|
* EV_REL:
|
||||||
|
- Used to describe relative axis value changes, e.g. moving the mouse 5 units
|
||||||
|
to the left.
|
||||||
|
|
||||||
|
* EV_ABS:
|
||||||
|
- Used to describe absolute axis value changes, e.g. describing the
|
||||||
|
coordinates of a touch on a touchscreen.
|
||||||
|
|
||||||
|
* EV_MSC:
|
||||||
|
- Used to describe miscellaneous input data that do not fit into other types.
|
||||||
|
|
||||||
|
* EV_SW:
|
||||||
|
- Used to describe binary state input switches.
|
||||||
|
|
||||||
|
* EV_LED:
|
||||||
|
- Used to turn LEDs on devices on and off.
|
||||||
|
|
||||||
|
* EV_SND:
|
||||||
|
- Used to output sound to devices.
|
||||||
|
|
||||||
|
* EV_REP:
|
||||||
|
- Used for autorepeating devices.
|
||||||
|
|
||||||
|
* EV_FF:
|
||||||
|
- Used to send force feedback commands to an input device.
|
||||||
|
|
||||||
|
* EV_PWR:
|
||||||
|
- A special type for power button and switch input.
|
||||||
|
|
||||||
|
* EV_FF_STATUS:
|
||||||
|
- Used to receive force feedback device status.
|
||||||
|
|
||||||
|
Codes:
|
||||||
|
==========
|
||||||
|
Codes define the precise type of event.
|
||||||
|
|
||||||
|
EV_SYN:
|
||||||
|
----------
|
||||||
|
EV_SYN event values are undefined. Their usage is defined only by when they are
|
||||||
|
sent in the evdev event stream.
|
||||||
|
|
||||||
|
* SYN_REPORT:
|
||||||
|
- Used to synchronize and separate events into packets of input data changes
|
||||||
|
occurring at the same moment in time. For example, motion of a mouse may set
|
||||||
|
the REL_X and REL_Y values for one motion, then emit a SYN_REPORT. The next
|
||||||
|
motion will emit more REL_X and REL_Y values and send another SYN_REPORT.
|
||||||
|
|
||||||
|
* SYN_CONFIG:
|
||||||
|
- TBD
|
||||||
|
|
||||||
|
* SYN_MT_REPORT:
|
||||||
|
- Used to synchronize and separate touch events. See the
|
||||||
|
multi-touch-protocol.txt document for more information.
|
||||||
|
|
||||||
|
* SYN_DROPPED:
|
||||||
|
- Used to indicate buffer overrun in the evdev client's event queue.
|
||||||
|
Client should ignore all events up to and including next SYN_REPORT
|
||||||
|
event and query the device (using EVIOCG* ioctls) to obtain its
|
||||||
|
current state.
|
||||||
|
|
||||||
|
EV_KEY:
|
||||||
|
----------
|
||||||
|
EV_KEY events take the form KEY_<name> or BTN_<name>. For example, KEY_A is used
|
||||||
|
to represent the 'A' key on a keyboard. When a key is depressed, an event with
|
||||||
|
the key's code is emitted with value 1. When the key is released, an event is
|
||||||
|
emitted with value 0. Some hardware send events when a key is repeated. These
|
||||||
|
events have a value of 2. In general, KEY_<name> is used for keyboard keys, and
|
||||||
|
BTN_<name> is used for other types of momentary switch events.
|
||||||
|
|
||||||
|
A few EV_KEY codes have special meanings:
|
||||||
|
|
||||||
|
* BTN_TOOL_<name>:
|
||||||
|
- These codes are used in conjunction with input trackpads, tablets, and
|
||||||
|
touchscreens. These devices may be used with fingers, pens, or other tools.
|
||||||
|
When an event occurs and a tool is used, the corresponding BTN_TOOL_<name>
|
||||||
|
code should be set to a value of 1. When the tool is no longer interacting
|
||||||
|
with the input device, the BTN_TOOL_<name> code should be reset to 0. All
|
||||||
|
trackpads, tablets, and touchscreens should use at least one BTN_TOOL_<name>
|
||||||
|
code when events are generated.
|
||||||
|
|
||||||
|
* BTN_TOUCH:
|
||||||
|
BTN_TOUCH is used for touch contact. While an input tool is determined to be
|
||||||
|
within meaningful physical contact, the value of this property must be set
|
||||||
|
to 1. Meaningful physical contact may mean any contact, or it may mean
|
||||||
|
contact conditioned by an implementation defined property. For example, a
|
||||||
|
touchpad may set the value to 1 only when the touch pressure rises above a
|
||||||
|
certain value. BTN_TOUCH may be combined with BTN_TOOL_<name> codes. For
|
||||||
|
example, a pen tablet may set BTN_TOOL_PEN to 1 and BTN_TOUCH to 0 while the
|
||||||
|
pen is hovering over but not touching the tablet surface.
|
||||||
|
|
||||||
|
Note: For appropriate function of the legacy mousedev emulation driver,
|
||||||
|
BTN_TOUCH must be the first evdev code emitted in a synchronization frame.
|
||||||
|
|
||||||
|
Note: Historically a touch device with BTN_TOOL_FINGER and BTN_TOUCH was
|
||||||
|
interpreted as a touchpad by userspace, while a similar device without
|
||||||
|
BTN_TOOL_FINGER was interpreted as a touchscreen. For backwards compatibility
|
||||||
|
with current userspace it is recommended to follow this distinction. In the
|
||||||
|
future, this distinction will be deprecated and the device properties ioctl
|
||||||
|
EVIOCGPROP, defined in linux/input.h, will be used to convey the device type.
|
||||||
|
|
||||||
|
* BTN_TOOL_FINGER, BTN_TOOL_DOUBLETAP, BTN_TOOL_TRIPLETAP, BTN_TOOL_QUADTAP:
|
||||||
|
- These codes denote one, two, three, and four finger interaction on a
|
||||||
|
trackpad or touchscreen. For example, if the user uses two fingers and moves
|
||||||
|
them on the touchpad in an effort to scroll content on screen,
|
||||||
|
BTN_TOOL_DOUBLETAP should be set to value 1 for the duration of the motion.
|
||||||
|
Note that all BTN_TOOL_<name> codes and the BTN_TOUCH code are orthogonal in
|
||||||
|
purpose. A trackpad event generated by finger touches should generate events
|
||||||
|
for one code from each group. At most only one of these BTN_TOOL_<name>
|
||||||
|
codes should have a value of 1 during any synchronization frame.
|
||||||
|
|
||||||
|
Note: Historically some drivers emitted multiple of the finger count codes with
|
||||||
|
a value of 1 in the same synchronization frame. This usage is deprecated.
|
||||||
|
|
||||||
|
Note: In multitouch drivers, the input_mt_report_finger_count() function should
|
||||||
|
be used to emit these codes. Please see multi-touch-protocol.txt for details.
|
||||||
|
|
||||||
|
EV_REL:
|
||||||
|
----------
|
||||||
|
EV_REL events describe relative changes in a property. For example, a mouse may
|
||||||
|
move to the left by a certain number of units, but its absolute position in
|
||||||
|
space is unknown. If the absolute position is known, EV_ABS codes should be used
|
||||||
|
instead of EV_REL codes.
|
||||||
|
|
||||||
|
A few EV_REL codes have special meanings:
|
||||||
|
|
||||||
|
* REL_WHEEL, REL_HWHEEL:
|
||||||
|
- These codes are used for vertical and horizontal scroll wheels,
|
||||||
|
respectively.
|
||||||
|
|
||||||
|
EV_ABS:
|
||||||
|
----------
|
||||||
|
EV_ABS events describe absolute changes in a property. For example, a touchpad
|
||||||
|
may emit coordinates for a touch location.
|
||||||
|
|
||||||
|
A few EV_ABS codes have special meanings:
|
||||||
|
|
||||||
|
* ABS_DISTANCE:
|
||||||
|
- Used to describe the distance of a tool from an interaction surface. This
|
||||||
|
event should only be emitted while the tool is hovering, meaning in close
|
||||||
|
proximity of the device and while the value of the BTN_TOUCH code is 0. If
|
||||||
|
the input device may be used freely in three dimensions, consider ABS_Z
|
||||||
|
instead.
|
||||||
|
|
||||||
|
* ABS_MT_<name>:
|
||||||
|
- Used to describe multitouch input events. Please see
|
||||||
|
multi-touch-protocol.txt for details.
|
||||||
|
|
||||||
|
EV_SW:
|
||||||
|
----------
|
||||||
|
EV_SW events describe stateful binary switches. For example, the SW_LID code is
|
||||||
|
used to denote when a laptop lid is closed.
|
||||||
|
|
||||||
|
Upon binding to a device or resuming from suspend, a driver must report
|
||||||
|
the current switch state. This ensures that the device, kernel, and userspace
|
||||||
|
state is in sync.
|
||||||
|
|
||||||
|
Upon resume, if the switch state is the same as before suspend, then the input
|
||||||
|
subsystem will filter out the duplicate switch state reports. The driver does
|
||||||
|
not need to keep the state of the switch at any time.
|
||||||
|
|
||||||
|
EV_MSC:
|
||||||
|
----------
|
||||||
|
EV_MSC events are used for input and output events that do not fall under other
|
||||||
|
categories.
|
||||||
|
|
||||||
|
EV_LED:
|
||||||
|
----------
|
||||||
|
EV_LED events are used for input and output to set and query the state of
|
||||||
|
various LEDs on devices.
|
||||||
|
|
||||||
|
EV_REP:
|
||||||
|
----------
|
||||||
|
EV_REP events are used for specifying autorepeating events.
|
||||||
|
|
||||||
|
EV_SND:
|
||||||
|
----------
|
||||||
|
EV_SND events are used for sending sound commands to simple sound output
|
||||||
|
devices.
|
||||||
|
|
||||||
|
EV_FF:
|
||||||
|
----------
|
||||||
|
EV_FF events are used to initialize a force feedback capable device and to cause
|
||||||
|
such device to feedback.
|
||||||
|
|
||||||
|
EV_PWR:
|
||||||
|
----------
|
||||||
|
EV_PWR events are a special type of event used specifically for power
|
||||||
|
mangement. Its usage is not well defined. To be addressed later.
|
||||||
|
|
||||||
|
Guidelines:
|
||||||
|
==========
|
||||||
|
The guidelines below ensure proper single-touch and multi-finger functionality.
|
||||||
|
For multi-touch functionality, see the multi-touch-protocol.txt document for
|
||||||
|
more information.
|
||||||
|
|
||||||
|
Mice:
|
||||||
|
----------
|
||||||
|
REL_{X,Y} must be reported when the mouse moves. BTN_LEFT must be used to report
|
||||||
|
the primary button press. BTN_{MIDDLE,RIGHT,4,5,etc.} should be used to report
|
||||||
|
further buttons of the device. REL_WHEEL and REL_HWHEEL should be used to report
|
||||||
|
scroll wheel events where available.
|
||||||
|
|
||||||
|
Touchscreens:
|
||||||
|
----------
|
||||||
|
ABS_{X,Y} must be reported with the location of the touch. BTN_TOUCH must be
|
||||||
|
used to report when a touch is active on the screen.
|
||||||
|
BTN_{MOUSE,LEFT,MIDDLE,RIGHT} must not be reported as the result of touch
|
||||||
|
contact. BTN_TOOL_<name> events should be reported where possible.
|
||||||
|
|
||||||
|
Trackpads:
|
||||||
|
----------
|
||||||
|
Legacy trackpads that only provide relative position information must report
|
||||||
|
events like mice described above.
|
||||||
|
|
||||||
|
Trackpads that provide absolute touch position must report ABS_{X,Y} for the
|
||||||
|
location of the touch. BTN_TOUCH should be used to report when a touch is active
|
||||||
|
on the trackpad. Where multi-finger support is available, BTN_TOOL_<name> should
|
||||||
|
be used to report the number of touches active on the trackpad.
|
||||||
|
|
||||||
|
Tablets:
|
||||||
|
----------
|
||||||
|
BTN_TOOL_<name> events must be reported when a stylus or other tool is active on
|
||||||
|
the tablet. ABS_{X,Y} must be reported with the location of the tool. BTN_TOUCH
|
||||||
|
should be used to report when the tool is in contact with the tablet.
|
||||||
|
BTN_{STYLUS,STYLUS2} should be used to report buttons on the tool itself. Any
|
||||||
|
button may be used for buttons on the tablet except BTN_{MOUSE,LEFT}.
|
||||||
|
BTN_{0,1,2,etc} are good generic codes for unlabeled buttons. Do not use
|
||||||
|
meaningful buttons, like BTN_FORWARD, unless the button is labeled for that
|
||||||
|
purpose on the device.
|
46
MAINTAINERS
46
MAINTAINERS
@ -184,10 +184,9 @@ F: Documentation/filesystems/9p.txt
|
|||||||
F: fs/9p/
|
F: fs/9p/
|
||||||
|
|
||||||
A2232 SERIAL BOARD DRIVER
|
A2232 SERIAL BOARD DRIVER
|
||||||
M: Enver Haase <A2232@gmx.net>
|
|
||||||
L: linux-m68k@lists.linux-m68k.org
|
L: linux-m68k@lists.linux-m68k.org
|
||||||
S: Maintained
|
S: Orphan
|
||||||
F: drivers/char/ser_a2232*
|
F: drivers/staging/generic_serial/ser_a2232*
|
||||||
|
|
||||||
AACRAID SCSI RAID DRIVER
|
AACRAID SCSI RAID DRIVER
|
||||||
M: Adaptec OEM Raid Solutions <aacraid@adaptec.com>
|
M: Adaptec OEM Raid Solutions <aacraid@adaptec.com>
|
||||||
@ -877,6 +876,13 @@ F: arch/arm/mach-mv78xx0/
|
|||||||
F: arch/arm/mach-orion5x/
|
F: arch/arm/mach-orion5x/
|
||||||
F: arch/arm/plat-orion/
|
F: arch/arm/plat-orion/
|
||||||
|
|
||||||
|
ARM/Orion SoC/Technologic Systems TS-78xx platform support
|
||||||
|
M: Alexander Clouter <alex@digriz.org.uk>
|
||||||
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
|
W: http://www.digriz.org.uk/ts78xx/kernel
|
||||||
|
S: Maintained
|
||||||
|
F: arch/arm/mach-orion5x/ts78xx-*
|
||||||
|
|
||||||
ARM/MIOA701 MACHINE SUPPORT
|
ARM/MIOA701 MACHINE SUPPORT
|
||||||
M: Robert Jarzmik <robert.jarzmik@free.fr>
|
M: Robert Jarzmik <robert.jarzmik@free.fr>
|
||||||
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
L: linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
|
||||||
@ -1063,7 +1069,7 @@ F: arch/arm/mach-shmobile/
|
|||||||
F: drivers/sh/
|
F: drivers/sh/
|
||||||
|
|
||||||
ARM/TELECHIPS ARM ARCHITECTURE
|
ARM/TELECHIPS ARM ARCHITECTURE
|
||||||
M: "Hans J. Koch" <hjk@linutronix.de>
|
M: "Hans J. Koch" <hjk@hansjkoch.de>
|
||||||
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
|
||||||
F: arch/arm/plat-tcc/
|
F: arch/arm/plat-tcc/
|
||||||
@ -1823,11 +1829,10 @@ S: Maintained
|
|||||||
F: drivers/platform/x86/compal-laptop.c
|
F: drivers/platform/x86/compal-laptop.c
|
||||||
|
|
||||||
COMPUTONE INTELLIPORT MULTIPORT CARD
|
COMPUTONE INTELLIPORT MULTIPORT CARD
|
||||||
M: "Michael H. Warfield" <mhw@wittsend.com>
|
|
||||||
W: http://www.wittsend.com/computone.html
|
W: http://www.wittsend.com/computone.html
|
||||||
S: Maintained
|
S: Orphan
|
||||||
F: Documentation/serial/computone.txt
|
F: Documentation/serial/computone.txt
|
||||||
F: drivers/char/ip2/
|
F: drivers/staging/tty/ip2/
|
||||||
|
|
||||||
CONEXANT ACCESSRUNNER USB DRIVER
|
CONEXANT ACCESSRUNNER USB DRIVER
|
||||||
M: Simon Arlott <cxacru@fire.lp0.eu>
|
M: Simon Arlott <cxacru@fire.lp0.eu>
|
||||||
@ -2010,7 +2015,7 @@ F: drivers/net/wan/cycx*
|
|||||||
CYCLADES ASYNC MUX DRIVER
|
CYCLADES ASYNC MUX DRIVER
|
||||||
W: http://www.cyclades.com/
|
W: http://www.cyclades.com/
|
||||||
S: Orphan
|
S: Orphan
|
||||||
F: drivers/char/cyclades.c
|
F: drivers/tty/cyclades.c
|
||||||
F: include/linux/cyclades.h
|
F: include/linux/cyclades.h
|
||||||
|
|
||||||
CYCLADES PC300 DRIVER
|
CYCLADES PC300 DRIVER
|
||||||
@ -2124,8 +2129,8 @@ L: Eng.Linux@digi.com
|
|||||||
W: http://www.digi.com
|
W: http://www.digi.com
|
||||||
S: Orphan
|
S: Orphan
|
||||||
F: Documentation/serial/digiepca.txt
|
F: Documentation/serial/digiepca.txt
|
||||||
F: drivers/char/epca*
|
F: drivers/staging/tty/epca*
|
||||||
F: drivers/char/digi*
|
F: drivers/staging/tty/digi*
|
||||||
|
|
||||||
DIOLAN U2C-12 I2C DRIVER
|
DIOLAN U2C-12 I2C DRIVER
|
||||||
M: Guenter Roeck <guenter.roeck@ericsson.com>
|
M: Guenter Roeck <guenter.roeck@ericsson.com>
|
||||||
@ -4077,7 +4082,7 @@ F: drivers/video/matrox/matroxfb_*
|
|||||||
F: include/linux/matroxfb.h
|
F: include/linux/matroxfb.h
|
||||||
|
|
||||||
MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER
|
MAX6650 HARDWARE MONITOR AND FAN CONTROLLER DRIVER
|
||||||
M: "Hans J. Koch" <hjk@linutronix.de>
|
M: "Hans J. Koch" <hjk@hansjkoch.de>
|
||||||
L: lm-sensors@lm-sensors.org
|
L: lm-sensors@lm-sensors.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/hwmon/max6650
|
F: Documentation/hwmon/max6650
|
||||||
@ -4192,7 +4197,7 @@ MOXA SMARTIO/INDUSTIO/INTELLIO SERIAL CARD
|
|||||||
M: Jiri Slaby <jirislaby@gmail.com>
|
M: Jiri Slaby <jirislaby@gmail.com>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/serial/moxa-smartio
|
F: Documentation/serial/moxa-smartio
|
||||||
F: drivers/char/mxser.*
|
F: drivers/tty/mxser.*
|
||||||
|
|
||||||
MSI LAPTOP SUPPORT
|
MSI LAPTOP SUPPORT
|
||||||
M: "Lee, Chun-Yi" <jlee@novell.com>
|
M: "Lee, Chun-Yi" <jlee@novell.com>
|
||||||
@ -4234,7 +4239,7 @@ F: sound/oss/msnd*
|
|||||||
|
|
||||||
MULTITECH MULTIPORT CARD (ISICOM)
|
MULTITECH MULTIPORT CARD (ISICOM)
|
||||||
S: Orphan
|
S: Orphan
|
||||||
F: drivers/char/isicom.c
|
F: drivers/tty/isicom.c
|
||||||
F: include/linux/isicom.h
|
F: include/linux/isicom.h
|
||||||
|
|
||||||
MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER
|
MUSB MULTIPOINT HIGH SPEED DUAL-ROLE CONTROLLER
|
||||||
@ -5273,14 +5278,14 @@ F: drivers/memstick/host/r592.*
|
|||||||
RISCOM8 DRIVER
|
RISCOM8 DRIVER
|
||||||
S: Orphan
|
S: Orphan
|
||||||
F: Documentation/serial/riscom8.txt
|
F: Documentation/serial/riscom8.txt
|
||||||
F: drivers/char/riscom8*
|
F: drivers/staging/tty/riscom8*
|
||||||
|
|
||||||
ROCKETPORT DRIVER
|
ROCKETPORT DRIVER
|
||||||
P: Comtrol Corp.
|
P: Comtrol Corp.
|
||||||
W: http://www.comtrol.com
|
W: http://www.comtrol.com
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/serial/rocket.txt
|
F: Documentation/serial/rocket.txt
|
||||||
F: drivers/char/rocket*
|
F: drivers/tty/rocket*
|
||||||
|
|
||||||
ROSE NETWORK LAYER
|
ROSE NETWORK LAYER
|
||||||
M: Ralf Baechle <ralf@linux-mips.org>
|
M: Ralf Baechle <ralf@linux-mips.org>
|
||||||
@ -5916,10 +5921,9 @@ F: arch/arm/mach-spear6xx/spear600.c
|
|||||||
F: arch/arm/mach-spear6xx/spear600_evb.c
|
F: arch/arm/mach-spear6xx/spear600_evb.c
|
||||||
|
|
||||||
SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER
|
SPECIALIX IO8+ MULTIPORT SERIAL CARD DRIVER
|
||||||
M: Roger Wolff <R.E.Wolff@BitWizard.nl>
|
S: Orphan
|
||||||
S: Supported
|
|
||||||
F: Documentation/serial/specialix.txt
|
F: Documentation/serial/specialix.txt
|
||||||
F: drivers/char/specialix*
|
F: drivers/staging/tty/specialix*
|
||||||
|
|
||||||
SPI SUBSYSTEM
|
SPI SUBSYSTEM
|
||||||
M: David Brownell <dbrownell@users.sourceforge.net>
|
M: David Brownell <dbrownell@users.sourceforge.net>
|
||||||
@ -5964,7 +5968,6 @@ F: arch/alpha/kernel/srm_env.c
|
|||||||
|
|
||||||
STABLE BRANCH
|
STABLE BRANCH
|
||||||
M: Greg Kroah-Hartman <greg@kroah.com>
|
M: Greg Kroah-Hartman <greg@kroah.com>
|
||||||
M: Chris Wright <chrisw@sous-sol.org>
|
|
||||||
L: stable@kernel.org
|
L: stable@kernel.org
|
||||||
S: Maintained
|
S: Maintained
|
||||||
|
|
||||||
@ -6248,7 +6251,8 @@ M: Greg Ungerer <gerg@uclinux.org>
|
|||||||
W: http://www.uclinux.org/
|
W: http://www.uclinux.org/
|
||||||
L: uclinux-dev@uclinux.org (subscribers-only)
|
L: uclinux-dev@uclinux.org (subscribers-only)
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: arch/m68knommu/
|
F: arch/m68k/*/*_no.*
|
||||||
|
F: arch/m68k/include/asm/*_no.*
|
||||||
|
|
||||||
UCLINUX FOR RENESAS H8/300 (H8300)
|
UCLINUX FOR RENESAS H8/300 (H8300)
|
||||||
M: Yoshinori Sato <ysato@users.sourceforge.jp>
|
M: Yoshinori Sato <ysato@users.sourceforge.jp>
|
||||||
@ -6618,7 +6622,7 @@ F: fs/hostfs/
|
|||||||
F: fs/hppfs/
|
F: fs/hppfs/
|
||||||
|
|
||||||
USERSPACE I/O (UIO)
|
USERSPACE I/O (UIO)
|
||||||
M: "Hans J. Koch" <hjk@linutronix.de>
|
M: "Hans J. Koch" <hjk@hansjkoch.de>
|
||||||
M: Greg Kroah-Hartman <gregkh@suse.de>
|
M: Greg Kroah-Hartman <gregkh@suse.de>
|
||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/DocBook/uio-howto.tmpl
|
F: Documentation/DocBook/uio-howto.tmpl
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
VERSION = 2
|
VERSION = 2
|
||||||
PATCHLEVEL = 6
|
PATCHLEVEL = 6
|
||||||
SUBLEVEL = 39
|
SUBLEVEL = 39
|
||||||
EXTRAVERSION = -rc3
|
EXTRAVERSION = -rc4
|
||||||
NAME = Flesh-Eating Bats with Fangs
|
NAME = Flesh-Eating Bats with Fangs
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
extra-y := head.o vmlinux.lds
|
extra-y := head.o vmlinux.lds
|
||||||
asflags-y := $(KBUILD_CFLAGS)
|
asflags-y := $(KBUILD_CFLAGS)
|
||||||
ccflags-y := -Werror -Wno-sign-compare
|
ccflags-y := -Wno-sign-compare
|
||||||
|
|
||||||
obj-y := entry.o traps.o process.o init_task.o osf_sys.o irq.o \
|
obj-y := entry.o traps.o process.o init_task.o osf_sys.o irq.o \
|
||||||
irq_alpha.o signal.o setup.o ptrace.o time.o \
|
irq_alpha.o signal.o setup.o ptrace.o time.o \
|
||||||
|
@ -88,7 +88,7 @@ conf_read(unsigned long addr, unsigned char type1,
|
|||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
unsigned long mid = MCPCIA_HOSE2MID(hose->index);
|
unsigned long mid = MCPCIA_HOSE2MID(hose->index);
|
||||||
unsigned int stat0, value, temp, cpu;
|
unsigned int stat0, value, cpu;
|
||||||
|
|
||||||
cpu = smp_processor_id();
|
cpu = smp_processor_id();
|
||||||
|
|
||||||
@ -101,7 +101,7 @@ conf_read(unsigned long addr, unsigned char type1,
|
|||||||
stat0 = *(vuip)MCPCIA_CAP_ERR(mid);
|
stat0 = *(vuip)MCPCIA_CAP_ERR(mid);
|
||||||
*(vuip)MCPCIA_CAP_ERR(mid) = stat0;
|
*(vuip)MCPCIA_CAP_ERR(mid) = stat0;
|
||||||
mb();
|
mb();
|
||||||
temp = *(vuip)MCPCIA_CAP_ERR(mid);
|
*(vuip)MCPCIA_CAP_ERR(mid);
|
||||||
DBG_CFG(("conf_read: MCPCIA_CAP_ERR(%d) was 0x%x\n", mid, stat0));
|
DBG_CFG(("conf_read: MCPCIA_CAP_ERR(%d) was 0x%x\n", mid, stat0));
|
||||||
|
|
||||||
mb();
|
mb();
|
||||||
@ -136,7 +136,7 @@ conf_write(unsigned long addr, unsigned int value, unsigned char type1,
|
|||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
unsigned long mid = MCPCIA_HOSE2MID(hose->index);
|
unsigned long mid = MCPCIA_HOSE2MID(hose->index);
|
||||||
unsigned int stat0, temp, cpu;
|
unsigned int stat0, cpu;
|
||||||
|
|
||||||
cpu = smp_processor_id();
|
cpu = smp_processor_id();
|
||||||
|
|
||||||
@ -145,7 +145,7 @@ conf_write(unsigned long addr, unsigned int value, unsigned char type1,
|
|||||||
/* Reset status register to avoid losing errors. */
|
/* Reset status register to avoid losing errors. */
|
||||||
stat0 = *(vuip)MCPCIA_CAP_ERR(mid);
|
stat0 = *(vuip)MCPCIA_CAP_ERR(mid);
|
||||||
*(vuip)MCPCIA_CAP_ERR(mid) = stat0; mb();
|
*(vuip)MCPCIA_CAP_ERR(mid) = stat0; mb();
|
||||||
temp = *(vuip)MCPCIA_CAP_ERR(mid);
|
*(vuip)MCPCIA_CAP_ERR(mid);
|
||||||
DBG_CFG(("conf_write: MCPCIA CAP_ERR(%d) was 0x%x\n", mid, stat0));
|
DBG_CFG(("conf_write: MCPCIA CAP_ERR(%d) was 0x%x\n", mid, stat0));
|
||||||
|
|
||||||
draina();
|
draina();
|
||||||
@ -157,7 +157,7 @@ conf_write(unsigned long addr, unsigned int value, unsigned char type1,
|
|||||||
*((vuip)addr) = value;
|
*((vuip)addr) = value;
|
||||||
mb();
|
mb();
|
||||||
mb(); /* magic */
|
mb(); /* magic */
|
||||||
temp = *(vuip)MCPCIA_CAP_ERR(mid); /* read to force the write */
|
*(vuip)MCPCIA_CAP_ERR(mid); /* read to force the write */
|
||||||
mcheck_expected(cpu) = 0;
|
mcheck_expected(cpu) = 0;
|
||||||
mb();
|
mb();
|
||||||
|
|
||||||
@ -572,12 +572,10 @@ mcpcia_print_system_area(unsigned long la_ptr)
|
|||||||
void
|
void
|
||||||
mcpcia_machine_check(unsigned long vector, unsigned long la_ptr)
|
mcpcia_machine_check(unsigned long vector, unsigned long la_ptr)
|
||||||
{
|
{
|
||||||
struct el_common *mchk_header;
|
|
||||||
struct el_MCPCIA_uncorrected_frame_mcheck *mchk_logout;
|
struct el_MCPCIA_uncorrected_frame_mcheck *mchk_logout;
|
||||||
unsigned int cpu = smp_processor_id();
|
unsigned int cpu = smp_processor_id();
|
||||||
int expected;
|
int expected;
|
||||||
|
|
||||||
mchk_header = (struct el_common *)la_ptr;
|
|
||||||
mchk_logout = (struct el_MCPCIA_uncorrected_frame_mcheck *)la_ptr;
|
mchk_logout = (struct el_MCPCIA_uncorrected_frame_mcheck *)la_ptr;
|
||||||
expected = mcheck_expected(cpu);
|
expected = mcheck_expected(cpu);
|
||||||
|
|
||||||
|
@ -533,8 +533,6 @@ static struct el_subpacket_annotation el_titan_annotations[] = {
|
|||||||
static struct el_subpacket *
|
static struct el_subpacket *
|
||||||
el_process_regatta_subpacket(struct el_subpacket *header)
|
el_process_regatta_subpacket(struct el_subpacket *header)
|
||||||
{
|
{
|
||||||
int status;
|
|
||||||
|
|
||||||
if (header->class != EL_CLASS__REGATTA_FAMILY) {
|
if (header->class != EL_CLASS__REGATTA_FAMILY) {
|
||||||
printk("%s ** Unexpected header CLASS %d TYPE %d, aborting\n",
|
printk("%s ** Unexpected header CLASS %d TYPE %d, aborting\n",
|
||||||
err_print_prefix,
|
err_print_prefix,
|
||||||
@ -551,7 +549,7 @@ el_process_regatta_subpacket(struct el_subpacket *header)
|
|||||||
printk("%s ** Occurred on CPU %d:\n",
|
printk("%s ** Occurred on CPU %d:\n",
|
||||||
err_print_prefix,
|
err_print_prefix,
|
||||||
(int)header->by_type.regatta_frame.cpuid);
|
(int)header->by_type.regatta_frame.cpuid);
|
||||||
status = privateer_process_logout_frame((struct el_common *)
|
privateer_process_logout_frame((struct el_common *)
|
||||||
header->by_type.regatta_frame.data_start, 1);
|
header->by_type.regatta_frame.data_start, 1);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -228,7 +228,7 @@ struct irqaction timer_irqaction = {
|
|||||||
void __init
|
void __init
|
||||||
init_rtc_irq(void)
|
init_rtc_irq(void)
|
||||||
{
|
{
|
||||||
irq_set_chip_and_handler_name(RTC_IRQ, &no_irq_chip,
|
irq_set_chip_and_handler_name(RTC_IRQ, &dummy_irq_chip,
|
||||||
handle_simple_irq, "RTC");
|
handle_simple_irq, "RTC");
|
||||||
setup_irq(RTC_IRQ, &timer_irqaction);
|
setup_irq(RTC_IRQ, &timer_irqaction);
|
||||||
}
|
}
|
||||||
|
@ -1404,8 +1404,6 @@ determine_cpu_caches (unsigned int cpu_type)
|
|||||||
case PCA56_CPU:
|
case PCA56_CPU:
|
||||||
case PCA57_CPU:
|
case PCA57_CPU:
|
||||||
{
|
{
|
||||||
unsigned long cbox_config, size;
|
|
||||||
|
|
||||||
if (cpu_type == PCA56_CPU) {
|
if (cpu_type == PCA56_CPU) {
|
||||||
L1I = CSHAPE(16*1024, 6, 1);
|
L1I = CSHAPE(16*1024, 6, 1);
|
||||||
L1D = CSHAPE(8*1024, 5, 1);
|
L1D = CSHAPE(8*1024, 5, 1);
|
||||||
@ -1415,10 +1413,12 @@ determine_cpu_caches (unsigned int cpu_type)
|
|||||||
}
|
}
|
||||||
L3 = -1;
|
L3 = -1;
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
unsigned long cbox_config, size;
|
||||||
|
|
||||||
cbox_config = *(vulp) phys_to_virt (0xfffff00008UL);
|
cbox_config = *(vulp) phys_to_virt (0xfffff00008UL);
|
||||||
size = 512*1024 * (1 << ((cbox_config >> 12) & 3));
|
size = 512*1024 * (1 << ((cbox_config >> 12) & 3));
|
||||||
|
|
||||||
#if 0
|
|
||||||
L2 = ((cbox_config >> 31) & 1 ? CSHAPE (size, 6, 1) : -1);
|
L2 = ((cbox_config >> 31) & 1 ? CSHAPE (size, 6, 1) : -1);
|
||||||
#else
|
#else
|
||||||
L2 = external_cache_probe(512*1024, 6);
|
L2 = external_cache_probe(512*1024, 6);
|
||||||
|
@ -79,7 +79,6 @@
|
|||||||
static unsigned long __init SMCConfigState(unsigned long baseAddr)
|
static unsigned long __init SMCConfigState(unsigned long baseAddr)
|
||||||
{
|
{
|
||||||
unsigned char devId;
|
unsigned char devId;
|
||||||
unsigned char devRev;
|
|
||||||
|
|
||||||
unsigned long configPort;
|
unsigned long configPort;
|
||||||
unsigned long indexPort;
|
unsigned long indexPort;
|
||||||
@ -100,7 +99,7 @@ static unsigned long __init SMCConfigState(unsigned long baseAddr)
|
|||||||
devId = inb(dataPort);
|
devId = inb(dataPort);
|
||||||
if (devId == VALID_DEVICE_ID) {
|
if (devId == VALID_DEVICE_ID) {
|
||||||
outb(DEVICE_REV, indexPort);
|
outb(DEVICE_REV, indexPort);
|
||||||
devRev = inb(dataPort);
|
/* unsigned char devRev = */ inb(dataPort);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -156,7 +156,6 @@ static void __init
|
|||||||
wildfire_init_irq_per_pca(int qbbno, int pcano)
|
wildfire_init_irq_per_pca(int qbbno, int pcano)
|
||||||
{
|
{
|
||||||
int i, irq_bias;
|
int i, irq_bias;
|
||||||
unsigned long io_bias;
|
|
||||||
static struct irqaction isa_enable = {
|
static struct irqaction isa_enable = {
|
||||||
.handler = no_action,
|
.handler = no_action,
|
||||||
.name = "isa_enable",
|
.name = "isa_enable",
|
||||||
@ -165,10 +164,12 @@ wildfire_init_irq_per_pca(int qbbno, int pcano)
|
|||||||
irq_bias = qbbno * (WILDFIRE_PCA_PER_QBB * WILDFIRE_IRQ_PER_PCA)
|
irq_bias = qbbno * (WILDFIRE_PCA_PER_QBB * WILDFIRE_IRQ_PER_PCA)
|
||||||
+ pcano * WILDFIRE_IRQ_PER_PCA;
|
+ pcano * WILDFIRE_IRQ_PER_PCA;
|
||||||
|
|
||||||
|
#if 0
|
||||||
|
unsigned long io_bias;
|
||||||
|
|
||||||
/* Only need the following for first PCI bus per PCA. */
|
/* Only need the following for first PCI bus per PCA. */
|
||||||
io_bias = WILDFIRE_IO(qbbno, pcano<<1) - WILDFIRE_IO_BIAS;
|
io_bias = WILDFIRE_IO(qbbno, pcano<<1) - WILDFIRE_IO_BIAS;
|
||||||
|
|
||||||
#if 0
|
|
||||||
outb(0, DMA1_RESET_REG + io_bias);
|
outb(0, DMA1_RESET_REG + io_bias);
|
||||||
outb(0, DMA2_RESET_REG + io_bias);
|
outb(0, DMA2_RESET_REG + io_bias);
|
||||||
outb(DMA_MODE_CASCADE, DMA2_MODE_REG + io_bias);
|
outb(DMA_MODE_CASCADE, DMA2_MODE_REG + io_bias);
|
||||||
|
@ -153,6 +153,7 @@ void read_persistent_clock(struct timespec *ts)
|
|||||||
year += 100;
|
year += 100;
|
||||||
|
|
||||||
ts->tv_sec = mktime(year, mon, day, hour, min, sec);
|
ts->tv_sec = mktime(year, mon, day, hour, min, sec);
|
||||||
|
ts->tv_nsec = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -63,6 +63,7 @@ config MACH_DAVINCI_EVM
|
|||||||
depends on ARCH_DAVINCI_DM644x
|
depends on ARCH_DAVINCI_DM644x
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Configure this option to specify the whether the board used
|
Configure this option to specify the whether the board used
|
||||||
for development is a DM644x EVM
|
for development is a DM644x EVM
|
||||||
@ -72,6 +73,7 @@ config MACH_SFFSDR
|
|||||||
depends on ARCH_DAVINCI_DM644x
|
depends on ARCH_DAVINCI_DM644x
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Say Y here to select the Lyrtech Small Form Factor
|
Say Y here to select the Lyrtech Small Form Factor
|
||||||
Software Defined Radio (SFFSDR) board.
|
Software Defined Radio (SFFSDR) board.
|
||||||
@ -105,6 +107,7 @@ config MACH_DAVINCI_DM6467_EVM
|
|||||||
select MACH_DAVINCI_DM6467TEVM
|
select MACH_DAVINCI_DM6467TEVM
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Configure this option to specify the whether the board used
|
Configure this option to specify the whether the board used
|
||||||
for development is a DM6467 EVM
|
for development is a DM6467 EVM
|
||||||
@ -118,6 +121,7 @@ config MACH_DAVINCI_DM365_EVM
|
|||||||
depends on ARCH_DAVINCI_DM365
|
depends on ARCH_DAVINCI_DM365
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Configure this option to specify whether the board used
|
Configure this option to specify whether the board used
|
||||||
for development is a DM365 EVM
|
for development is a DM365 EVM
|
||||||
@ -129,6 +133,7 @@ config MACH_DAVINCI_DA830_EVM
|
|||||||
select GPIO_PCF857X
|
select GPIO_PCF857X
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Say Y here to select the TI DA830/OMAP-L137/AM17x Evaluation Module.
|
Say Y here to select the TI DA830/OMAP-L137/AM17x Evaluation Module.
|
||||||
|
|
||||||
@ -205,6 +210,7 @@ config MACH_MITYOMAPL138
|
|||||||
depends on ARCH_DAVINCI_DA850
|
depends on ARCH_DAVINCI_DA850
|
||||||
select MISC_DEVICES
|
select MISC_DEVICES
|
||||||
select EEPROM_AT24
|
select EEPROM_AT24
|
||||||
|
select I2C
|
||||||
help
|
help
|
||||||
Say Y here to select the Critical Link MityDSP-L138/MityARM-1808
|
Say Y here to select the Critical Link MityDSP-L138/MityARM-1808
|
||||||
System on Module. Information on this SoM may be found at
|
System on Module. Information on this SoM may be found at
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
#include <mach/mux.h>
|
#include <mach/mux.h>
|
||||||
#include <mach/spi.h>
|
#include <mach/spi.h>
|
||||||
|
|
||||||
#define MITYOMAPL138_PHY_ID "0:03"
|
#define MITYOMAPL138_PHY_ID ""
|
||||||
|
|
||||||
#define FACTORY_CONFIG_MAGIC 0x012C0138
|
#define FACTORY_CONFIG_MAGIC 0x012C0138
|
||||||
#define FACTORY_CONFIG_VERSION 0x00010001
|
#define FACTORY_CONFIG_VERSION 0x00010001
|
||||||
@ -414,7 +414,7 @@ static struct resource mityomapl138_nandflash_resource[] = {
|
|||||||
|
|
||||||
static struct platform_device mityomapl138_nandflash_device = {
|
static struct platform_device mityomapl138_nandflash_device = {
|
||||||
.name = "davinci_nand",
|
.name = "davinci_nand",
|
||||||
.id = 0,
|
.id = 1,
|
||||||
.dev = {
|
.dev = {
|
||||||
.platform_data = &mityomapl138_nandflash_data,
|
.platform_data = &mityomapl138_nandflash_data,
|
||||||
},
|
},
|
||||||
|
@ -39,7 +39,8 @@
|
|||||||
#define DA8XX_GPIO_BASE 0x01e26000
|
#define DA8XX_GPIO_BASE 0x01e26000
|
||||||
#define DA8XX_I2C1_BASE 0x01e28000
|
#define DA8XX_I2C1_BASE 0x01e28000
|
||||||
#define DA8XX_SPI0_BASE 0x01c41000
|
#define DA8XX_SPI0_BASE 0x01c41000
|
||||||
#define DA8XX_SPI1_BASE 0x01f0e000
|
#define DA830_SPI1_BASE 0x01e12000
|
||||||
|
#define DA850_SPI1_BASE 0x01f0e000
|
||||||
|
|
||||||
#define DA8XX_EMAC_CTRL_REG_OFFSET 0x3000
|
#define DA8XX_EMAC_CTRL_REG_OFFSET 0x3000
|
||||||
#define DA8XX_EMAC_MOD_REG_OFFSET 0x2000
|
#define DA8XX_EMAC_MOD_REG_OFFSET 0x2000
|
||||||
@ -762,8 +763,8 @@ static struct resource da8xx_spi0_resources[] = {
|
|||||||
|
|
||||||
static struct resource da8xx_spi1_resources[] = {
|
static struct resource da8xx_spi1_resources[] = {
|
||||||
[0] = {
|
[0] = {
|
||||||
.start = DA8XX_SPI1_BASE,
|
.start = DA830_SPI1_BASE,
|
||||||
.end = DA8XX_SPI1_BASE + SZ_4K - 1,
|
.end = DA830_SPI1_BASE + SZ_4K - 1,
|
||||||
.flags = IORESOURCE_MEM,
|
.flags = IORESOURCE_MEM,
|
||||||
},
|
},
|
||||||
[1] = {
|
[1] = {
|
||||||
@ -832,5 +833,10 @@ int __init da8xx_register_spi(int instance, struct spi_board_info *info,
|
|||||||
|
|
||||||
da8xx_spi_pdata[instance].num_chipselect = len;
|
da8xx_spi_pdata[instance].num_chipselect = len;
|
||||||
|
|
||||||
|
if (instance == 1 && cpu_is_davinci_da850()) {
|
||||||
|
da8xx_spi1_resources[0].start = DA850_SPI1_BASE;
|
||||||
|
da8xx_spi1_resources[0].end = DA850_SPI1_BASE + SZ_4K - 1;
|
||||||
|
}
|
||||||
|
|
||||||
return platform_device_register(&da8xx_spi_device[instance]);
|
return platform_device_register(&da8xx_spi_device[instance]);
|
||||||
}
|
}
|
||||||
|
@ -24,6 +24,9 @@
|
|||||||
|
|
||||||
#define UART_SHIFT 2
|
#define UART_SHIFT 2
|
||||||
|
|
||||||
|
#define davinci_uart_v2p(x) ((x) - PAGE_OFFSET + PLAT_PHYS_OFFSET)
|
||||||
|
#define davinci_uart_p2v(x) ((x) - PLAT_PHYS_OFFSET + PAGE_OFFSET)
|
||||||
|
|
||||||
.pushsection .data
|
.pushsection .data
|
||||||
davinci_uart_phys: .word 0
|
davinci_uart_phys: .word 0
|
||||||
davinci_uart_virt: .word 0
|
davinci_uart_virt: .word 0
|
||||||
@ -34,7 +37,7 @@ davinci_uart_virt: .word 0
|
|||||||
/* Use davinci_uart_phys/virt if already configured */
|
/* Use davinci_uart_phys/virt if already configured */
|
||||||
10: mrc p15, 0, \rp, c1, c0
|
10: mrc p15, 0, \rp, c1, c0
|
||||||
tst \rp, #1 @ MMU enabled?
|
tst \rp, #1 @ MMU enabled?
|
||||||
ldreq \rp, =__virt_to_phys(davinci_uart_phys)
|
ldreq \rp, =davinci_uart_v2p(davinci_uart_phys)
|
||||||
ldrne \rp, =davinci_uart_phys
|
ldrne \rp, =davinci_uart_phys
|
||||||
add \rv, \rp, #4 @ davinci_uart_virt
|
add \rv, \rp, #4 @ davinci_uart_virt
|
||||||
ldr \rp, [\rp, #0]
|
ldr \rp, [\rp, #0]
|
||||||
@ -48,18 +51,18 @@ davinci_uart_virt: .word 0
|
|||||||
tst \rp, #1 @ MMU enabled?
|
tst \rp, #1 @ MMU enabled?
|
||||||
|
|
||||||
/* Copy uart phys address from decompressor uart info */
|
/* Copy uart phys address from decompressor uart info */
|
||||||
ldreq \rv, =__virt_to_phys(davinci_uart_phys)
|
ldreq \rv, =davinci_uart_v2p(davinci_uart_phys)
|
||||||
ldrne \rv, =davinci_uart_phys
|
ldrne \rv, =davinci_uart_phys
|
||||||
ldreq \rp, =DAVINCI_UART_INFO
|
ldreq \rp, =DAVINCI_UART_INFO
|
||||||
ldrne \rp, =__phys_to_virt(DAVINCI_UART_INFO)
|
ldrne \rp, =davinci_uart_p2v(DAVINCI_UART_INFO)
|
||||||
ldr \rp, [\rp, #0]
|
ldr \rp, [\rp, #0]
|
||||||
str \rp, [\rv]
|
str \rp, [\rv]
|
||||||
|
|
||||||
/* Copy uart virt address from decompressor uart info */
|
/* Copy uart virt address from decompressor uart info */
|
||||||
ldreq \rv, =__virt_to_phys(davinci_uart_virt)
|
ldreq \rv, =davinci_uart_v2p(davinci_uart_virt)
|
||||||
ldrne \rv, =davinci_uart_virt
|
ldrne \rv, =davinci_uart_virt
|
||||||
ldreq \rp, =DAVINCI_UART_INFO
|
ldreq \rp, =DAVINCI_UART_INFO
|
||||||
ldrne \rp, =__phys_to_virt(DAVINCI_UART_INFO)
|
ldrne \rp, =davinci_uart_p2v(DAVINCI_UART_INFO)
|
||||||
ldr \rp, [\rp, #4]
|
ldr \rp, [\rp, #4]
|
||||||
str \rp, [\rv]
|
str \rp, [\rv]
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@
|
|||||||
*
|
*
|
||||||
* This area sits just below the page tables (see arch/arm/kernel/head.S).
|
* This area sits just below the page tables (see arch/arm/kernel/head.S).
|
||||||
*/
|
*/
|
||||||
#define DAVINCI_UART_INFO (PHYS_OFFSET + 0x3ff8)
|
#define DAVINCI_UART_INFO (PLAT_PHYS_OFFSET + 0x3ff8)
|
||||||
|
|
||||||
#define DAVINCI_UART0_BASE (IO_PHYS + 0x20000)
|
#define DAVINCI_UART0_BASE (IO_PHYS + 0x20000)
|
||||||
#define DAVINCI_UART1_BASE (IO_PHYS + 0x20400)
|
#define DAVINCI_UART1_BASE (IO_PHYS + 0x20400)
|
||||||
|
@ -160,10 +160,7 @@ static struct msm_mmc_platform_data qsd8x50_sdc1_data = {
|
|||||||
|
|
||||||
static void __init qsd8x50_init_mmc(void)
|
static void __init qsd8x50_init_mmc(void)
|
||||||
{
|
{
|
||||||
if (machine_is_qsd8x50_ffa() || machine_is_qsd8x50a_ffa())
|
vreg_mmc = vreg_get(NULL, "gp5");
|
||||||
vreg_mmc = vreg_get(NULL, "gp6");
|
|
||||||
else
|
|
||||||
vreg_mmc = vreg_get(NULL, "gp5");
|
|
||||||
|
|
||||||
if (IS_ERR(vreg_mmc)) {
|
if (IS_ERR(vreg_mmc)) {
|
||||||
pr_err("vreg get for vreg_mmc failed (%ld)\n",
|
pr_err("vreg get for vreg_mmc failed (%ld)\n",
|
||||||
|
@ -269,7 +269,7 @@ int __cpuinit local_timer_setup(struct clock_event_device *evt)
|
|||||||
|
|
||||||
/* Use existing clock_event for cpu 0 */
|
/* Use existing clock_event for cpu 0 */
|
||||||
if (!smp_processor_id())
|
if (!smp_processor_id())
|
||||||
return;
|
return 0;
|
||||||
|
|
||||||
writel(DGT_CLK_CTL_DIV_4, MSM_TMR_BASE + DGT_CLK_CTL);
|
writel(DGT_CLK_CTL_DIV_4, MSM_TMR_BASE + DGT_CLK_CTL);
|
||||||
|
|
||||||
|
@ -257,7 +257,8 @@ static void tegra_gpio_irq_handler(unsigned int irq, struct irq_desc *desc)
|
|||||||
void tegra_gpio_resume(void)
|
void tegra_gpio_resume(void)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int b, p, i;
|
int b;
|
||||||
|
int p;
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
|
|
||||||
@ -280,7 +281,8 @@ void tegra_gpio_resume(void)
|
|||||||
void tegra_gpio_suspend(void)
|
void tegra_gpio_suspend(void)
|
||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int b, p, i;
|
int b;
|
||||||
|
int p;
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
for (b = 0; b < ARRAY_SIZE(tegra_gpio_banks); b++) {
|
for (b = 0; b < ARRAY_SIZE(tegra_gpio_banks); b++) {
|
||||||
|
@ -1362,14 +1362,15 @@ static int tegra_clk_shared_bus_set_rate(struct clk *c, unsigned long rate)
|
|||||||
{
|
{
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int ret;
|
int ret;
|
||||||
|
long new_rate = rate;
|
||||||
|
|
||||||
rate = clk_round_rate(c->parent, rate);
|
new_rate = clk_round_rate(c->parent, new_rate);
|
||||||
if (rate < 0)
|
if (new_rate < 0)
|
||||||
return rate;
|
return new_rate;
|
||||||
|
|
||||||
spin_lock_irqsave(&c->parent->spinlock, flags);
|
spin_lock_irqsave(&c->parent->spinlock, flags);
|
||||||
|
|
||||||
c->u.shared_bus_user.rate = rate;
|
c->u.shared_bus_user.rate = new_rate;
|
||||||
ret = tegra_clk_shared_bus_update(c->parent);
|
ret = tegra_clk_shared_bus_update(c->parent);
|
||||||
|
|
||||||
spin_unlock_irqrestore(&c->parent->spinlock, flags);
|
spin_unlock_irqrestore(&c->parent->spinlock, flags);
|
||||||
|
@ -19,17 +19,6 @@
|
|||||||
|
|
||||||
#define PFX "s5p pm: "
|
#define PFX "s5p pm: "
|
||||||
|
|
||||||
/* s3c_pm_check_resume_pin
|
|
||||||
*
|
|
||||||
* check to see if the pin is configured correctly for sleep mode, and
|
|
||||||
* make any necessary adjustments if it is not
|
|
||||||
*/
|
|
||||||
|
|
||||||
static void s3c_pm_check_resume_pin(unsigned int pin, unsigned int irqoffs)
|
|
||||||
{
|
|
||||||
/* nothing here yet */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* s3c_pm_configure_extint
|
/* s3c_pm_configure_extint
|
||||||
*
|
*
|
||||||
* configure all external interrupt pins
|
* configure all external interrupt pins
|
||||||
|
@ -164,7 +164,6 @@ static inline int in_region(void *ptr, int size, void *what, size_t whatsz)
|
|||||||
*/
|
*/
|
||||||
static u32 *s3c_pm_runcheck(struct resource *res, u32 *val)
|
static u32 *s3c_pm_runcheck(struct resource *res, u32 *val)
|
||||||
{
|
{
|
||||||
void *save_at = phys_to_virt(s3c_sleep_save_phys);
|
|
||||||
unsigned long addr;
|
unsigned long addr;
|
||||||
unsigned long left;
|
unsigned long left;
|
||||||
void *stkpage;
|
void *stkpage;
|
||||||
@ -192,11 +191,6 @@ static u32 *s3c_pm_runcheck(struct resource *res, u32 *val)
|
|||||||
goto skip_check;
|
goto skip_check;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (in_region(ptr, left, save_at, 32*4 )) {
|
|
||||||
S3C_PMDBG("skipping %08lx, has save block in\n", addr);
|
|
||||||
goto skip_check;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* calculate and check the checksum */
|
/* calculate and check the checksum */
|
||||||
|
|
||||||
calc = crc32_le(~0, ptr, left);
|
calc = crc32_le(~0, ptr, left);
|
||||||
|
@ -214,8 +214,9 @@ void s3c_pm_do_restore_core(struct sleep_save *ptr, int count)
|
|||||||
*
|
*
|
||||||
* print any IRQs asserted at resume time (ie, we woke from)
|
* print any IRQs asserted at resume time (ie, we woke from)
|
||||||
*/
|
*/
|
||||||
static void s3c_pm_show_resume_irqs(int start, unsigned long which,
|
static void __maybe_unused s3c_pm_show_resume_irqs(int start,
|
||||||
unsigned long mask)
|
unsigned long which,
|
||||||
|
unsigned long mask)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -94,6 +94,13 @@ struct tag_ethernet {
|
|||||||
|
|
||||||
#define ETH_INVALID_PHY 0xff
|
#define ETH_INVALID_PHY 0xff
|
||||||
|
|
||||||
|
/* board information */
|
||||||
|
#define ATAG_BOARDINFO 0x54410008
|
||||||
|
|
||||||
|
struct tag_boardinfo {
|
||||||
|
u32 board_number;
|
||||||
|
};
|
||||||
|
|
||||||
struct tag {
|
struct tag {
|
||||||
struct tag_header hdr;
|
struct tag_header hdr;
|
||||||
union {
|
union {
|
||||||
@ -102,6 +109,7 @@ struct tag {
|
|||||||
struct tag_cmdline cmdline;
|
struct tag_cmdline cmdline;
|
||||||
struct tag_clock clock;
|
struct tag_clock clock;
|
||||||
struct tag_ethernet ethernet;
|
struct tag_ethernet ethernet;
|
||||||
|
struct tag_boardinfo boardinfo;
|
||||||
} u;
|
} u;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -128,6 +136,7 @@ extern struct tag *bootloader_tags;
|
|||||||
|
|
||||||
extern resource_size_t fbmem_start;
|
extern resource_size_t fbmem_start;
|
||||||
extern resource_size_t fbmem_size;
|
extern resource_size_t fbmem_size;
|
||||||
|
extern u32 board_number;
|
||||||
|
|
||||||
void setup_processor(void);
|
void setup_processor(void);
|
||||||
|
|
||||||
|
@ -390,6 +390,21 @@ static int __init parse_tag_clock(struct tag *tag)
|
|||||||
}
|
}
|
||||||
__tagtable(ATAG_CLOCK, parse_tag_clock);
|
__tagtable(ATAG_CLOCK, parse_tag_clock);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The board_number correspond to the bd->bi_board_number in U-Boot. This
|
||||||
|
* parameter is only available during initialisation and can be used in some
|
||||||
|
* kind of board identification.
|
||||||
|
*/
|
||||||
|
u32 __initdata board_number;
|
||||||
|
|
||||||
|
static int __init parse_tag_boardinfo(struct tag *tag)
|
||||||
|
{
|
||||||
|
board_number = tag->u.boardinfo.board_number;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
__tagtable(ATAG_BOARDINFO, parse_tag_boardinfo);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Scan the tag table for this tag, and call its parse function. The
|
* Scan the tag table for this tag, and call its parse function. The
|
||||||
* tag table is built by the linker from all the __tagtable
|
* tag table is built by the linker from all the __tagtable
|
||||||
|
@ -95,28 +95,6 @@ void _exception(long signr, struct pt_regs *regs, int code,
|
|||||||
info.si_code = code;
|
info.si_code = code;
|
||||||
info.si_addr = (void __user *)addr;
|
info.si_addr = (void __user *)addr;
|
||||||
force_sig_info(signr, &info, current);
|
force_sig_info(signr, &info, current);
|
||||||
|
|
||||||
/*
|
|
||||||
* Init gets no signals that it doesn't have a handler for.
|
|
||||||
* That's all very well, but if it has caused a synchronous
|
|
||||||
* exception and we ignore the resulting signal, it will just
|
|
||||||
* generate the same exception over and over again and we get
|
|
||||||
* nowhere. Better to kill it and let the kernel panic.
|
|
||||||
*/
|
|
||||||
if (is_global_init(current)) {
|
|
||||||
__sighandler_t handler;
|
|
||||||
|
|
||||||
spin_lock_irq(¤t->sighand->siglock);
|
|
||||||
handler = current->sighand->action[signr-1].sa.sa_handler;
|
|
||||||
spin_unlock_irq(¤t->sighand->siglock);
|
|
||||||
if (handler == SIG_DFL) {
|
|
||||||
/* init has generated a synchronous exception
|
|
||||||
and it doesn't have a handler for the signal */
|
|
||||||
printk(KERN_CRIT "init has generated signal %ld "
|
|
||||||
"but has no handler for it\n", signr);
|
|
||||||
do_exit(signr);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage void do_nmi(unsigned long ecr, struct pt_regs *regs)
|
asmlinkage void do_nmi(unsigned long ecr, struct pt_regs *regs)
|
||||||
|
@ -35,22 +35,30 @@ void at32_clk_register(struct clk *clk)
|
|||||||
spin_unlock(&clk_list_lock);
|
spin_unlock(&clk_list_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static struct clk *__clk_get(struct device *dev, const char *id)
|
||||||
|
{
|
||||||
|
struct clk *clk;
|
||||||
|
|
||||||
|
list_for_each_entry(clk, &at32_clock_list, list) {
|
||||||
|
if (clk->dev == dev && strcmp(id, clk->name) == 0) {
|
||||||
|
return clk;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ERR_PTR(-ENOENT);
|
||||||
|
}
|
||||||
|
|
||||||
struct clk *clk_get(struct device *dev, const char *id)
|
struct clk *clk_get(struct device *dev, const char *id)
|
||||||
{
|
{
|
||||||
struct clk *clk;
|
struct clk *clk;
|
||||||
|
|
||||||
spin_lock(&clk_list_lock);
|
spin_lock(&clk_list_lock);
|
||||||
|
clk = __clk_get(dev, id);
|
||||||
list_for_each_entry(clk, &at32_clock_list, list) {
|
|
||||||
if (clk->dev == dev && strcmp(id, clk->name) == 0) {
|
|
||||||
spin_unlock(&clk_list_lock);
|
|
||||||
return clk;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
spin_unlock(&clk_list_lock);
|
spin_unlock(&clk_list_lock);
|
||||||
return ERR_PTR(-ENOENT);
|
|
||||||
|
return clk;
|
||||||
}
|
}
|
||||||
|
|
||||||
EXPORT_SYMBOL(clk_get);
|
EXPORT_SYMBOL(clk_get);
|
||||||
|
|
||||||
void clk_put(struct clk *clk)
|
void clk_put(struct clk *clk)
|
||||||
@ -257,15 +265,15 @@ static int clk_show(struct seq_file *s, void *unused)
|
|||||||
spin_lock(&clk_list_lock);
|
spin_lock(&clk_list_lock);
|
||||||
|
|
||||||
/* show clock tree as derived from the three oscillators */
|
/* show clock tree as derived from the three oscillators */
|
||||||
clk = clk_get(NULL, "osc32k");
|
clk = __clk_get(NULL, "osc32k");
|
||||||
dump_clock(clk, &r);
|
dump_clock(clk, &r);
|
||||||
clk_put(clk);
|
clk_put(clk);
|
||||||
|
|
||||||
clk = clk_get(NULL, "osc0");
|
clk = __clk_get(NULL, "osc0");
|
||||||
dump_clock(clk, &r);
|
dump_clock(clk, &r);
|
||||||
clk_put(clk);
|
clk_put(clk);
|
||||||
|
|
||||||
clk = clk_get(NULL, "osc1");
|
clk = __clk_get(NULL, "osc1");
|
||||||
dump_clock(clk, &r);
|
dump_clock(clk, &r);
|
||||||
clk_put(clk);
|
clk_put(clk);
|
||||||
|
|
||||||
|
@ -61,34 +61,34 @@ struct eic {
|
|||||||
static struct eic *nmi_eic;
|
static struct eic *nmi_eic;
|
||||||
static bool nmi_enabled;
|
static bool nmi_enabled;
|
||||||
|
|
||||||
static void eic_ack_irq(struct irq_chip *d)
|
static void eic_ack_irq(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct eic *eic = irq_data_get_irq_chip_data(data);
|
struct eic *eic = irq_data_get_irq_chip_data(d);
|
||||||
eic_writel(eic, ICR, 1 << (d->irq - eic->first_irq));
|
eic_writel(eic, ICR, 1 << (d->irq - eic->first_irq));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void eic_mask_irq(struct irq_chip *d)
|
static void eic_mask_irq(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct eic *eic = irq_data_get_irq_chip_data(data);
|
struct eic *eic = irq_data_get_irq_chip_data(d);
|
||||||
eic_writel(eic, IDR, 1 << (d->irq - eic->first_irq));
|
eic_writel(eic, IDR, 1 << (d->irq - eic->first_irq));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void eic_mask_ack_irq(struct irq_chip *d)
|
static void eic_mask_ack_irq(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct eic *eic = irq_data_get_irq_chip_data(data);
|
struct eic *eic = irq_data_get_irq_chip_data(d);
|
||||||
eic_writel(eic, ICR, 1 << (d->irq - eic->first_irq));
|
eic_writel(eic, ICR, 1 << (d->irq - eic->first_irq));
|
||||||
eic_writel(eic, IDR, 1 << (d->irq - eic->first_irq));
|
eic_writel(eic, IDR, 1 << (d->irq - eic->first_irq));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void eic_unmask_irq(struct irq_chip *d)
|
static void eic_unmask_irq(struct irq_data *d)
|
||||||
{
|
{
|
||||||
struct eic *eic = irq_data_get_irq_chip_data(data);
|
struct eic *eic = irq_data_get_irq_chip_data(d);
|
||||||
eic_writel(eic, IER, 1 << (d->irq - eic->first_irq));
|
eic_writel(eic, IER, 1 << (d->irq - eic->first_irq));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int eic_set_irq_type(struct irq_chip *d, unsigned int flow_type)
|
static int eic_set_irq_type(struct irq_data *d, unsigned int flow_type)
|
||||||
{
|
{
|
||||||
struct eic *eic = irq_data_get_irq_chip_data(data);
|
struct eic *eic = irq_data_get_irq_chip_data(d);
|
||||||
unsigned int irq = d->irq;
|
unsigned int irq = d->irq;
|
||||||
unsigned int i = irq - eic->first_irq;
|
unsigned int i = irq - eic->first_irq;
|
||||||
u32 mode, edge, level;
|
u32 mode, edge, level;
|
||||||
@ -191,7 +191,7 @@ static int __init eic_probe(struct platform_device *pdev)
|
|||||||
|
|
||||||
regs = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
regs = platform_get_resource(pdev, IORESOURCE_MEM, 0);
|
||||||
int_irq = platform_get_irq(pdev, 0);
|
int_irq = platform_get_irq(pdev, 0);
|
||||||
if (!regs || !int_irq) {
|
if (!regs || (int)int_irq <= 0) {
|
||||||
dev_dbg(&pdev->dev, "missing regs and/or irq resource\n");
|
dev_dbg(&pdev->dev, "missing regs and/or irq resource\n");
|
||||||
return -ENXIO;
|
return -ENXIO;
|
||||||
}
|
}
|
||||||
|
@ -257,7 +257,7 @@ static void gpio_irq_mask(struct irq_data *d)
|
|||||||
pio_writel(pio, IDR, 1 << (gpio & 0x1f));
|
pio_writel(pio, IDR, 1 << (gpio & 0x1f));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void gpio_irq_unmask(struct irq_data *d))
|
static void gpio_irq_unmask(struct irq_data *d)
|
||||||
{
|
{
|
||||||
unsigned gpio = irq_to_gpio(d->irq);
|
unsigned gpio = irq_to_gpio(d->irq);
|
||||||
struct pio_device *pio = &pio_dev[gpio >> 5];
|
struct pio_device *pio = &pio_dev[gpio >> 5];
|
||||||
|
@ -53,7 +53,7 @@ cpu_enter_idle:
|
|||||||
st.w r8[TI_flags], r9
|
st.w r8[TI_flags], r9
|
||||||
unmask_interrupts
|
unmask_interrupts
|
||||||
sleep CPU_SLEEP_IDLE
|
sleep CPU_SLEEP_IDLE
|
||||||
.size cpu_idle_sleep, . - cpu_idle_sleep
|
.size cpu_enter_idle, . - cpu_enter_idle
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Common return path for PM functions that don't run from
|
* Common return path for PM functions that don't run from
|
||||||
|
@ -19,11 +19,11 @@
|
|||||||
* Force strict CPU ordering.
|
* Force strict CPU ordering.
|
||||||
*/
|
*/
|
||||||
#define nop() __asm__ __volatile__ ("nop;\n\t" : : )
|
#define nop() __asm__ __volatile__ ("nop;\n\t" : : )
|
||||||
#define mb() __asm__ __volatile__ ("" : : : "memory")
|
#define smp_mb() mb()
|
||||||
#define rmb() __asm__ __volatile__ ("" : : : "memory")
|
#define smp_rmb() rmb()
|
||||||
#define wmb() __asm__ __volatile__ ("" : : : "memory")
|
#define smp_wmb() wmb()
|
||||||
#define set_mb(var, value) do { (void) xchg(&var, value); } while (0)
|
#define set_mb(var, value) do { var = value; mb(); } while (0)
|
||||||
#define read_barrier_depends() do { } while(0)
|
#define smp_read_barrier_depends() read_barrier_depends()
|
||||||
|
|
||||||
#ifdef CONFIG_SMP
|
#ifdef CONFIG_SMP
|
||||||
asmlinkage unsigned long __raw_xchg_1_asm(volatile void *ptr, unsigned long value);
|
asmlinkage unsigned long __raw_xchg_1_asm(volatile void *ptr, unsigned long value);
|
||||||
@ -37,16 +37,16 @@ asmlinkage unsigned long __raw_cmpxchg_4_asm(volatile void *ptr,
|
|||||||
unsigned long new, unsigned long old);
|
unsigned long new, unsigned long old);
|
||||||
|
|
||||||
#ifdef __ARCH_SYNC_CORE_DCACHE
|
#ifdef __ARCH_SYNC_CORE_DCACHE
|
||||||
# define smp_mb() do { barrier(); smp_check_barrier(); smp_mark_barrier(); } while (0)
|
/* Force Core data cache coherence */
|
||||||
# define smp_rmb() do { barrier(); smp_check_barrier(); } while (0)
|
# define mb() do { barrier(); smp_check_barrier(); smp_mark_barrier(); } while (0)
|
||||||
# define smp_wmb() do { barrier(); smp_mark_barrier(); } while (0)
|
# define rmb() do { barrier(); smp_check_barrier(); } while (0)
|
||||||
#define smp_read_barrier_depends() do { barrier(); smp_check_barrier(); } while (0)
|
# define wmb() do { barrier(); smp_mark_barrier(); } while (0)
|
||||||
|
# define read_barrier_depends() do { barrier(); smp_check_barrier(); } while (0)
|
||||||
#else
|
#else
|
||||||
# define smp_mb() barrier()
|
# define mb() barrier()
|
||||||
# define smp_rmb() barrier()
|
# define rmb() barrier()
|
||||||
# define smp_wmb() barrier()
|
# define wmb() barrier()
|
||||||
#define smp_read_barrier_depends() barrier()
|
# define read_barrier_depends() do { } while (0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static inline unsigned long __xchg(unsigned long x, volatile void *ptr,
|
static inline unsigned long __xchg(unsigned long x, volatile void *ptr,
|
||||||
@ -99,10 +99,10 @@ static inline unsigned long __cmpxchg(volatile void *ptr, unsigned long old,
|
|||||||
|
|
||||||
#else /* !CONFIG_SMP */
|
#else /* !CONFIG_SMP */
|
||||||
|
|
||||||
#define smp_mb() barrier()
|
#define mb() barrier()
|
||||||
#define smp_rmb() barrier()
|
#define rmb() barrier()
|
||||||
#define smp_wmb() barrier()
|
#define wmb() barrier()
|
||||||
#define smp_read_barrier_depends() do { } while(0)
|
#define read_barrier_depends() do { } while (0)
|
||||||
|
|
||||||
struct __xchg_dummy {
|
struct __xchg_dummy {
|
||||||
unsigned long a[100];
|
unsigned long a[100];
|
||||||
|
@ -268,7 +268,7 @@ void disable_gptimers(uint16_t mask)
|
|||||||
_disable_gptimers(mask);
|
_disable_gptimers(mask);
|
||||||
for (i = 0; i < MAX_BLACKFIN_GPTIMERS; ++i)
|
for (i = 0; i < MAX_BLACKFIN_GPTIMERS; ++i)
|
||||||
if (mask & (1 << i))
|
if (mask & (1 << i))
|
||||||
group_regs[BFIN_TIMER_OCTET(i)]->status |= trun_mask[i];
|
group_regs[BFIN_TIMER_OCTET(i)]->status = trun_mask[i];
|
||||||
SSYNC();
|
SSYNC();
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(disable_gptimers);
|
EXPORT_SYMBOL(disable_gptimers);
|
||||||
|
@ -206,8 +206,14 @@ irqreturn_t bfin_gptmr0_interrupt(int irq, void *dev_id)
|
|||||||
{
|
{
|
||||||
struct clock_event_device *evt = dev_id;
|
struct clock_event_device *evt = dev_id;
|
||||||
smp_mb();
|
smp_mb();
|
||||||
evt->event_handler(evt);
|
/*
|
||||||
|
* We want to ACK before we handle so that we can handle smaller timer
|
||||||
|
* intervals. This way if the timer expires again while we're handling
|
||||||
|
* things, we're more likely to see that 2nd int rather than swallowing
|
||||||
|
* it by ACKing the int at the end of this handler.
|
||||||
|
*/
|
||||||
bfin_gptmr0_ack();
|
bfin_gptmr0_ack();
|
||||||
|
evt->event_handler(evt);
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,10 +109,23 @@ static void ipi_flush_icache(void *info)
|
|||||||
struct blackfin_flush_data *fdata = info;
|
struct blackfin_flush_data *fdata = info;
|
||||||
|
|
||||||
/* Invalidate the memory holding the bounds of the flushed region. */
|
/* Invalidate the memory holding the bounds of the flushed region. */
|
||||||
invalidate_dcache_range((unsigned long)fdata,
|
blackfin_dcache_invalidate_range((unsigned long)fdata,
|
||||||
(unsigned long)fdata + sizeof(*fdata));
|
(unsigned long)fdata + sizeof(*fdata));
|
||||||
|
|
||||||
flush_icache_range(fdata->start, fdata->end);
|
/* Make sure all write buffers in the data side of the core
|
||||||
|
* are flushed before trying to invalidate the icache. This
|
||||||
|
* needs to be after the data flush and before the icache
|
||||||
|
* flush so that the SSYNC does the right thing in preventing
|
||||||
|
* the instruction prefetcher from hitting things in cached
|
||||||
|
* memory at the wrong time -- it runs much further ahead than
|
||||||
|
* the pipeline.
|
||||||
|
*/
|
||||||
|
SSYNC();
|
||||||
|
|
||||||
|
/* ipi_flaush_icache is invoked by generic flush_icache_range,
|
||||||
|
* so call blackfin arch icache flush directly here.
|
||||||
|
*/
|
||||||
|
blackfin_icache_flush_range(fdata->start, fdata->end);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ipi_call_function(unsigned int cpu, struct ipi_message *msg)
|
static void ipi_call_function(unsigned int cpu, struct ipi_message *msg)
|
||||||
|
@ -343,10 +343,14 @@
|
|||||||
#define __NR_fanotify_init 337
|
#define __NR_fanotify_init 337
|
||||||
#define __NR_fanotify_mark 338
|
#define __NR_fanotify_mark 338
|
||||||
#define __NR_prlimit64 339
|
#define __NR_prlimit64 339
|
||||||
|
#define __NR_name_to_handle_at 340
|
||||||
|
#define __NR_open_by_handle_at 341
|
||||||
|
#define __NR_clock_adjtime 342
|
||||||
|
#define __NR_syncfs 343
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
#ifdef __KERNEL__
|
||||||
|
|
||||||
#define NR_syscalls 340
|
#define NR_syscalls 344
|
||||||
|
|
||||||
#define __ARCH_WANT_IPC_PARSE_VERSION
|
#define __ARCH_WANT_IPC_PARSE_VERSION
|
||||||
#define __ARCH_WANT_OLD_READDIR
|
#define __ARCH_WANT_OLD_READDIR
|
||||||
|
@ -750,4 +750,8 @@ sys_call_table:
|
|||||||
.long sys_fanotify_init
|
.long sys_fanotify_init
|
||||||
.long sys_fanotify_mark
|
.long sys_fanotify_mark
|
||||||
.long sys_prlimit64
|
.long sys_prlimit64
|
||||||
|
.long sys_name_to_handle_at /* 340 */
|
||||||
|
.long sys_open_by_handle_at
|
||||||
|
.long sys_clock_adjtime
|
||||||
|
.long sys_syncfs
|
||||||
|
|
||||||
|
@ -358,6 +358,10 @@ ENTRY(sys_call_table)
|
|||||||
.long sys_fanotify_init
|
.long sys_fanotify_init
|
||||||
.long sys_fanotify_mark
|
.long sys_fanotify_mark
|
||||||
.long sys_prlimit64
|
.long sys_prlimit64
|
||||||
|
.long sys_name_to_handle_at /* 340 */
|
||||||
|
.long sys_open_by_handle_at
|
||||||
|
.long sys_clock_adjtime
|
||||||
|
.long sys_syncfs
|
||||||
|
|
||||||
.rept NR_syscalls-(.-sys_call_table)/4
|
.rept NR_syscalls-(.-sys_call_table)/4
|
||||||
.long sys_ni_syscall
|
.long sys_ni_syscall
|
||||||
|
@ -6,7 +6,6 @@ config MICROBLAZE
|
|||||||
select HAVE_FUNCTION_GRAPH_TRACER
|
select HAVE_FUNCTION_GRAPH_TRACER
|
||||||
select HAVE_DYNAMIC_FTRACE
|
select HAVE_DYNAMIC_FTRACE
|
||||||
select HAVE_FTRACE_MCOUNT_RECORD
|
select HAVE_FTRACE_MCOUNT_RECORD
|
||||||
select USB_ARCH_HAS_EHCI
|
|
||||||
select ARCH_WANT_OPTIONAL_GPIOLIB
|
select ARCH_WANT_OPTIONAL_GPIOLIB
|
||||||
select HAVE_OPROFILE
|
select HAVE_OPROFILE
|
||||||
select HAVE_ARCH_KGDB
|
select HAVE_ARCH_KGDB
|
||||||
|
@ -209,7 +209,7 @@ config ARCH_HIBERNATION_POSSIBLE
|
|||||||
config ARCH_SUSPEND_POSSIBLE
|
config ARCH_SUSPEND_POSSIBLE
|
||||||
def_bool y
|
def_bool y
|
||||||
depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx || \
|
depends on ADB_PMU || PPC_EFIKA || PPC_LITE5200 || PPC_83xx || \
|
||||||
PPC_85xx || PPC_86xx || PPC_PSERIES || 44x || 40x
|
(PPC_85xx && !SMP) || PPC_86xx || PPC_PSERIES || 44x || 40x
|
||||||
|
|
||||||
config PPC_DCR_NATIVE
|
config PPC_DCR_NATIVE
|
||||||
bool
|
bool
|
||||||
|
@ -382,10 +382,12 @@ extern const char *powerpc_base_platform;
|
|||||||
#define CPU_FTRS_E500_2 (CPU_FTR_MAYBE_CAN_DOZE | CPU_FTR_USE_TB | \
|
#define CPU_FTRS_E500_2 (CPU_FTR_MAYBE_CAN_DOZE | CPU_FTR_USE_TB | \
|
||||||
CPU_FTR_SPE_COMP | CPU_FTR_MAYBE_CAN_NAP | \
|
CPU_FTR_SPE_COMP | CPU_FTR_MAYBE_CAN_NAP | \
|
||||||
CPU_FTR_NODSISRALIGN | CPU_FTR_NOEXECUTE)
|
CPU_FTR_NODSISRALIGN | CPU_FTR_NOEXECUTE)
|
||||||
#define CPU_FTRS_E500MC (CPU_FTR_MAYBE_CAN_DOZE | CPU_FTR_USE_TB | \
|
#define CPU_FTRS_E500MC (CPU_FTR_USE_TB | CPU_FTR_NODSISRALIGN | \
|
||||||
CPU_FTR_MAYBE_CAN_NAP | CPU_FTR_NODSISRALIGN | \
|
|
||||||
CPU_FTR_L2CSR | CPU_FTR_LWSYNC | CPU_FTR_NOEXECUTE | \
|
CPU_FTR_L2CSR | CPU_FTR_LWSYNC | CPU_FTR_NOEXECUTE | \
|
||||||
CPU_FTR_DBELL)
|
CPU_FTR_DBELL)
|
||||||
|
#define CPU_FTRS_E5500 (CPU_FTR_USE_TB | CPU_FTR_NODSISRALIGN | \
|
||||||
|
CPU_FTR_L2CSR | CPU_FTR_LWSYNC | CPU_FTR_NOEXECUTE | \
|
||||||
|
CPU_FTR_DBELL | CPU_FTR_POPCNTB | CPU_FTR_POPCNTD)
|
||||||
#define CPU_FTRS_GENERIC_32 (CPU_FTR_COMMON | CPU_FTR_NODSISRALIGN)
|
#define CPU_FTRS_GENERIC_32 (CPU_FTR_COMMON | CPU_FTR_NODSISRALIGN)
|
||||||
|
|
||||||
/* 64-bit CPUs */
|
/* 64-bit CPUs */
|
||||||
@ -435,11 +437,15 @@ extern const char *powerpc_base_platform;
|
|||||||
#define CPU_FTRS_COMPATIBLE (CPU_FTR_USE_TB | CPU_FTR_PPCAS_ARCH_V2)
|
#define CPU_FTRS_COMPATIBLE (CPU_FTR_USE_TB | CPU_FTR_PPCAS_ARCH_V2)
|
||||||
|
|
||||||
#ifdef __powerpc64__
|
#ifdef __powerpc64__
|
||||||
|
#ifdef CONFIG_PPC_BOOK3E
|
||||||
|
#define CPU_FTRS_POSSIBLE (CPU_FTRS_E5500)
|
||||||
|
#else
|
||||||
#define CPU_FTRS_POSSIBLE \
|
#define CPU_FTRS_POSSIBLE \
|
||||||
(CPU_FTRS_POWER3 | CPU_FTRS_RS64 | CPU_FTRS_POWER4 | \
|
(CPU_FTRS_POWER3 | CPU_FTRS_RS64 | CPU_FTRS_POWER4 | \
|
||||||
CPU_FTRS_PPC970 | CPU_FTRS_POWER5 | CPU_FTRS_POWER6 | \
|
CPU_FTRS_PPC970 | CPU_FTRS_POWER5 | CPU_FTRS_POWER6 | \
|
||||||
CPU_FTRS_POWER7 | CPU_FTRS_CELL | CPU_FTRS_PA6T | \
|
CPU_FTRS_POWER7 | CPU_FTRS_CELL | CPU_FTRS_PA6T | \
|
||||||
CPU_FTR_1T_SEGMENT | CPU_FTR_VSX)
|
CPU_FTR_1T_SEGMENT | CPU_FTR_VSX)
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
enum {
|
enum {
|
||||||
CPU_FTRS_POSSIBLE =
|
CPU_FTRS_POSSIBLE =
|
||||||
@ -473,16 +479,21 @@ enum {
|
|||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_E500
|
#ifdef CONFIG_E500
|
||||||
CPU_FTRS_E500 | CPU_FTRS_E500_2 | CPU_FTRS_E500MC |
|
CPU_FTRS_E500 | CPU_FTRS_E500_2 | CPU_FTRS_E500MC |
|
||||||
|
CPU_FTRS_E5500 |
|
||||||
#endif
|
#endif
|
||||||
0,
|
0,
|
||||||
};
|
};
|
||||||
#endif /* __powerpc64__ */
|
#endif /* __powerpc64__ */
|
||||||
|
|
||||||
#ifdef __powerpc64__
|
#ifdef __powerpc64__
|
||||||
|
#ifdef CONFIG_PPC_BOOK3E
|
||||||
|
#define CPU_FTRS_ALWAYS (CPU_FTRS_E5500)
|
||||||
|
#else
|
||||||
#define CPU_FTRS_ALWAYS \
|
#define CPU_FTRS_ALWAYS \
|
||||||
(CPU_FTRS_POWER3 & CPU_FTRS_RS64 & CPU_FTRS_POWER4 & \
|
(CPU_FTRS_POWER3 & CPU_FTRS_RS64 & CPU_FTRS_POWER4 & \
|
||||||
CPU_FTRS_PPC970 & CPU_FTRS_POWER5 & CPU_FTRS_POWER6 & \
|
CPU_FTRS_PPC970 & CPU_FTRS_POWER5 & CPU_FTRS_POWER6 & \
|
||||||
CPU_FTRS_POWER7 & CPU_FTRS_CELL & CPU_FTRS_PA6T & CPU_FTRS_POSSIBLE)
|
CPU_FTRS_POWER7 & CPU_FTRS_CELL & CPU_FTRS_PA6T & CPU_FTRS_POSSIBLE)
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
enum {
|
enum {
|
||||||
CPU_FTRS_ALWAYS =
|
CPU_FTRS_ALWAYS =
|
||||||
@ -513,6 +524,7 @@ enum {
|
|||||||
#endif
|
#endif
|
||||||
#ifdef CONFIG_E500
|
#ifdef CONFIG_E500
|
||||||
CPU_FTRS_E500 & CPU_FTRS_E500_2 & CPU_FTRS_E500MC &
|
CPU_FTRS_E500 & CPU_FTRS_E500_2 & CPU_FTRS_E500MC &
|
||||||
|
CPU_FTRS_E5500 &
|
||||||
#endif
|
#endif
|
||||||
CPU_FTRS_POSSIBLE,
|
CPU_FTRS_POSSIBLE,
|
||||||
};
|
};
|
||||||
|
@ -162,7 +162,7 @@ extern unsigned long bad_call_to_PMD_PAGE_SIZE(void);
|
|||||||
* on platforms where such control is possible.
|
* on platforms where such control is possible.
|
||||||
*/
|
*/
|
||||||
#if defined(CONFIG_KGDB) || defined(CONFIG_XMON) || defined(CONFIG_BDI_SWITCH) ||\
|
#if defined(CONFIG_KGDB) || defined(CONFIG_XMON) || defined(CONFIG_BDI_SWITCH) ||\
|
||||||
defined(CONFIG_KPROBES)
|
defined(CONFIG_KPROBES) || defined(CONFIG_DYNAMIC_FTRACE)
|
||||||
#define PAGE_KERNEL_TEXT PAGE_KERNEL_X
|
#define PAGE_KERNEL_TEXT PAGE_KERNEL_X
|
||||||
#else
|
#else
|
||||||
#define PAGE_KERNEL_TEXT PAGE_KERNEL_ROX
|
#define PAGE_KERNEL_TEXT PAGE_KERNEL_ROX
|
||||||
|
@ -1973,7 +1973,7 @@ static struct cpu_spec __initdata cpu_specs[] = {
|
|||||||
.pvr_mask = 0xffff0000,
|
.pvr_mask = 0xffff0000,
|
||||||
.pvr_value = 0x80240000,
|
.pvr_value = 0x80240000,
|
||||||
.cpu_name = "e5500",
|
.cpu_name = "e5500",
|
||||||
.cpu_features = CPU_FTRS_E500MC,
|
.cpu_features = CPU_FTRS_E5500,
|
||||||
.cpu_user_features = COMMON_USER_BOOKE,
|
.cpu_user_features = COMMON_USER_BOOKE,
|
||||||
.mmu_features = MMU_FTR_TYPE_FSL_E | MMU_FTR_BIG_PHYS |
|
.mmu_features = MMU_FTR_TYPE_FSL_E | MMU_FTR_BIG_PHYS |
|
||||||
MMU_FTR_USE_TLBILX,
|
MMU_FTR_USE_TLBILX,
|
||||||
|
@ -163,7 +163,7 @@ static void crash_kexec_prepare_cpus(int cpu)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* wait for all the CPUs to hit real mode but timeout if they don't come in */
|
/* wait for all the CPUs to hit real mode but timeout if they don't come in */
|
||||||
#if defined(CONFIG_PPC_STD_MMU_64) && defined(CONFIG_SMP)
|
#ifdef CONFIG_PPC_STD_MMU_64
|
||||||
static void crash_kexec_wait_realmode(int cpu)
|
static void crash_kexec_wait_realmode(int cpu)
|
||||||
{
|
{
|
||||||
unsigned int msecs;
|
unsigned int msecs;
|
||||||
@ -188,9 +188,7 @@ static void crash_kexec_wait_realmode(int cpu)
|
|||||||
}
|
}
|
||||||
mb();
|
mb();
|
||||||
}
|
}
|
||||||
#else
|
#endif /* CONFIG_PPC_STD_MMU_64 */
|
||||||
static inline void crash_kexec_wait_realmode(int cpu) {}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This function will be called by secondary cpus or by kexec cpu
|
* This function will be called by secondary cpus or by kexec cpu
|
||||||
@ -235,7 +233,9 @@ void crash_kexec_secondary(struct pt_regs *regs)
|
|||||||
crash_ipi_callback(regs);
|
crash_ipi_callback(regs);
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#else /* ! CONFIG_SMP */
|
||||||
|
static inline void crash_kexec_wait_realmode(int cpu) {}
|
||||||
|
|
||||||
static void crash_kexec_prepare_cpus(int cpu)
|
static void crash_kexec_prepare_cpus(int cpu)
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
@ -255,7 +255,7 @@ void crash_kexec_secondary(struct pt_regs *regs)
|
|||||||
{
|
{
|
||||||
cpus_in_sr = CPU_MASK_NONE;
|
cpus_in_sr = CPU_MASK_NONE;
|
||||||
}
|
}
|
||||||
#endif
|
#endif /* CONFIG_SMP */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Register a function to be called on shutdown. Only use this if you
|
* Register a function to be called on shutdown. Only use this if you
|
||||||
|
@ -527,7 +527,7 @@ static int ibmebus_bus_pm_resume_noirq(struct device *dev)
|
|||||||
|
|
||||||
#endif /* !CONFIG_SUSPEND */
|
#endif /* !CONFIG_SUSPEND */
|
||||||
|
|
||||||
#ifdef CONFIG_HIBERNATION
|
#ifdef CONFIG_HIBERNATE_CALLBACKS
|
||||||
|
|
||||||
static int ibmebus_bus_pm_freeze(struct device *dev)
|
static int ibmebus_bus_pm_freeze(struct device *dev)
|
||||||
{
|
{
|
||||||
@ -665,7 +665,7 @@ static int ibmebus_bus_pm_restore_noirq(struct device *dev)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else /* !CONFIG_HIBERNATION */
|
#else /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
#define ibmebus_bus_pm_freeze NULL
|
#define ibmebus_bus_pm_freeze NULL
|
||||||
#define ibmebus_bus_pm_thaw NULL
|
#define ibmebus_bus_pm_thaw NULL
|
||||||
@ -676,7 +676,7 @@ static int ibmebus_bus_pm_restore_noirq(struct device *dev)
|
|||||||
#define ibmebus_bus_pm_poweroff_noirq NULL
|
#define ibmebus_bus_pm_poweroff_noirq NULL
|
||||||
#define ibmebus_bus_pm_restore_noirq NULL
|
#define ibmebus_bus_pm_restore_noirq NULL
|
||||||
|
|
||||||
#endif /* !CONFIG_HIBERNATION */
|
#endif /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
static struct dev_pm_ops ibmebus_bus_dev_pm_ops = {
|
static struct dev_pm_ops ibmebus_bus_dev_pm_ops = {
|
||||||
.prepare = ibmebus_bus_pm_prepare,
|
.prepare = ibmebus_bus_pm_prepare,
|
||||||
|
@ -330,9 +330,11 @@ void __init find_legacy_serial_ports(void)
|
|||||||
if (!parent)
|
if (!parent)
|
||||||
continue;
|
continue;
|
||||||
if (of_match_node(legacy_serial_parents, parent) != NULL) {
|
if (of_match_node(legacy_serial_parents, parent) != NULL) {
|
||||||
index = add_legacy_soc_port(np, np);
|
if (of_device_is_available(np)) {
|
||||||
if (index >= 0 && np == stdout)
|
index = add_legacy_soc_port(np, np);
|
||||||
legacy_serial_console = index;
|
if (index >= 0 && np == stdout)
|
||||||
|
legacy_serial_console = index;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
of_node_put(parent);
|
of_node_put(parent);
|
||||||
}
|
}
|
||||||
|
@ -398,6 +398,25 @@ static int check_excludes(struct perf_event **ctrs, unsigned int cflags[],
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static u64 check_and_compute_delta(u64 prev, u64 val)
|
||||||
|
{
|
||||||
|
u64 delta = (val - prev) & 0xfffffffful;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* POWER7 can roll back counter values, if the new value is smaller
|
||||||
|
* than the previous value it will cause the delta and the counter to
|
||||||
|
* have bogus values unless we rolled a counter over. If a coutner is
|
||||||
|
* rolled back, it will be smaller, but within 256, which is the maximum
|
||||||
|
* number of events to rollback at once. If we dectect a rollback
|
||||||
|
* return 0. This can lead to a small lack of precision in the
|
||||||
|
* counters.
|
||||||
|
*/
|
||||||
|
if (prev > val && (prev - val) < 256)
|
||||||
|
delta = 0;
|
||||||
|
|
||||||
|
return delta;
|
||||||
|
}
|
||||||
|
|
||||||
static void power_pmu_read(struct perf_event *event)
|
static void power_pmu_read(struct perf_event *event)
|
||||||
{
|
{
|
||||||
s64 val, delta, prev;
|
s64 val, delta, prev;
|
||||||
@ -416,10 +435,11 @@ static void power_pmu_read(struct perf_event *event)
|
|||||||
prev = local64_read(&event->hw.prev_count);
|
prev = local64_read(&event->hw.prev_count);
|
||||||
barrier();
|
barrier();
|
||||||
val = read_pmc(event->hw.idx);
|
val = read_pmc(event->hw.idx);
|
||||||
|
delta = check_and_compute_delta(prev, val);
|
||||||
|
if (!delta)
|
||||||
|
return;
|
||||||
} while (local64_cmpxchg(&event->hw.prev_count, prev, val) != prev);
|
} while (local64_cmpxchg(&event->hw.prev_count, prev, val) != prev);
|
||||||
|
|
||||||
/* The counters are only 32 bits wide */
|
|
||||||
delta = (val - prev) & 0xfffffffful;
|
|
||||||
local64_add(delta, &event->count);
|
local64_add(delta, &event->count);
|
||||||
local64_sub(delta, &event->hw.period_left);
|
local64_sub(delta, &event->hw.period_left);
|
||||||
}
|
}
|
||||||
@ -449,8 +469,9 @@ static void freeze_limited_counters(struct cpu_hw_events *cpuhw,
|
|||||||
val = (event->hw.idx == 5) ? pmc5 : pmc6;
|
val = (event->hw.idx == 5) ? pmc5 : pmc6;
|
||||||
prev = local64_read(&event->hw.prev_count);
|
prev = local64_read(&event->hw.prev_count);
|
||||||
event->hw.idx = 0;
|
event->hw.idx = 0;
|
||||||
delta = (val - prev) & 0xfffffffful;
|
delta = check_and_compute_delta(prev, val);
|
||||||
local64_add(delta, &event->count);
|
if (delta)
|
||||||
|
local64_add(delta, &event->count);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -458,14 +479,16 @@ static void thaw_limited_counters(struct cpu_hw_events *cpuhw,
|
|||||||
unsigned long pmc5, unsigned long pmc6)
|
unsigned long pmc5, unsigned long pmc6)
|
||||||
{
|
{
|
||||||
struct perf_event *event;
|
struct perf_event *event;
|
||||||
u64 val;
|
u64 val, prev;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
for (i = 0; i < cpuhw->n_limited; ++i) {
|
for (i = 0; i < cpuhw->n_limited; ++i) {
|
||||||
event = cpuhw->limited_counter[i];
|
event = cpuhw->limited_counter[i];
|
||||||
event->hw.idx = cpuhw->limited_hwidx[i];
|
event->hw.idx = cpuhw->limited_hwidx[i];
|
||||||
val = (event->hw.idx == 5) ? pmc5 : pmc6;
|
val = (event->hw.idx == 5) ? pmc5 : pmc6;
|
||||||
local64_set(&event->hw.prev_count, val);
|
prev = local64_read(&event->hw.prev_count);
|
||||||
|
if (check_and_compute_delta(prev, val))
|
||||||
|
local64_set(&event->hw.prev_count, val);
|
||||||
perf_event_update_userpage(event);
|
perf_event_update_userpage(event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1197,7 +1220,7 @@ static void record_and_restart(struct perf_event *event, unsigned long val,
|
|||||||
|
|
||||||
/* we don't have to worry about interrupts here */
|
/* we don't have to worry about interrupts here */
|
||||||
prev = local64_read(&event->hw.prev_count);
|
prev = local64_read(&event->hw.prev_count);
|
||||||
delta = (val - prev) & 0xfffffffful;
|
delta = check_and_compute_delta(prev, val);
|
||||||
local64_add(delta, &event->count);
|
local64_add(delta, &event->count);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -229,6 +229,9 @@ static u64 scan_dispatch_log(u64 stop_tb)
|
|||||||
u64 stolen = 0;
|
u64 stolen = 0;
|
||||||
u64 dtb;
|
u64 dtb;
|
||||||
|
|
||||||
|
if (!dtl)
|
||||||
|
return 0;
|
||||||
|
|
||||||
if (i == vpa->dtl_idx)
|
if (i == vpa->dtl_idx)
|
||||||
return 0;
|
return 0;
|
||||||
while (i < vpa->dtl_idx) {
|
while (i < vpa->dtl_idx) {
|
||||||
|
@ -842,6 +842,7 @@ static void __devinit smp_core99_setup_cpu(int cpu_nr)
|
|||||||
mpic_setup_this_cpu();
|
mpic_setup_this_cpu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CONFIG_PPC64
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
static int smp_core99_cpu_notify(struct notifier_block *self,
|
static int smp_core99_cpu_notify(struct notifier_block *self,
|
||||||
unsigned long action, void *hcpu)
|
unsigned long action, void *hcpu)
|
||||||
@ -879,7 +880,6 @@ static struct notifier_block __cpuinitdata smp_core99_cpu_nb = {
|
|||||||
|
|
||||||
static void __init smp_core99_bringup_done(void)
|
static void __init smp_core99_bringup_done(void)
|
||||||
{
|
{
|
||||||
#ifdef CONFIG_PPC64
|
|
||||||
extern void g5_phy_disable_cpu1(void);
|
extern void g5_phy_disable_cpu1(void);
|
||||||
|
|
||||||
/* Close i2c bus if it was used for tb sync */
|
/* Close i2c bus if it was used for tb sync */
|
||||||
@ -894,14 +894,14 @@ static void __init smp_core99_bringup_done(void)
|
|||||||
set_cpu_present(1, false);
|
set_cpu_present(1, false);
|
||||||
g5_phy_disable_cpu1();
|
g5_phy_disable_cpu1();
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_PPC64 */
|
|
||||||
|
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
register_cpu_notifier(&smp_core99_cpu_nb);
|
register_cpu_notifier(&smp_core99_cpu_nb);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (ppc_md.progress)
|
if (ppc_md.progress)
|
||||||
ppc_md.progress("smp_core99_bringup_done", 0x349);
|
ppc_md.progress("smp_core99_bringup_done", 0x349);
|
||||||
}
|
}
|
||||||
|
#endif /* CONFIG_PPC64 */
|
||||||
|
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
|
|
||||||
@ -975,7 +975,9 @@ static void pmac_cpu_die(void)
|
|||||||
struct smp_ops_t core99_smp_ops = {
|
struct smp_ops_t core99_smp_ops = {
|
||||||
.message_pass = smp_mpic_message_pass,
|
.message_pass = smp_mpic_message_pass,
|
||||||
.probe = smp_core99_probe,
|
.probe = smp_core99_probe,
|
||||||
|
#ifdef CONFIG_PPC64
|
||||||
.bringup_done = smp_core99_bringup_done,
|
.bringup_done = smp_core99_bringup_done,
|
||||||
|
#endif
|
||||||
.kick_cpu = smp_core99_kick_cpu,
|
.kick_cpu = smp_core99_kick_cpu,
|
||||||
.setup_cpu = smp_core99_setup_cpu,
|
.setup_cpu = smp_core99_setup_cpu,
|
||||||
.give_timebase = smp_core99_give_timebase,
|
.give_timebase = smp_core99_give_timebase,
|
||||||
|
@ -287,14 +287,22 @@ static int alloc_dispatch_logs(void)
|
|||||||
int cpu, ret;
|
int cpu, ret;
|
||||||
struct paca_struct *pp;
|
struct paca_struct *pp;
|
||||||
struct dtl_entry *dtl;
|
struct dtl_entry *dtl;
|
||||||
|
struct kmem_cache *dtl_cache;
|
||||||
|
|
||||||
if (!firmware_has_feature(FW_FEATURE_SPLPAR))
|
if (!firmware_has_feature(FW_FEATURE_SPLPAR))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
dtl_cache = kmem_cache_create("dtl", DISPATCH_LOG_BYTES,
|
||||||
|
DISPATCH_LOG_BYTES, 0, NULL);
|
||||||
|
if (!dtl_cache) {
|
||||||
|
pr_warn("Failed to create dispatch trace log buffer cache\n");
|
||||||
|
pr_warn("Stolen time statistics will be unreliable\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
for_each_possible_cpu(cpu) {
|
for_each_possible_cpu(cpu) {
|
||||||
pp = &paca[cpu];
|
pp = &paca[cpu];
|
||||||
dtl = kmalloc_node(DISPATCH_LOG_BYTES, GFP_KERNEL,
|
dtl = kmem_cache_alloc(dtl_cache, GFP_KERNEL);
|
||||||
cpu_to_node(cpu));
|
|
||||||
if (!dtl) {
|
if (!dtl) {
|
||||||
pr_warn("Failed to allocate dispatch trace log for cpu %d\n",
|
pr_warn("Failed to allocate dispatch trace log for cpu %d\n",
|
||||||
cpu);
|
cpu);
|
||||||
|
@ -324,6 +324,11 @@ int __init fsl_add_bridge(struct device_node *dev, int is_primary)
|
|||||||
struct resource rsrc;
|
struct resource rsrc;
|
||||||
const int *bus_range;
|
const int *bus_range;
|
||||||
|
|
||||||
|
if (!of_device_is_available(dev)) {
|
||||||
|
pr_warning("%s: disabled\n", dev->full_name);
|
||||||
|
return -ENODEV;
|
||||||
|
}
|
||||||
|
|
||||||
pr_debug("Adding PCI host bridge %s\n", dev->full_name);
|
pr_debug("Adding PCI host bridge %s\n", dev->full_name);
|
||||||
|
|
||||||
/* Fetch host bridge registers address */
|
/* Fetch host bridge registers address */
|
||||||
|
@ -1457,7 +1457,6 @@ int fsl_rio_setup(struct platform_device *dev)
|
|||||||
port->ops = ops;
|
port->ops = ops;
|
||||||
port->priv = priv;
|
port->priv = priv;
|
||||||
port->phys_efptr = 0x100;
|
port->phys_efptr = 0x100;
|
||||||
rio_register_mport(port);
|
|
||||||
|
|
||||||
priv->regs_win = ioremap(regs.start, regs.end - regs.start + 1);
|
priv->regs_win = ioremap(regs.start, regs.end - regs.start + 1);
|
||||||
rio_regs_win = priv->regs_win;
|
rio_regs_win = priv->regs_win;
|
||||||
@ -1504,6 +1503,9 @@ int fsl_rio_setup(struct platform_device *dev)
|
|||||||
dev_info(&dev->dev, "RapidIO Common Transport System size: %d\n",
|
dev_info(&dev->dev, "RapidIO Common Transport System size: %d\n",
|
||||||
port->sys_size ? 65536 : 256);
|
port->sys_size ? 65536 : 256);
|
||||||
|
|
||||||
|
if (rio_register_mport(port))
|
||||||
|
goto err;
|
||||||
|
|
||||||
if (port->host_deviceid >= 0)
|
if (port->host_deviceid >= 0)
|
||||||
out_be32(priv->regs_win + RIO_GCCSR, RIO_PORT_GEN_HOST |
|
out_be32(priv->regs_win + RIO_GCCSR, RIO_PORT_GEN_HOST |
|
||||||
RIO_PORT_GEN_MASTER | RIO_PORT_GEN_DISCOVERED);
|
RIO_PORT_GEN_MASTER | RIO_PORT_GEN_DISCOVERED);
|
||||||
|
@ -4,6 +4,10 @@ menu "UML-specific options"
|
|||||||
|
|
||||||
menu "Host processor type and features"
|
menu "Host processor type and features"
|
||||||
|
|
||||||
|
config CMPXCHG_LOCAL
|
||||||
|
bool
|
||||||
|
default n
|
||||||
|
|
||||||
source "arch/x86/Kconfig.cpu"
|
source "arch/x86/Kconfig.cpu"
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
6
arch/um/include/asm/bug.h
Normal file
6
arch/um/include/asm/bug.h
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
#ifndef __UM_BUG_H
|
||||||
|
#define __UM_BUG_H
|
||||||
|
|
||||||
|
#include <asm-generic/bug.h>
|
||||||
|
|
||||||
|
#endif
|
@ -96,11 +96,15 @@
|
|||||||
#define MSR_IA32_MC0_ADDR 0x00000402
|
#define MSR_IA32_MC0_ADDR 0x00000402
|
||||||
#define MSR_IA32_MC0_MISC 0x00000403
|
#define MSR_IA32_MC0_MISC 0x00000403
|
||||||
|
|
||||||
|
#define MSR_AMD64_MC0_MASK 0xc0010044
|
||||||
|
|
||||||
#define MSR_IA32_MCx_CTL(x) (MSR_IA32_MC0_CTL + 4*(x))
|
#define MSR_IA32_MCx_CTL(x) (MSR_IA32_MC0_CTL + 4*(x))
|
||||||
#define MSR_IA32_MCx_STATUS(x) (MSR_IA32_MC0_STATUS + 4*(x))
|
#define MSR_IA32_MCx_STATUS(x) (MSR_IA32_MC0_STATUS + 4*(x))
|
||||||
#define MSR_IA32_MCx_ADDR(x) (MSR_IA32_MC0_ADDR + 4*(x))
|
#define MSR_IA32_MCx_ADDR(x) (MSR_IA32_MC0_ADDR + 4*(x))
|
||||||
#define MSR_IA32_MCx_MISC(x) (MSR_IA32_MC0_MISC + 4*(x))
|
#define MSR_IA32_MCx_MISC(x) (MSR_IA32_MC0_MISC + 4*(x))
|
||||||
|
|
||||||
|
#define MSR_AMD64_MCx_MASK(x) (MSR_AMD64_MC0_MASK + (x))
|
||||||
|
|
||||||
/* These are consecutive and not in the normal 4er MCE bank block */
|
/* These are consecutive and not in the normal 4er MCE bank block */
|
||||||
#define MSR_IA32_MC0_CTL2 0x00000280
|
#define MSR_IA32_MC0_CTL2 0x00000280
|
||||||
#define MSR_IA32_MCx_CTL2(x) (MSR_IA32_MC0_CTL2 + (x))
|
#define MSR_IA32_MCx_CTL2(x) (MSR_IA32_MC0_CTL2 + (x))
|
||||||
|
@ -615,6 +615,25 @@ static void __cpuinit init_amd(struct cpuinfo_x86 *c)
|
|||||||
/* As a rule processors have APIC timer running in deep C states */
|
/* As a rule processors have APIC timer running in deep C states */
|
||||||
if (c->x86 >= 0xf && !cpu_has_amd_erratum(amd_erratum_400))
|
if (c->x86 >= 0xf && !cpu_has_amd_erratum(amd_erratum_400))
|
||||||
set_cpu_cap(c, X86_FEATURE_ARAT);
|
set_cpu_cap(c, X86_FEATURE_ARAT);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Disable GART TLB Walk Errors on Fam10h. We do this here
|
||||||
|
* because this is always needed when GART is enabled, even in a
|
||||||
|
* kernel which has no MCE support built in.
|
||||||
|
*/
|
||||||
|
if (c->x86 == 0x10) {
|
||||||
|
/*
|
||||||
|
* BIOS should disable GartTlbWlk Errors themself. If
|
||||||
|
* it doesn't do it here as suggested by the BKDG.
|
||||||
|
*
|
||||||
|
* Fixes: https://bugzilla.kernel.org/show_bug.cgi?id=33012
|
||||||
|
*/
|
||||||
|
u64 mask;
|
||||||
|
|
||||||
|
rdmsrl(MSR_AMD64_MCx_MASK(4), mask);
|
||||||
|
mask |= (1 << 10);
|
||||||
|
wrmsrl(MSR_AMD64_MCx_MASK(4), mask);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
|
@ -312,6 +312,26 @@ void __cpuinit smp_store_cpu_info(int id)
|
|||||||
identify_secondary_cpu(c);
|
identify_secondary_cpu(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void __cpuinit check_cpu_siblings_on_same_node(int cpu1, int cpu2)
|
||||||
|
{
|
||||||
|
int node1 = early_cpu_to_node(cpu1);
|
||||||
|
int node2 = early_cpu_to_node(cpu2);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Our CPU scheduler assumes all logical cpus in the same physical cpu
|
||||||
|
* share the same node. But, buggy ACPI or NUMA emulation might assign
|
||||||
|
* them to different node. Fix it.
|
||||||
|
*/
|
||||||
|
if (node1 != node2) {
|
||||||
|
pr_warning("CPU %d in node %d and CPU %d in node %d are in the same physical CPU. forcing same node %d\n",
|
||||||
|
cpu1, node1, cpu2, node2, node2);
|
||||||
|
|
||||||
|
numa_remove_cpu(cpu1);
|
||||||
|
numa_set_node(cpu1, node2);
|
||||||
|
numa_add_cpu(cpu1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void __cpuinit link_thread_siblings(int cpu1, int cpu2)
|
static void __cpuinit link_thread_siblings(int cpu1, int cpu2)
|
||||||
{
|
{
|
||||||
cpumask_set_cpu(cpu1, cpu_sibling_mask(cpu2));
|
cpumask_set_cpu(cpu1, cpu_sibling_mask(cpu2));
|
||||||
@ -320,6 +340,7 @@ static void __cpuinit link_thread_siblings(int cpu1, int cpu2)
|
|||||||
cpumask_set_cpu(cpu2, cpu_core_mask(cpu1));
|
cpumask_set_cpu(cpu2, cpu_core_mask(cpu1));
|
||||||
cpumask_set_cpu(cpu1, cpu_llc_shared_mask(cpu2));
|
cpumask_set_cpu(cpu1, cpu_llc_shared_mask(cpu2));
|
||||||
cpumask_set_cpu(cpu2, cpu_llc_shared_mask(cpu1));
|
cpumask_set_cpu(cpu2, cpu_llc_shared_mask(cpu1));
|
||||||
|
check_cpu_siblings_on_same_node(cpu1, cpu2);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -361,10 +382,12 @@ void __cpuinit set_cpu_sibling_map(int cpu)
|
|||||||
per_cpu(cpu_llc_id, cpu) == per_cpu(cpu_llc_id, i)) {
|
per_cpu(cpu_llc_id, cpu) == per_cpu(cpu_llc_id, i)) {
|
||||||
cpumask_set_cpu(i, cpu_llc_shared_mask(cpu));
|
cpumask_set_cpu(i, cpu_llc_shared_mask(cpu));
|
||||||
cpumask_set_cpu(cpu, cpu_llc_shared_mask(i));
|
cpumask_set_cpu(cpu, cpu_llc_shared_mask(i));
|
||||||
|
check_cpu_siblings_on_same_node(cpu, i);
|
||||||
}
|
}
|
||||||
if (c->phys_proc_id == cpu_data(i).phys_proc_id) {
|
if (c->phys_proc_id == cpu_data(i).phys_proc_id) {
|
||||||
cpumask_set_cpu(i, cpu_core_mask(cpu));
|
cpumask_set_cpu(i, cpu_core_mask(cpu));
|
||||||
cpumask_set_cpu(cpu, cpu_core_mask(i));
|
cpumask_set_cpu(cpu, cpu_core_mask(i));
|
||||||
|
check_cpu_siblings_on_same_node(cpu, i);
|
||||||
/*
|
/*
|
||||||
* Does this new cpu bringup a new core?
|
* Does this new cpu bringup a new core?
|
||||||
*/
|
*/
|
||||||
|
@ -74,6 +74,7 @@
|
|||||||
compatible = "intel,ce4100-pci", "pci";
|
compatible = "intel,ce4100-pci", "pci";
|
||||||
device_type = "pci";
|
device_type = "pci";
|
||||||
bus-range = <1 1>;
|
bus-range = <1 1>;
|
||||||
|
reg = <0x0800 0x0 0x0 0x0 0x0>;
|
||||||
ranges = <0x2000000 0 0xdffe0000 0x2000000 0 0xdffe0000 0 0x1000>;
|
ranges = <0x2000000 0 0xdffe0000 0x2000000 0 0xdffe0000 0 0x1000>;
|
||||||
|
|
||||||
interrupt-parent = <&ioapic2>;
|
interrupt-parent = <&ioapic2>;
|
||||||
@ -412,6 +413,7 @@
|
|||||||
#address-cells = <2>;
|
#address-cells = <2>;
|
||||||
#size-cells = <1>;
|
#size-cells = <1>;
|
||||||
compatible = "isa";
|
compatible = "isa";
|
||||||
|
reg = <0xf800 0x0 0x0 0x0 0x0>;
|
||||||
ranges = <1 0 0 0 0 0x100>;
|
ranges = <1 0 0 0 0 0x100>;
|
||||||
|
|
||||||
rtc@70 {
|
rtc@70 {
|
||||||
|
@ -97,11 +97,11 @@ static int __init sfi_parse_mtmr(struct sfi_table_header *table)
|
|||||||
pentry->freq_hz, pentry->irq);
|
pentry->freq_hz, pentry->irq);
|
||||||
if (!pentry->irq)
|
if (!pentry->irq)
|
||||||
continue;
|
continue;
|
||||||
mp_irq.type = MP_IOAPIC;
|
mp_irq.type = MP_INTSRC;
|
||||||
mp_irq.irqtype = mp_INT;
|
mp_irq.irqtype = mp_INT;
|
||||||
/* triggering mode edge bit 2-3, active high polarity bit 0-1 */
|
/* triggering mode edge bit 2-3, active high polarity bit 0-1 */
|
||||||
mp_irq.irqflag = 5;
|
mp_irq.irqflag = 5;
|
||||||
mp_irq.srcbus = 0;
|
mp_irq.srcbus = MP_BUS_ISA;
|
||||||
mp_irq.srcbusirq = pentry->irq; /* IRQ */
|
mp_irq.srcbusirq = pentry->irq; /* IRQ */
|
||||||
mp_irq.dstapic = MP_APIC_ALL;
|
mp_irq.dstapic = MP_APIC_ALL;
|
||||||
mp_irq.dstirq = pentry->irq;
|
mp_irq.dstirq = pentry->irq;
|
||||||
@ -168,10 +168,10 @@ int __init sfi_parse_mrtc(struct sfi_table_header *table)
|
|||||||
for (totallen = 0; totallen < sfi_mrtc_num; totallen++, pentry++) {
|
for (totallen = 0; totallen < sfi_mrtc_num; totallen++, pentry++) {
|
||||||
pr_debug("RTC[%d]: paddr = 0x%08x, irq = %d\n",
|
pr_debug("RTC[%d]: paddr = 0x%08x, irq = %d\n",
|
||||||
totallen, (u32)pentry->phys_addr, pentry->irq);
|
totallen, (u32)pentry->phys_addr, pentry->irq);
|
||||||
mp_irq.type = MP_IOAPIC;
|
mp_irq.type = MP_INTSRC;
|
||||||
mp_irq.irqtype = mp_INT;
|
mp_irq.irqtype = mp_INT;
|
||||||
mp_irq.irqflag = 0xf; /* level trigger and active low */
|
mp_irq.irqflag = 0xf; /* level trigger and active low */
|
||||||
mp_irq.srcbus = 0;
|
mp_irq.srcbus = MP_BUS_ISA;
|
||||||
mp_irq.srcbusirq = pentry->irq; /* IRQ */
|
mp_irq.srcbusirq = pentry->irq; /* IRQ */
|
||||||
mp_irq.dstapic = MP_APIC_ALL;
|
mp_irq.dstapic = MP_APIC_ALL;
|
||||||
mp_irq.dstirq = pentry->irq;
|
mp_irq.dstirq = pentry->irq;
|
||||||
@ -282,7 +282,7 @@ void __init x86_mrst_early_setup(void)
|
|||||||
/* Avoid searching for BIOS MP tables */
|
/* Avoid searching for BIOS MP tables */
|
||||||
x86_init.mpparse.find_smp_config = x86_init_noop;
|
x86_init.mpparse.find_smp_config = x86_init_noop;
|
||||||
x86_init.mpparse.get_smp_config = x86_init_uint_noop;
|
x86_init.mpparse.get_smp_config = x86_init_uint_noop;
|
||||||
|
set_bit(MP_BUS_ISA, mp_bus_not_pci);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -39,6 +39,7 @@ config XEN_MAX_DOMAIN_MEMORY
|
|||||||
config XEN_SAVE_RESTORE
|
config XEN_SAVE_RESTORE
|
||||||
bool
|
bool
|
||||||
depends on XEN
|
depends on XEN
|
||||||
|
select HIBERNATE_CALLBACKS
|
||||||
default y
|
default y
|
||||||
|
|
||||||
config XEN_DEBUG_FS
|
config XEN_DEBUG_FS
|
||||||
|
@ -238,6 +238,7 @@ static void xen_cpuid(unsigned int *ax, unsigned int *bx,
|
|||||||
static __init void xen_init_cpuid_mask(void)
|
static __init void xen_init_cpuid_mask(void)
|
||||||
{
|
{
|
||||||
unsigned int ax, bx, cx, dx;
|
unsigned int ax, bx, cx, dx;
|
||||||
|
unsigned int xsave_mask;
|
||||||
|
|
||||||
cpuid_leaf1_edx_mask =
|
cpuid_leaf1_edx_mask =
|
||||||
~((1 << X86_FEATURE_MCE) | /* disable MCE */
|
~((1 << X86_FEATURE_MCE) | /* disable MCE */
|
||||||
@ -249,24 +250,16 @@ static __init void xen_init_cpuid_mask(void)
|
|||||||
cpuid_leaf1_edx_mask &=
|
cpuid_leaf1_edx_mask &=
|
||||||
~((1 << X86_FEATURE_APIC) | /* disable local APIC */
|
~((1 << X86_FEATURE_APIC) | /* disable local APIC */
|
||||||
(1 << X86_FEATURE_ACPI)); /* disable ACPI */
|
(1 << X86_FEATURE_ACPI)); /* disable ACPI */
|
||||||
|
|
||||||
ax = 1;
|
ax = 1;
|
||||||
cx = 0;
|
|
||||||
xen_cpuid(&ax, &bx, &cx, &dx);
|
xen_cpuid(&ax, &bx, &cx, &dx);
|
||||||
|
|
||||||
/* cpuid claims we support xsave; try enabling it to see what happens */
|
xsave_mask =
|
||||||
if (cx & (1 << (X86_FEATURE_XSAVE % 32))) {
|
(1 << (X86_FEATURE_XSAVE % 32)) |
|
||||||
unsigned long cr4;
|
(1 << (X86_FEATURE_OSXSAVE % 32));
|
||||||
|
|
||||||
set_in_cr4(X86_CR4_OSXSAVE);
|
/* Xen will set CR4.OSXSAVE if supported and not disabled by force */
|
||||||
|
if ((cx & xsave_mask) != xsave_mask)
|
||||||
cr4 = read_cr4();
|
cpuid_leaf1_ecx_mask &= ~xsave_mask; /* disable XSAVE & OSXSAVE */
|
||||||
|
|
||||||
if ((cr4 & X86_CR4_OSXSAVE) == 0)
|
|
||||||
cpuid_leaf1_ecx_mask &= ~(1 << (X86_FEATURE_XSAVE % 32));
|
|
||||||
|
|
||||||
clear_in_cr4(X86_CR4_OSXSAVE);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xen_set_debugreg(int reg, unsigned long val)
|
static void xen_set_debugreg(int reg, unsigned long val)
|
||||||
|
@ -565,13 +565,13 @@ pte_t xen_make_pte_debug(pteval_t pte)
|
|||||||
if (io_page &&
|
if (io_page &&
|
||||||
(xen_initial_domain() || addr >= ISA_END_ADDRESS)) {
|
(xen_initial_domain() || addr >= ISA_END_ADDRESS)) {
|
||||||
other_addr = pfn_to_mfn(addr >> PAGE_SHIFT) << PAGE_SHIFT;
|
other_addr = pfn_to_mfn(addr >> PAGE_SHIFT) << PAGE_SHIFT;
|
||||||
WARN(addr != other_addr,
|
WARN_ONCE(addr != other_addr,
|
||||||
"0x%lx is using VM_IO, but it is 0x%lx!\n",
|
"0x%lx is using VM_IO, but it is 0x%lx!\n",
|
||||||
(unsigned long)addr, (unsigned long)other_addr);
|
(unsigned long)addr, (unsigned long)other_addr);
|
||||||
} else {
|
} else {
|
||||||
pteval_t iomap_set = (_pte.pte & PTE_FLAGS_MASK) & _PAGE_IOMAP;
|
pteval_t iomap_set = (_pte.pte & PTE_FLAGS_MASK) & _PAGE_IOMAP;
|
||||||
other_addr = (_pte.pte & PTE_PFN_MASK);
|
other_addr = (_pte.pte & PTE_PFN_MASK);
|
||||||
WARN((addr == other_addr) && (!io_page) && (!iomap_set),
|
WARN_ONCE((addr == other_addr) && (!io_page) && (!iomap_set),
|
||||||
"0x%lx is missing VM_IO (and wasn't fixed)!\n",
|
"0x%lx is missing VM_IO (and wasn't fixed)!\n",
|
||||||
(unsigned long)addr);
|
(unsigned long)addr);
|
||||||
}
|
}
|
||||||
|
169
block/blk-core.c
169
block/blk-core.c
@ -198,26 +198,13 @@ void blk_dump_rq_flags(struct request *rq, char *msg)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_dump_rq_flags);
|
EXPORT_SYMBOL(blk_dump_rq_flags);
|
||||||
|
|
||||||
/*
|
|
||||||
* Make sure that plugs that were pending when this function was entered,
|
|
||||||
* are now complete and requests pushed to the queue.
|
|
||||||
*/
|
|
||||||
static inline void queue_sync_plugs(struct request_queue *q)
|
|
||||||
{
|
|
||||||
/*
|
|
||||||
* If the current process is plugged and has barriers submitted,
|
|
||||||
* we will livelock if we don't unplug first.
|
|
||||||
*/
|
|
||||||
blk_flush_plug(current);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void blk_delay_work(struct work_struct *work)
|
static void blk_delay_work(struct work_struct *work)
|
||||||
{
|
{
|
||||||
struct request_queue *q;
|
struct request_queue *q;
|
||||||
|
|
||||||
q = container_of(work, struct request_queue, delay_work.work);
|
q = container_of(work, struct request_queue, delay_work.work);
|
||||||
spin_lock_irq(q->queue_lock);
|
spin_lock_irq(q->queue_lock);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
spin_unlock_irq(q->queue_lock);
|
spin_unlock_irq(q->queue_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -233,7 +220,8 @@ static void blk_delay_work(struct work_struct *work)
|
|||||||
*/
|
*/
|
||||||
void blk_delay_queue(struct request_queue *q, unsigned long msecs)
|
void blk_delay_queue(struct request_queue *q, unsigned long msecs)
|
||||||
{
|
{
|
||||||
schedule_delayed_work(&q->delay_work, msecs_to_jiffies(msecs));
|
queue_delayed_work(kblockd_workqueue, &q->delay_work,
|
||||||
|
msecs_to_jiffies(msecs));
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_delay_queue);
|
EXPORT_SYMBOL(blk_delay_queue);
|
||||||
|
|
||||||
@ -251,7 +239,7 @@ void blk_start_queue(struct request_queue *q)
|
|||||||
WARN_ON(!irqs_disabled());
|
WARN_ON(!irqs_disabled());
|
||||||
|
|
||||||
queue_flag_clear(QUEUE_FLAG_STOPPED, q);
|
queue_flag_clear(QUEUE_FLAG_STOPPED, q);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_start_queue);
|
EXPORT_SYMBOL(blk_start_queue);
|
||||||
|
|
||||||
@ -298,7 +286,6 @@ void blk_sync_queue(struct request_queue *q)
|
|||||||
{
|
{
|
||||||
del_timer_sync(&q->timeout);
|
del_timer_sync(&q->timeout);
|
||||||
cancel_delayed_work_sync(&q->delay_work);
|
cancel_delayed_work_sync(&q->delay_work);
|
||||||
queue_sync_plugs(q);
|
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_sync_queue);
|
EXPORT_SYMBOL(blk_sync_queue);
|
||||||
|
|
||||||
@ -310,9 +297,8 @@ EXPORT_SYMBOL(blk_sync_queue);
|
|||||||
* Description:
|
* Description:
|
||||||
* See @blk_run_queue. This variant must be called with the queue lock
|
* See @blk_run_queue. This variant must be called with the queue lock
|
||||||
* held and interrupts disabled.
|
* held and interrupts disabled.
|
||||||
*
|
|
||||||
*/
|
*/
|
||||||
void __blk_run_queue(struct request_queue *q, bool force_kblockd)
|
void __blk_run_queue(struct request_queue *q)
|
||||||
{
|
{
|
||||||
if (unlikely(blk_queue_stopped(q)))
|
if (unlikely(blk_queue_stopped(q)))
|
||||||
return;
|
return;
|
||||||
@ -321,7 +307,7 @@ void __blk_run_queue(struct request_queue *q, bool force_kblockd)
|
|||||||
* Only recurse once to avoid overrunning the stack, let the unplug
|
* Only recurse once to avoid overrunning the stack, let the unplug
|
||||||
* handling reinvoke the handler shortly if we already got there.
|
* handling reinvoke the handler shortly if we already got there.
|
||||||
*/
|
*/
|
||||||
if (!force_kblockd && !queue_flag_test_and_set(QUEUE_FLAG_REENTER, q)) {
|
if (!queue_flag_test_and_set(QUEUE_FLAG_REENTER, q)) {
|
||||||
q->request_fn(q);
|
q->request_fn(q);
|
||||||
queue_flag_clear(QUEUE_FLAG_REENTER, q);
|
queue_flag_clear(QUEUE_FLAG_REENTER, q);
|
||||||
} else
|
} else
|
||||||
@ -329,6 +315,20 @@ void __blk_run_queue(struct request_queue *q, bool force_kblockd)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(__blk_run_queue);
|
EXPORT_SYMBOL(__blk_run_queue);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* blk_run_queue_async - run a single device queue in workqueue context
|
||||||
|
* @q: The queue to run
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Tells kblockd to perform the equivalent of @blk_run_queue on behalf
|
||||||
|
* of us.
|
||||||
|
*/
|
||||||
|
void blk_run_queue_async(struct request_queue *q)
|
||||||
|
{
|
||||||
|
if (likely(!blk_queue_stopped(q)))
|
||||||
|
queue_delayed_work(kblockd_workqueue, &q->delay_work, 0);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* blk_run_queue - run a single device queue
|
* blk_run_queue - run a single device queue
|
||||||
* @q: The queue to run
|
* @q: The queue to run
|
||||||
@ -342,7 +342,7 @@ void blk_run_queue(struct request_queue *q)
|
|||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
spin_lock_irqsave(q->queue_lock, flags);
|
spin_lock_irqsave(q->queue_lock, flags);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
spin_unlock_irqrestore(q->queue_lock, flags);
|
spin_unlock_irqrestore(q->queue_lock, flags);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_run_queue);
|
EXPORT_SYMBOL(blk_run_queue);
|
||||||
@ -991,7 +991,7 @@ void blk_insert_request(struct request_queue *q, struct request *rq,
|
|||||||
blk_queue_end_tag(q, rq);
|
blk_queue_end_tag(q, rq);
|
||||||
|
|
||||||
add_acct_request(q, rq, where);
|
add_acct_request(q, rq, where);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
spin_unlock_irqrestore(q->queue_lock, flags);
|
spin_unlock_irqrestore(q->queue_lock, flags);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_insert_request);
|
EXPORT_SYMBOL(blk_insert_request);
|
||||||
@ -1311,7 +1311,15 @@ get_rq:
|
|||||||
|
|
||||||
plug = current->plug;
|
plug = current->plug;
|
||||||
if (plug) {
|
if (plug) {
|
||||||
if (!plug->should_sort && !list_empty(&plug->list)) {
|
/*
|
||||||
|
* If this is the first request added after a plug, fire
|
||||||
|
* of a plug trace. If others have been added before, check
|
||||||
|
* if we have multiple devices in this plug. If so, make a
|
||||||
|
* note to sort the list before dispatch.
|
||||||
|
*/
|
||||||
|
if (list_empty(&plug->list))
|
||||||
|
trace_block_plug(q);
|
||||||
|
else if (!plug->should_sort) {
|
||||||
struct request *__rq;
|
struct request *__rq;
|
||||||
|
|
||||||
__rq = list_entry_rq(plug->list.prev);
|
__rq = list_entry_rq(plug->list.prev);
|
||||||
@ -1327,7 +1335,7 @@ get_rq:
|
|||||||
} else {
|
} else {
|
||||||
spin_lock_irq(q->queue_lock);
|
spin_lock_irq(q->queue_lock);
|
||||||
add_acct_request(q, req, where);
|
add_acct_request(q, req, where);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
out_unlock:
|
out_unlock:
|
||||||
spin_unlock_irq(q->queue_lock);
|
spin_unlock_irq(q->queue_lock);
|
||||||
}
|
}
|
||||||
@ -2644,6 +2652,7 @@ void blk_start_plug(struct blk_plug *plug)
|
|||||||
|
|
||||||
plug->magic = PLUG_MAGIC;
|
plug->magic = PLUG_MAGIC;
|
||||||
INIT_LIST_HEAD(&plug->list);
|
INIT_LIST_HEAD(&plug->list);
|
||||||
|
INIT_LIST_HEAD(&plug->cb_list);
|
||||||
plug->should_sort = 0;
|
plug->should_sort = 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2668,33 +2677,93 @@ static int plug_rq_cmp(void *priv, struct list_head *a, struct list_head *b)
|
|||||||
return !(rqa->q <= rqb->q);
|
return !(rqa->q <= rqb->q);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void flush_plug_list(struct blk_plug *plug)
|
/*
|
||||||
|
* If 'from_schedule' is true, then postpone the dispatch of requests
|
||||||
|
* until a safe kblockd context. We due this to avoid accidental big
|
||||||
|
* additional stack usage in driver dispatch, in places where the originally
|
||||||
|
* plugger did not intend it.
|
||||||
|
*/
|
||||||
|
static void queue_unplugged(struct request_queue *q, unsigned int depth,
|
||||||
|
bool from_schedule)
|
||||||
|
__releases(q->queue_lock)
|
||||||
|
{
|
||||||
|
trace_block_unplug(q, depth, !from_schedule);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* If we are punting this to kblockd, then we can safely drop
|
||||||
|
* the queue_lock before waking kblockd (which needs to take
|
||||||
|
* this lock).
|
||||||
|
*/
|
||||||
|
if (from_schedule) {
|
||||||
|
spin_unlock(q->queue_lock);
|
||||||
|
blk_run_queue_async(q);
|
||||||
|
} else {
|
||||||
|
__blk_run_queue(q);
|
||||||
|
spin_unlock(q->queue_lock);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
static void flush_plug_callbacks(struct blk_plug *plug)
|
||||||
|
{
|
||||||
|
LIST_HEAD(callbacks);
|
||||||
|
|
||||||
|
if (list_empty(&plug->cb_list))
|
||||||
|
return;
|
||||||
|
|
||||||
|
list_splice_init(&plug->cb_list, &callbacks);
|
||||||
|
|
||||||
|
while (!list_empty(&callbacks)) {
|
||||||
|
struct blk_plug_cb *cb = list_first_entry(&callbacks,
|
||||||
|
struct blk_plug_cb,
|
||||||
|
list);
|
||||||
|
list_del(&cb->list);
|
||||||
|
cb->callback(cb);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void blk_flush_plug_list(struct blk_plug *plug, bool from_schedule)
|
||||||
{
|
{
|
||||||
struct request_queue *q;
|
struct request_queue *q;
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
struct request *rq;
|
struct request *rq;
|
||||||
|
LIST_HEAD(list);
|
||||||
|
unsigned int depth;
|
||||||
|
|
||||||
BUG_ON(plug->magic != PLUG_MAGIC);
|
BUG_ON(plug->magic != PLUG_MAGIC);
|
||||||
|
|
||||||
|
flush_plug_callbacks(plug);
|
||||||
if (list_empty(&plug->list))
|
if (list_empty(&plug->list))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (plug->should_sort)
|
list_splice_init(&plug->list, &list);
|
||||||
list_sort(NULL, &plug->list, plug_rq_cmp);
|
|
||||||
|
if (plug->should_sort) {
|
||||||
|
list_sort(NULL, &list, plug_rq_cmp);
|
||||||
|
plug->should_sort = 0;
|
||||||
|
}
|
||||||
|
|
||||||
q = NULL;
|
q = NULL;
|
||||||
|
depth = 0;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Save and disable interrupts here, to avoid doing it for every
|
||||||
|
* queue lock we have to take.
|
||||||
|
*/
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
while (!list_empty(&plug->list)) {
|
while (!list_empty(&list)) {
|
||||||
rq = list_entry_rq(plug->list.next);
|
rq = list_entry_rq(list.next);
|
||||||
list_del_init(&rq->queuelist);
|
list_del_init(&rq->queuelist);
|
||||||
BUG_ON(!(rq->cmd_flags & REQ_ON_PLUG));
|
BUG_ON(!(rq->cmd_flags & REQ_ON_PLUG));
|
||||||
BUG_ON(!rq->q);
|
BUG_ON(!rq->q);
|
||||||
if (rq->q != q) {
|
if (rq->q != q) {
|
||||||
if (q) {
|
/*
|
||||||
__blk_run_queue(q, false);
|
* This drops the queue lock
|
||||||
spin_unlock(q->queue_lock);
|
*/
|
||||||
}
|
if (q)
|
||||||
|
queue_unplugged(q, depth, from_schedule);
|
||||||
q = rq->q;
|
q = rq->q;
|
||||||
|
depth = 0;
|
||||||
spin_lock(q->queue_lock);
|
spin_lock(q->queue_lock);
|
||||||
}
|
}
|
||||||
rq->cmd_flags &= ~REQ_ON_PLUG;
|
rq->cmd_flags &= ~REQ_ON_PLUG;
|
||||||
@ -2706,39 +2775,29 @@ static void flush_plug_list(struct blk_plug *plug)
|
|||||||
__elv_add_request(q, rq, ELEVATOR_INSERT_FLUSH);
|
__elv_add_request(q, rq, ELEVATOR_INSERT_FLUSH);
|
||||||
else
|
else
|
||||||
__elv_add_request(q, rq, ELEVATOR_INSERT_SORT_MERGE);
|
__elv_add_request(q, rq, ELEVATOR_INSERT_SORT_MERGE);
|
||||||
|
|
||||||
|
depth++;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (q) {
|
/*
|
||||||
__blk_run_queue(q, false);
|
* This drops the queue lock
|
||||||
spin_unlock(q->queue_lock);
|
*/
|
||||||
}
|
if (q)
|
||||||
|
queue_unplugged(q, depth, from_schedule);
|
||||||
|
|
||||||
BUG_ON(!list_empty(&plug->list));
|
|
||||||
local_irq_restore(flags);
|
local_irq_restore(flags);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(blk_flush_plug_list);
|
||||||
static void __blk_finish_plug(struct task_struct *tsk, struct blk_plug *plug)
|
|
||||||
{
|
|
||||||
flush_plug_list(plug);
|
|
||||||
|
|
||||||
if (plug == tsk->plug)
|
|
||||||
tsk->plug = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
void blk_finish_plug(struct blk_plug *plug)
|
void blk_finish_plug(struct blk_plug *plug)
|
||||||
{
|
{
|
||||||
if (plug)
|
blk_flush_plug_list(plug, false);
|
||||||
__blk_finish_plug(current, plug);
|
|
||||||
|
if (plug == current->plug)
|
||||||
|
current->plug = NULL;
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_finish_plug);
|
EXPORT_SYMBOL(blk_finish_plug);
|
||||||
|
|
||||||
void __blk_flush_plug(struct task_struct *tsk, struct blk_plug *plug)
|
|
||||||
{
|
|
||||||
__blk_finish_plug(tsk, plug);
|
|
||||||
tsk->plug = plug;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(__blk_flush_plug);
|
|
||||||
|
|
||||||
int __init blk_dev_init(void)
|
int __init blk_dev_init(void)
|
||||||
{
|
{
|
||||||
BUILD_BUG_ON(__REQ_NR_BITS > 8 *
|
BUILD_BUG_ON(__REQ_NR_BITS > 8 *
|
||||||
|
@ -55,7 +55,7 @@ void blk_execute_rq_nowait(struct request_queue *q, struct gendisk *bd_disk,
|
|||||||
WARN_ON(irqs_disabled());
|
WARN_ON(irqs_disabled());
|
||||||
spin_lock_irq(q->queue_lock);
|
spin_lock_irq(q->queue_lock);
|
||||||
__elv_add_request(q, rq, where);
|
__elv_add_request(q, rq, where);
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
/* the queue is stopped so it won't be plugged+unplugged */
|
/* the queue is stopped so it won't be plugged+unplugged */
|
||||||
if (rq->cmd_type == REQ_TYPE_PM_RESUME)
|
if (rq->cmd_type == REQ_TYPE_PM_RESUME)
|
||||||
q->request_fn(q);
|
q->request_fn(q);
|
||||||
|
@ -218,7 +218,7 @@ static void flush_end_io(struct request *flush_rq, int error)
|
|||||||
* request_fn may confuse the driver. Always use kblockd.
|
* request_fn may confuse the driver. Always use kblockd.
|
||||||
*/
|
*/
|
||||||
if (queued)
|
if (queued)
|
||||||
__blk_run_queue(q, true);
|
blk_run_queue_async(q);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -274,7 +274,7 @@ static void flush_data_end_io(struct request *rq, int error)
|
|||||||
* the comment in flush_end_io().
|
* the comment in flush_end_io().
|
||||||
*/
|
*/
|
||||||
if (blk_flush_complete_seq(rq, REQ_FSEQ_DATA, error))
|
if (blk_flush_complete_seq(rq, REQ_FSEQ_DATA, error))
|
||||||
__blk_run_queue(q, true);
|
blk_run_queue_async(q);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -498,7 +498,6 @@ int blk_register_queue(struct gendisk *disk)
|
|||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
struct device *dev = disk_to_dev(disk);
|
struct device *dev = disk_to_dev(disk);
|
||||||
|
|
||||||
struct request_queue *q = disk->queue;
|
struct request_queue *q = disk->queue;
|
||||||
|
|
||||||
if (WARN_ON(!q))
|
if (WARN_ON(!q))
|
||||||
@ -521,7 +520,7 @@ int blk_register_queue(struct gendisk *disk)
|
|||||||
if (ret) {
|
if (ret) {
|
||||||
kobject_uevent(&q->kobj, KOBJ_REMOVE);
|
kobject_uevent(&q->kobj, KOBJ_REMOVE);
|
||||||
kobject_del(&q->kobj);
|
kobject_del(&q->kobj);
|
||||||
blk_trace_remove_sysfs(disk_to_dev(disk));
|
blk_trace_remove_sysfs(dev);
|
||||||
kobject_put(&dev->kobj);
|
kobject_put(&dev->kobj);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ void blk_rq_timed_out_timer(unsigned long data);
|
|||||||
void blk_delete_timer(struct request *);
|
void blk_delete_timer(struct request *);
|
||||||
void blk_add_timer(struct request *);
|
void blk_add_timer(struct request *);
|
||||||
void __generic_unplug_device(struct request_queue *);
|
void __generic_unplug_device(struct request_queue *);
|
||||||
|
void blk_run_queue_async(struct request_queue *q);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Internal atomic flags for request handling
|
* Internal atomic flags for request handling
|
||||||
|
@ -3368,7 +3368,7 @@ cfq_rq_enqueued(struct cfq_data *cfqd, struct cfq_queue *cfqq,
|
|||||||
cfqd->busy_queues > 1) {
|
cfqd->busy_queues > 1) {
|
||||||
cfq_del_timer(cfqd, cfqq);
|
cfq_del_timer(cfqd, cfqq);
|
||||||
cfq_clear_cfqq_wait_request(cfqq);
|
cfq_clear_cfqq_wait_request(cfqq);
|
||||||
__blk_run_queue(cfqd->queue, false);
|
__blk_run_queue(cfqd->queue);
|
||||||
} else {
|
} else {
|
||||||
cfq_blkiocg_update_idle_time_stats(
|
cfq_blkiocg_update_idle_time_stats(
|
||||||
&cfqq->cfqg->blkg);
|
&cfqq->cfqg->blkg);
|
||||||
@ -3383,7 +3383,7 @@ cfq_rq_enqueued(struct cfq_data *cfqd, struct cfq_queue *cfqq,
|
|||||||
* this new queue is RT and the current one is BE
|
* this new queue is RT and the current one is BE
|
||||||
*/
|
*/
|
||||||
cfq_preempt_queue(cfqd, cfqq);
|
cfq_preempt_queue(cfqd, cfqq);
|
||||||
__blk_run_queue(cfqd->queue, false);
|
__blk_run_queue(cfqd->queue);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3743,7 +3743,7 @@ static void cfq_kick_queue(struct work_struct *work)
|
|||||||
struct request_queue *q = cfqd->queue;
|
struct request_queue *q = cfqd->queue;
|
||||||
|
|
||||||
spin_lock_irq(q->queue_lock);
|
spin_lock_irq(q->queue_lock);
|
||||||
__blk_run_queue(cfqd->queue, false);
|
__blk_run_queue(cfqd->queue);
|
||||||
spin_unlock_irq(q->queue_lock);
|
spin_unlock_irq(q->queue_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -642,7 +642,7 @@ void elv_quiesce_start(struct request_queue *q)
|
|||||||
*/
|
*/
|
||||||
elv_drain_elevator(q);
|
elv_drain_elevator(q);
|
||||||
while (q->rq.elvpriv) {
|
while (q->rq.elvpriv) {
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
spin_unlock_irq(q->queue_lock);
|
spin_unlock_irq(q->queue_lock);
|
||||||
msleep(10);
|
msleep(10);
|
||||||
spin_lock_irq(q->queue_lock);
|
spin_lock_irq(q->queue_lock);
|
||||||
@ -695,7 +695,7 @@ void __elv_add_request(struct request_queue *q, struct request *rq, int where)
|
|||||||
* with anything. There's no point in delaying queue
|
* with anything. There's no point in delaying queue
|
||||||
* processing.
|
* processing.
|
||||||
*/
|
*/
|
||||||
__blk_run_queue(q, false);
|
__blk_run_queue(q);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ELEVATOR_INSERT_SORT_MERGE:
|
case ELEVATOR_INSERT_SORT_MERGE:
|
||||||
|
@ -214,7 +214,7 @@ static int amba_pm_resume_noirq(struct device *dev)
|
|||||||
|
|
||||||
#endif /* !CONFIG_SUSPEND */
|
#endif /* !CONFIG_SUSPEND */
|
||||||
|
|
||||||
#ifdef CONFIG_HIBERNATION
|
#ifdef CONFIG_HIBERNATE_CALLBACKS
|
||||||
|
|
||||||
static int amba_pm_freeze(struct device *dev)
|
static int amba_pm_freeze(struct device *dev)
|
||||||
{
|
{
|
||||||
@ -352,7 +352,7 @@ static int amba_pm_restore_noirq(struct device *dev)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else /* !CONFIG_HIBERNATION */
|
#else /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
#define amba_pm_freeze NULL
|
#define amba_pm_freeze NULL
|
||||||
#define amba_pm_thaw NULL
|
#define amba_pm_thaw NULL
|
||||||
@ -363,7 +363,7 @@ static int amba_pm_restore_noirq(struct device *dev)
|
|||||||
#define amba_pm_poweroff_noirq NULL
|
#define amba_pm_poweroff_noirq NULL
|
||||||
#define amba_pm_restore_noirq NULL
|
#define amba_pm_restore_noirq NULL
|
||||||
|
|
||||||
#endif /* !CONFIG_HIBERNATION */
|
#endif /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM
|
||||||
|
|
||||||
|
@ -149,6 +149,7 @@ static void platform_device_release(struct device *dev)
|
|||||||
|
|
||||||
of_device_node_put(&pa->pdev.dev);
|
of_device_node_put(&pa->pdev.dev);
|
||||||
kfree(pa->pdev.dev.platform_data);
|
kfree(pa->pdev.dev.platform_data);
|
||||||
|
kfree(pa->pdev.mfd_cell);
|
||||||
kfree(pa->pdev.resource);
|
kfree(pa->pdev.resource);
|
||||||
kfree(pa);
|
kfree(pa);
|
||||||
}
|
}
|
||||||
@ -771,7 +772,7 @@ int __weak platform_pm_resume_noirq(struct device *dev)
|
|||||||
|
|
||||||
#endif /* !CONFIG_SUSPEND */
|
#endif /* !CONFIG_SUSPEND */
|
||||||
|
|
||||||
#ifdef CONFIG_HIBERNATION
|
#ifdef CONFIG_HIBERNATE_CALLBACKS
|
||||||
|
|
||||||
static int platform_pm_freeze(struct device *dev)
|
static int platform_pm_freeze(struct device *dev)
|
||||||
{
|
{
|
||||||
@ -909,7 +910,7 @@ static int platform_pm_restore_noirq(struct device *dev)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
#else /* !CONFIG_HIBERNATION */
|
#else /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
#define platform_pm_freeze NULL
|
#define platform_pm_freeze NULL
|
||||||
#define platform_pm_thaw NULL
|
#define platform_pm_thaw NULL
|
||||||
@ -920,7 +921,7 @@ static int platform_pm_restore_noirq(struct device *dev)
|
|||||||
#define platform_pm_poweroff_noirq NULL
|
#define platform_pm_poweroff_noirq NULL
|
||||||
#define platform_pm_restore_noirq NULL
|
#define platform_pm_restore_noirq NULL
|
||||||
|
|
||||||
#endif /* !CONFIG_HIBERNATION */
|
#endif /* !CONFIG_HIBERNATE_CALLBACKS */
|
||||||
|
|
||||||
#ifdef CONFIG_PM_RUNTIME
|
#ifdef CONFIG_PM_RUNTIME
|
||||||
|
|
||||||
|
@ -233,7 +233,7 @@ static int pm_op(struct device *dev,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif /* CONFIG_SUSPEND */
|
#endif /* CONFIG_SUSPEND */
|
||||||
#ifdef CONFIG_HIBERNATION
|
#ifdef CONFIG_HIBERNATE_CALLBACKS
|
||||||
case PM_EVENT_FREEZE:
|
case PM_EVENT_FREEZE:
|
||||||
case PM_EVENT_QUIESCE:
|
case PM_EVENT_QUIESCE:
|
||||||
if (ops->freeze) {
|
if (ops->freeze) {
|
||||||
@ -260,7 +260,7 @@ static int pm_op(struct device *dev,
|
|||||||
suspend_report_result(ops->restore, error);
|
suspend_report_result(ops->restore, error);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif /* CONFIG_HIBERNATION */
|
#endif /* CONFIG_HIBERNATE_CALLBACKS */
|
||||||
default:
|
default:
|
||||||
error = -EINVAL;
|
error = -EINVAL;
|
||||||
}
|
}
|
||||||
@ -308,7 +308,7 @@ static int pm_noirq_op(struct device *dev,
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif /* CONFIG_SUSPEND */
|
#endif /* CONFIG_SUSPEND */
|
||||||
#ifdef CONFIG_HIBERNATION
|
#ifdef CONFIG_HIBERNATE_CALLBACKS
|
||||||
case PM_EVENT_FREEZE:
|
case PM_EVENT_FREEZE:
|
||||||
case PM_EVENT_QUIESCE:
|
case PM_EVENT_QUIESCE:
|
||||||
if (ops->freeze_noirq) {
|
if (ops->freeze_noirq) {
|
||||||
@ -335,7 +335,7 @@ static int pm_noirq_op(struct device *dev,
|
|||||||
suspend_report_result(ops->restore_noirq, error);
|
suspend_report_result(ops->restore_noirq, error);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#endif /* CONFIG_HIBERNATION */
|
#endif /* CONFIG_HIBERNATE_CALLBACKS */
|
||||||
default:
|
default:
|
||||||
error = -EINVAL;
|
error = -EINVAL;
|
||||||
}
|
}
|
||||||
|
@ -96,6 +96,7 @@ config DRM_I915
|
|||||||
# i915 depends on ACPI_VIDEO when ACPI is enabled
|
# i915 depends on ACPI_VIDEO when ACPI is enabled
|
||||||
# but for select to work, need to select ACPI_VIDEO's dependencies, ick
|
# but for select to work, need to select ACPI_VIDEO's dependencies, ick
|
||||||
select BACKLIGHT_CLASS_DEVICE if ACPI
|
select BACKLIGHT_CLASS_DEVICE if ACPI
|
||||||
|
select VIDEO_OUTPUT_CONTROL if ACPI
|
||||||
select INPUT if ACPI
|
select INPUT if ACPI
|
||||||
select ACPI_VIDEO if ACPI
|
select ACPI_VIDEO if ACPI
|
||||||
select ACPI_BUTTON if ACPI
|
select ACPI_BUTTON if ACPI
|
||||||
|
@ -269,7 +269,7 @@ struct init_tbl_entry {
|
|||||||
int (*handler)(struct nvbios *, uint16_t, struct init_exec *);
|
int (*handler)(struct nvbios *, uint16_t, struct init_exec *);
|
||||||
};
|
};
|
||||||
|
|
||||||
static int parse_init_table(struct nvbios *, unsigned int, struct init_exec *);
|
static int parse_init_table(struct nvbios *, uint16_t, struct init_exec *);
|
||||||
|
|
||||||
#define MACRO_INDEX_SIZE 2
|
#define MACRO_INDEX_SIZE 2
|
||||||
#define MACRO_SIZE 8
|
#define MACRO_SIZE 8
|
||||||
@ -2010,6 +2010,27 @@ init_sub_direct(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
|
|||||||
return 3;
|
return 3;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int
|
||||||
|
init_jump(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* INIT_JUMP opcode: 0x5C ('\')
|
||||||
|
*
|
||||||
|
* offset (8 bit): opcode
|
||||||
|
* offset + 1 (16 bit): offset (in bios)
|
||||||
|
*
|
||||||
|
* Continue execution of init table from 'offset'
|
||||||
|
*/
|
||||||
|
|
||||||
|
uint16_t jmp_offset = ROM16(bios->data[offset + 1]);
|
||||||
|
|
||||||
|
if (!iexec->execute)
|
||||||
|
return 3;
|
||||||
|
|
||||||
|
BIOSLOG(bios, "0x%04X: Jump to 0x%04X\n", offset, jmp_offset);
|
||||||
|
return jmp_offset - offset;
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
init_i2c_if(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
|
init_i2c_if(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
|
||||||
{
|
{
|
||||||
@ -3659,6 +3680,7 @@ static struct init_tbl_entry itbl_entry[] = {
|
|||||||
{ "INIT_ZM_REG_SEQUENCE" , 0x58, init_zm_reg_sequence },
|
{ "INIT_ZM_REG_SEQUENCE" , 0x58, init_zm_reg_sequence },
|
||||||
/* INIT_INDIRECT_REG (0x5A, 7, 0, 0) removed due to no example of use */
|
/* INIT_INDIRECT_REG (0x5A, 7, 0, 0) removed due to no example of use */
|
||||||
{ "INIT_SUB_DIRECT" , 0x5B, init_sub_direct },
|
{ "INIT_SUB_DIRECT" , 0x5B, init_sub_direct },
|
||||||
|
{ "INIT_JUMP" , 0x5C, init_jump },
|
||||||
{ "INIT_I2C_IF" , 0x5E, init_i2c_if },
|
{ "INIT_I2C_IF" , 0x5E, init_i2c_if },
|
||||||
{ "INIT_COPY_NV_REG" , 0x5F, init_copy_nv_reg },
|
{ "INIT_COPY_NV_REG" , 0x5F, init_copy_nv_reg },
|
||||||
{ "INIT_ZM_INDEX_IO" , 0x62, init_zm_index_io },
|
{ "INIT_ZM_INDEX_IO" , 0x62, init_zm_index_io },
|
||||||
@ -3700,8 +3722,7 @@ static struct init_tbl_entry itbl_entry[] = {
|
|||||||
#define MAX_TABLE_OPS 1000
|
#define MAX_TABLE_OPS 1000
|
||||||
|
|
||||||
static int
|
static int
|
||||||
parse_init_table(struct nvbios *bios, unsigned int offset,
|
parse_init_table(struct nvbios *bios, uint16_t offset, struct init_exec *iexec)
|
||||||
struct init_exec *iexec)
|
|
||||||
{
|
{
|
||||||
/*
|
/*
|
||||||
* Parses all commands in an init table.
|
* Parses all commands in an init table.
|
||||||
@ -6333,6 +6354,32 @@ apply_dcb_encoder_quirks(struct drm_device *dev, int idx, u32 *conn, u32 *conf)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* XFX GT-240X-YA
|
||||||
|
*
|
||||||
|
* So many things wrong here, replace the entire encoder table..
|
||||||
|
*/
|
||||||
|
if (nv_match_device(dev, 0x0ca3, 0x1682, 0x3003)) {
|
||||||
|
if (idx == 0) {
|
||||||
|
*conn = 0x02001300; /* VGA, connector 1 */
|
||||||
|
*conf = 0x00000028;
|
||||||
|
} else
|
||||||
|
if (idx == 1) {
|
||||||
|
*conn = 0x01010312; /* DVI, connector 0 */
|
||||||
|
*conf = 0x00020030;
|
||||||
|
} else
|
||||||
|
if (idx == 2) {
|
||||||
|
*conn = 0x01010310; /* VGA, connector 0 */
|
||||||
|
*conf = 0x00000028;
|
||||||
|
} else
|
||||||
|
if (idx == 3) {
|
||||||
|
*conn = 0x02022362; /* HDMI, connector 2 */
|
||||||
|
*conf = 0x00020010;
|
||||||
|
} else {
|
||||||
|
*conn = 0x0000000e; /* EOL */
|
||||||
|
*conf = 0x00000000;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1190,7 +1190,7 @@ extern int nv50_graph_load_context(struct nouveau_channel *);
|
|||||||
extern int nv50_graph_unload_context(struct drm_device *);
|
extern int nv50_graph_unload_context(struct drm_device *);
|
||||||
extern int nv50_grctx_init(struct nouveau_grctx *);
|
extern int nv50_grctx_init(struct nouveau_grctx *);
|
||||||
extern void nv50_graph_tlb_flush(struct drm_device *dev);
|
extern void nv50_graph_tlb_flush(struct drm_device *dev);
|
||||||
extern void nv86_graph_tlb_flush(struct drm_device *dev);
|
extern void nv84_graph_tlb_flush(struct drm_device *dev);
|
||||||
extern struct nouveau_enum nv50_data_error_names[];
|
extern struct nouveau_enum nv50_data_error_names[];
|
||||||
|
|
||||||
/* nvc0_graph.c */
|
/* nvc0_graph.c */
|
||||||
|
@ -552,6 +552,7 @@ nouveau_mem_timing_init(struct drm_device *dev)
|
|||||||
u8 tRC; /* Byte 9 */
|
u8 tRC; /* Byte 9 */
|
||||||
u8 tUNK_10, tUNK_11, tUNK_12, tUNK_13, tUNK_14;
|
u8 tUNK_10, tUNK_11, tUNK_12, tUNK_13, tUNK_14;
|
||||||
u8 tUNK_18, tUNK_19, tUNK_20, tUNK_21;
|
u8 tUNK_18, tUNK_19, tUNK_20, tUNK_21;
|
||||||
|
u8 magic_number = 0; /* Yeah... sorry*/
|
||||||
u8 *mem = NULL, *entry;
|
u8 *mem = NULL, *entry;
|
||||||
int i, recordlen, entries;
|
int i, recordlen, entries;
|
||||||
|
|
||||||
@ -596,6 +597,12 @@ nouveau_mem_timing_init(struct drm_device *dev)
|
|||||||
if (!memtimings->timing)
|
if (!memtimings->timing)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
/* Get "some number" from the timing reg for NV_40
|
||||||
|
* Used in calculations later */
|
||||||
|
if(dev_priv->card_type == NV_40) {
|
||||||
|
magic_number = (nv_rd32(dev,0x100228) & 0x0f000000) >> 24;
|
||||||
|
}
|
||||||
|
|
||||||
entry = mem + mem[1];
|
entry = mem + mem[1];
|
||||||
for (i = 0; i < entries; i++, entry += recordlen) {
|
for (i = 0; i < entries; i++, entry += recordlen) {
|
||||||
struct nouveau_pm_memtiming *timing = &pm->memtimings.timing[i];
|
struct nouveau_pm_memtiming *timing = &pm->memtimings.timing[i];
|
||||||
@ -635,36 +642,51 @@ nouveau_mem_timing_init(struct drm_device *dev)
|
|||||||
|
|
||||||
/* XXX: I don't trust the -1's and +1's... they must come
|
/* XXX: I don't trust the -1's and +1's... they must come
|
||||||
* from somewhere! */
|
* from somewhere! */
|
||||||
timing->reg_100224 = ((tUNK_0 + tUNK_19 + 1) << 24 |
|
timing->reg_100224 = (tUNK_0 + tUNK_19 + 1 + magic_number) << 24 |
|
||||||
tUNK_18 << 16 |
|
tUNK_18 << 16 |
|
||||||
(tUNK_1 + tUNK_19 + 1) << 8 |
|
(tUNK_1 + tUNK_19 + 1 + magic_number) << 8;
|
||||||
(tUNK_2 - 1));
|
if(dev_priv->chipset == 0xa8) {
|
||||||
|
timing->reg_100224 |= (tUNK_2 - 1);
|
||||||
|
} else {
|
||||||
|
timing->reg_100224 |= (tUNK_2 + 2 - magic_number);
|
||||||
|
}
|
||||||
|
|
||||||
timing->reg_100228 = (tUNK_12 << 16 | tUNK_11 << 8 | tUNK_10);
|
timing->reg_100228 = (tUNK_12 << 16 | tUNK_11 << 8 | tUNK_10);
|
||||||
if(recordlen > 19) {
|
if(dev_priv->chipset >= 0xa3 && dev_priv->chipset < 0xaa) {
|
||||||
timing->reg_100228 += (tUNK_19 - 1) << 24;
|
timing->reg_100228 |= (tUNK_19 - 1) << 24;
|
||||||
}/* I cannot back-up this else-statement right now
|
}
|
||||||
else {
|
|
||||||
timing->reg_100228 += tUNK_12 << 24;
|
|
||||||
}*/
|
|
||||||
|
|
||||||
/* XXX: reg_10022c */
|
if(dev_priv->card_type == NV_40) {
|
||||||
timing->reg_10022c = tUNK_2 - 1;
|
/* NV40: don't know what the rest of the regs are..
|
||||||
|
* And don't need to know either */
|
||||||
|
timing->reg_100228 |= 0x20200000 | magic_number << 24;
|
||||||
|
} else if(dev_priv->card_type >= NV_50) {
|
||||||
|
/* XXX: reg_10022c */
|
||||||
|
timing->reg_10022c = tUNK_2 - 1;
|
||||||
|
|
||||||
timing->reg_100230 = (tUNK_20 << 24 | tUNK_21 << 16 |
|
timing->reg_100230 = (tUNK_20 << 24 | tUNK_21 << 16 |
|
||||||
tUNK_13 << 8 | tUNK_13);
|
tUNK_13 << 8 | tUNK_13);
|
||||||
|
|
||||||
/* XXX: +6? */
|
timing->reg_100234 = (tRAS << 24 | tRC);
|
||||||
timing->reg_100234 = (tRAS << 24 | (tUNK_19 + 6) << 8 | tRC);
|
timing->reg_100234 += max(tUNK_10,tUNK_11) << 16;
|
||||||
timing->reg_100234 += max(tUNK_10,tUNK_11) << 16;
|
|
||||||
|
|
||||||
/* XXX; reg_100238, reg_10023c
|
if(dev_priv->chipset < 0xa3) {
|
||||||
* reg: 0x00??????
|
timing->reg_100234 |= (tUNK_2 + 2) << 8;
|
||||||
* reg_10023c:
|
} else {
|
||||||
* 0 for pre-NV50 cards
|
/* XXX: +6? */
|
||||||
* 0x????0202 for NV50+ cards (empirical evidence) */
|
timing->reg_100234 |= (tUNK_19 + 6) << 8;
|
||||||
if(dev_priv->card_type >= NV_50) {
|
}
|
||||||
|
|
||||||
|
/* XXX; reg_100238, reg_10023c
|
||||||
|
* reg_100238: 0x00??????
|
||||||
|
* reg_10023c: 0x!!??0202 for NV50+ cards (empirical evidence) */
|
||||||
timing->reg_10023c = 0x202;
|
timing->reg_10023c = 0x202;
|
||||||
|
if(dev_priv->chipset < 0xa3) {
|
||||||
|
timing->reg_10023c |= 0x4000000 | (tUNK_2 - 1) << 16;
|
||||||
|
} else {
|
||||||
|
/* currently unknown
|
||||||
|
* 10023c seen as 06xxxxxx, 0bxxxxxx or 0fxxxxxx */
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
NV_DEBUG(dev, "Entry %d: 220: %08x %08x %08x %08x\n", i,
|
NV_DEBUG(dev, "Entry %d: 220: %08x %08x %08x %08x\n", i,
|
||||||
@ -675,7 +697,7 @@ nouveau_mem_timing_init(struct drm_device *dev)
|
|||||||
timing->reg_100238, timing->reg_10023c);
|
timing->reg_100238, timing->reg_10023c);
|
||||||
}
|
}
|
||||||
|
|
||||||
memtimings->nr_timing = entries;
|
memtimings->nr_timing = entries;
|
||||||
memtimings->supported = true;
|
memtimings->supported = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,7 +134,7 @@ nouveau_perf_init(struct drm_device *dev)
|
|||||||
case 0x13:
|
case 0x13:
|
||||||
case 0x15:
|
case 0x15:
|
||||||
perflvl->fanspeed = entry[55];
|
perflvl->fanspeed = entry[55];
|
||||||
perflvl->voltage = entry[56];
|
perflvl->voltage = (recordlen > 56) ? entry[56] : 0;
|
||||||
perflvl->core = ROM32(entry[1]) * 10;
|
perflvl->core = ROM32(entry[1]) * 10;
|
||||||
perflvl->memory = ROM32(entry[5]) * 20;
|
perflvl->memory = ROM32(entry[5]) * 20;
|
||||||
break;
|
break;
|
||||||
|
@ -376,15 +376,11 @@ static int nouveau_init_engine_ptrs(struct drm_device *dev)
|
|||||||
engine->graph.destroy_context = nv50_graph_destroy_context;
|
engine->graph.destroy_context = nv50_graph_destroy_context;
|
||||||
engine->graph.load_context = nv50_graph_load_context;
|
engine->graph.load_context = nv50_graph_load_context;
|
||||||
engine->graph.unload_context = nv50_graph_unload_context;
|
engine->graph.unload_context = nv50_graph_unload_context;
|
||||||
if (dev_priv->chipset != 0x86)
|
if (dev_priv->chipset == 0x50 ||
|
||||||
|
dev_priv->chipset == 0xac)
|
||||||
engine->graph.tlb_flush = nv50_graph_tlb_flush;
|
engine->graph.tlb_flush = nv50_graph_tlb_flush;
|
||||||
else {
|
else
|
||||||
/* from what i can see nvidia do this on every
|
engine->graph.tlb_flush = nv84_graph_tlb_flush;
|
||||||
* pre-NVA3 board except NVAC, but, we've only
|
|
||||||
* ever seen problems on NV86
|
|
||||||
*/
|
|
||||||
engine->graph.tlb_flush = nv86_graph_tlb_flush;
|
|
||||||
}
|
|
||||||
engine->fifo.channels = 128;
|
engine->fifo.channels = 128;
|
||||||
engine->fifo.init = nv50_fifo_init;
|
engine->fifo.init = nv50_fifo_init;
|
||||||
engine->fifo.takedown = nv50_fifo_takedown;
|
engine->fifo.takedown = nv50_fifo_takedown;
|
||||||
|
@ -581,12 +581,13 @@ static void nv04_dfp_restore(struct drm_encoder *encoder)
|
|||||||
int head = nv_encoder->restore.head;
|
int head = nv_encoder->restore.head;
|
||||||
|
|
||||||
if (nv_encoder->dcb->type == OUTPUT_LVDS) {
|
if (nv_encoder->dcb->type == OUTPUT_LVDS) {
|
||||||
struct drm_display_mode *native_mode = nouveau_encoder_connector_get(nv_encoder)->native_mode;
|
struct nouveau_connector *connector =
|
||||||
if (native_mode)
|
nouveau_encoder_connector_get(nv_encoder);
|
||||||
call_lvds_script(dev, nv_encoder->dcb, head, LVDS_PANEL_ON,
|
|
||||||
native_mode->clock);
|
if (connector && connector->native_mode)
|
||||||
else
|
call_lvds_script(dev, nv_encoder->dcb, head,
|
||||||
NV_ERROR(dev, "Not restoring LVDS without native mode\n");
|
LVDS_PANEL_ON,
|
||||||
|
connector->native_mode->clock);
|
||||||
|
|
||||||
} else if (nv_encoder->dcb->type == OUTPUT_TMDS) {
|
} else if (nv_encoder->dcb->type == OUTPUT_TMDS) {
|
||||||
int clock = nouveau_hw_pllvals_to_clk
|
int clock = nouveau_hw_pllvals_to_clk
|
||||||
|
@ -469,9 +469,6 @@ nv50_crtc_wait_complete(struct drm_crtc *crtc)
|
|||||||
|
|
||||||
start = ptimer->read(dev);
|
start = ptimer->read(dev);
|
||||||
do {
|
do {
|
||||||
nv_wr32(dev, 0x61002c, 0x370);
|
|
||||||
nv_wr32(dev, 0x000140, 1);
|
|
||||||
|
|
||||||
if (nv_ro32(disp->ntfy, 0x000))
|
if (nv_ro32(disp->ntfy, 0x000))
|
||||||
return 0;
|
return 0;
|
||||||
} while (ptimer->read(dev) - start < 2000000000ULL);
|
} while (ptimer->read(dev) - start < 2000000000ULL);
|
||||||
|
@ -186,6 +186,7 @@ nv50_evo_channel_init(struct nouveau_channel *evo)
|
|||||||
nv_mask(dev, 0x610028, 0x00000000, 0x00010001 << id);
|
nv_mask(dev, 0x610028, 0x00000000, 0x00010001 << id);
|
||||||
|
|
||||||
evo->dma.max = (4096/4) - 2;
|
evo->dma.max = (4096/4) - 2;
|
||||||
|
evo->dma.max &= ~7;
|
||||||
evo->dma.put = 0;
|
evo->dma.put = 0;
|
||||||
evo->dma.cur = evo->dma.put;
|
evo->dma.cur = evo->dma.put;
|
||||||
evo->dma.free = evo->dma.max - evo->dma.cur;
|
evo->dma.free = evo->dma.max - evo->dma.cur;
|
||||||
|
@ -503,7 +503,7 @@ nv50_graph_tlb_flush(struct drm_device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
nv86_graph_tlb_flush(struct drm_device *dev)
|
nv84_graph_tlb_flush(struct drm_device *dev)
|
||||||
{
|
{
|
||||||
struct drm_nouveau_private *dev_priv = dev->dev_private;
|
struct drm_nouveau_private *dev_priv = dev->dev_private;
|
||||||
struct nouveau_timer_engine *ptimer = &dev_priv->engine.timer;
|
struct nouveau_timer_engine *ptimer = &dev_priv->engine.timer;
|
||||||
|
@ -104,20 +104,26 @@ nvc0_vm_flush(struct nouveau_vm *vm)
|
|||||||
struct nouveau_instmem_engine *pinstmem = &dev_priv->engine.instmem;
|
struct nouveau_instmem_engine *pinstmem = &dev_priv->engine.instmem;
|
||||||
struct drm_device *dev = vm->dev;
|
struct drm_device *dev = vm->dev;
|
||||||
struct nouveau_vm_pgd *vpgd;
|
struct nouveau_vm_pgd *vpgd;
|
||||||
u32 r100c80, engine;
|
u32 engine = (dev_priv->chan_vm == vm) ? 1 : 5;
|
||||||
|
|
||||||
pinstmem->flush(vm->dev);
|
pinstmem->flush(vm->dev);
|
||||||
|
|
||||||
if (vm == dev_priv->chan_vm)
|
spin_lock(&dev_priv->ramin_lock);
|
||||||
engine = 1;
|
|
||||||
else
|
|
||||||
engine = 5;
|
|
||||||
|
|
||||||
list_for_each_entry(vpgd, &vm->pgd_list, head) {
|
list_for_each_entry(vpgd, &vm->pgd_list, head) {
|
||||||
r100c80 = nv_rd32(dev, 0x100c80);
|
/* looks like maybe a "free flush slots" counter, the
|
||||||
|
* faster you write to 0x100cbc to more it decreases
|
||||||
|
*/
|
||||||
|
if (!nv_wait_ne(dev, 0x100c80, 0x00ff0000, 0x00000000)) {
|
||||||
|
NV_ERROR(dev, "vm timeout 0: 0x%08x %d\n",
|
||||||
|
nv_rd32(dev, 0x100c80), engine);
|
||||||
|
}
|
||||||
nv_wr32(dev, 0x100cb8, vpgd->obj->vinst >> 8);
|
nv_wr32(dev, 0x100cb8, vpgd->obj->vinst >> 8);
|
||||||
nv_wr32(dev, 0x100cbc, 0x80000000 | engine);
|
nv_wr32(dev, 0x100cbc, 0x80000000 | engine);
|
||||||
if (!nv_wait(dev, 0x100c80, 0xffffffff, r100c80))
|
/* wait for flush to be queued? */
|
||||||
NV_ERROR(dev, "vm flush timeout eng %d\n", engine);
|
if (!nv_wait(dev, 0x100c80, 0x00008000, 0x00008000)) {
|
||||||
|
NV_ERROR(dev, "vm timeout 1: 0x%08x %d\n",
|
||||||
|
nv_rd32(dev, 0x100c80), engine);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
spin_unlock(&dev_priv->ramin_lock);
|
||||||
}
|
}
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include "atom.h"
|
#include "atom.h"
|
||||||
#include "atom-names.h"
|
#include "atom-names.h"
|
||||||
#include "atom-bits.h"
|
#include "atom-bits.h"
|
||||||
|
#include "radeon.h"
|
||||||
|
|
||||||
#define ATOM_COND_ABOVE 0
|
#define ATOM_COND_ABOVE 0
|
||||||
#define ATOM_COND_ABOVEOREQUAL 1
|
#define ATOM_COND_ABOVEOREQUAL 1
|
||||||
@ -101,7 +102,9 @@ static void debug_print_spaces(int n)
|
|||||||
static uint32_t atom_iio_execute(struct atom_context *ctx, int base,
|
static uint32_t atom_iio_execute(struct atom_context *ctx, int base,
|
||||||
uint32_t index, uint32_t data)
|
uint32_t index, uint32_t data)
|
||||||
{
|
{
|
||||||
|
struct radeon_device *rdev = ctx->card->dev->dev_private;
|
||||||
uint32_t temp = 0xCDCDCDCD;
|
uint32_t temp = 0xCDCDCDCD;
|
||||||
|
|
||||||
while (1)
|
while (1)
|
||||||
switch (CU8(base)) {
|
switch (CU8(base)) {
|
||||||
case ATOM_IIO_NOP:
|
case ATOM_IIO_NOP:
|
||||||
@ -112,7 +115,8 @@ static uint32_t atom_iio_execute(struct atom_context *ctx, int base,
|
|||||||
base += 3;
|
base += 3;
|
||||||
break;
|
break;
|
||||||
case ATOM_IIO_WRITE:
|
case ATOM_IIO_WRITE:
|
||||||
(void)ctx->card->ioreg_read(ctx->card, CU16(base + 1));
|
if (rdev->family == CHIP_RV515)
|
||||||
|
(void)ctx->card->ioreg_read(ctx->card, CU16(base + 1));
|
||||||
ctx->card->ioreg_write(ctx->card, CU16(base + 1), temp);
|
ctx->card->ioreg_write(ctx->card, CU16(base + 1), temp);
|
||||||
base += 3;
|
base += 3;
|
||||||
break;
|
break;
|
||||||
|
@ -531,6 +531,12 @@ static u32 atombios_adjust_pll(struct drm_crtc *crtc,
|
|||||||
pll->flags |= RADEON_PLL_PREFER_HIGH_FB_DIV;
|
pll->flags |= RADEON_PLL_PREFER_HIGH_FB_DIV;
|
||||||
else
|
else
|
||||||
pll->flags |= RADEON_PLL_PREFER_LOW_REF_DIV;
|
pll->flags |= RADEON_PLL_PREFER_LOW_REF_DIV;
|
||||||
|
|
||||||
|
if ((rdev->family == CHIP_R600) ||
|
||||||
|
(rdev->family == CHIP_RV610) ||
|
||||||
|
(rdev->family == CHIP_RV630) ||
|
||||||
|
(rdev->family == CHIP_RV670))
|
||||||
|
pll->flags |= RADEON_PLL_PREFER_MINM_OVER_MAXP;
|
||||||
} else {
|
} else {
|
||||||
pll->flags |= RADEON_PLL_LEGACY;
|
pll->flags |= RADEON_PLL_LEGACY;
|
||||||
|
|
||||||
|
@ -120,11 +120,16 @@ void evergreen_pm_misc(struct radeon_device *rdev)
|
|||||||
struct radeon_power_state *ps = &rdev->pm.power_state[req_ps_idx];
|
struct radeon_power_state *ps = &rdev->pm.power_state[req_ps_idx];
|
||||||
struct radeon_voltage *voltage = &ps->clock_info[req_cm_idx].voltage;
|
struct radeon_voltage *voltage = &ps->clock_info[req_cm_idx].voltage;
|
||||||
|
|
||||||
if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
|
if (voltage->type == VOLTAGE_SW) {
|
||||||
if (voltage->voltage != rdev->pm.current_vddc) {
|
if (voltage->voltage && (voltage->voltage != rdev->pm.current_vddc)) {
|
||||||
radeon_atom_set_voltage(rdev, voltage->voltage);
|
radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
rdev->pm.current_vddc = voltage->voltage;
|
rdev->pm.current_vddc = voltage->voltage;
|
||||||
DRM_DEBUG("Setting: v: %d\n", voltage->voltage);
|
DRM_DEBUG("Setting: vddc: %d\n", voltage->voltage);
|
||||||
|
}
|
||||||
|
if (voltage->vddci && (voltage->vddci != rdev->pm.current_vddci)) {
|
||||||
|
radeon_atom_set_voltage(rdev, voltage->vddci, SET_VOLTAGE_TYPE_ASIC_VDDCI);
|
||||||
|
rdev->pm.current_vddci = voltage->vddci;
|
||||||
|
DRM_DEBUG("Setting: vddci: %d\n", voltage->vddci);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -3036,9 +3041,6 @@ int evergreen_init(struct radeon_device *rdev)
|
|||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
r = radeon_dummy_page_init(rdev);
|
|
||||||
if (r)
|
|
||||||
return r;
|
|
||||||
/* This don't do much */
|
/* This don't do much */
|
||||||
r = radeon_gem_init(rdev);
|
r = radeon_gem_init(rdev);
|
||||||
if (r)
|
if (r)
|
||||||
@ -3150,7 +3152,6 @@ void evergreen_fini(struct radeon_device *rdev)
|
|||||||
radeon_atombios_fini(rdev);
|
radeon_atombios_fini(rdev);
|
||||||
kfree(rdev->bios);
|
kfree(rdev->bios);
|
||||||
rdev->bios = NULL;
|
rdev->bios = NULL;
|
||||||
radeon_dummy_page_fini(rdev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void evergreen_pcie_gen2_enable(struct radeon_device *rdev)
|
static void evergreen_pcie_gen2_enable(struct radeon_device *rdev)
|
||||||
|
@ -587,7 +587,7 @@ void r600_pm_misc(struct radeon_device *rdev)
|
|||||||
|
|
||||||
if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
|
if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
|
||||||
if (voltage->voltage != rdev->pm.current_vddc) {
|
if (voltage->voltage != rdev->pm.current_vddc) {
|
||||||
radeon_atom_set_voltage(rdev, voltage->voltage);
|
radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
rdev->pm.current_vddc = voltage->voltage;
|
rdev->pm.current_vddc = voltage->voltage;
|
||||||
DRM_DEBUG_DRIVER("Setting: v: %d\n", voltage->voltage);
|
DRM_DEBUG_DRIVER("Setting: v: %d\n", voltage->voltage);
|
||||||
}
|
}
|
||||||
@ -2509,9 +2509,6 @@ int r600_init(struct radeon_device *rdev)
|
|||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
r = radeon_dummy_page_init(rdev);
|
|
||||||
if (r)
|
|
||||||
return r;
|
|
||||||
if (r600_debugfs_mc_info_init(rdev)) {
|
if (r600_debugfs_mc_info_init(rdev)) {
|
||||||
DRM_ERROR("Failed to register debugfs file for mc !\n");
|
DRM_ERROR("Failed to register debugfs file for mc !\n");
|
||||||
}
|
}
|
||||||
@ -2625,7 +2622,6 @@ void r600_fini(struct radeon_device *rdev)
|
|||||||
radeon_atombios_fini(rdev);
|
radeon_atombios_fini(rdev);
|
||||||
kfree(rdev->bios);
|
kfree(rdev->bios);
|
||||||
rdev->bios = NULL;
|
rdev->bios = NULL;
|
||||||
radeon_dummy_page_fini(rdev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -177,7 +177,7 @@ void radeon_pm_suspend(struct radeon_device *rdev);
|
|||||||
void radeon_pm_resume(struct radeon_device *rdev);
|
void radeon_pm_resume(struct radeon_device *rdev);
|
||||||
void radeon_combios_get_power_modes(struct radeon_device *rdev);
|
void radeon_combios_get_power_modes(struct radeon_device *rdev);
|
||||||
void radeon_atombios_get_power_modes(struct radeon_device *rdev);
|
void radeon_atombios_get_power_modes(struct radeon_device *rdev);
|
||||||
void radeon_atom_set_voltage(struct radeon_device *rdev, u16 level);
|
void radeon_atom_set_voltage(struct radeon_device *rdev, u16 voltage_level, u8 voltage_type);
|
||||||
void rs690_pm_info(struct radeon_device *rdev);
|
void rs690_pm_info(struct radeon_device *rdev);
|
||||||
extern int rv6xx_get_temp(struct radeon_device *rdev);
|
extern int rv6xx_get_temp(struct radeon_device *rdev);
|
||||||
extern int rv770_get_temp(struct radeon_device *rdev);
|
extern int rv770_get_temp(struct radeon_device *rdev);
|
||||||
@ -767,7 +767,9 @@ struct radeon_voltage {
|
|||||||
u8 vddci_id; /* index into vddci voltage table */
|
u8 vddci_id; /* index into vddci voltage table */
|
||||||
bool vddci_enabled;
|
bool vddci_enabled;
|
||||||
/* r6xx+ sw */
|
/* r6xx+ sw */
|
||||||
u32 voltage;
|
u16 voltage;
|
||||||
|
/* evergreen+ vddci */
|
||||||
|
u16 vddci;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* clock mode flags */
|
/* clock mode flags */
|
||||||
@ -835,10 +837,12 @@ struct radeon_pm {
|
|||||||
int default_power_state_index;
|
int default_power_state_index;
|
||||||
u32 current_sclk;
|
u32 current_sclk;
|
||||||
u32 current_mclk;
|
u32 current_mclk;
|
||||||
u32 current_vddc;
|
u16 current_vddc;
|
||||||
|
u16 current_vddci;
|
||||||
u32 default_sclk;
|
u32 default_sclk;
|
||||||
u32 default_mclk;
|
u32 default_mclk;
|
||||||
u32 default_vddc;
|
u16 default_vddc;
|
||||||
|
u16 default_vddci;
|
||||||
struct radeon_i2c_chan *i2c_bus;
|
struct radeon_i2c_chan *i2c_bus;
|
||||||
/* selected pm method */
|
/* selected pm method */
|
||||||
enum radeon_pm_method pm_method;
|
enum radeon_pm_method pm_method;
|
||||||
|
@ -94,7 +94,7 @@ static void radeon_register_accessor_init(struct radeon_device *rdev)
|
|||||||
rdev->mc_rreg = &rs600_mc_rreg;
|
rdev->mc_rreg = &rs600_mc_rreg;
|
||||||
rdev->mc_wreg = &rs600_mc_wreg;
|
rdev->mc_wreg = &rs600_mc_wreg;
|
||||||
}
|
}
|
||||||
if ((rdev->family >= CHIP_R600) && (rdev->family <= CHIP_HEMLOCK)) {
|
if (rdev->family >= CHIP_R600) {
|
||||||
rdev->pciep_rreg = &r600_pciep_rreg;
|
rdev->pciep_rreg = &r600_pciep_rreg;
|
||||||
rdev->pciep_wreg = &r600_pciep_wreg;
|
rdev->pciep_wreg = &r600_pciep_wreg;
|
||||||
}
|
}
|
||||||
|
@ -2176,24 +2176,27 @@ static void radeon_atombios_add_pplib_thermal_controller(struct radeon_device *r
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static u16 radeon_atombios_get_default_vddc(struct radeon_device *rdev)
|
static void radeon_atombios_get_default_voltages(struct radeon_device *rdev,
|
||||||
|
u16 *vddc, u16 *vddci)
|
||||||
{
|
{
|
||||||
struct radeon_mode_info *mode_info = &rdev->mode_info;
|
struct radeon_mode_info *mode_info = &rdev->mode_info;
|
||||||
int index = GetIndexIntoMasterTable(DATA, FirmwareInfo);
|
int index = GetIndexIntoMasterTable(DATA, FirmwareInfo);
|
||||||
u8 frev, crev;
|
u8 frev, crev;
|
||||||
u16 data_offset;
|
u16 data_offset;
|
||||||
union firmware_info *firmware_info;
|
union firmware_info *firmware_info;
|
||||||
u16 vddc = 0;
|
|
||||||
|
*vddc = 0;
|
||||||
|
*vddci = 0;
|
||||||
|
|
||||||
if (atom_parse_data_header(mode_info->atom_context, index, NULL,
|
if (atom_parse_data_header(mode_info->atom_context, index, NULL,
|
||||||
&frev, &crev, &data_offset)) {
|
&frev, &crev, &data_offset)) {
|
||||||
firmware_info =
|
firmware_info =
|
||||||
(union firmware_info *)(mode_info->atom_context->bios +
|
(union firmware_info *)(mode_info->atom_context->bios +
|
||||||
data_offset);
|
data_offset);
|
||||||
vddc = le16_to_cpu(firmware_info->info_14.usBootUpVDDCVoltage);
|
*vddc = le16_to_cpu(firmware_info->info_14.usBootUpVDDCVoltage);
|
||||||
|
if ((frev == 2) && (crev >= 2))
|
||||||
|
*vddci = le16_to_cpu(firmware_info->info_22.usBootUpVDDCIVoltage);
|
||||||
}
|
}
|
||||||
|
|
||||||
return vddc;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void radeon_atombios_parse_pplib_non_clock_info(struct radeon_device *rdev,
|
static void radeon_atombios_parse_pplib_non_clock_info(struct radeon_device *rdev,
|
||||||
@ -2203,7 +2206,9 @@ static void radeon_atombios_parse_pplib_non_clock_info(struct radeon_device *rde
|
|||||||
int j;
|
int j;
|
||||||
u32 misc = le32_to_cpu(non_clock_info->ulCapsAndSettings);
|
u32 misc = le32_to_cpu(non_clock_info->ulCapsAndSettings);
|
||||||
u32 misc2 = le16_to_cpu(non_clock_info->usClassification);
|
u32 misc2 = le16_to_cpu(non_clock_info->usClassification);
|
||||||
u16 vddc = radeon_atombios_get_default_vddc(rdev);
|
u16 vddc, vddci;
|
||||||
|
|
||||||
|
radeon_atombios_get_default_voltages(rdev, &vddc, &vddci);
|
||||||
|
|
||||||
rdev->pm.power_state[state_index].misc = misc;
|
rdev->pm.power_state[state_index].misc = misc;
|
||||||
rdev->pm.power_state[state_index].misc2 = misc2;
|
rdev->pm.power_state[state_index].misc2 = misc2;
|
||||||
@ -2244,6 +2249,7 @@ static void radeon_atombios_parse_pplib_non_clock_info(struct radeon_device *rde
|
|||||||
rdev->pm.default_sclk = rdev->pm.power_state[state_index].clock_info[0].sclk;
|
rdev->pm.default_sclk = rdev->pm.power_state[state_index].clock_info[0].sclk;
|
||||||
rdev->pm.default_mclk = rdev->pm.power_state[state_index].clock_info[0].mclk;
|
rdev->pm.default_mclk = rdev->pm.power_state[state_index].clock_info[0].mclk;
|
||||||
rdev->pm.default_vddc = rdev->pm.power_state[state_index].clock_info[0].voltage.voltage;
|
rdev->pm.default_vddc = rdev->pm.power_state[state_index].clock_info[0].voltage.voltage;
|
||||||
|
rdev->pm.default_vddci = rdev->pm.power_state[state_index].clock_info[0].voltage.vddci;
|
||||||
} else {
|
} else {
|
||||||
/* patch the table values with the default slck/mclk from firmware info */
|
/* patch the table values with the default slck/mclk from firmware info */
|
||||||
for (j = 0; j < mode_index; j++) {
|
for (j = 0; j < mode_index; j++) {
|
||||||
@ -2286,6 +2292,8 @@ static bool radeon_atombios_parse_pplib_clock_info(struct radeon_device *rdev,
|
|||||||
VOLTAGE_SW;
|
VOLTAGE_SW;
|
||||||
rdev->pm.power_state[state_index].clock_info[mode_index].voltage.voltage =
|
rdev->pm.power_state[state_index].clock_info[mode_index].voltage.voltage =
|
||||||
le16_to_cpu(clock_info->evergreen.usVDDC);
|
le16_to_cpu(clock_info->evergreen.usVDDC);
|
||||||
|
rdev->pm.power_state[state_index].clock_info[mode_index].voltage.vddci =
|
||||||
|
le16_to_cpu(clock_info->evergreen.usVDDCI);
|
||||||
} else {
|
} else {
|
||||||
sclk = le16_to_cpu(clock_info->r600.usEngineClockLow);
|
sclk = le16_to_cpu(clock_info->r600.usEngineClockLow);
|
||||||
sclk |= clock_info->r600.ucEngineClockHigh << 16;
|
sclk |= clock_info->r600.ucEngineClockHigh << 16;
|
||||||
@ -2577,25 +2585,25 @@ union set_voltage {
|
|||||||
struct _SET_VOLTAGE_PARAMETERS_V2 v2;
|
struct _SET_VOLTAGE_PARAMETERS_V2 v2;
|
||||||
};
|
};
|
||||||
|
|
||||||
void radeon_atom_set_voltage(struct radeon_device *rdev, u16 level)
|
void radeon_atom_set_voltage(struct radeon_device *rdev, u16 voltage_level, u8 voltage_type)
|
||||||
{
|
{
|
||||||
union set_voltage args;
|
union set_voltage args;
|
||||||
int index = GetIndexIntoMasterTable(COMMAND, SetVoltage);
|
int index = GetIndexIntoMasterTable(COMMAND, SetVoltage);
|
||||||
u8 frev, crev, volt_index = level;
|
u8 frev, crev, volt_index = voltage_level;
|
||||||
|
|
||||||
if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev))
|
if (!atom_parse_cmd_header(rdev->mode_info.atom_context, index, &frev, &crev))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
switch (crev) {
|
switch (crev) {
|
||||||
case 1:
|
case 1:
|
||||||
args.v1.ucVoltageType = SET_VOLTAGE_TYPE_ASIC_VDDC;
|
args.v1.ucVoltageType = voltage_type;
|
||||||
args.v1.ucVoltageMode = SET_ASIC_VOLTAGE_MODE_ALL_SOURCE;
|
args.v1.ucVoltageMode = SET_ASIC_VOLTAGE_MODE_ALL_SOURCE;
|
||||||
args.v1.ucVoltageIndex = volt_index;
|
args.v1.ucVoltageIndex = volt_index;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
args.v2.ucVoltageType = SET_VOLTAGE_TYPE_ASIC_VDDC;
|
args.v2.ucVoltageType = voltage_type;
|
||||||
args.v2.ucVoltageMode = SET_ASIC_VOLTAGE_MODE_SET_VOLTAGE;
|
args.v2.ucVoltageMode = SET_ASIC_VOLTAGE_MODE_SET_VOLTAGE;
|
||||||
args.v2.usVoltageLevel = cpu_to_le16(level);
|
args.v2.usVoltageLevel = cpu_to_le16(voltage_level);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
DRM_ERROR("Unknown table version %d, %d\n", frev, crev);
|
DRM_ERROR("Unknown table version %d, %d\n", frev, crev);
|
||||||
|
@ -79,7 +79,7 @@ static bool radeon_fence_poll_locked(struct radeon_device *rdev)
|
|||||||
scratch_index = R600_WB_EVENT_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
|
scratch_index = R600_WB_EVENT_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
|
||||||
else
|
else
|
||||||
scratch_index = RADEON_WB_SCRATCH_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
|
scratch_index = RADEON_WB_SCRATCH_OFFSET + rdev->fence_drv.scratch_reg - rdev->scratch.reg_base;
|
||||||
seq = rdev->wb.wb[scratch_index/4];
|
seq = le32_to_cpu(rdev->wb.wb[scratch_index/4]);
|
||||||
} else
|
} else
|
||||||
seq = RREG32(rdev->fence_drv.scratch_reg);
|
seq = RREG32(rdev->fence_drv.scratch_reg);
|
||||||
if (seq != rdev->fence_drv.last_seq) {
|
if (seq != rdev->fence_drv.last_seq) {
|
||||||
|
@ -285,4 +285,6 @@ void radeon_gart_fini(struct radeon_device *rdev)
|
|||||||
rdev->gart.pages = NULL;
|
rdev->gart.pages = NULL;
|
||||||
rdev->gart.pages_addr = NULL;
|
rdev->gart.pages_addr = NULL;
|
||||||
rdev->gart.ttm_alloced = NULL;
|
rdev->gart.ttm_alloced = NULL;
|
||||||
|
|
||||||
|
radeon_dummy_page_fini(rdev);
|
||||||
}
|
}
|
||||||
|
@ -1062,7 +1062,7 @@ void radeon_i2c_get_byte(struct radeon_i2c_chan *i2c_bus,
|
|||||||
*val = in_buf[0];
|
*val = in_buf[0];
|
||||||
DRM_DEBUG("val = 0x%02x\n", *val);
|
DRM_DEBUG("val = 0x%02x\n", *val);
|
||||||
} else {
|
} else {
|
||||||
DRM_ERROR("i2c 0x%02x 0x%02x read failed\n",
|
DRM_DEBUG("i2c 0x%02x 0x%02x read failed\n",
|
||||||
addr, *val);
|
addr, *val);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1084,7 +1084,7 @@ void radeon_i2c_put_byte(struct radeon_i2c_chan *i2c_bus,
|
|||||||
out_buf[1] = val;
|
out_buf[1] = val;
|
||||||
|
|
||||||
if (i2c_transfer(&i2c_bus->adapter, &msg, 1) != 1)
|
if (i2c_transfer(&i2c_bus->adapter, &msg, 1) != 1)
|
||||||
DRM_ERROR("i2c 0x%02x 0x%02x write failed\n",
|
DRM_DEBUG("i2c 0x%02x 0x%02x write failed\n",
|
||||||
addr, val);
|
addr, val);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -269,7 +269,7 @@ static const struct drm_encoder_helper_funcs radeon_legacy_lvds_helper_funcs = {
|
|||||||
.disable = radeon_legacy_encoder_disable,
|
.disable = radeon_legacy_encoder_disable,
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_BACKLIGHT_CLASS_DEVICE
|
#if defined(CONFIG_BACKLIGHT_CLASS_DEVICE) || defined(CONFIG_BACKLIGHT_CLASS_DEVICE_MODULE)
|
||||||
|
|
||||||
#define MAX_RADEON_LEVEL 0xFF
|
#define MAX_RADEON_LEVEL 0xFF
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "drmP.h"
|
#include "drmP.h"
|
||||||
#include "radeon.h"
|
#include "radeon.h"
|
||||||
#include "avivod.h"
|
#include "avivod.h"
|
||||||
|
#include "atom.h"
|
||||||
#ifdef CONFIG_ACPI
|
#ifdef CONFIG_ACPI
|
||||||
#include <linux/acpi.h>
|
#include <linux/acpi.h>
|
||||||
#endif
|
#endif
|
||||||
@ -535,7 +536,11 @@ void radeon_pm_resume(struct radeon_device *rdev)
|
|||||||
/* set up the default clocks if the MC ucode is loaded */
|
/* set up the default clocks if the MC ucode is loaded */
|
||||||
if (ASIC_IS_DCE5(rdev) && rdev->mc_fw) {
|
if (ASIC_IS_DCE5(rdev) && rdev->mc_fw) {
|
||||||
if (rdev->pm.default_vddc)
|
if (rdev->pm.default_vddc)
|
||||||
radeon_atom_set_voltage(rdev, rdev->pm.default_vddc);
|
radeon_atom_set_voltage(rdev, rdev->pm.default_vddc,
|
||||||
|
SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
|
if (rdev->pm.default_vddci)
|
||||||
|
radeon_atom_set_voltage(rdev, rdev->pm.default_vddci,
|
||||||
|
SET_VOLTAGE_TYPE_ASIC_VDDCI);
|
||||||
if (rdev->pm.default_sclk)
|
if (rdev->pm.default_sclk)
|
||||||
radeon_set_engine_clock(rdev, rdev->pm.default_sclk);
|
radeon_set_engine_clock(rdev, rdev->pm.default_sclk);
|
||||||
if (rdev->pm.default_mclk)
|
if (rdev->pm.default_mclk)
|
||||||
@ -548,6 +553,7 @@ void radeon_pm_resume(struct radeon_device *rdev)
|
|||||||
rdev->pm.current_sclk = rdev->pm.default_sclk;
|
rdev->pm.current_sclk = rdev->pm.default_sclk;
|
||||||
rdev->pm.current_mclk = rdev->pm.default_mclk;
|
rdev->pm.current_mclk = rdev->pm.default_mclk;
|
||||||
rdev->pm.current_vddc = rdev->pm.power_state[rdev->pm.default_power_state_index].clock_info[0].voltage.voltage;
|
rdev->pm.current_vddc = rdev->pm.power_state[rdev->pm.default_power_state_index].clock_info[0].voltage.voltage;
|
||||||
|
rdev->pm.current_vddci = rdev->pm.power_state[rdev->pm.default_power_state_index].clock_info[0].voltage.vddci;
|
||||||
if (rdev->pm.pm_method == PM_METHOD_DYNPM
|
if (rdev->pm.pm_method == PM_METHOD_DYNPM
|
||||||
&& rdev->pm.dynpm_state == DYNPM_STATE_SUSPENDED) {
|
&& rdev->pm.dynpm_state == DYNPM_STATE_SUSPENDED) {
|
||||||
rdev->pm.dynpm_state = DYNPM_STATE_ACTIVE;
|
rdev->pm.dynpm_state = DYNPM_STATE_ACTIVE;
|
||||||
@ -585,7 +591,8 @@ int radeon_pm_init(struct radeon_device *rdev)
|
|||||||
/* set up the default clocks if the MC ucode is loaded */
|
/* set up the default clocks if the MC ucode is loaded */
|
||||||
if (ASIC_IS_DCE5(rdev) && rdev->mc_fw) {
|
if (ASIC_IS_DCE5(rdev) && rdev->mc_fw) {
|
||||||
if (rdev->pm.default_vddc)
|
if (rdev->pm.default_vddc)
|
||||||
radeon_atom_set_voltage(rdev, rdev->pm.default_vddc);
|
radeon_atom_set_voltage(rdev, rdev->pm.default_vddc,
|
||||||
|
SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
if (rdev->pm.default_sclk)
|
if (rdev->pm.default_sclk)
|
||||||
radeon_set_engine_clock(rdev, rdev->pm.default_sclk);
|
radeon_set_engine_clock(rdev, rdev->pm.default_sclk);
|
||||||
if (rdev->pm.default_mclk)
|
if (rdev->pm.default_mclk)
|
||||||
|
@ -248,7 +248,7 @@ void radeon_ib_pool_fini(struct radeon_device *rdev)
|
|||||||
void radeon_ring_free_size(struct radeon_device *rdev)
|
void radeon_ring_free_size(struct radeon_device *rdev)
|
||||||
{
|
{
|
||||||
if (rdev->wb.enabled)
|
if (rdev->wb.enabled)
|
||||||
rdev->cp.rptr = rdev->wb.wb[RADEON_WB_CP_RPTR_OFFSET/4];
|
rdev->cp.rptr = le32_to_cpu(rdev->wb.wb[RADEON_WB_CP_RPTR_OFFSET/4]);
|
||||||
else {
|
else {
|
||||||
if (rdev->family >= CHIP_R600)
|
if (rdev->family >= CHIP_R600)
|
||||||
rdev->cp.rptr = RREG32(R600_CP_RB_RPTR);
|
rdev->cp.rptr = RREG32(R600_CP_RB_RPTR);
|
||||||
|
@ -114,7 +114,7 @@ void rs600_pm_misc(struct radeon_device *rdev)
|
|||||||
udelay(voltage->delay);
|
udelay(voltage->delay);
|
||||||
}
|
}
|
||||||
} else if (voltage->type == VOLTAGE_VDDC)
|
} else if (voltage->type == VOLTAGE_VDDC)
|
||||||
radeon_atom_set_voltage(rdev, voltage->vddc_id);
|
radeon_atom_set_voltage(rdev, voltage->vddc_id, SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
|
|
||||||
dyn_pwrmgt_sclk_length = RREG32_PLL(DYN_PWRMGT_SCLK_LENGTH);
|
dyn_pwrmgt_sclk_length = RREG32_PLL(DYN_PWRMGT_SCLK_LENGTH);
|
||||||
dyn_pwrmgt_sclk_length &= ~REDUCED_POWER_SCLK_HILEN(0xf);
|
dyn_pwrmgt_sclk_length &= ~REDUCED_POWER_SCLK_HILEN(0xf);
|
||||||
|
@ -106,7 +106,7 @@ void rv770_pm_misc(struct radeon_device *rdev)
|
|||||||
|
|
||||||
if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
|
if ((voltage->type == VOLTAGE_SW) && voltage->voltage) {
|
||||||
if (voltage->voltage != rdev->pm.current_vddc) {
|
if (voltage->voltage != rdev->pm.current_vddc) {
|
||||||
radeon_atom_set_voltage(rdev, voltage->voltage);
|
radeon_atom_set_voltage(rdev, voltage->voltage, SET_VOLTAGE_TYPE_ASIC_VDDC);
|
||||||
rdev->pm.current_vddc = voltage->voltage;
|
rdev->pm.current_vddc = voltage->voltage;
|
||||||
DRM_DEBUG("Setting: v: %d\n", voltage->voltage);
|
DRM_DEBUG("Setting: v: %d\n", voltage->voltage);
|
||||||
}
|
}
|
||||||
@ -1255,9 +1255,6 @@ int rv770_init(struct radeon_device *rdev)
|
|||||||
{
|
{
|
||||||
int r;
|
int r;
|
||||||
|
|
||||||
r = radeon_dummy_page_init(rdev);
|
|
||||||
if (r)
|
|
||||||
return r;
|
|
||||||
/* This don't do much */
|
/* This don't do much */
|
||||||
r = radeon_gem_init(rdev);
|
r = radeon_gem_init(rdev);
|
||||||
if (r)
|
if (r)
|
||||||
@ -1372,7 +1369,6 @@ void rv770_fini(struct radeon_device *rdev)
|
|||||||
radeon_atombios_fini(rdev);
|
radeon_atombios_fini(rdev);
|
||||||
kfree(rdev->bios);
|
kfree(rdev->bios);
|
||||||
rdev->bios = NULL;
|
rdev->bios = NULL;
|
||||||
radeon_dummy_page_fini(rdev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void rv770_pcie_gen2_enable(struct radeon_device *rdev)
|
static void rv770_pcie_gen2_enable(struct radeon_device *rdev)
|
||||||
|
@ -683,22 +683,14 @@ int ttm_get_pages(struct list_head *pages, int flags,
|
|||||||
gfp_flags |= GFP_HIGHUSER;
|
gfp_flags |= GFP_HIGHUSER;
|
||||||
|
|
||||||
for (r = 0; r < count; ++r) {
|
for (r = 0; r < count; ++r) {
|
||||||
if ((flags & TTM_PAGE_FLAG_DMA32) && dma_address) {
|
p = alloc_page(gfp_flags);
|
||||||
void *addr;
|
|
||||||
addr = dma_alloc_coherent(NULL, PAGE_SIZE,
|
|
||||||
&dma_address[r],
|
|
||||||
gfp_flags);
|
|
||||||
if (addr == NULL)
|
|
||||||
return -ENOMEM;
|
|
||||||
p = virt_to_page(addr);
|
|
||||||
} else
|
|
||||||
p = alloc_page(gfp_flags);
|
|
||||||
if (!p) {
|
if (!p) {
|
||||||
|
|
||||||
printk(KERN_ERR TTM_PFX
|
printk(KERN_ERR TTM_PFX
|
||||||
"Unable to allocate page.");
|
"Unable to allocate page.");
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
}
|
}
|
||||||
|
|
||||||
list_add(&p->lru, pages);
|
list_add(&p->lru, pages);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
@ -746,24 +738,12 @@ void ttm_put_pages(struct list_head *pages, unsigned page_count, int flags,
|
|||||||
unsigned long irq_flags;
|
unsigned long irq_flags;
|
||||||
struct ttm_page_pool *pool = ttm_get_pool(flags, cstate);
|
struct ttm_page_pool *pool = ttm_get_pool(flags, cstate);
|
||||||
struct page *p, *tmp;
|
struct page *p, *tmp;
|
||||||
unsigned r;
|
|
||||||
|
|
||||||
if (pool == NULL) {
|
if (pool == NULL) {
|
||||||
/* No pool for this memory type so free the pages */
|
/* No pool for this memory type so free the pages */
|
||||||
|
|
||||||
r = page_count-1;
|
|
||||||
list_for_each_entry_safe(p, tmp, pages, lru) {
|
list_for_each_entry_safe(p, tmp, pages, lru) {
|
||||||
if ((flags & TTM_PAGE_FLAG_DMA32) && dma_address) {
|
__free_page(p);
|
||||||
void *addr = page_address(p);
|
|
||||||
WARN_ON(!addr || !dma_address[r]);
|
|
||||||
if (addr)
|
|
||||||
dma_free_coherent(NULL, PAGE_SIZE,
|
|
||||||
addr,
|
|
||||||
dma_address[r]);
|
|
||||||
dma_address[r] = 0;
|
|
||||||
} else
|
|
||||||
__free_page(p);
|
|
||||||
r--;
|
|
||||||
}
|
}
|
||||||
/* Make the pages list empty */
|
/* Make the pages list empty */
|
||||||
INIT_LIST_HEAD(pages);
|
INIT_LIST_HEAD(pages);
|
||||||
|
@ -5,6 +5,7 @@ config STUB_POULSBO
|
|||||||
# Poulsbo stub depends on ACPI_VIDEO when ACPI is enabled
|
# Poulsbo stub depends on ACPI_VIDEO when ACPI is enabled
|
||||||
# but for select to work, need to select ACPI_VIDEO's dependencies, ick
|
# but for select to work, need to select ACPI_VIDEO's dependencies, ick
|
||||||
select BACKLIGHT_CLASS_DEVICE if ACPI
|
select BACKLIGHT_CLASS_DEVICE if ACPI
|
||||||
|
select VIDEO_OUTPUT_CONTROL if ACPI
|
||||||
select INPUT if ACPI
|
select INPUT if ACPI
|
||||||
select ACPI_VIDEO if ACPI
|
select ACPI_VIDEO if ACPI
|
||||||
select THERMAL if ACPI
|
select THERMAL if ACPI
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user