mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-04 04:16:46 +07:00
Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6 into s3c-fixes
This commit is contained in:
commit
1264fa6f8c
@ -1,3 +1,46 @@
|
|||||||
|
What: /sys/bus/pci/drivers/.../bind
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device location to this file will cause
|
||||||
|
the driver to attempt to bind to the device found at
|
||||||
|
this location. This is useful for overriding default
|
||||||
|
bindings. The format for the location is: DDDD:BB:DD.F.
|
||||||
|
That is Domain:Bus:Device.Function and is the same as
|
||||||
|
found in /sys/bus/pci/devices/. For example:
|
||||||
|
# echo 0000:00:19.0 > /sys/bus/pci/drivers/foo/bind
|
||||||
|
(Note: kernels before 2.6.28 may require echo -n).
|
||||||
|
|
||||||
|
What: /sys/bus/pci/drivers/.../unbind
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device location to this file will cause the
|
||||||
|
driver to attempt to unbind from the device found at
|
||||||
|
this location. This may be useful when overriding default
|
||||||
|
bindings. The format for the location is: DDDD:BB:DD.F.
|
||||||
|
That is Domain:Bus:Device.Function and is the same as
|
||||||
|
found in /sys/bus/pci/devices/. For example:
|
||||||
|
# echo 0000:00:19.0 > /sys/bus/pci/drivers/foo/unbind
|
||||||
|
(Note: kernels before 2.6.28 may require echo -n).
|
||||||
|
|
||||||
|
What: /sys/bus/pci/drivers/.../new_id
|
||||||
|
Date: December 2003
|
||||||
|
Contact: linux-pci@vger.kernel.org
|
||||||
|
Description:
|
||||||
|
Writing a device ID to this file will attempt to
|
||||||
|
dynamically add a new device ID to a PCI device driver.
|
||||||
|
This may allow the driver to support more hardware than
|
||||||
|
was included in the driver's static device ID support
|
||||||
|
table at compile time. The format for the device ID is:
|
||||||
|
VVVV DDDD SVVV SDDD CCCC MMMM PPPP. That is Vendor ID,
|
||||||
|
Device ID, Subsystem Vendor ID, Subsystem Device ID,
|
||||||
|
Class, Class Mask, and Private Driver Data. The Vendor ID
|
||||||
|
and Device ID fields are required, the rest are optional.
|
||||||
|
Upon successfully adding an ID, the driver will probe
|
||||||
|
for the device and attempt to bind to it. For example:
|
||||||
|
# echo "8086 10f5" > /sys/bus/pci/drivers/foo/new_id
|
||||||
|
|
||||||
What: /sys/bus/pci/devices/.../vpd
|
What: /sys/bus/pci/devices/.../vpd
|
||||||
Date: February 2008
|
Date: February 2008
|
||||||
Contact: Ben Hutchings <bhutchings@solarflare.com>
|
Contact: Ben Hutchings <bhutchings@solarflare.com>
|
||||||
|
@ -1,205 +0,0 @@
|
|||||||
This README escorted the skystar2-driver rewriting procedure. It describes the
|
|
||||||
state of the new flexcop-driver set and some internals are written down here
|
|
||||||
too.
|
|
||||||
|
|
||||||
This document hopefully describes things about the flexcop and its
|
|
||||||
device-offsprings. Goal was to write an easy-to-write and easy-to-read set of
|
|
||||||
drivers based on the skystar2.c and other information.
|
|
||||||
|
|
||||||
Remark: flexcop-pci.c was a copy of skystar2.c, but every line has been
|
|
||||||
touched and rewritten.
|
|
||||||
|
|
||||||
History & News
|
|
||||||
==============
|
|
||||||
2005-04-01 - correct USB ISOC transfers (thanks to Vadim Catana)
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
General coding processing
|
|
||||||
=========================
|
|
||||||
|
|
||||||
We should proceed as follows (as long as no one complains):
|
|
||||||
|
|
||||||
0) Think before start writing code!
|
|
||||||
|
|
||||||
1) rewriting the skystar2.c with the help of the flexcop register descriptions
|
|
||||||
and splitting up the files to a pci-bus-part and a flexcop-part.
|
|
||||||
The new driver will be called b2c2-flexcop-pci.ko/b2c2-flexcop-usb.ko for the
|
|
||||||
device-specific part and b2c2-flexcop.ko for the common flexcop-functions.
|
|
||||||
|
|
||||||
2) Search for errors in the leftover of flexcop-pci.c (compare with pluto2.c
|
|
||||||
and other pci drivers)
|
|
||||||
|
|
||||||
3) make some beautification (see 'Improvements when rewriting (refactoring) is
|
|
||||||
done')
|
|
||||||
|
|
||||||
4) Testing the new driver and maybe substitute the skystar2.c with it, to reach
|
|
||||||
a wider tester audience.
|
|
||||||
|
|
||||||
5) creating an usb-bus-part using the already written flexcop code for the pci
|
|
||||||
card.
|
|
||||||
|
|
||||||
Idea: create a kernel-object for the flexcop and export all important
|
|
||||||
functions. This option saves kernel-memory, but maybe a lot of functions have
|
|
||||||
to be exported to kernel namespace.
|
|
||||||
|
|
||||||
|
|
||||||
Current situation
|
|
||||||
=================
|
|
||||||
|
|
||||||
0) Done :)
|
|
||||||
1) Done (some minor issues left)
|
|
||||||
2) Done
|
|
||||||
3) Not ready yet, more information is necessary
|
|
||||||
4) next to be done (see the table below)
|
|
||||||
5) USB driver is working (yes, there are some minor issues)
|
|
||||||
|
|
||||||
What seems to be ready?
|
|
||||||
-----------------------
|
|
||||||
|
|
||||||
1) Rewriting
|
|
||||||
1a) i2c is cut off from the flexcop-pci.c and seems to work
|
|
||||||
1b) moved tuner and demod stuff from flexcop-pci.c to flexcop-tuner-fe.c
|
|
||||||
1c) moved lnb and diseqc stuff from flexcop-pci.c to flexcop-tuner-fe.c
|
|
||||||
1e) eeprom (reading MAC address)
|
|
||||||
1d) sram (no dynamic sll size detection (commented out) (using default as JJ told me))
|
|
||||||
1f) misc. register accesses for reading parameters (e.g. resetting, revision)
|
|
||||||
1g) pid/mac filter (flexcop-hw-filter.c)
|
|
||||||
1i) dvb-stuff initialization in flexcop.c (done)
|
|
||||||
1h) dma stuff (now just using the size-irq, instead of all-together, to be done)
|
|
||||||
1j) remove flexcop initialization from flexcop-pci.c completely (done)
|
|
||||||
1l) use a well working dma IRQ method (done, see 'Known bugs and problems and TODO')
|
|
||||||
1k) cleanup flexcop-files (remove unused EXPORT_SYMBOLs, make static from
|
|
||||||
non-static where possible, moved code to proper places)
|
|
||||||
|
|
||||||
2) Search for errors in the leftover of flexcop-pci.c (partially done)
|
|
||||||
5a) add MAC address reading
|
|
||||||
5c) feeding of ISOC data to the software demux (format of the isochronous data
|
|
||||||
and speed optimization, no real error) (thanks to Vadim Catana)
|
|
||||||
|
|
||||||
What to do in the near future?
|
|
||||||
--------------------------------------
|
|
||||||
(no special order here)
|
|
||||||
|
|
||||||
5) USB driver
|
|
||||||
5b) optimize isoc-transfer (submitting/killing isoc URBs when transfer is starting)
|
|
||||||
|
|
||||||
Testing changes
|
|
||||||
---------------
|
|
||||||
|
|
||||||
O = item is working
|
|
||||||
P = item is partially working
|
|
||||||
X = item is not working
|
|
||||||
N = item does not apply here
|
|
||||||
<empty field> = item need to be examined
|
|
||||||
|
|
||||||
| PCI | USB
|
|
||||||
item | mt352 | nxt2002 | stv0299 | mt312 | mt352 | nxt2002 | stv0299 | mt312
|
|
||||||
-------+-------+---------+---------+-------+-------+---------+---------+-------
|
|
||||||
1a) | O | | | | N | N | N | N
|
|
||||||
1b) | O | | | | | | O |
|
|
||||||
1c) | N | N | | | N | N | O |
|
|
||||||
1d) | O | O
|
|
||||||
1e) | O | O
|
|
||||||
1f) | P
|
|
||||||
1g) | O
|
|
||||||
1h) | P |
|
|
||||||
1i) | O | N
|
|
||||||
1j) | O | N
|
|
||||||
1l) | O | N
|
|
||||||
2) | O | N
|
|
||||||
5a) | N | O
|
|
||||||
5b)* | N |
|
|
||||||
5c) | N | O
|
|
||||||
|
|
||||||
* - not done yet
|
|
||||||
|
|
||||||
Known bugs and problems and TODO
|
|
||||||
--------------------------------
|
|
||||||
|
|
||||||
1g/h/l) when pid filtering is enabled on the pci card
|
|
||||||
|
|
||||||
DMA usage currently:
|
|
||||||
The DMA is splitted in 2 equal-sized subbuffers. The Flexcop writes to first
|
|
||||||
address and triggers an IRQ when it's full and starts writing to the second
|
|
||||||
address. When the second address is full, the IRQ is triggered again, and
|
|
||||||
the flexcop writes to first address again, and so on.
|
|
||||||
The buffersize of each address is currently 640*188 bytes.
|
|
||||||
|
|
||||||
Problem is, when using hw-pid-filtering and doing some low-bandwidth
|
|
||||||
operation (like scanning) the buffers won't be filled enough to trigger
|
|
||||||
the IRQ. That's why:
|
|
||||||
|
|
||||||
When PID filtering is activated, the timer IRQ is used. Every 1.97 ms the IRQ
|
|
||||||
is triggered. Is the current write address of DMA1 different to the one
|
|
||||||
during the last IRQ, then the data is passed to the demuxer.
|
|
||||||
|
|
||||||
There is an additional DMA-IRQ-method: packet count IRQ. This isn't
|
|
||||||
implemented correctly yet.
|
|
||||||
|
|
||||||
The solution is to disable HW PID filtering, but I don't know how the DVB
|
|
||||||
API software demux behaves on slow systems with 45MBit/s TS.
|
|
||||||
|
|
||||||
Solved bugs :)
|
|
||||||
--------------
|
|
||||||
1g) pid-filtering (somehow pid index 4 and 5 (EMM_PID and ECM_PID) aren't
|
|
||||||
working)
|
|
||||||
SOLUTION: also index 0 was affected, because net_translation is done for
|
|
||||||
these indexes by default
|
|
||||||
|
|
||||||
5b) isochronous transfer does only work in the first attempt (for the Sky2PC
|
|
||||||
USB, Air2PC is working) SOLUTION: the flexcop was going asleep and never really
|
|
||||||
woke up again (don't know if this need fixes, see
|
|
||||||
flexcop-fe-tuner.c:flexcop_sleep)
|
|
||||||
|
|
||||||
NEWS: when the driver is loaded and unloaded and loaded again (w/o doing
|
|
||||||
anything in the while the driver is loaded the first time), no transfers take
|
|
||||||
place anymore.
|
|
||||||
|
|
||||||
Improvements when rewriting (refactoring) is done
|
|
||||||
=================================================
|
|
||||||
|
|
||||||
- split sleeping of the flexcop (misc_204.ACPI3_sig = 1;) from lnb_control
|
|
||||||
(enable sleeping for other demods than dvb-s)
|
|
||||||
- add support for CableStar (stv0297 Microtune 203x/ALPS) (almost done, incompatibilities with the Nexus-CA)
|
|
||||||
|
|
||||||
Debugging
|
|
||||||
---------
|
|
||||||
- add verbose debugging to skystar2.c (dump the reg_dw_data) and compare it
|
|
||||||
with this flexcop, this is important, because i2c is now using the
|
|
||||||
flexcop_ibi_value union from flexcop-reg.h (do you have a better idea for
|
|
||||||
that, please tell us so).
|
|
||||||
|
|
||||||
Everything which is identical in the following table, can be put into a common
|
|
||||||
flexcop-module.
|
|
||||||
|
|
||||||
PCI USB
|
|
||||||
-------------------------------------------------------------------------------
|
|
||||||
Different:
|
|
||||||
Register access: accessing IO memory USB control message
|
|
||||||
I2C bus: I2C bus of the FC USB control message
|
|
||||||
Data transfer: DMA isochronous transfer
|
|
||||||
EEPROM transfer: through i2c bus not clear yet
|
|
||||||
|
|
||||||
Identical:
|
|
||||||
Streaming: accessing registers
|
|
||||||
PID Filtering: accessing registers
|
|
||||||
Sram destinations: accessing registers
|
|
||||||
Tuner/Demod: I2C bus
|
|
||||||
DVB-stuff: can be written for common use
|
|
||||||
|
|
||||||
Acknowledgements (just for the rewriting part)
|
|
||||||
================
|
|
||||||
|
|
||||||
Bjarne Steinsbo thought a lot in the first place of the pci part for this code
|
|
||||||
sharing idea.
|
|
||||||
|
|
||||||
Andreas Oberritter for providing a recent PCI initialization template
|
|
||||||
(pluto2.c).
|
|
||||||
|
|
||||||
Boleslaw Ciesielski for pointing out a problem with firmware loader.
|
|
||||||
|
|
||||||
Vadim Catana for correcting the USB transfer.
|
|
||||||
|
|
||||||
comments, critics and ideas to linux-dvb@linuxtv.org.
|
|
@ -1,5 +1,5 @@
|
|||||||
How to set up the Technisat devices
|
How to set up the Technisat/B2C2 Flexcop devices
|
||||||
===================================
|
================================================
|
||||||
|
|
||||||
1) Find out what device you have
|
1) Find out what device you have
|
||||||
================================
|
================================
|
||||||
@ -16,54 +16,60 @@ DVB: registering frontend 0 (Conexant CX24123/CX24109)...
|
|||||||
|
|
||||||
If the Technisat is the only TV device in your box get rid of unnecessary modules and check this one:
|
If the Technisat is the only TV device in your box get rid of unnecessary modules and check this one:
|
||||||
"Multimedia devices" => "Customise analog and hybrid tuner modules to build"
|
"Multimedia devices" => "Customise analog and hybrid tuner modules to build"
|
||||||
In this directory uncheck every driver which is activated there.
|
In this directory uncheck every driver which is activated there (except "Simple tuner support" for case 9 only).
|
||||||
|
|
||||||
Then please activate:
|
Then please activate:
|
||||||
2a) Main module part:
|
2a) Main module part:
|
||||||
|
|
||||||
a.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters"
|
a.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters"
|
||||||
b.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC PCI" in case of a PCI card OR
|
b.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC PCI" in case of a PCI card
|
||||||
|
OR
|
||||||
c.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC USB" in case of an USB 1.1 adapter
|
c.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Technisat/B2C2 Air/Sky/Cable2PC USB" in case of an USB 1.1 adapter
|
||||||
d.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Enable debug for the B2C2 FlexCop drivers"
|
d.)"Multimedia devices" => "DVB/ATSC adapters" => "Technisat/B2C2 FlexcopII(b) and FlexCopIII adapters" => "Enable debug for the B2C2 FlexCop drivers"
|
||||||
Notice: d.) is helpful for troubleshooting
|
Notice: d.) is helpful for troubleshooting
|
||||||
|
|
||||||
2b) Frontend module part:
|
2b) Frontend module part:
|
||||||
|
|
||||||
1.) Revision 2.3:
|
1.) SkyStar DVB-S Revision 2.3:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink VP310/MT312/ZL10313 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink VP310/MT312/ZL10313 based"
|
||||||
|
|
||||||
2.) Revision 2.6:
|
2.) SkyStar DVB-S Revision 2.6:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0299 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0299 based"
|
||||||
|
|
||||||
3.) Revision 2.7:
|
3.) SkyStar DVB-S Revision 2.7:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Samsung S5H1420 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Samsung S5H1420 based"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "Integrant ITD1000 Zero IF tuner for DVB-S/DSS"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Integrant ITD1000 Zero IF tuner for DVB-S/DSS"
|
||||||
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
||||||
|
|
||||||
4.) Revision 2.8:
|
4.) SkyStar DVB-S Revision 2.8:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24113/CX24128 tuner for DVB-S/DSS"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24113/CX24128 tuner for DVB-S/DSS"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24123 based"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Conexant CX24123 based"
|
||||||
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
d.)"Multimedia devices" => "Customise DVB frontends" => "ISL6421 SEC controller"
|
||||||
|
|
||||||
5.) DVB-T card:
|
5.) AirStar DVB-T card:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink MT352 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Zarlink MT352 based"
|
||||||
|
|
||||||
6.) DVB-C card:
|
6.) CableStar DVB-C card:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0297 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "ST STV0297 based"
|
||||||
|
|
||||||
7.) ATSC card 1st generation:
|
7.) AirStar ATSC card 1st generation:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "Broadcom BCM3510"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "Broadcom BCM3510"
|
||||||
|
|
||||||
8.) ATSC card 2nd generation:
|
8.) AirStar ATSC card 2nd generation:
|
||||||
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
b.)"Multimedia devices" => "Customise DVB frontends" => "NxtWave Communications NXT2002/NXT2004 based"
|
b.)"Multimedia devices" => "Customise DVB frontends" => "NxtWave Communications NXT2002/NXT2004 based"
|
||||||
c.)"Multimedia devices" => "Customise DVB frontends" => "LG Electronics LGDT3302/LGDT3303 based"
|
c.)"Multimedia devices" => "Customise DVB frontends" => "Generic I2C PLL based tuners"
|
||||||
|
|
||||||
Author: Uwe Bugla <uwe.bugla@gmx.de> December 2008
|
9.) AirStar ATSC card 3rd generation:
|
||||||
|
a.)"Multimedia devices" => "Customise DVB frontends" => "Customise the frontend modules to build"
|
||||||
|
b.)"Multimedia devices" => "Customise DVB frontends" => "LG Electronics LGDT3302/LGDT3303 based"
|
||||||
|
c.)"Multimedia devices" => "Customise analog and hybrid tuner modules to build" => "Simple tuner support"
|
||||||
|
|
||||||
|
Author: Uwe Bugla <uwe.bugla@gmx.de> February 2009
|
||||||
|
@ -114,7 +114,7 @@ In addition, the following text indicates that the option:
|
|||||||
Parameters denoted with BOOT are actually interpreted by the boot
|
Parameters denoted with BOOT are actually interpreted by the boot
|
||||||
loader, and have no meaning to the kernel directly.
|
loader, and have no meaning to the kernel directly.
|
||||||
Do not modify the syntax of boot loader parameters without extreme
|
Do not modify the syntax of boot loader parameters without extreme
|
||||||
need or coordination with <Documentation/x86/i386/boot.txt>.
|
need or coordination with <Documentation/x86/boot.txt>.
|
||||||
|
|
||||||
There are also arch-specific kernel-parameters not documented here.
|
There are also arch-specific kernel-parameters not documented here.
|
||||||
See for example <Documentation/x86/x86_64/boot-options.txt>.
|
See for example <Documentation/x86/x86_64/boot-options.txt>.
|
||||||
@ -868,8 +868,10 @@ and is between 256 and 4096 characters. It is defined in the file
|
|||||||
icn= [HW,ISDN]
|
icn= [HW,ISDN]
|
||||||
Format: <io>[,<membase>[,<icn_id>[,<icn_id2>]]]
|
Format: <io>[,<membase>[,<icn_id>[,<icn_id2>]]]
|
||||||
|
|
||||||
ide= [HW] (E)IDE subsystem
|
ide-core.nodma= [HW] (E)IDE subsystem
|
||||||
Format: ide=nodma or ide=doubler
|
Format: =0.0 to prevent dma on hda, =0.1 hdb =1.0 hdc
|
||||||
|
.vlb_clock .pci_clock .noflush .noprobe .nowerr .cdrom
|
||||||
|
.chs .ignore_cable are additional options
|
||||||
See Documentation/ide/ide.txt.
|
See Documentation/ide/ide.txt.
|
||||||
|
|
||||||
idebus= [HW] (E)IDE subsystem - VLB/PCI bus speed
|
idebus= [HW] (E)IDE subsystem - VLB/PCI bus speed
|
||||||
@ -2449,7 +2451,7 @@ and is between 256 and 4096 characters. It is defined in the file
|
|||||||
See Documentation/fb/modedb.txt.
|
See Documentation/fb/modedb.txt.
|
||||||
|
|
||||||
vga= [BOOT,X86-32] Select a particular video mode
|
vga= [BOOT,X86-32] Select a particular video mode
|
||||||
See Documentation/x86/i386/boot.txt and
|
See Documentation/x86/boot.txt and
|
||||||
Documentation/svga.txt.
|
Documentation/svga.txt.
|
||||||
Use vga=ask for menu.
|
Use vga=ask for menu.
|
||||||
This is actually a boot loader parameter; the value is
|
This is actually a boot loader parameter; the value is
|
||||||
|
@ -4,7 +4,7 @@ Introduction
|
|||||||
============
|
============
|
||||||
|
|
||||||
The Chelsio T3 ASIC based Adapters (S310, S320, S302, S304, Mezz cards, etc.
|
The Chelsio T3 ASIC based Adapters (S310, S320, S302, S304, Mezz cards, etc.
|
||||||
series of products) supports iSCSI acceleration and iSCSI Direct Data Placement
|
series of products) support iSCSI acceleration and iSCSI Direct Data Placement
|
||||||
(DDP) where the hardware handles the expensive byte touching operations, such
|
(DDP) where the hardware handles the expensive byte touching operations, such
|
||||||
as CRC computation and verification, and direct DMA to the final host memory
|
as CRC computation and verification, and direct DMA to the final host memory
|
||||||
destination:
|
destination:
|
||||||
@ -31,9 +31,9 @@ destination:
|
|||||||
the TCP segments onto the wire. It handles TCP retransmission if
|
the TCP segments onto the wire. It handles TCP retransmission if
|
||||||
needed.
|
needed.
|
||||||
|
|
||||||
On receving, S3 h/w recovers the iSCSI PDU by reassembling TCP
|
On receiving, S3 h/w recovers the iSCSI PDU by reassembling TCP
|
||||||
segments, separating the header and data, calculating and verifying
|
segments, separating the header and data, calculating and verifying
|
||||||
the digests, then forwards the header to the host. The payload data,
|
the digests, then forwarding the header to the host. The payload data,
|
||||||
if possible, will be directly placed into the pre-posted host DDP
|
if possible, will be directly placed into the pre-posted host DDP
|
||||||
buffer. Otherwise, the payload data will be sent to the host too.
|
buffer. Otherwise, the payload data will be sent to the host too.
|
||||||
|
|
||||||
@ -68,9 +68,8 @@ The following steps need to be taken to accelerates the open-iscsi initiator:
|
|||||||
sure the ip address is unique in the network.
|
sure the ip address is unique in the network.
|
||||||
|
|
||||||
3. edit /etc/iscsi/iscsid.conf
|
3. edit /etc/iscsi/iscsid.conf
|
||||||
The default setting for MaxRecvDataSegmentLength (131072) is too big,
|
The default setting for MaxRecvDataSegmentLength (131072) is too big;
|
||||||
replace "node.conn[0].iscsi.MaxRecvDataSegmentLength" to be a value no
|
replace with a value no bigger than 15360 (for example 8192):
|
||||||
bigger than 15360 (for example 8192):
|
|
||||||
|
|
||||||
node.conn[0].iscsi.MaxRecvDataSegmentLength = 8192
|
node.conn[0].iscsi.MaxRecvDataSegmentLength = 8192
|
||||||
|
|
||||||
|
@ -2464,7 +2464,7 @@ S: Maintained
|
|||||||
|
|
||||||
ISDN SUBSYSTEM
|
ISDN SUBSYSTEM
|
||||||
P: Karsten Keil
|
P: Karsten Keil
|
||||||
M: kkeil@suse.de
|
M: isdn@linux-pingi.de
|
||||||
L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
|
L: isdn4linux@listserv.isdn4linux.de (subscribers-only)
|
||||||
W: http://www.isdn4linux.de
|
W: http://www.isdn4linux.de
|
||||||
T: git kernel.org:/pub/scm/linux/kernel/kkeil/isdn-2.6.git
|
T: git kernel.org:/pub/scm/linux/kernel/kkeil/isdn-2.6.git
|
||||||
|
2
Makefile
2
Makefile
@ -1,7 +1,7 @@
|
|||||||
VERSION = 2
|
VERSION = 2
|
||||||
PATCHLEVEL = 6
|
PATCHLEVEL = 6
|
||||||
SUBLEVEL = 29
|
SUBLEVEL = 29
|
||||||
EXTRAVERSION = -rc6
|
EXTRAVERSION = -rc7
|
||||||
NAME = Erotic Pickled Herring
|
NAME = Erotic Pickled Herring
|
||||||
|
|
||||||
# *DOCUMENTATION*
|
# *DOCUMENTATION*
|
||||||
|
@ -233,12 +233,13 @@ static void __init cacheid_init(void)
|
|||||||
unsigned int cachetype = read_cpuid_cachetype();
|
unsigned int cachetype = read_cpuid_cachetype();
|
||||||
unsigned int arch = cpu_architecture();
|
unsigned int arch = cpu_architecture();
|
||||||
|
|
||||||
if (arch >= CPU_ARCH_ARMv7) {
|
if (arch >= CPU_ARCH_ARMv6) {
|
||||||
cacheid = CACHEID_VIPT_NONALIASING;
|
if ((cachetype & (7 << 29)) == 4 << 29) {
|
||||||
if ((cachetype & (3 << 14)) == 1 << 14)
|
/* ARMv7 register format */
|
||||||
cacheid |= CACHEID_ASID_TAGGED;
|
cacheid = CACHEID_VIPT_NONALIASING;
|
||||||
} else if (arch >= CPU_ARCH_ARMv6) {
|
if ((cachetype & (3 << 14)) == 1 << 14)
|
||||||
if (cachetype & (1 << 23))
|
cacheid |= CACHEID_ASID_TAGGED;
|
||||||
|
} else if (cachetype & (1 << 23))
|
||||||
cacheid = CACHEID_VIPT_ALIASING;
|
cacheid = CACHEID_VIPT_ALIASING;
|
||||||
else
|
else
|
||||||
cacheid = CACHEID_VIPT_NONALIASING;
|
cacheid = CACHEID_VIPT_NONALIASING;
|
||||||
|
@ -332,7 +332,6 @@ static int at91_pm_enter(suspend_state_t state)
|
|||||||
at91_sys_read(AT91_AIC_IPR) & at91_sys_read(AT91_AIC_IMR));
|
at91_sys_read(AT91_AIC_IPR) & at91_sys_read(AT91_AIC_IMR));
|
||||||
|
|
||||||
error:
|
error:
|
||||||
sdram_selfrefresh_disable();
|
|
||||||
target_state = PM_SUSPEND_ON;
|
target_state = PM_SUSPEND_ON;
|
||||||
at91_irq_resume();
|
at91_irq_resume();
|
||||||
at91_gpio_resume();
|
at91_gpio_resume();
|
||||||
|
@ -311,6 +311,9 @@ evm_u35_setup(struct i2c_client *client, int gpio, unsigned ngpio, void *c)
|
|||||||
gpio_request(gpio + 7, "nCF_SEL");
|
gpio_request(gpio + 7, "nCF_SEL");
|
||||||
gpio_direction_output(gpio + 7, 1);
|
gpio_direction_output(gpio + 7, 1);
|
||||||
|
|
||||||
|
/* irlml6401 sustains over 3A, switches 5V in under 8 msec */
|
||||||
|
setup_usb(500, 8);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -417,9 +420,6 @@ static __init void davinci_evm_init(void)
|
|||||||
platform_add_devices(davinci_evm_devices,
|
platform_add_devices(davinci_evm_devices,
|
||||||
ARRAY_SIZE(davinci_evm_devices));
|
ARRAY_SIZE(davinci_evm_devices));
|
||||||
evm_init_i2c();
|
evm_init_i2c();
|
||||||
|
|
||||||
/* irlml6401 sustains over 3A, switches 5V in under 8 msec */
|
|
||||||
setup_usb(500, 8);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static __init void davinci_evm_irq_init(void)
|
static __init void davinci_evm_irq_init(void)
|
||||||
|
@ -230,6 +230,11 @@ static struct clk davinci_clks[] = {
|
|||||||
.rate = &commonrate,
|
.rate = &commonrate,
|
||||||
.lpsc = DAVINCI_LPSC_GPIO,
|
.lpsc = DAVINCI_LPSC_GPIO,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
.name = "usb",
|
||||||
|
.rate = &commonrate,
|
||||||
|
.lpsc = DAVINCI_LPSC_USB,
|
||||||
|
},
|
||||||
{
|
{
|
||||||
.name = "AEMIFCLK",
|
.name = "AEMIFCLK",
|
||||||
.rate = &commonrate,
|
.rate = &commonrate,
|
||||||
|
@ -47,6 +47,7 @@ static struct musb_hdrc_platform_data usb_data = {
|
|||||||
#elif defined(CONFIG_USB_MUSB_HOST)
|
#elif defined(CONFIG_USB_MUSB_HOST)
|
||||||
.mode = MUSB_HOST,
|
.mode = MUSB_HOST,
|
||||||
#endif
|
#endif
|
||||||
|
.clock = "usb",
|
||||||
.config = &musb_config,
|
.config = &musb_config,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include <linux/serial_8250.h>
|
#include <linux/serial_8250.h>
|
||||||
#include <linux/ata_platform.h>
|
#include <linux/ata_platform.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
|
||||||
#include <asm/elf.h>
|
#include <asm/elf.h>
|
||||||
#include <asm/mach-types.h>
|
#include <asm/mach-types.h>
|
||||||
@ -201,8 +202,13 @@ static struct platform_device *devs[] __initdata = {
|
|||||||
&pata_device,
|
&pata_device,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static struct i2c_board_info i2c_rtc = {
|
||||||
|
I2C_BOARD_INFO("pcf8583", 0x50)
|
||||||
|
};
|
||||||
|
|
||||||
static int __init rpc_init(void)
|
static int __init rpc_init(void)
|
||||||
{
|
{
|
||||||
|
i2c_register_board_info(0, &i2c_rtc, 1);
|
||||||
return platform_add_devices(devs, ARRAY_SIZE(devs));
|
return platform_add_devices(devs, ARRAY_SIZE(devs));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,7 +23,8 @@ ENTRY(v6_early_abort)
|
|||||||
#ifdef CONFIG_CPU_32v6K
|
#ifdef CONFIG_CPU_32v6K
|
||||||
clrex
|
clrex
|
||||||
#else
|
#else
|
||||||
strex r0, r1, [sp] @ Clear the exclusive monitor
|
sub r1, sp, #4 @ Get unused stack location
|
||||||
|
strex r0, r1, [r1] @ Clear the exclusive monitor
|
||||||
#endif
|
#endif
|
||||||
mrc p15, 0, r1, c5, c0, 0 @ get FSR
|
mrc p15, 0, r1, c5, c0, 0 @ get FSR
|
||||||
mrc p15, 0, r0, c6, c0, 0 @ get FAR
|
mrc p15, 0, r0, c6, c0, 0 @ get FAR
|
||||||
|
@ -58,7 +58,7 @@ static void s3c_irq_eint_unmask(unsigned int irq)
|
|||||||
u32 mask;
|
u32 mask;
|
||||||
|
|
||||||
mask = __raw_readl(S3C64XX_EINT0MASK);
|
mask = __raw_readl(S3C64XX_EINT0MASK);
|
||||||
mask |= eint_irq_to_bit(irq);
|
mask &= ~eint_irq_to_bit(irq);
|
||||||
__raw_writel(mask, S3C64XX_EINT0MASK);
|
__raw_writel(mask, S3C64XX_EINT0MASK);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -638,6 +638,17 @@ config DMAR
|
|||||||
and include PCI device scope covered by these DMA
|
and include PCI device scope covered by these DMA
|
||||||
remapping devices.
|
remapping devices.
|
||||||
|
|
||||||
|
config DMAR_DEFAULT_ON
|
||||||
|
def_bool y
|
||||||
|
prompt "Enable DMA Remapping Devices by default"
|
||||||
|
depends on DMAR
|
||||||
|
help
|
||||||
|
Selecting this option will enable a DMAR device at boot time if
|
||||||
|
one is found. If this option is not selected, DMAR support can
|
||||||
|
be enabled by passing intel_iommu=on to the kernel. It is
|
||||||
|
recommended you say N here while the DMAR code remains
|
||||||
|
experimental.
|
||||||
|
|
||||||
endmenu
|
endmenu
|
||||||
|
|
||||||
endif
|
endif
|
||||||
|
@ -507,7 +507,7 @@ static int iosapic_find_sharable_irq(unsigned long trigger, unsigned long pol)
|
|||||||
if (trigger == IOSAPIC_EDGE)
|
if (trigger == IOSAPIC_EDGE)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
for (i = 0; i <= NR_IRQS; i++) {
|
for (i = 0; i < NR_IRQS; i++) {
|
||||||
info = &iosapic_intr_info[i];
|
info = &iosapic_intr_info[i];
|
||||||
if (info->trigger == trigger && info->polarity == pol &&
|
if (info->trigger == trigger && info->polarity == pol &&
|
||||||
(info->dmode == IOSAPIC_FIXED ||
|
(info->dmode == IOSAPIC_FIXED ||
|
||||||
|
@ -2149,7 +2149,7 @@ unw_remove_unwind_table (void *handle)
|
|||||||
|
|
||||||
/* next, remove hash table entries for this table */
|
/* next, remove hash table entries for this table */
|
||||||
|
|
||||||
for (index = 0; index <= UNW_HASH_SIZE; ++index) {
|
for (index = 0; index < UNW_HASH_SIZE; ++index) {
|
||||||
tmp = unw.cache + unw.hash[index];
|
tmp = unw.cache + unw.hash[index];
|
||||||
if (unw.hash[index] >= UNW_CACHE_SIZE
|
if (unw.hash[index] >= UNW_CACHE_SIZE
|
||||||
|| tmp->ip < table->start || tmp->ip >= table->end)
|
|| tmp->ip < table->start || tmp->ip >= table->end)
|
||||||
|
@ -603,7 +603,7 @@ config CAVIUM_OCTEON_SIMULATOR
|
|||||||
select SYS_SUPPORTS_64BIT_KERNEL
|
select SYS_SUPPORTS_64BIT_KERNEL
|
||||||
select SYS_SUPPORTS_BIG_ENDIAN
|
select SYS_SUPPORTS_BIG_ENDIAN
|
||||||
select SYS_SUPPORTS_HIGHMEM
|
select SYS_SUPPORTS_HIGHMEM
|
||||||
select CPU_CAVIUM_OCTEON
|
select SYS_HAS_CPU_CAVIUM_OCTEON
|
||||||
help
|
help
|
||||||
The Octeon simulator is software performance model of the Cavium
|
The Octeon simulator is software performance model of the Cavium
|
||||||
Octeon Processor. It supports simulating Octeon processors on x86
|
Octeon Processor. It supports simulating Octeon processors on x86
|
||||||
@ -618,7 +618,7 @@ config CAVIUM_OCTEON_REFERENCE_BOARD
|
|||||||
select SYS_SUPPORTS_BIG_ENDIAN
|
select SYS_SUPPORTS_BIG_ENDIAN
|
||||||
select SYS_SUPPORTS_HIGHMEM
|
select SYS_SUPPORTS_HIGHMEM
|
||||||
select SYS_HAS_EARLY_PRINTK
|
select SYS_HAS_EARLY_PRINTK
|
||||||
select CPU_CAVIUM_OCTEON
|
select SYS_HAS_CPU_CAVIUM_OCTEON
|
||||||
select SWAP_IO_SPACE
|
select SWAP_IO_SPACE
|
||||||
help
|
help
|
||||||
This option supports all of the Octeon reference boards from Cavium
|
This option supports all of the Octeon reference boards from Cavium
|
||||||
@ -1234,6 +1234,7 @@ config CPU_SB1
|
|||||||
|
|
||||||
config CPU_CAVIUM_OCTEON
|
config CPU_CAVIUM_OCTEON
|
||||||
bool "Cavium Octeon processor"
|
bool "Cavium Octeon processor"
|
||||||
|
depends on SYS_HAS_CPU_CAVIUM_OCTEON
|
||||||
select IRQ_CPU
|
select IRQ_CPU
|
||||||
select IRQ_CPU_OCTEON
|
select IRQ_CPU_OCTEON
|
||||||
select CPU_HAS_PREFETCH
|
select CPU_HAS_PREFETCH
|
||||||
@ -1314,6 +1315,9 @@ config SYS_HAS_CPU_RM9000
|
|||||||
config SYS_HAS_CPU_SB1
|
config SYS_HAS_CPU_SB1
|
||||||
bool
|
bool
|
||||||
|
|
||||||
|
config SYS_HAS_CPU_CAVIUM_OCTEON
|
||||||
|
bool
|
||||||
|
|
||||||
#
|
#
|
||||||
# CPU may reorder R->R, R->W, W->R, W->W
|
# CPU may reorder R->R, R->W, W->R, W->W
|
||||||
# Reordering beyond LL and SC is handled in WEAK_REORDERING_BEYOND_LLSC
|
# Reordering beyond LL and SC is handled in WEAK_REORDERING_BEYOND_LLSC
|
||||||
@ -1387,6 +1391,7 @@ config 32BIT
|
|||||||
config 64BIT
|
config 64BIT
|
||||||
bool "64-bit kernel"
|
bool "64-bit kernel"
|
||||||
depends on CPU_SUPPORTS_64BIT_KERNEL && SYS_SUPPORTS_64BIT_KERNEL
|
depends on CPU_SUPPORTS_64BIT_KERNEL && SYS_SUPPORTS_64BIT_KERNEL
|
||||||
|
select HAVE_SYSCALL_WRAPPERS
|
||||||
help
|
help
|
||||||
Select this option if you want to build a 64-bit kernel.
|
Select this option if you want to build a 64-bit kernel.
|
||||||
|
|
||||||
|
@ -118,7 +118,7 @@ void __init plat_time_init(void)
|
|||||||
* setup counter 1 (RTC) to tick at full speed
|
* setup counter 1 (RTC) to tick at full speed
|
||||||
*/
|
*/
|
||||||
t = 0xffffff;
|
t = 0xffffff;
|
||||||
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_T1S) && t--)
|
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_T1S) && --t)
|
||||||
asm volatile ("nop");
|
asm volatile ("nop");
|
||||||
if (!t)
|
if (!t)
|
||||||
goto cntr_err;
|
goto cntr_err;
|
||||||
@ -127,7 +127,7 @@ void __init plat_time_init(void)
|
|||||||
au_sync();
|
au_sync();
|
||||||
|
|
||||||
t = 0xffffff;
|
t = 0xffffff;
|
||||||
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && t--)
|
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && --t)
|
||||||
asm volatile ("nop");
|
asm volatile ("nop");
|
||||||
if (!t)
|
if (!t)
|
||||||
goto cntr_err;
|
goto cntr_err;
|
||||||
@ -135,7 +135,7 @@ void __init plat_time_init(void)
|
|||||||
au_sync();
|
au_sync();
|
||||||
|
|
||||||
t = 0xffffff;
|
t = 0xffffff;
|
||||||
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && t--)
|
while ((au_readl(SYS_COUNTER_CNTRL) & SYS_CNTRL_C1S) && --t)
|
||||||
asm volatile ("nop");
|
asm volatile ("nop");
|
||||||
if (!t)
|
if (!t)
|
||||||
goto cntr_err;
|
goto cntr_err;
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
#ifndef __ASM_SECCOMP_H
|
#ifndef __ASM_SECCOMP_H
|
||||||
|
|
||||||
#include <linux/thread_info.h>
|
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
|
|
||||||
#define __NR_seccomp_read __NR_read
|
#define __NR_seccomp_read __NR_read
|
||||||
|
@ -111,7 +111,6 @@ int show_interrupts(struct seq_file *p, void *v)
|
|||||||
seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]);
|
seq_printf(p, "%10u ", kstat_cpu(j).irqs[i]);
|
||||||
#endif
|
#endif
|
||||||
seq_printf(p, " %14s", irq_desc[i].chip->name);
|
seq_printf(p, " %14s", irq_desc[i].chip->name);
|
||||||
seq_printf(p, "-%-8s", irq_desc[i].name);
|
|
||||||
seq_printf(p, " %s", action->name);
|
seq_printf(p, " %s", action->name);
|
||||||
|
|
||||||
for (action=action->next; action; action = action->next)
|
for (action=action->next; action; action = action->next)
|
||||||
|
@ -32,6 +32,7 @@
|
|||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/binfmts.h>
|
#include <linux/binfmts.h>
|
||||||
#include <linux/security.h>
|
#include <linux/security.h>
|
||||||
|
#include <linux/syscalls.h>
|
||||||
#include <linux/compat.h>
|
#include <linux/compat.h>
|
||||||
#include <linux/vfs.h>
|
#include <linux/vfs.h>
|
||||||
#include <linux/ipc.h>
|
#include <linux/ipc.h>
|
||||||
@ -63,9 +64,9 @@
|
|||||||
#define merge_64(r1, r2) ((((r2) & 0xffffffffUL) << 32) + ((r1) & 0xffffffffUL))
|
#define merge_64(r1, r2) ((((r2) & 0xffffffffUL) << 32) + ((r1) & 0xffffffffUL))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
asmlinkage unsigned long
|
SYSCALL_DEFINE6(32_mmap2, unsigned long, addr, unsigned long, len,
|
||||||
sys32_mmap2(unsigned long addr, unsigned long len, unsigned long prot,
|
unsigned long, prot, unsigned long, flags, unsigned long, fd,
|
||||||
unsigned long flags, unsigned long fd, unsigned long pgoff)
|
unsigned long, pgoff)
|
||||||
{
|
{
|
||||||
struct file * file = NULL;
|
struct file * file = NULL;
|
||||||
unsigned long error;
|
unsigned long error;
|
||||||
@ -121,21 +122,21 @@ struct rlimit32 {
|
|||||||
int rlim_max;
|
int rlim_max;
|
||||||
};
|
};
|
||||||
|
|
||||||
asmlinkage long sys32_truncate64(const char __user * path,
|
SYSCALL_DEFINE4(32_truncate64, const char __user *, path,
|
||||||
unsigned long __dummy, int a2, int a3)
|
unsigned long, __dummy, unsigned long, a2, unsigned long, a3)
|
||||||
{
|
{
|
||||||
return sys_truncate(path, merge_64(a2, a3));
|
return sys_truncate(path, merge_64(a2, a3));
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage long sys32_ftruncate64(unsigned int fd, unsigned long __dummy,
|
SYSCALL_DEFINE4(32_ftruncate64, unsigned long, fd, unsigned long, __dummy,
|
||||||
int a2, int a3)
|
unsigned long, a2, unsigned long, a3)
|
||||||
{
|
{
|
||||||
return sys_ftruncate(fd, merge_64(a2, a3));
|
return sys_ftruncate(fd, merge_64(a2, a3));
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_llseek(unsigned int fd, unsigned int offset_high,
|
SYSCALL_DEFINE5(32_llseek, unsigned long, fd, unsigned long, offset_high,
|
||||||
unsigned int offset_low, loff_t __user * result,
|
unsigned long, offset_low, loff_t __user *, result,
|
||||||
unsigned int origin)
|
unsigned long, origin)
|
||||||
{
|
{
|
||||||
return sys_llseek(fd, offset_high, offset_low, result, origin);
|
return sys_llseek(fd, offset_high, offset_low, result, origin);
|
||||||
}
|
}
|
||||||
@ -144,20 +145,20 @@ asmlinkage int sys32_llseek(unsigned int fd, unsigned int offset_high,
|
|||||||
lseek back to original location. They fail just like lseek does on
|
lseek back to original location. They fail just like lseek does on
|
||||||
non-seekable files. */
|
non-seekable files. */
|
||||||
|
|
||||||
asmlinkage ssize_t sys32_pread(unsigned int fd, char __user * buf,
|
SYSCALL_DEFINE6(32_pread, unsigned long, fd, char __user *, buf, size_t, count,
|
||||||
size_t count, u32 unused, u64 a4, u64 a5)
|
unsigned long, unused, unsigned long, a4, unsigned long, a5)
|
||||||
{
|
{
|
||||||
return sys_pread64(fd, buf, count, merge_64(a4, a5));
|
return sys_pread64(fd, buf, count, merge_64(a4, a5));
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage ssize_t sys32_pwrite(unsigned int fd, const char __user * buf,
|
SYSCALL_DEFINE6(32_pwrite, unsigned int, fd, const char __user *, buf,
|
||||||
size_t count, u32 unused, u64 a4, u64 a5)
|
size_t, count, u32, unused, u64, a4, u64, a5)
|
||||||
{
|
{
|
||||||
return sys_pwrite64(fd, buf, count, merge_64(a4, a5));
|
return sys_pwrite64(fd, buf, count, merge_64(a4, a5));
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_sched_rr_get_interval(compat_pid_t pid,
|
SYSCALL_DEFINE2(32_sched_rr_get_interval, compat_pid_t, pid,
|
||||||
struct compat_timespec __user *interval)
|
struct compat_timespec __user *, interval)
|
||||||
{
|
{
|
||||||
struct timespec t;
|
struct timespec t;
|
||||||
int ret;
|
int ret;
|
||||||
@ -174,8 +175,8 @@ asmlinkage int sys32_sched_rr_get_interval(compat_pid_t pid,
|
|||||||
|
|
||||||
#ifdef CONFIG_SYSVIPC
|
#ifdef CONFIG_SYSVIPC
|
||||||
|
|
||||||
asmlinkage long
|
SYSCALL_DEFINE6(32_ipc, u32, call, long, first, long, second, long, third,
|
||||||
sys32_ipc(u32 call, int first, int second, int third, u32 ptr, u32 fifth)
|
unsigned long, ptr, unsigned long, fifth)
|
||||||
{
|
{
|
||||||
int version, err;
|
int version, err;
|
||||||
|
|
||||||
@ -233,8 +234,8 @@ sys32_ipc(u32 call, int first, int second, int third, u32 ptr, u32 fifth)
|
|||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
asmlinkage long
|
SYSCALL_DEFINE6(32_ipc, u32, call, int, first, int, second, int, third,
|
||||||
sys32_ipc(u32 call, int first, int second, int third, u32 ptr, u32 fifth)
|
u32, ptr, u32 fifth)
|
||||||
{
|
{
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
@ -242,7 +243,7 @@ sys32_ipc(u32 call, int first, int second, int third, u32 ptr, u32 fifth)
|
|||||||
#endif /* CONFIG_SYSVIPC */
|
#endif /* CONFIG_SYSVIPC */
|
||||||
|
|
||||||
#ifdef CONFIG_MIPS32_N32
|
#ifdef CONFIG_MIPS32_N32
|
||||||
asmlinkage long sysn32_semctl(int semid, int semnum, int cmd, u32 arg)
|
SYSCALL_DEFINE4(n32_semctl, int, semid, int, semnum, int, cmd, u32, arg)
|
||||||
{
|
{
|
||||||
/* compat_sys_semctl expects a pointer to union semun */
|
/* compat_sys_semctl expects a pointer to union semun */
|
||||||
u32 __user *uptr = compat_alloc_user_space(sizeof(u32));
|
u32 __user *uptr = compat_alloc_user_space(sizeof(u32));
|
||||||
@ -251,13 +252,14 @@ asmlinkage long sysn32_semctl(int semid, int semnum, int cmd, u32 arg)
|
|||||||
return compat_sys_semctl(semid, semnum, cmd, uptr);
|
return compat_sys_semctl(semid, semnum, cmd, uptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage long sysn32_msgsnd(int msqid, u32 msgp, unsigned msgsz, int msgflg)
|
SYSCALL_DEFINE4(n32_msgsnd, int, msqid, u32, msgp, unsigned int, msgsz,
|
||||||
|
int, msgflg)
|
||||||
{
|
{
|
||||||
return compat_sys_msgsnd(msqid, msgsz, msgflg, compat_ptr(msgp));
|
return compat_sys_msgsnd(msqid, msgsz, msgflg, compat_ptr(msgp));
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage long sysn32_msgrcv(int msqid, u32 msgp, size_t msgsz, int msgtyp,
|
SYSCALL_DEFINE5(n32_msgrcv, int, msqid, u32, msgp, size_t, msgsz,
|
||||||
int msgflg)
|
int, msgtyp, int, msgflg)
|
||||||
{
|
{
|
||||||
return compat_sys_msgrcv(msqid, msgsz, msgtyp, msgflg, IPC_64,
|
return compat_sys_msgrcv(msqid, msgsz, msgtyp, msgflg, IPC_64,
|
||||||
compat_ptr(msgp));
|
compat_ptr(msgp));
|
||||||
@ -277,7 +279,7 @@ struct sysctl_args32
|
|||||||
|
|
||||||
#ifdef CONFIG_SYSCTL_SYSCALL
|
#ifdef CONFIG_SYSCTL_SYSCALL
|
||||||
|
|
||||||
asmlinkage long sys32_sysctl(struct sysctl_args32 __user *args)
|
SYSCALL_DEFINE1(32_sysctl, struct sysctl_args32 __user *, args)
|
||||||
{
|
{
|
||||||
struct sysctl_args32 tmp;
|
struct sysctl_args32 tmp;
|
||||||
int error;
|
int error;
|
||||||
@ -316,9 +318,16 @@ asmlinkage long sys32_sysctl(struct sysctl_args32 __user *args)
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
|
||||||
|
SYSCALL_DEFINE1(32_sysctl, struct sysctl_args32 __user *, args)
|
||||||
|
{
|
||||||
|
return -ENOSYS;
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* CONFIG_SYSCTL_SYSCALL */
|
#endif /* CONFIG_SYSCTL_SYSCALL */
|
||||||
|
|
||||||
asmlinkage long sys32_newuname(struct new_utsname __user * name)
|
SYSCALL_DEFINE1(32_newuname, struct new_utsname __user *, name)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
@ -334,7 +343,7 @@ asmlinkage long sys32_newuname(struct new_utsname __user * name)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_personality(unsigned long personality)
|
SYSCALL_DEFINE1(32_personality, unsigned long, personality)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
personality &= 0xffffffff;
|
personality &= 0xffffffff;
|
||||||
@ -357,7 +366,7 @@ struct ustat32 {
|
|||||||
|
|
||||||
extern asmlinkage long sys_ustat(dev_t dev, struct ustat __user * ubuf);
|
extern asmlinkage long sys_ustat(dev_t dev, struct ustat __user * ubuf);
|
||||||
|
|
||||||
asmlinkage int sys32_ustat(dev_t dev, struct ustat32 __user * ubuf32)
|
SYSCALL_DEFINE2(32_ustat, dev_t, dev, struct ustat32 __user *, ubuf32)
|
||||||
{
|
{
|
||||||
int err;
|
int err;
|
||||||
struct ustat tmp;
|
struct ustat tmp;
|
||||||
@ -381,8 +390,8 @@ asmlinkage int sys32_ustat(dev_t dev, struct ustat32 __user * ubuf32)
|
|||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_sendfile(int out_fd, int in_fd, compat_off_t __user *offset,
|
SYSCALL_DEFINE4(32_sendfile, long, out_fd, long, in_fd,
|
||||||
s32 count)
|
compat_off_t __user *, offset, s32, count)
|
||||||
{
|
{
|
||||||
mm_segment_t old_fs = get_fs();
|
mm_segment_t old_fs = get_fs();
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -399,7 +399,7 @@ einval: li v0, -ENOSYS
|
|||||||
sys sys_swapon 2
|
sys sys_swapon 2
|
||||||
sys sys_reboot 3
|
sys sys_reboot 3
|
||||||
sys sys_old_readdir 3
|
sys sys_old_readdir 3
|
||||||
sys old_mmap 6 /* 4090 */
|
sys sys_mips_mmap 6 /* 4090 */
|
||||||
sys sys_munmap 2
|
sys sys_munmap 2
|
||||||
sys sys_truncate 2
|
sys sys_truncate 2
|
||||||
sys sys_ftruncate 2
|
sys sys_ftruncate 2
|
||||||
@ -519,7 +519,7 @@ einval: li v0, -ENOSYS
|
|||||||
sys sys_sendfile 4
|
sys sys_sendfile 4
|
||||||
sys sys_ni_syscall 0
|
sys sys_ni_syscall 0
|
||||||
sys sys_ni_syscall 0
|
sys sys_ni_syscall 0
|
||||||
sys sys_mmap2 6 /* 4210 */
|
sys sys_mips_mmap2 6 /* 4210 */
|
||||||
sys sys_truncate64 4
|
sys sys_truncate64 4
|
||||||
sys sys_ftruncate64 4
|
sys sys_ftruncate64 4
|
||||||
sys sys_stat64 2
|
sys sys_stat64 2
|
||||||
|
@ -207,7 +207,7 @@ sys_call_table:
|
|||||||
PTR sys_newlstat
|
PTR sys_newlstat
|
||||||
PTR sys_poll
|
PTR sys_poll
|
||||||
PTR sys_lseek
|
PTR sys_lseek
|
||||||
PTR old_mmap
|
PTR sys_mips_mmap
|
||||||
PTR sys_mprotect /* 5010 */
|
PTR sys_mprotect /* 5010 */
|
||||||
PTR sys_munmap
|
PTR sys_munmap
|
||||||
PTR sys_brk
|
PTR sys_brk
|
||||||
|
@ -129,12 +129,12 @@ EXPORT(sysn32_call_table)
|
|||||||
PTR sys_newlstat
|
PTR sys_newlstat
|
||||||
PTR sys_poll
|
PTR sys_poll
|
||||||
PTR sys_lseek
|
PTR sys_lseek
|
||||||
PTR old_mmap
|
PTR sys_mips_mmap
|
||||||
PTR sys_mprotect /* 6010 */
|
PTR sys_mprotect /* 6010 */
|
||||||
PTR sys_munmap
|
PTR sys_munmap
|
||||||
PTR sys_brk
|
PTR sys_brk
|
||||||
PTR sys32_rt_sigaction
|
PTR sys_32_rt_sigaction
|
||||||
PTR sys32_rt_sigprocmask
|
PTR sys_32_rt_sigprocmask
|
||||||
PTR compat_sys_ioctl /* 6015 */
|
PTR compat_sys_ioctl /* 6015 */
|
||||||
PTR sys_pread64
|
PTR sys_pread64
|
||||||
PTR sys_pwrite64
|
PTR sys_pwrite64
|
||||||
@ -159,7 +159,7 @@ EXPORT(sysn32_call_table)
|
|||||||
PTR compat_sys_setitimer
|
PTR compat_sys_setitimer
|
||||||
PTR sys_alarm
|
PTR sys_alarm
|
||||||
PTR sys_getpid
|
PTR sys_getpid
|
||||||
PTR sys32_sendfile
|
PTR sys_32_sendfile
|
||||||
PTR sys_socket /* 6040 */
|
PTR sys_socket /* 6040 */
|
||||||
PTR sys_connect
|
PTR sys_connect
|
||||||
PTR sys_accept
|
PTR sys_accept
|
||||||
@ -181,14 +181,14 @@ EXPORT(sysn32_call_table)
|
|||||||
PTR sys_exit
|
PTR sys_exit
|
||||||
PTR compat_sys_wait4
|
PTR compat_sys_wait4
|
||||||
PTR sys_kill /* 6060 */
|
PTR sys_kill /* 6060 */
|
||||||
PTR sys32_newuname
|
PTR sys_32_newuname
|
||||||
PTR sys_semget
|
PTR sys_semget
|
||||||
PTR sys_semop
|
PTR sys_semop
|
||||||
PTR sysn32_semctl
|
PTR sys_n32_semctl
|
||||||
PTR sys_shmdt /* 6065 */
|
PTR sys_shmdt /* 6065 */
|
||||||
PTR sys_msgget
|
PTR sys_msgget
|
||||||
PTR sysn32_msgsnd
|
PTR sys_n32_msgsnd
|
||||||
PTR sysn32_msgrcv
|
PTR sys_n32_msgrcv
|
||||||
PTR compat_sys_msgctl
|
PTR compat_sys_msgctl
|
||||||
PTR compat_sys_fcntl /* 6070 */
|
PTR compat_sys_fcntl /* 6070 */
|
||||||
PTR sys_flock
|
PTR sys_flock
|
||||||
@ -245,15 +245,15 @@ EXPORT(sysn32_call_table)
|
|||||||
PTR sys_getsid
|
PTR sys_getsid
|
||||||
PTR sys_capget
|
PTR sys_capget
|
||||||
PTR sys_capset
|
PTR sys_capset
|
||||||
PTR sys32_rt_sigpending /* 6125 */
|
PTR sys_32_rt_sigpending /* 6125 */
|
||||||
PTR compat_sys_rt_sigtimedwait
|
PTR compat_sys_rt_sigtimedwait
|
||||||
PTR sys32_rt_sigqueueinfo
|
PTR sys_32_rt_sigqueueinfo
|
||||||
PTR sysn32_rt_sigsuspend
|
PTR sysn32_rt_sigsuspend
|
||||||
PTR sys32_sigaltstack
|
PTR sys32_sigaltstack
|
||||||
PTR compat_sys_utime /* 6130 */
|
PTR compat_sys_utime /* 6130 */
|
||||||
PTR sys_mknod
|
PTR sys_mknod
|
||||||
PTR sys32_personality
|
PTR sys_32_personality
|
||||||
PTR sys32_ustat
|
PTR sys_32_ustat
|
||||||
PTR compat_sys_statfs
|
PTR compat_sys_statfs
|
||||||
PTR compat_sys_fstatfs /* 6135 */
|
PTR compat_sys_fstatfs /* 6135 */
|
||||||
PTR sys_sysfs
|
PTR sys_sysfs
|
||||||
@ -265,14 +265,14 @@ EXPORT(sysn32_call_table)
|
|||||||
PTR sys_sched_getscheduler
|
PTR sys_sched_getscheduler
|
||||||
PTR sys_sched_get_priority_max
|
PTR sys_sched_get_priority_max
|
||||||
PTR sys_sched_get_priority_min
|
PTR sys_sched_get_priority_min
|
||||||
PTR sys32_sched_rr_get_interval /* 6145 */
|
PTR sys_32_sched_rr_get_interval /* 6145 */
|
||||||
PTR sys_mlock
|
PTR sys_mlock
|
||||||
PTR sys_munlock
|
PTR sys_munlock
|
||||||
PTR sys_mlockall
|
PTR sys_mlockall
|
||||||
PTR sys_munlockall
|
PTR sys_munlockall
|
||||||
PTR sys_vhangup /* 6150 */
|
PTR sys_vhangup /* 6150 */
|
||||||
PTR sys_pivot_root
|
PTR sys_pivot_root
|
||||||
PTR sys32_sysctl
|
PTR sys_32_sysctl
|
||||||
PTR sys_prctl
|
PTR sys_prctl
|
||||||
PTR compat_sys_adjtimex
|
PTR compat_sys_adjtimex
|
||||||
PTR compat_sys_setrlimit /* 6155 */
|
PTR compat_sys_setrlimit /* 6155 */
|
||||||
|
@ -265,12 +265,12 @@ sys_call_table:
|
|||||||
PTR sys_olduname
|
PTR sys_olduname
|
||||||
PTR sys_umask /* 4060 */
|
PTR sys_umask /* 4060 */
|
||||||
PTR sys_chroot
|
PTR sys_chroot
|
||||||
PTR sys32_ustat
|
PTR sys_32_ustat
|
||||||
PTR sys_dup2
|
PTR sys_dup2
|
||||||
PTR sys_getppid
|
PTR sys_getppid
|
||||||
PTR sys_getpgrp /* 4065 */
|
PTR sys_getpgrp /* 4065 */
|
||||||
PTR sys_setsid
|
PTR sys_setsid
|
||||||
PTR sys32_sigaction
|
PTR sys_32_sigaction
|
||||||
PTR sys_sgetmask
|
PTR sys_sgetmask
|
||||||
PTR sys_ssetmask
|
PTR sys_ssetmask
|
||||||
PTR sys_setreuid /* 4070 */
|
PTR sys_setreuid /* 4070 */
|
||||||
@ -293,7 +293,7 @@ sys_call_table:
|
|||||||
PTR sys_swapon
|
PTR sys_swapon
|
||||||
PTR sys_reboot
|
PTR sys_reboot
|
||||||
PTR compat_sys_old_readdir
|
PTR compat_sys_old_readdir
|
||||||
PTR old_mmap /* 4090 */
|
PTR sys_mips_mmap /* 4090 */
|
||||||
PTR sys_munmap
|
PTR sys_munmap
|
||||||
PTR sys_truncate
|
PTR sys_truncate
|
||||||
PTR sys_ftruncate
|
PTR sys_ftruncate
|
||||||
@ -320,12 +320,12 @@ sys_call_table:
|
|||||||
PTR compat_sys_wait4
|
PTR compat_sys_wait4
|
||||||
PTR sys_swapoff /* 4115 */
|
PTR sys_swapoff /* 4115 */
|
||||||
PTR compat_sys_sysinfo
|
PTR compat_sys_sysinfo
|
||||||
PTR sys32_ipc
|
PTR sys_32_ipc
|
||||||
PTR sys_fsync
|
PTR sys_fsync
|
||||||
PTR sys32_sigreturn
|
PTR sys32_sigreturn
|
||||||
PTR sys32_clone /* 4120 */
|
PTR sys32_clone /* 4120 */
|
||||||
PTR sys_setdomainname
|
PTR sys_setdomainname
|
||||||
PTR sys32_newuname
|
PTR sys_32_newuname
|
||||||
PTR sys_ni_syscall /* sys_modify_ldt */
|
PTR sys_ni_syscall /* sys_modify_ldt */
|
||||||
PTR compat_sys_adjtimex
|
PTR compat_sys_adjtimex
|
||||||
PTR sys_mprotect /* 4125 */
|
PTR sys_mprotect /* 4125 */
|
||||||
@ -339,11 +339,11 @@ sys_call_table:
|
|||||||
PTR sys_fchdir
|
PTR sys_fchdir
|
||||||
PTR sys_bdflush
|
PTR sys_bdflush
|
||||||
PTR sys_sysfs /* 4135 */
|
PTR sys_sysfs /* 4135 */
|
||||||
PTR sys32_personality
|
PTR sys_32_personality
|
||||||
PTR sys_ni_syscall /* for afs_syscall */
|
PTR sys_ni_syscall /* for afs_syscall */
|
||||||
PTR sys_setfsuid
|
PTR sys_setfsuid
|
||||||
PTR sys_setfsgid
|
PTR sys_setfsgid
|
||||||
PTR sys32_llseek /* 4140 */
|
PTR sys_32_llseek /* 4140 */
|
||||||
PTR compat_sys_getdents
|
PTR compat_sys_getdents
|
||||||
PTR compat_sys_select
|
PTR compat_sys_select
|
||||||
PTR sys_flock
|
PTR sys_flock
|
||||||
@ -356,7 +356,7 @@ sys_call_table:
|
|||||||
PTR sys_ni_syscall /* 4150 */
|
PTR sys_ni_syscall /* 4150 */
|
||||||
PTR sys_getsid
|
PTR sys_getsid
|
||||||
PTR sys_fdatasync
|
PTR sys_fdatasync
|
||||||
PTR sys32_sysctl
|
PTR sys_32_sysctl
|
||||||
PTR sys_mlock
|
PTR sys_mlock
|
||||||
PTR sys_munlock /* 4155 */
|
PTR sys_munlock /* 4155 */
|
||||||
PTR sys_mlockall
|
PTR sys_mlockall
|
||||||
@ -368,7 +368,7 @@ sys_call_table:
|
|||||||
PTR sys_sched_yield
|
PTR sys_sched_yield
|
||||||
PTR sys_sched_get_priority_max
|
PTR sys_sched_get_priority_max
|
||||||
PTR sys_sched_get_priority_min
|
PTR sys_sched_get_priority_min
|
||||||
PTR sys32_sched_rr_get_interval /* 4165 */
|
PTR sys_32_sched_rr_get_interval /* 4165 */
|
||||||
PTR compat_sys_nanosleep
|
PTR compat_sys_nanosleep
|
||||||
PTR sys_mremap
|
PTR sys_mremap
|
||||||
PTR sys_accept
|
PTR sys_accept
|
||||||
@ -397,25 +397,25 @@ sys_call_table:
|
|||||||
PTR sys_getresgid
|
PTR sys_getresgid
|
||||||
PTR sys_prctl
|
PTR sys_prctl
|
||||||
PTR sys32_rt_sigreturn
|
PTR sys32_rt_sigreturn
|
||||||
PTR sys32_rt_sigaction
|
PTR sys_32_rt_sigaction
|
||||||
PTR sys32_rt_sigprocmask /* 4195 */
|
PTR sys_32_rt_sigprocmask /* 4195 */
|
||||||
PTR sys32_rt_sigpending
|
PTR sys_32_rt_sigpending
|
||||||
PTR compat_sys_rt_sigtimedwait
|
PTR compat_sys_rt_sigtimedwait
|
||||||
PTR sys32_rt_sigqueueinfo
|
PTR sys_32_rt_sigqueueinfo
|
||||||
PTR sys32_rt_sigsuspend
|
PTR sys32_rt_sigsuspend
|
||||||
PTR sys32_pread /* 4200 */
|
PTR sys_32_pread /* 4200 */
|
||||||
PTR sys32_pwrite
|
PTR sys_32_pwrite
|
||||||
PTR sys_chown
|
PTR sys_chown
|
||||||
PTR sys_getcwd
|
PTR sys_getcwd
|
||||||
PTR sys_capget
|
PTR sys_capget
|
||||||
PTR sys_capset /* 4205 */
|
PTR sys_capset /* 4205 */
|
||||||
PTR sys32_sigaltstack
|
PTR sys32_sigaltstack
|
||||||
PTR sys32_sendfile
|
PTR sys_32_sendfile
|
||||||
PTR sys_ni_syscall
|
PTR sys_ni_syscall
|
||||||
PTR sys_ni_syscall
|
PTR sys_ni_syscall
|
||||||
PTR sys32_mmap2 /* 4210 */
|
PTR sys_mips_mmap2 /* 4210 */
|
||||||
PTR sys32_truncate64
|
PTR sys_32_truncate64
|
||||||
PTR sys32_ftruncate64
|
PTR sys_32_ftruncate64
|
||||||
PTR sys_newstat
|
PTR sys_newstat
|
||||||
PTR sys_newlstat
|
PTR sys_newlstat
|
||||||
PTR sys_newfstat /* 4215 */
|
PTR sys_newfstat /* 4215 */
|
||||||
@ -481,7 +481,7 @@ sys_call_table:
|
|||||||
PTR compat_sys_mq_notify /* 4275 */
|
PTR compat_sys_mq_notify /* 4275 */
|
||||||
PTR compat_sys_mq_getsetattr
|
PTR compat_sys_mq_getsetattr
|
||||||
PTR sys_ni_syscall /* sys_vserver */
|
PTR sys_ni_syscall /* sys_vserver */
|
||||||
PTR sys32_waitid
|
PTR sys_32_waitid
|
||||||
PTR sys_ni_syscall /* available, was setaltroot */
|
PTR sys_ni_syscall /* available, was setaltroot */
|
||||||
PTR sys_add_key /* 4280 */
|
PTR sys_add_key /* 4280 */
|
||||||
PTR sys_request_key
|
PTR sys_request_key
|
||||||
|
@ -19,6 +19,7 @@
|
|||||||
#include <linux/ptrace.h>
|
#include <linux/ptrace.h>
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
#include <linux/compiler.h>
|
#include <linux/compiler.h>
|
||||||
|
#include <linux/syscalls.h>
|
||||||
#include <linux/uaccess.h>
|
#include <linux/uaccess.h>
|
||||||
|
|
||||||
#include <asm/abi.h>
|
#include <asm/abi.h>
|
||||||
@ -338,8 +339,8 @@ asmlinkage int sys_rt_sigsuspend(nabi_no_regargs struct pt_regs regs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_TRAD_SIGNALS
|
#ifdef CONFIG_TRAD_SIGNALS
|
||||||
asmlinkage int sys_sigaction(int sig, const struct sigaction __user *act,
|
SYSCALL_DEFINE3(sigaction, int, sig, const struct sigaction __user *, act,
|
||||||
struct sigaction __user *oact)
|
struct sigaction __user *, oact)
|
||||||
{
|
{
|
||||||
struct k_sigaction new_ka, old_ka;
|
struct k_sigaction new_ka, old_ka;
|
||||||
int ret;
|
int ret;
|
||||||
|
@ -349,8 +349,8 @@ asmlinkage int sys32_rt_sigsuspend(nabi_no_regargs struct pt_regs regs)
|
|||||||
return -ERESTARTNOHAND;
|
return -ERESTARTNOHAND;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_sigaction(int sig, const struct sigaction32 __user *act,
|
SYSCALL_DEFINE3(32_sigaction, long, sig, const struct sigaction32 __user *, act,
|
||||||
struct sigaction32 __user *oact)
|
struct sigaction32 __user *, oact)
|
||||||
{
|
{
|
||||||
struct k_sigaction new_ka, old_ka;
|
struct k_sigaction new_ka, old_ka;
|
||||||
int ret;
|
int ret;
|
||||||
@ -704,9 +704,9 @@ struct mips_abi mips_abi_32 = {
|
|||||||
.restart = __NR_O32_restart_syscall
|
.restart = __NR_O32_restart_syscall
|
||||||
};
|
};
|
||||||
|
|
||||||
asmlinkage int sys32_rt_sigaction(int sig, const struct sigaction32 __user *act,
|
SYSCALL_DEFINE4(32_rt_sigaction, int, sig,
|
||||||
struct sigaction32 __user *oact,
|
const struct sigaction32 __user *, act,
|
||||||
unsigned int sigsetsize)
|
struct sigaction32 __user *, oact, unsigned int, sigsetsize)
|
||||||
{
|
{
|
||||||
struct k_sigaction new_sa, old_sa;
|
struct k_sigaction new_sa, old_sa;
|
||||||
int ret = -EINVAL;
|
int ret = -EINVAL;
|
||||||
@ -748,8 +748,8 @@ asmlinkage int sys32_rt_sigaction(int sig, const struct sigaction32 __user *act,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_rt_sigprocmask(int how, compat_sigset_t __user *set,
|
SYSCALL_DEFINE4(32_rt_sigprocmask, int, how, compat_sigset_t __user *, set,
|
||||||
compat_sigset_t __user *oset, unsigned int sigsetsize)
|
compat_sigset_t __user *, oset, unsigned int, sigsetsize)
|
||||||
{
|
{
|
||||||
sigset_t old_set, new_set;
|
sigset_t old_set, new_set;
|
||||||
int ret;
|
int ret;
|
||||||
@ -770,8 +770,8 @@ asmlinkage int sys32_rt_sigprocmask(int how, compat_sigset_t __user *set,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_rt_sigpending(compat_sigset_t __user *uset,
|
SYSCALL_DEFINE2(32_rt_sigpending, compat_sigset_t __user *, uset,
|
||||||
unsigned int sigsetsize)
|
unsigned int, sigsetsize)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
sigset_t set;
|
sigset_t set;
|
||||||
@ -787,7 +787,8 @@ asmlinkage int sys32_rt_sigpending(compat_sigset_t __user *uset,
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys32_rt_sigqueueinfo(int pid, int sig, compat_siginfo_t __user *uinfo)
|
SYSCALL_DEFINE3(32_rt_sigqueueinfo, int, pid, int, sig,
|
||||||
|
compat_siginfo_t __user *, uinfo)
|
||||||
{
|
{
|
||||||
siginfo_t info;
|
siginfo_t info;
|
||||||
int ret;
|
int ret;
|
||||||
@ -802,10 +803,9 @@ asmlinkage int sys32_rt_sigqueueinfo(int pid, int sig, compat_siginfo_t __user *
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage long
|
SYSCALL_DEFINE5(32_waitid, int, which, compat_pid_t, pid,
|
||||||
sys32_waitid(int which, compat_pid_t pid,
|
compat_siginfo_t __user *, uinfo, int, options,
|
||||||
compat_siginfo_t __user *uinfo, int options,
|
struct compat_rusage __user *, uru)
|
||||||
struct compat_rusage __user *uru)
|
|
||||||
{
|
{
|
||||||
siginfo_t info;
|
siginfo_t info;
|
||||||
struct rusage ru;
|
struct rusage ru;
|
||||||
|
@ -152,9 +152,9 @@ do_mmap2(unsigned long addr, unsigned long len, unsigned long prot,
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage unsigned long
|
SYSCALL_DEFINE6(mips_mmap, unsigned long, addr, unsigned long, len,
|
||||||
old_mmap(unsigned long addr, unsigned long len, int prot,
|
unsigned long, prot, unsigned long, flags, unsigned long,
|
||||||
int flags, int fd, off_t offset)
|
fd, off_t, offset)
|
||||||
{
|
{
|
||||||
unsigned long result;
|
unsigned long result;
|
||||||
|
|
||||||
@ -168,9 +168,9 @@ old_mmap(unsigned long addr, unsigned long len, int prot,
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage unsigned long
|
SYSCALL_DEFINE6(mips_mmap2, unsigned long, addr, unsigned long, len,
|
||||||
sys_mmap2(unsigned long addr, unsigned long len, unsigned long prot,
|
unsigned long, prot, unsigned long, flags, unsigned long, fd,
|
||||||
unsigned long flags, unsigned long fd, unsigned long pgoff)
|
unsigned long, pgoff)
|
||||||
{
|
{
|
||||||
if (pgoff & (~PAGE_MASK >> 12))
|
if (pgoff & (~PAGE_MASK >> 12))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
@ -240,7 +240,7 @@ asmlinkage int sys_execve(nabi_no_regargs struct pt_regs regs)
|
|||||||
/*
|
/*
|
||||||
* Compacrapability ...
|
* Compacrapability ...
|
||||||
*/
|
*/
|
||||||
asmlinkage int sys_uname(struct old_utsname __user * name)
|
SYSCALL_DEFINE1(uname, struct old_utsname __user *, name)
|
||||||
{
|
{
|
||||||
if (name && !copy_to_user(name, utsname(), sizeof (*name)))
|
if (name && !copy_to_user(name, utsname(), sizeof (*name)))
|
||||||
return 0;
|
return 0;
|
||||||
@ -250,7 +250,7 @@ asmlinkage int sys_uname(struct old_utsname __user * name)
|
|||||||
/*
|
/*
|
||||||
* Compacrapability ...
|
* Compacrapability ...
|
||||||
*/
|
*/
|
||||||
asmlinkage int sys_olduname(struct oldold_utsname __user * name)
|
SYSCALL_DEFINE1(olduname, struct oldold_utsname __user *, name)
|
||||||
{
|
{
|
||||||
int error;
|
int error;
|
||||||
|
|
||||||
@ -279,7 +279,7 @@ asmlinkage int sys_olduname(struct oldold_utsname __user * name)
|
|||||||
return error;
|
return error;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int sys_set_thread_area(unsigned long addr)
|
SYSCALL_DEFINE1(set_thread_area, unsigned long, addr)
|
||||||
{
|
{
|
||||||
struct thread_info *ti = task_thread_info(current);
|
struct thread_info *ti = task_thread_info(current);
|
||||||
|
|
||||||
@ -290,7 +290,7 @@ asmlinkage int sys_set_thread_area(unsigned long addr)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
asmlinkage int _sys_sysmips(int cmd, long arg1, int arg2, int arg3)
|
asmlinkage int _sys_sysmips(long cmd, long arg1, long arg2, long arg3)
|
||||||
{
|
{
|
||||||
switch (cmd) {
|
switch (cmd) {
|
||||||
case MIPS_ATOMIC_SET:
|
case MIPS_ATOMIC_SET:
|
||||||
@ -325,8 +325,8 @@ asmlinkage int _sys_sysmips(int cmd, long arg1, int arg2, int arg3)
|
|||||||
*
|
*
|
||||||
* This is really horribly ugly.
|
* This is really horribly ugly.
|
||||||
*/
|
*/
|
||||||
asmlinkage int sys_ipc(unsigned int call, int first, int second,
|
SYSCALL_DEFINE6(ipc, unsigned int, call, int, first, int, second,
|
||||||
unsigned long third, void __user *ptr, long fifth)
|
unsigned long, third, void __user *, ptr, long, fifth)
|
||||||
{
|
{
|
||||||
int version, ret;
|
int version, ret;
|
||||||
|
|
||||||
@ -411,7 +411,7 @@ asmlinkage int sys_ipc(unsigned int call, int first, int second,
|
|||||||
/*
|
/*
|
||||||
* No implemented yet ...
|
* No implemented yet ...
|
||||||
*/
|
*/
|
||||||
asmlinkage int sys_cachectl(char *addr, int nbytes, int op)
|
SYSCALL_DEFINE3(cachectl, char *, addr, int, nbytes, int, op)
|
||||||
{
|
{
|
||||||
return -ENOSYS;
|
return -ENOSYS;
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
#include <linux/linkage.h>
|
#include <linux/linkage.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
|
#include <linux/syscalls.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
|
|
||||||
#include <asm/cacheflush.h>
|
#include <asm/cacheflush.h>
|
||||||
@ -58,8 +59,8 @@ EXPORT_SYMBOL(_dma_cache_wback_inv);
|
|||||||
* We could optimize the case where the cache argument is not BCACHE but
|
* We could optimize the case where the cache argument is not BCACHE but
|
||||||
* that seems very atypical use ...
|
* that seems very atypical use ...
|
||||||
*/
|
*/
|
||||||
asmlinkage int sys_cacheflush(unsigned long addr,
|
SYSCALL_DEFINE3(cacheflush, unsigned long, addr, unsigned long, bytes,
|
||||||
unsigned long bytes, unsigned int cache)
|
unsigned int, cache)
|
||||||
{
|
{
|
||||||
if (bytes == 0)
|
if (bytes == 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -210,5 +210,10 @@ struct compat_shmid64_ds {
|
|||||||
compat_ulong_t __unused6;
|
compat_ulong_t __unused6;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline int is_compat_task(void)
|
||||||
|
{
|
||||||
|
return test_thread_flag(TIF_32BIT);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* __KERNEL__ */
|
#endif /* __KERNEL__ */
|
||||||
#endif /* _ASM_POWERPC_COMPAT_H */
|
#endif /* _ASM_POWERPC_COMPAT_H */
|
||||||
|
@ -1,10 +1,6 @@
|
|||||||
#ifndef _ASM_POWERPC_SECCOMP_H
|
#ifndef _ASM_POWERPC_SECCOMP_H
|
||||||
#define _ASM_POWERPC_SECCOMP_H
|
#define _ASM_POWERPC_SECCOMP_H
|
||||||
|
|
||||||
#ifdef __KERNEL__
|
|
||||||
#include <linux/thread_info.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
|
|
||||||
#define __NR_seccomp_read __NR_read
|
#define __NR_seccomp_read __NR_read
|
||||||
|
@ -367,27 +367,24 @@ static int emulate_multiple(struct pt_regs *regs, unsigned char __user *addr,
|
|||||||
static int emulate_fp_pair(unsigned char __user *addr, unsigned int reg,
|
static int emulate_fp_pair(unsigned char __user *addr, unsigned int reg,
|
||||||
unsigned int flags)
|
unsigned int flags)
|
||||||
{
|
{
|
||||||
char *ptr = (char *) ¤t->thread.TS_FPR(reg);
|
char *ptr0 = (char *) ¤t->thread.TS_FPR(reg);
|
||||||
int i, ret;
|
char *ptr1 = (char *) ¤t->thread.TS_FPR(reg+1);
|
||||||
|
int i, ret, sw = 0;
|
||||||
|
|
||||||
if (!(flags & F))
|
if (!(flags & F))
|
||||||
return 0;
|
return 0;
|
||||||
if (reg & 1)
|
if (reg & 1)
|
||||||
return 0; /* invalid form: FRS/FRT must be even */
|
return 0; /* invalid form: FRS/FRT must be even */
|
||||||
if (!(flags & SW)) {
|
if (flags & SW)
|
||||||
/* not byte-swapped - easy */
|
sw = 7;
|
||||||
if (!(flags & ST))
|
ret = 0;
|
||||||
ret = __copy_from_user(ptr, addr, 16);
|
for (i = 0; i < 8; ++i) {
|
||||||
else
|
if (!(flags & ST)) {
|
||||||
ret = __copy_to_user(addr, ptr, 16);
|
ret |= __get_user(ptr0[i^sw], addr + i);
|
||||||
} else {
|
ret |= __get_user(ptr1[i^sw], addr + i + 8);
|
||||||
/* each FPR value is byte-swapped separately */
|
} else {
|
||||||
ret = 0;
|
ret |= __put_user(ptr0[i^sw], addr + i);
|
||||||
for (i = 0; i < 16; ++i) {
|
ret |= __put_user(ptr1[i^sw], addr + i + 8);
|
||||||
if (!(flags & ST))
|
|
||||||
ret |= __get_user(ptr[i^7], addr + i);
|
|
||||||
else
|
|
||||||
ret |= __put_user(ptr[i^7], addr + i);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (ret)
|
if (ret)
|
||||||
|
@ -62,18 +62,19 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
72: std r8,8(r3)
|
72: std r8,8(r3)
|
||||||
beq+ 3f
|
beq+ 3f
|
||||||
addi r3,r3,16
|
addi r3,r3,16
|
||||||
23: ld r9,8(r4)
|
|
||||||
.Ldo_tail:
|
.Ldo_tail:
|
||||||
bf cr7*4+1,1f
|
bf cr7*4+1,1f
|
||||||
rotldi r9,r9,32
|
23: lwz r9,8(r4)
|
||||||
|
addi r4,r4,4
|
||||||
73: stw r9,0(r3)
|
73: stw r9,0(r3)
|
||||||
addi r3,r3,4
|
addi r3,r3,4
|
||||||
1: bf cr7*4+2,2f
|
1: bf cr7*4+2,2f
|
||||||
rotldi r9,r9,16
|
44: lhz r9,8(r4)
|
||||||
|
addi r4,r4,2
|
||||||
74: sth r9,0(r3)
|
74: sth r9,0(r3)
|
||||||
addi r3,r3,2
|
addi r3,r3,2
|
||||||
2: bf cr7*4+3,3f
|
2: bf cr7*4+3,3f
|
||||||
rotldi r9,r9,8
|
45: lbz r9,8(r4)
|
||||||
75: stb r9,0(r3)
|
75: stb r9,0(r3)
|
||||||
3: li r3,0
|
3: li r3,0
|
||||||
blr
|
blr
|
||||||
@ -141,11 +142,24 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
6: cmpwi cr1,r5,8
|
6: cmpwi cr1,r5,8
|
||||||
addi r3,r3,32
|
addi r3,r3,32
|
||||||
sld r9,r9,r10
|
sld r9,r9,r10
|
||||||
ble cr1,.Ldo_tail
|
ble cr1,7f
|
||||||
34: ld r0,8(r4)
|
34: ld r0,8(r4)
|
||||||
srd r7,r0,r11
|
srd r7,r0,r11
|
||||||
or r9,r7,r9
|
or r9,r7,r9
|
||||||
b .Ldo_tail
|
7:
|
||||||
|
bf cr7*4+1,1f
|
||||||
|
rotldi r9,r9,32
|
||||||
|
94: stw r9,0(r3)
|
||||||
|
addi r3,r3,4
|
||||||
|
1: bf cr7*4+2,2f
|
||||||
|
rotldi r9,r9,16
|
||||||
|
95: sth r9,0(r3)
|
||||||
|
addi r3,r3,2
|
||||||
|
2: bf cr7*4+3,3f
|
||||||
|
rotldi r9,r9,8
|
||||||
|
96: stb r9,0(r3)
|
||||||
|
3: li r3,0
|
||||||
|
blr
|
||||||
|
|
||||||
.Ldst_unaligned:
|
.Ldst_unaligned:
|
||||||
PPC_MTOCRF 0x01,r6 /* put #bytes to 8B bdry into cr7 */
|
PPC_MTOCRF 0x01,r6 /* put #bytes to 8B bdry into cr7 */
|
||||||
@ -218,7 +232,6 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
121:
|
121:
|
||||||
132:
|
132:
|
||||||
addi r3,r3,8
|
addi r3,r3,8
|
||||||
123:
|
|
||||||
134:
|
134:
|
||||||
135:
|
135:
|
||||||
138:
|
138:
|
||||||
@ -226,6 +239,9 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
140:
|
140:
|
||||||
141:
|
141:
|
||||||
142:
|
142:
|
||||||
|
123:
|
||||||
|
144:
|
||||||
|
145:
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* here we have had a fault on a load and r3 points to the first
|
* here we have had a fault on a load and r3 points to the first
|
||||||
@ -309,6 +325,9 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
187:
|
187:
|
||||||
188:
|
188:
|
||||||
189:
|
189:
|
||||||
|
194:
|
||||||
|
195:
|
||||||
|
196:
|
||||||
1:
|
1:
|
||||||
ld r6,-24(r1)
|
ld r6,-24(r1)
|
||||||
ld r5,-8(r1)
|
ld r5,-8(r1)
|
||||||
@ -329,7 +348,9 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
.llong 72b,172b
|
.llong 72b,172b
|
||||||
.llong 23b,123b
|
.llong 23b,123b
|
||||||
.llong 73b,173b
|
.llong 73b,173b
|
||||||
|
.llong 44b,144b
|
||||||
.llong 74b,174b
|
.llong 74b,174b
|
||||||
|
.llong 45b,145b
|
||||||
.llong 75b,175b
|
.llong 75b,175b
|
||||||
.llong 24b,124b
|
.llong 24b,124b
|
||||||
.llong 25b,125b
|
.llong 25b,125b
|
||||||
@ -347,6 +368,9 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
.llong 79b,179b
|
.llong 79b,179b
|
||||||
.llong 80b,180b
|
.llong 80b,180b
|
||||||
.llong 34b,134b
|
.llong 34b,134b
|
||||||
|
.llong 94b,194b
|
||||||
|
.llong 95b,195b
|
||||||
|
.llong 96b,196b
|
||||||
.llong 35b,135b
|
.llong 35b,135b
|
||||||
.llong 81b,181b
|
.llong 81b,181b
|
||||||
.llong 36b,136b
|
.llong 36b,136b
|
||||||
|
@ -53,18 +53,19 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
3: std r8,8(r3)
|
3: std r8,8(r3)
|
||||||
beq 3f
|
beq 3f
|
||||||
addi r3,r3,16
|
addi r3,r3,16
|
||||||
ld r9,8(r4)
|
|
||||||
.Ldo_tail:
|
.Ldo_tail:
|
||||||
bf cr7*4+1,1f
|
bf cr7*4+1,1f
|
||||||
rotldi r9,r9,32
|
lwz r9,8(r4)
|
||||||
|
addi r4,r4,4
|
||||||
stw r9,0(r3)
|
stw r9,0(r3)
|
||||||
addi r3,r3,4
|
addi r3,r3,4
|
||||||
1: bf cr7*4+2,2f
|
1: bf cr7*4+2,2f
|
||||||
rotldi r9,r9,16
|
lhz r9,8(r4)
|
||||||
|
addi r4,r4,2
|
||||||
sth r9,0(r3)
|
sth r9,0(r3)
|
||||||
addi r3,r3,2
|
addi r3,r3,2
|
||||||
2: bf cr7*4+3,3f
|
2: bf cr7*4+3,3f
|
||||||
rotldi r9,r9,8
|
lbz r9,8(r4)
|
||||||
stb r9,0(r3)
|
stb r9,0(r3)
|
||||||
3: ld r3,48(r1) /* return dest pointer */
|
3: ld r3,48(r1) /* return dest pointer */
|
||||||
blr
|
blr
|
||||||
@ -133,11 +134,24 @@ END_FTR_SECTION_IFCLR(CPU_FTR_UNALIGNED_LD_STD)
|
|||||||
cmpwi cr1,r5,8
|
cmpwi cr1,r5,8
|
||||||
addi r3,r3,32
|
addi r3,r3,32
|
||||||
sld r9,r9,r10
|
sld r9,r9,r10
|
||||||
ble cr1,.Ldo_tail
|
ble cr1,6f
|
||||||
ld r0,8(r4)
|
ld r0,8(r4)
|
||||||
srd r7,r0,r11
|
srd r7,r0,r11
|
||||||
or r9,r7,r9
|
or r9,r7,r9
|
||||||
b .Ldo_tail
|
6:
|
||||||
|
bf cr7*4+1,1f
|
||||||
|
rotldi r9,r9,32
|
||||||
|
stw r9,0(r3)
|
||||||
|
addi r3,r3,4
|
||||||
|
1: bf cr7*4+2,2f
|
||||||
|
rotldi r9,r9,16
|
||||||
|
sth r9,0(r3)
|
||||||
|
addi r3,r3,2
|
||||||
|
2: bf cr7*4+3,3f
|
||||||
|
rotldi r9,r9,8
|
||||||
|
stb r9,0(r3)
|
||||||
|
3: ld r3,48(r1) /* return dest pointer */
|
||||||
|
blr
|
||||||
|
|
||||||
.Ldst_unaligned:
|
.Ldst_unaligned:
|
||||||
PPC_MTOCRF 0x01,r6 # put #bytes to 8B bdry into cr7
|
PPC_MTOCRF 0x01,r6 # put #bytes to 8B bdry into cr7
|
||||||
|
@ -142,6 +142,10 @@ static void __init gef_sbc610_nec_fixup(struct pci_dev *pdev)
|
|||||||
{
|
{
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
|
|
||||||
|
/* Do not do the fixup on other platforms! */
|
||||||
|
if (!machine_is(gef_sbc610))
|
||||||
|
return;
|
||||||
|
|
||||||
printk(KERN_INFO "Running NEC uPD720101 Fixup\n");
|
printk(KERN_INFO "Running NEC uPD720101 Fixup\n");
|
||||||
|
|
||||||
/* Ensure ports 1, 2, 3, 4 & 5 are enabled */
|
/* Ensure ports 1, 2, 3, 4 & 5 are enabled */
|
||||||
|
@ -204,6 +204,23 @@ static int __init ppc4xx_setup_one_pci_PMM(struct pci_controller *hose,
|
|||||||
{
|
{
|
||||||
u32 ma, pcila, pciha;
|
u32 ma, pcila, pciha;
|
||||||
|
|
||||||
|
/* Hack warning ! The "old" PCI 2.x cell only let us configure the low
|
||||||
|
* 32-bit of incoming PLB addresses. The top 4 bits of the 36-bit
|
||||||
|
* address are actually hard wired to a value that appears to depend
|
||||||
|
* on the specific SoC. For example, it's 0 on 440EP and 1 on 440EPx.
|
||||||
|
*
|
||||||
|
* The trick here is we just crop those top bits and ignore them when
|
||||||
|
* programming the chip. That means the device-tree has to be right
|
||||||
|
* for the specific part used (we don't print a warning if it's wrong
|
||||||
|
* but on the other hand, you'll crash quickly enough), but at least
|
||||||
|
* this code should work whatever the hard coded value is
|
||||||
|
*/
|
||||||
|
plb_addr &= 0xffffffffull;
|
||||||
|
|
||||||
|
/* Note: Due to the above hack, the test below doesn't actually test
|
||||||
|
* if you address is above 4G, but it tests that address and
|
||||||
|
* (address + size) are both contained in the same 4G
|
||||||
|
*/
|
||||||
if ((plb_addr + size) > 0xffffffffull || !is_power_of_2(size) ||
|
if ((plb_addr + size) > 0xffffffffull || !is_power_of_2(size) ||
|
||||||
size < 0x1000 || (plb_addr & (size - 1)) != 0) {
|
size < 0x1000 || (plb_addr & (size - 1)) != 0) {
|
||||||
printk(KERN_WARNING "%s: Resource out of range\n",
|
printk(KERN_WARNING "%s: Resource out of range\n",
|
||||||
|
@ -556,7 +556,7 @@ static void __exit aes_s390_fini(void)
|
|||||||
module_init(aes_s390_init);
|
module_init(aes_s390_init);
|
||||||
module_exit(aes_s390_fini);
|
module_exit(aes_s390_fini);
|
||||||
|
|
||||||
MODULE_ALIAS("aes");
|
MODULE_ALIAS("aes-all");
|
||||||
|
|
||||||
MODULE_DESCRIPTION("Rijndael (AES) Cipher Algorithm");
|
MODULE_DESCRIPTION("Rijndael (AES) Cipher Algorithm");
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
@ -22,7 +22,6 @@
|
|||||||
#include <linux/gpio.h>
|
#include <linux/gpio.h>
|
||||||
#include <linux/spi/spi.h>
|
#include <linux/spi/spi.h>
|
||||||
#include <linux/spi/spi_gpio.h>
|
#include <linux/spi/spi_gpio.h>
|
||||||
#include <media/ov772x.h>
|
|
||||||
#include <media/soc_camera_platform.h>
|
#include <media/soc_camera_platform.h>
|
||||||
#include <media/sh_mobile_ceu.h>
|
#include <media/sh_mobile_ceu.h>
|
||||||
#include <video/sh_mobile_lcdc.h>
|
#include <video/sh_mobile_lcdc.h>
|
||||||
@ -224,7 +223,6 @@ static void camera_power(int val)
|
|||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_I2C
|
#ifdef CONFIG_I2C
|
||||||
/* support for the old ncm03j camera */
|
|
||||||
static unsigned char camera_ncm03j_magic[] =
|
static unsigned char camera_ncm03j_magic[] =
|
||||||
{
|
{
|
||||||
0x87, 0x00, 0x88, 0x08, 0x89, 0x01, 0x8A, 0xE8,
|
0x87, 0x00, 0x88, 0x08, 0x89, 0x01, 0x8A, 0xE8,
|
||||||
@ -245,23 +243,6 @@ static unsigned char camera_ncm03j_magic[] =
|
|||||||
0x63, 0xD4, 0x64, 0xEA, 0xD6, 0x0F,
|
0x63, 0xD4, 0x64, 0xEA, 0xD6, 0x0F,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int camera_probe(void)
|
|
||||||
{
|
|
||||||
struct i2c_adapter *a = i2c_get_adapter(0);
|
|
||||||
struct i2c_msg msg;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
camera_power(1);
|
|
||||||
msg.addr = 0x6e;
|
|
||||||
msg.buf = camera_ncm03j_magic;
|
|
||||||
msg.len = 2;
|
|
||||||
msg.flags = 0;
|
|
||||||
ret = i2c_transfer(a, &msg, 1);
|
|
||||||
camera_power(0);
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int camera_set_capture(struct soc_camera_platform_info *info,
|
static int camera_set_capture(struct soc_camera_platform_info *info,
|
||||||
int enable)
|
int enable)
|
||||||
{
|
{
|
||||||
@ -313,35 +294,8 @@ static struct platform_device camera_device = {
|
|||||||
.platform_data = &camera_info,
|
.platform_data = &camera_info,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static int __init camera_setup(void)
|
|
||||||
{
|
|
||||||
if (camera_probe() > 0)
|
|
||||||
platform_device_register(&camera_device);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
late_initcall(camera_setup);
|
|
||||||
|
|
||||||
#endif /* CONFIG_I2C */
|
#endif /* CONFIG_I2C */
|
||||||
|
|
||||||
static int ov7725_power(struct device *dev, int mode)
|
|
||||||
{
|
|
||||||
camera_power(0);
|
|
||||||
if (mode)
|
|
||||||
camera_power(1);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static struct ov772x_camera_info ov7725_info = {
|
|
||||||
.buswidth = SOCAM_DATAWIDTH_8,
|
|
||||||
.flags = OV772X_FLAG_VFLIP | OV772X_FLAG_HFLIP,
|
|
||||||
.link = {
|
|
||||||
.power = ov7725_power,
|
|
||||||
},
|
|
||||||
};
|
|
||||||
|
|
||||||
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
static struct sh_mobile_ceu_info sh_mobile_ceu_info = {
|
||||||
.flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_HSYNC_ACTIVE_HIGH |
|
.flags = SOCAM_PCLK_SAMPLE_RISING | SOCAM_HSYNC_ACTIVE_HIGH |
|
||||||
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_MASTER | SOCAM_DATAWIDTH_8,
|
SOCAM_VSYNC_ACTIVE_HIGH | SOCAM_MASTER | SOCAM_DATAWIDTH_8,
|
||||||
@ -392,6 +346,9 @@ static struct platform_device *ap325rxa_devices[] __initdata = {
|
|||||||
&ap325rxa_nor_flash_device,
|
&ap325rxa_nor_flash_device,
|
||||||
&lcdc_device,
|
&lcdc_device,
|
||||||
&ceu_device,
|
&ceu_device,
|
||||||
|
#ifdef CONFIG_I2C
|
||||||
|
&camera_device,
|
||||||
|
#endif
|
||||||
&nand_flash_device,
|
&nand_flash_device,
|
||||||
&sdcard_cn3_device,
|
&sdcard_cn3_device,
|
||||||
};
|
};
|
||||||
@ -400,10 +357,6 @@ static struct i2c_board_info __initdata ap325rxa_i2c_devices[] = {
|
|||||||
{
|
{
|
||||||
I2C_BOARD_INFO("pcf8563", 0x51),
|
I2C_BOARD_INFO("pcf8563", 0x51),
|
||||||
},
|
},
|
||||||
{
|
|
||||||
I2C_BOARD_INFO("ov772x", 0x21),
|
|
||||||
.platform_data = &ov7725_info,
|
|
||||||
},
|
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct spi_board_info ap325rxa_spi_devices[] = {
|
static struct spi_board_info ap325rxa_spi_devices[] = {
|
||||||
|
@ -18,8 +18,8 @@
|
|||||||
#include <asm/freq.h>
|
#include <asm/freq.h>
|
||||||
#include <asm/io.h>
|
#include <asm/io.h>
|
||||||
|
|
||||||
const static int pll1rate[]={1,2,3,4,6,8};
|
static const int pll1rate[]={1,2,3,4,6,8};
|
||||||
const static int pfc_divisors[]={1,2,3,4,6,8,12};
|
static const int pfc_divisors[]={1,2,3,4,6,8,12};
|
||||||
#define ifc_divisors pfc_divisors
|
#define ifc_divisors pfc_divisors
|
||||||
|
|
||||||
#if (CONFIG_SH_CLK_MD == 0)
|
#if (CONFIG_SH_CLK_MD == 0)
|
||||||
|
@ -240,4 +240,9 @@ struct compat_shmid64_ds {
|
|||||||
unsigned int __unused2;
|
unsigned int __unused2;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static inline int is_compat_task(void)
|
||||||
|
{
|
||||||
|
return test_thread_flag(TIF_32BIT);
|
||||||
|
}
|
||||||
|
|
||||||
#endif /* _ASM_SPARC64_COMPAT_H */
|
#endif /* _ASM_SPARC64_COMPAT_H */
|
||||||
|
@ -1,11 +1,5 @@
|
|||||||
#ifndef _ASM_SECCOMP_H
|
#ifndef _ASM_SECCOMP_H
|
||||||
|
|
||||||
#include <linux/thread_info.h> /* already defines TIF_32BIT */
|
|
||||||
|
|
||||||
#ifndef TIF_32BIT
|
|
||||||
#error "unexpected TIF_32BIT on sparc64"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
|
|
||||||
#define __NR_seccomp_read __NR_read
|
#define __NR_seccomp_read __NR_read
|
||||||
|
@ -306,6 +306,7 @@ static int jbusmc_print_dimm(int syndrome_code,
|
|||||||
buf[1] = '?';
|
buf[1] = '?';
|
||||||
buf[2] = '?';
|
buf[2] = '?';
|
||||||
buf[3] = '\0';
|
buf[3] = '\0';
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
p = dp->controller;
|
p = dp->controller;
|
||||||
prop = &p->layout;
|
prop = &p->layout;
|
||||||
|
@ -1803,7 +1803,7 @@ config DMAR
|
|||||||
remapping devices.
|
remapping devices.
|
||||||
|
|
||||||
config DMAR_DEFAULT_ON
|
config DMAR_DEFAULT_ON
|
||||||
def_bool n
|
def_bool y
|
||||||
prompt "Enable DMA Remapping Devices by default"
|
prompt "Enable DMA Remapping Devices by default"
|
||||||
depends on DMAR
|
depends on DMAR
|
||||||
help
|
help
|
||||||
|
@ -23,6 +23,9 @@
|
|||||||
#include <asm/pgtable.h>
|
#include <asm/pgtable.h>
|
||||||
#include <asm/tlbflush.h>
|
#include <asm/tlbflush.h>
|
||||||
|
|
||||||
|
int
|
||||||
|
is_io_mapping_possible(resource_size_t base, unsigned long size);
|
||||||
|
|
||||||
void *
|
void *
|
||||||
iomap_atomic_prot_pfn(unsigned long pfn, enum km_type type, pgprot_t prot);
|
iomap_atomic_prot_pfn(unsigned long pfn, enum km_type type, pgprot_t prot);
|
||||||
|
|
||||||
|
@ -1,12 +1,6 @@
|
|||||||
#ifndef _ASM_X86_SECCOMP_32_H
|
#ifndef _ASM_X86_SECCOMP_32_H
|
||||||
#define _ASM_X86_SECCOMP_32_H
|
#define _ASM_X86_SECCOMP_32_H
|
||||||
|
|
||||||
#include <linux/thread_info.h>
|
|
||||||
|
|
||||||
#ifdef TIF_32BIT
|
|
||||||
#error "unexpected TIF_32BIT on i386"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
|
|
||||||
#define __NR_seccomp_read __NR_read
|
#define __NR_seccomp_read __NR_read
|
||||||
|
@ -1,14 +1,6 @@
|
|||||||
#ifndef _ASM_X86_SECCOMP_64_H
|
#ifndef _ASM_X86_SECCOMP_64_H
|
||||||
#define _ASM_X86_SECCOMP_64_H
|
#define _ASM_X86_SECCOMP_64_H
|
||||||
|
|
||||||
#include <linux/thread_info.h>
|
|
||||||
|
|
||||||
#ifdef TIF_32BIT
|
|
||||||
#error "unexpected TIF_32BIT on x86_64"
|
|
||||||
#else
|
|
||||||
#define TIF_32BIT TIF_IA32
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <linux/unistd.h>
|
#include <linux/unistd.h>
|
||||||
#include <asm/ia32_unistd.h>
|
#include <asm/ia32_unistd.h>
|
||||||
|
|
||||||
|
@ -1388,7 +1388,7 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs,
|
|||||||
#ifdef CONFIG_X86_32
|
#ifdef CONFIG_X86_32
|
||||||
# define IS_IA32 1
|
# define IS_IA32 1
|
||||||
#elif defined CONFIG_IA32_EMULATION
|
#elif defined CONFIG_IA32_EMULATION
|
||||||
# define IS_IA32 test_thread_flag(TIF_IA32)
|
# define IS_IA32 is_compat_task()
|
||||||
#else
|
#else
|
||||||
# define IS_IA32 0
|
# define IS_IA32 0
|
||||||
#endif
|
#endif
|
||||||
|
@ -65,7 +65,7 @@ static volatile unsigned long smp_invalidate_needed;
|
|||||||
|
|
||||||
/* Bitmask of CPUs present in the system - exported by i386_syms.c, used
|
/* Bitmask of CPUs present in the system - exported by i386_syms.c, used
|
||||||
* by scheduler but indexed physically */
|
* by scheduler but indexed physically */
|
||||||
cpumask_t phys_cpu_present_map = CPU_MASK_NONE;
|
static cpumask_t voyager_phys_cpu_present_map = CPU_MASK_NONE;
|
||||||
|
|
||||||
/* The internal functions */
|
/* The internal functions */
|
||||||
static void send_CPI(__u32 cpuset, __u8 cpi);
|
static void send_CPI(__u32 cpuset, __u8 cpi);
|
||||||
@ -366,19 +366,19 @@ void __init find_smp_config(void)
|
|||||||
/* set up everything for just this CPU, we can alter
|
/* set up everything for just this CPU, we can alter
|
||||||
* this as we start the other CPUs later */
|
* this as we start the other CPUs later */
|
||||||
/* now get the CPU disposition from the extended CMOS */
|
/* now get the CPU disposition from the extended CMOS */
|
||||||
cpus_addr(phys_cpu_present_map)[0] =
|
cpus_addr(voyager_phys_cpu_present_map)[0] =
|
||||||
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK);
|
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK);
|
||||||
cpus_addr(phys_cpu_present_map)[0] |=
|
cpus_addr(voyager_phys_cpu_present_map)[0] |=
|
||||||
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK + 1) << 8;
|
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK + 1) << 8;
|
||||||
cpus_addr(phys_cpu_present_map)[0] |=
|
cpus_addr(voyager_phys_cpu_present_map)[0] |=
|
||||||
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK +
|
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK +
|
||||||
2) << 16;
|
2) << 16;
|
||||||
cpus_addr(phys_cpu_present_map)[0] |=
|
cpus_addr(voyager_phys_cpu_present_map)[0] |=
|
||||||
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK +
|
voyager_extended_cmos_read(VOYAGER_PROCESSOR_PRESENT_MASK +
|
||||||
3) << 24;
|
3) << 24;
|
||||||
init_cpu_possible(&phys_cpu_present_map);
|
init_cpu_possible(&voyager_phys_cpu_present_map);
|
||||||
printk("VOYAGER SMP: phys_cpu_present_map = 0x%lx\n",
|
printk("VOYAGER SMP: voyager_phys_cpu_present_map = 0x%lx\n",
|
||||||
cpus_addr(phys_cpu_present_map)[0]);
|
cpus_addr(voyager_phys_cpu_present_map)[0]);
|
||||||
/* Here we set up the VIC to enable SMP */
|
/* Here we set up the VIC to enable SMP */
|
||||||
/* enable the CPIs by writing the base vector to their register */
|
/* enable the CPIs by writing the base vector to their register */
|
||||||
outb(VIC_DEFAULT_CPI_BASE, VIC_CPI_BASE_REGISTER);
|
outb(VIC_DEFAULT_CPI_BASE, VIC_CPI_BASE_REGISTER);
|
||||||
@ -628,15 +628,15 @@ void __init smp_boot_cpus(void)
|
|||||||
/* now that the cat has probed the Voyager System Bus, sanity
|
/* now that the cat has probed the Voyager System Bus, sanity
|
||||||
* check the cpu map */
|
* check the cpu map */
|
||||||
if (((voyager_quad_processors | voyager_extended_vic_processors)
|
if (((voyager_quad_processors | voyager_extended_vic_processors)
|
||||||
& cpus_addr(phys_cpu_present_map)[0]) !=
|
& cpus_addr(voyager_phys_cpu_present_map)[0]) !=
|
||||||
cpus_addr(phys_cpu_present_map)[0]) {
|
cpus_addr(voyager_phys_cpu_present_map)[0]) {
|
||||||
/* should panic */
|
/* should panic */
|
||||||
printk("\n\n***WARNING*** "
|
printk("\n\n***WARNING*** "
|
||||||
"Sanity check of CPU present map FAILED\n");
|
"Sanity check of CPU present map FAILED\n");
|
||||||
}
|
}
|
||||||
} else if (voyager_level == 4)
|
} else if (voyager_level == 4)
|
||||||
voyager_extended_vic_processors =
|
voyager_extended_vic_processors =
|
||||||
cpus_addr(phys_cpu_present_map)[0];
|
cpus_addr(voyager_phys_cpu_present_map)[0];
|
||||||
|
|
||||||
/* this sets up the idle task to run on the current cpu */
|
/* this sets up the idle task to run on the current cpu */
|
||||||
voyager_extended_cpus = 1;
|
voyager_extended_cpus = 1;
|
||||||
@ -670,7 +670,7 @@ void __init smp_boot_cpus(void)
|
|||||||
/* loop over all the extended VIC CPUs and boot them. The
|
/* loop over all the extended VIC CPUs and boot them. The
|
||||||
* Quad CPUs must be bootstrapped by their extended VIC cpu */
|
* Quad CPUs must be bootstrapped by their extended VIC cpu */
|
||||||
for (i = 0; i < nr_cpu_ids; i++) {
|
for (i = 0; i < nr_cpu_ids; i++) {
|
||||||
if (i == boot_cpu_id || !cpu_isset(i, phys_cpu_present_map))
|
if (i == boot_cpu_id || !cpu_isset(i, voyager_phys_cpu_present_map))
|
||||||
continue;
|
continue;
|
||||||
do_boot_cpu(i);
|
do_boot_cpu(i);
|
||||||
/* This udelay seems to be needed for the Quad boots
|
/* This udelay seems to be needed for the Quad boots
|
||||||
|
@ -714,6 +714,8 @@ unsigned long __init_refok init_memory_mapping(unsigned long start,
|
|||||||
pos = start_pfn << PAGE_SHIFT;
|
pos = start_pfn << PAGE_SHIFT;
|
||||||
end_pfn = ((pos + (PMD_SIZE - 1)) >> PMD_SHIFT)
|
end_pfn = ((pos + (PMD_SIZE - 1)) >> PMD_SHIFT)
|
||||||
<< (PMD_SHIFT - PAGE_SHIFT);
|
<< (PMD_SHIFT - PAGE_SHIFT);
|
||||||
|
if (end_pfn > (end >> PAGE_SHIFT))
|
||||||
|
end_pfn = end >> PAGE_SHIFT;
|
||||||
if (start_pfn < end_pfn) {
|
if (start_pfn < end_pfn) {
|
||||||
nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, 0);
|
nr_range = save_mr(mr, nr_range, start_pfn, end_pfn, 0);
|
||||||
pos = end_pfn << PAGE_SHIFT;
|
pos = end_pfn << PAGE_SHIFT;
|
||||||
|
@ -20,6 +20,17 @@
|
|||||||
#include <asm/pat.h>
|
#include <asm/pat.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
|
||||||
|
int is_io_mapping_possible(resource_size_t base, unsigned long size)
|
||||||
|
{
|
||||||
|
#ifndef CONFIG_X86_PAE
|
||||||
|
/* There is no way to map greater than 1 << 32 address without PAE */
|
||||||
|
if (base + size > 0x100000000ULL)
|
||||||
|
return 0;
|
||||||
|
#endif
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(is_io_mapping_possible);
|
||||||
|
|
||||||
/* Map 'pfn' using fixed map 'type' and protections 'prot'
|
/* Map 'pfn' using fixed map 'type' and protections 'prot'
|
||||||
*/
|
*/
|
||||||
void *
|
void *
|
||||||
|
@ -32,11 +32,14 @@ struct kmmio_fault_page {
|
|||||||
struct list_head list;
|
struct list_head list;
|
||||||
struct kmmio_fault_page *release_next;
|
struct kmmio_fault_page *release_next;
|
||||||
unsigned long page; /* location of the fault page */
|
unsigned long page; /* location of the fault page */
|
||||||
|
bool old_presence; /* page presence prior to arming */
|
||||||
|
bool armed;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Number of times this page has been registered as a part
|
* Number of times this page has been registered as a part
|
||||||
* of a probe. If zero, page is disarmed and this may be freed.
|
* of a probe. If zero, page is disarmed and this may be freed.
|
||||||
* Used only by writers (RCU).
|
* Used only by writers (RCU) and post_kmmio_handler().
|
||||||
|
* Protected by kmmio_lock, when linked into kmmio_page_table.
|
||||||
*/
|
*/
|
||||||
int count;
|
int count;
|
||||||
};
|
};
|
||||||
@ -105,57 +108,85 @@ static struct kmmio_fault_page *get_kmmio_fault_page(unsigned long page)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void set_page_present(unsigned long addr, bool present,
|
static void set_pmd_presence(pmd_t *pmd, bool present, bool *old)
|
||||||
unsigned int *pglevel)
|
{
|
||||||
|
pmdval_t v = pmd_val(*pmd);
|
||||||
|
*old = !!(v & _PAGE_PRESENT);
|
||||||
|
v &= ~_PAGE_PRESENT;
|
||||||
|
if (present)
|
||||||
|
v |= _PAGE_PRESENT;
|
||||||
|
set_pmd(pmd, __pmd(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void set_pte_presence(pte_t *pte, bool present, bool *old)
|
||||||
|
{
|
||||||
|
pteval_t v = pte_val(*pte);
|
||||||
|
*old = !!(v & _PAGE_PRESENT);
|
||||||
|
v &= ~_PAGE_PRESENT;
|
||||||
|
if (present)
|
||||||
|
v |= _PAGE_PRESENT;
|
||||||
|
set_pte_atomic(pte, __pte(v));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int set_page_presence(unsigned long addr, bool present, bool *old)
|
||||||
{
|
{
|
||||||
pteval_t pteval;
|
|
||||||
pmdval_t pmdval;
|
|
||||||
unsigned int level;
|
unsigned int level;
|
||||||
pmd_t *pmd;
|
|
||||||
pte_t *pte = lookup_address(addr, &level);
|
pte_t *pte = lookup_address(addr, &level);
|
||||||
|
|
||||||
if (!pte) {
|
if (!pte) {
|
||||||
pr_err("kmmio: no pte for page 0x%08lx\n", addr);
|
pr_err("kmmio: no pte for page 0x%08lx\n", addr);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pglevel)
|
|
||||||
*pglevel = level;
|
|
||||||
|
|
||||||
switch (level) {
|
switch (level) {
|
||||||
case PG_LEVEL_2M:
|
case PG_LEVEL_2M:
|
||||||
pmd = (pmd_t *)pte;
|
set_pmd_presence((pmd_t *)pte, present, old);
|
||||||
pmdval = pmd_val(*pmd) & ~_PAGE_PRESENT;
|
|
||||||
if (present)
|
|
||||||
pmdval |= _PAGE_PRESENT;
|
|
||||||
set_pmd(pmd, __pmd(pmdval));
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case PG_LEVEL_4K:
|
case PG_LEVEL_4K:
|
||||||
pteval = pte_val(*pte) & ~_PAGE_PRESENT;
|
set_pte_presence(pte, present, old);
|
||||||
if (present)
|
|
||||||
pteval |= _PAGE_PRESENT;
|
|
||||||
set_pte_atomic(pte, __pte(pteval));
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
pr_err("kmmio: unexpected page level 0x%x.\n", level);
|
pr_err("kmmio: unexpected page level 0x%x.\n", level);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
__flush_tlb_one(addr);
|
__flush_tlb_one(addr);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Mark the given page as not present. Access to it will trigger a fault. */
|
/*
|
||||||
static void arm_kmmio_fault_page(unsigned long page, unsigned int *pglevel)
|
* Mark the given page as not present. Access to it will trigger a fault.
|
||||||
|
*
|
||||||
|
* Struct kmmio_fault_page is protected by RCU and kmmio_lock, but the
|
||||||
|
* protection is ignored here. RCU read lock is assumed held, so the struct
|
||||||
|
* will not disappear unexpectedly. Furthermore, the caller must guarantee,
|
||||||
|
* that double arming the same virtual address (page) cannot occur.
|
||||||
|
*
|
||||||
|
* Double disarming on the other hand is allowed, and may occur when a fault
|
||||||
|
* and mmiotrace shutdown happen simultaneously.
|
||||||
|
*/
|
||||||
|
static int arm_kmmio_fault_page(struct kmmio_fault_page *f)
|
||||||
{
|
{
|
||||||
set_page_present(page & PAGE_MASK, false, pglevel);
|
int ret;
|
||||||
|
WARN_ONCE(f->armed, KERN_ERR "kmmio page already armed.\n");
|
||||||
|
if (f->armed) {
|
||||||
|
pr_warning("kmmio double-arm: page 0x%08lx, ref %d, old %d\n",
|
||||||
|
f->page, f->count, f->old_presence);
|
||||||
|
}
|
||||||
|
ret = set_page_presence(f->page, false, &f->old_presence);
|
||||||
|
WARN_ONCE(ret < 0, KERN_ERR "kmmio arming 0x%08lx failed.\n", f->page);
|
||||||
|
f->armed = true;
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Mark the given page as present. */
|
/** Restore the given page to saved presence state. */
|
||||||
static void disarm_kmmio_fault_page(unsigned long page, unsigned int *pglevel)
|
static void disarm_kmmio_fault_page(struct kmmio_fault_page *f)
|
||||||
{
|
{
|
||||||
set_page_present(page & PAGE_MASK, true, pglevel);
|
bool tmp;
|
||||||
|
int ret = set_page_presence(f->page, f->old_presence, &tmp);
|
||||||
|
WARN_ONCE(ret < 0,
|
||||||
|
KERN_ERR "kmmio disarming 0x%08lx failed.\n", f->page);
|
||||||
|
f->armed = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -202,28 +233,32 @@ int kmmio_handler(struct pt_regs *regs, unsigned long addr)
|
|||||||
|
|
||||||
ctx = &get_cpu_var(kmmio_ctx);
|
ctx = &get_cpu_var(kmmio_ctx);
|
||||||
if (ctx->active) {
|
if (ctx->active) {
|
||||||
disarm_kmmio_fault_page(faultpage->page, NULL);
|
|
||||||
if (addr == ctx->addr) {
|
if (addr == ctx->addr) {
|
||||||
/*
|
/*
|
||||||
* On SMP we sometimes get recursive probe hits on the
|
* A second fault on the same page means some other
|
||||||
* same address. Context is already saved, fall out.
|
* condition needs handling by do_page_fault(), the
|
||||||
|
* page really not being present is the most common.
|
||||||
*/
|
*/
|
||||||
pr_debug("kmmio: duplicate probe hit on CPU %d, for "
|
pr_debug("kmmio: secondary hit for 0x%08lx CPU %d.\n",
|
||||||
"address 0x%08lx.\n",
|
addr, smp_processor_id());
|
||||||
smp_processor_id(), addr);
|
|
||||||
ret = 1;
|
if (!faultpage->old_presence)
|
||||||
goto no_kmmio_ctx;
|
pr_info("kmmio: unexpected secondary hit for "
|
||||||
}
|
"address 0x%08lx on CPU %d.\n", addr,
|
||||||
/*
|
smp_processor_id());
|
||||||
* Prevent overwriting already in-flight context.
|
} else {
|
||||||
* This should not happen, let's hope disarming at least
|
/*
|
||||||
* prevents a panic.
|
* Prevent overwriting already in-flight context.
|
||||||
*/
|
* This should not happen, let's hope disarming at
|
||||||
pr_emerg("kmmio: recursive probe hit on CPU %d, "
|
* least prevents a panic.
|
||||||
|
*/
|
||||||
|
pr_emerg("kmmio: recursive probe hit on CPU %d, "
|
||||||
"for address 0x%08lx. Ignoring.\n",
|
"for address 0x%08lx. Ignoring.\n",
|
||||||
smp_processor_id(), addr);
|
smp_processor_id(), addr);
|
||||||
pr_emerg("kmmio: previous hit was at 0x%08lx.\n",
|
pr_emerg("kmmio: previous hit was at 0x%08lx.\n",
|
||||||
ctx->addr);
|
ctx->addr);
|
||||||
|
disarm_kmmio_fault_page(faultpage);
|
||||||
|
}
|
||||||
goto no_kmmio_ctx;
|
goto no_kmmio_ctx;
|
||||||
}
|
}
|
||||||
ctx->active++;
|
ctx->active++;
|
||||||
@ -244,7 +279,7 @@ int kmmio_handler(struct pt_regs *regs, unsigned long addr)
|
|||||||
regs->flags &= ~X86_EFLAGS_IF;
|
regs->flags &= ~X86_EFLAGS_IF;
|
||||||
|
|
||||||
/* Now we set present bit in PTE and single step. */
|
/* Now we set present bit in PTE and single step. */
|
||||||
disarm_kmmio_fault_page(ctx->fpage->page, NULL);
|
disarm_kmmio_fault_page(ctx->fpage);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If another cpu accesses the same page while we are stepping,
|
* If another cpu accesses the same page while we are stepping,
|
||||||
@ -275,7 +310,7 @@ static int post_kmmio_handler(unsigned long condition, struct pt_regs *regs)
|
|||||||
struct kmmio_context *ctx = &get_cpu_var(kmmio_ctx);
|
struct kmmio_context *ctx = &get_cpu_var(kmmio_ctx);
|
||||||
|
|
||||||
if (!ctx->active) {
|
if (!ctx->active) {
|
||||||
pr_debug("kmmio: spurious debug trap on CPU %d.\n",
|
pr_warning("kmmio: spurious debug trap on CPU %d.\n",
|
||||||
smp_processor_id());
|
smp_processor_id());
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
@ -283,7 +318,11 @@ static int post_kmmio_handler(unsigned long condition, struct pt_regs *regs)
|
|||||||
if (ctx->probe && ctx->probe->post_handler)
|
if (ctx->probe && ctx->probe->post_handler)
|
||||||
ctx->probe->post_handler(ctx->probe, condition, regs);
|
ctx->probe->post_handler(ctx->probe, condition, regs);
|
||||||
|
|
||||||
arm_kmmio_fault_page(ctx->fpage->page, NULL);
|
/* Prevent racing against release_kmmio_fault_page(). */
|
||||||
|
spin_lock(&kmmio_lock);
|
||||||
|
if (ctx->fpage->count)
|
||||||
|
arm_kmmio_fault_page(ctx->fpage);
|
||||||
|
spin_unlock(&kmmio_lock);
|
||||||
|
|
||||||
regs->flags &= ~X86_EFLAGS_TF;
|
regs->flags &= ~X86_EFLAGS_TF;
|
||||||
regs->flags |= ctx->saved_flags;
|
regs->flags |= ctx->saved_flags;
|
||||||
@ -315,20 +354,24 @@ static int add_kmmio_fault_page(unsigned long page)
|
|||||||
f = get_kmmio_fault_page(page);
|
f = get_kmmio_fault_page(page);
|
||||||
if (f) {
|
if (f) {
|
||||||
if (!f->count)
|
if (!f->count)
|
||||||
arm_kmmio_fault_page(f->page, NULL);
|
arm_kmmio_fault_page(f);
|
||||||
f->count++;
|
f->count++;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
f = kmalloc(sizeof(*f), GFP_ATOMIC);
|
f = kzalloc(sizeof(*f), GFP_ATOMIC);
|
||||||
if (!f)
|
if (!f)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
f->count = 1;
|
f->count = 1;
|
||||||
f->page = page;
|
f->page = page;
|
||||||
list_add_rcu(&f->list, kmmio_page_list(f->page));
|
|
||||||
|
|
||||||
arm_kmmio_fault_page(f->page, NULL);
|
if (arm_kmmio_fault_page(f)) {
|
||||||
|
kfree(f);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
list_add_rcu(&f->list, kmmio_page_list(f->page));
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -347,7 +390,7 @@ static void release_kmmio_fault_page(unsigned long page,
|
|||||||
f->count--;
|
f->count--;
|
||||||
BUG_ON(f->count < 0);
|
BUG_ON(f->count < 0);
|
||||||
if (!f->count) {
|
if (!f->count) {
|
||||||
disarm_kmmio_fault_page(f->page, NULL);
|
disarm_kmmio_fault_page(f);
|
||||||
f->release_next = *release_list;
|
f->release_next = *release_list;
|
||||||
*release_list = f;
|
*release_list = f;
|
||||||
}
|
}
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
#include <linux/bootmem.h>
|
#include <linux/bootmem.h>
|
||||||
#include <linux/debugfs.h>
|
#include <linux/debugfs.h>
|
||||||
#include <linux/kernel.h>
|
#include <linux/kernel.h>
|
||||||
|
#include <linux/module.h>
|
||||||
#include <linux/gfp.h>
|
#include <linux/gfp.h>
|
||||||
#include <linux/mm.h>
|
#include <linux/mm.h>
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
@ -868,6 +869,7 @@ pgprot_t pgprot_writecombine(pgprot_t prot)
|
|||||||
else
|
else
|
||||||
return pgprot_noncached(prot);
|
return pgprot_noncached(prot);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(pgprot_writecombine);
|
||||||
|
|
||||||
#if defined(CONFIG_DEBUG_FS) && defined(CONFIG_X86_PAT)
|
#if defined(CONFIG_DEBUG_FS) && defined(CONFIG_X86_PAT)
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Written by Pekka Paalanen, 2008 <pq@iki.fi>
|
* Written by Pekka Paalanen, 2008-2009 <pq@iki.fi>
|
||||||
*/
|
*/
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
@ -9,35 +9,74 @@
|
|||||||
|
|
||||||
static unsigned long mmio_address;
|
static unsigned long mmio_address;
|
||||||
module_param(mmio_address, ulong, 0);
|
module_param(mmio_address, ulong, 0);
|
||||||
MODULE_PARM_DESC(mmio_address, "Start address of the mapping of 16 kB.");
|
MODULE_PARM_DESC(mmio_address, " Start address of the mapping of 16 kB "
|
||||||
|
"(or 8 MB if read_far is non-zero).");
|
||||||
|
|
||||||
|
static unsigned long read_far = 0x400100;
|
||||||
|
module_param(read_far, ulong, 0);
|
||||||
|
MODULE_PARM_DESC(read_far, " Offset of a 32-bit read within 8 MB "
|
||||||
|
"(default: 0x400100).");
|
||||||
|
|
||||||
|
static unsigned v16(unsigned i)
|
||||||
|
{
|
||||||
|
return i * 12 + 7;
|
||||||
|
}
|
||||||
|
|
||||||
|
static unsigned v32(unsigned i)
|
||||||
|
{
|
||||||
|
return i * 212371 + 13;
|
||||||
|
}
|
||||||
|
|
||||||
static void do_write_test(void __iomem *p)
|
static void do_write_test(void __iomem *p)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
pr_info(MODULE_NAME ": write test.\n");
|
||||||
mmiotrace_printk("Write test.\n");
|
mmiotrace_printk("Write test.\n");
|
||||||
|
|
||||||
for (i = 0; i < 256; i++)
|
for (i = 0; i < 256; i++)
|
||||||
iowrite8(i, p + i);
|
iowrite8(i, p + i);
|
||||||
|
|
||||||
for (i = 1024; i < (5 * 1024); i += 2)
|
for (i = 1024; i < (5 * 1024); i += 2)
|
||||||
iowrite16(i * 12 + 7, p + i);
|
iowrite16(v16(i), p + i);
|
||||||
|
|
||||||
for (i = (5 * 1024); i < (16 * 1024); i += 4)
|
for (i = (5 * 1024); i < (16 * 1024); i += 4)
|
||||||
iowrite32(i * 212371 + 13, p + i);
|
iowrite32(v32(i), p + i);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_read_test(void __iomem *p)
|
static void do_read_test(void __iomem *p)
|
||||||
{
|
{
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
unsigned errs[3] = { 0 };
|
||||||
|
pr_info(MODULE_NAME ": read test.\n");
|
||||||
mmiotrace_printk("Read test.\n");
|
mmiotrace_printk("Read test.\n");
|
||||||
|
|
||||||
for (i = 0; i < 256; i++)
|
for (i = 0; i < 256; i++)
|
||||||
ioread8(p + i);
|
if (ioread8(p + i) != i)
|
||||||
|
++errs[0];
|
||||||
|
|
||||||
for (i = 1024; i < (5 * 1024); i += 2)
|
for (i = 1024; i < (5 * 1024); i += 2)
|
||||||
ioread16(p + i);
|
if (ioread16(p + i) != v16(i))
|
||||||
|
++errs[1];
|
||||||
|
|
||||||
for (i = (5 * 1024); i < (16 * 1024); i += 4)
|
for (i = (5 * 1024); i < (16 * 1024); i += 4)
|
||||||
ioread32(p + i);
|
if (ioread32(p + i) != v32(i))
|
||||||
|
++errs[2];
|
||||||
|
|
||||||
|
mmiotrace_printk("Read errors: 8-bit %d, 16-bit %d, 32-bit %d.\n",
|
||||||
|
errs[0], errs[1], errs[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_test(void)
|
static void do_read_far_test(void __iomem *p)
|
||||||
{
|
{
|
||||||
void __iomem *p = ioremap_nocache(mmio_address, 0x4000);
|
pr_info(MODULE_NAME ": read far test.\n");
|
||||||
|
mmiotrace_printk("Read far test.\n");
|
||||||
|
|
||||||
|
ioread32(p + read_far);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void do_test(unsigned long size)
|
||||||
|
{
|
||||||
|
void __iomem *p = ioremap_nocache(mmio_address, size);
|
||||||
if (!p) {
|
if (!p) {
|
||||||
pr_err(MODULE_NAME ": could not ioremap, aborting.\n");
|
pr_err(MODULE_NAME ": could not ioremap, aborting.\n");
|
||||||
return;
|
return;
|
||||||
@ -45,11 +84,15 @@ static void do_test(void)
|
|||||||
mmiotrace_printk("ioremap returned %p.\n", p);
|
mmiotrace_printk("ioremap returned %p.\n", p);
|
||||||
do_write_test(p);
|
do_write_test(p);
|
||||||
do_read_test(p);
|
do_read_test(p);
|
||||||
|
if (read_far && read_far < size - 4)
|
||||||
|
do_read_far_test(p);
|
||||||
iounmap(p);
|
iounmap(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int __init init(void)
|
static int __init init(void)
|
||||||
{
|
{
|
||||||
|
unsigned long size = (read_far) ? (8 << 20) : (16 << 10);
|
||||||
|
|
||||||
if (mmio_address == 0) {
|
if (mmio_address == 0) {
|
||||||
pr_err(MODULE_NAME ": you have to use the module argument "
|
pr_err(MODULE_NAME ": you have to use the module argument "
|
||||||
"mmio_address.\n");
|
"mmio_address.\n");
|
||||||
@ -58,10 +101,11 @@ static int __init init(void)
|
|||||||
return -ENXIO;
|
return -ENXIO;
|
||||||
}
|
}
|
||||||
|
|
||||||
pr_warning(MODULE_NAME ": WARNING: mapping 16 kB @ 0x%08lx "
|
pr_warning(MODULE_NAME ": WARNING: mapping %lu kB @ 0x%08lx in PCI "
|
||||||
"in PCI address space, and writing "
|
"address space, and writing 16 kB of rubbish in there.\n",
|
||||||
"rubbish in there.\n", mmio_address);
|
size >> 10, mmio_address);
|
||||||
do_test();
|
do_test(size);
|
||||||
|
pr_info(MODULE_NAME ": All done.\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -78,8 +78,18 @@ static void ppro_setup_ctrs(struct op_msrs const * const msrs)
|
|||||||
if (cpu_has_arch_perfmon) {
|
if (cpu_has_arch_perfmon) {
|
||||||
union cpuid10_eax eax;
|
union cpuid10_eax eax;
|
||||||
eax.full = cpuid_eax(0xa);
|
eax.full = cpuid_eax(0xa);
|
||||||
if (counter_width < eax.split.bit_width)
|
|
||||||
counter_width = eax.split.bit_width;
|
/*
|
||||||
|
* For Core2 (family 6, model 15), don't reset the
|
||||||
|
* counter width:
|
||||||
|
*/
|
||||||
|
if (!(eax.split.version_id == 0 &&
|
||||||
|
current_cpu_data.x86 == 6 &&
|
||||||
|
current_cpu_data.x86_model == 15)) {
|
||||||
|
|
||||||
|
if (counter_width < eax.split.bit_width)
|
||||||
|
counter_width = eax.split.bit_width;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* clear all counters */
|
/* clear all counters */
|
||||||
|
@ -1672,6 +1672,9 @@ asmlinkage void __init xen_start_kernel(void)
|
|||||||
possible map and a non-dummy shared_info. */
|
possible map and a non-dummy shared_info. */
|
||||||
per_cpu(xen_vcpu, 0) = &HYPERVISOR_shared_info->vcpu_info[0];
|
per_cpu(xen_vcpu, 0) = &HYPERVISOR_shared_info->vcpu_info[0];
|
||||||
|
|
||||||
|
local_irq_disable();
|
||||||
|
early_boot_irqs_off();
|
||||||
|
|
||||||
xen_raw_console_write("mapping kernel into physical memory\n");
|
xen_raw_console_write("mapping kernel into physical memory\n");
|
||||||
pgd = xen_setup_kernel_pagetable(pgd, xen_start_info->nr_pages);
|
pgd = xen_setup_kernel_pagetable(pgd, xen_start_info->nr_pages);
|
||||||
|
|
||||||
|
@ -38,72 +38,84 @@ void blk_recalc_rq_sectors(struct request *rq, int nsect)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void blk_recalc_rq_segments(struct request *rq)
|
static unsigned int __blk_recalc_rq_segments(struct request_queue *q,
|
||||||
|
struct bio *bio,
|
||||||
|
unsigned int *seg_size_ptr)
|
||||||
{
|
{
|
||||||
int nr_phys_segs;
|
|
||||||
unsigned int phys_size;
|
unsigned int phys_size;
|
||||||
struct bio_vec *bv, *bvprv = NULL;
|
struct bio_vec *bv, *bvprv = NULL;
|
||||||
int seg_size;
|
int cluster, i, high, highprv = 1;
|
||||||
int cluster;
|
unsigned int seg_size, nr_phys_segs;
|
||||||
struct req_iterator iter;
|
struct bio *fbio;
|
||||||
int high, highprv = 1;
|
|
||||||
struct request_queue *q = rq->q;
|
|
||||||
|
|
||||||
if (!rq->bio)
|
if (!bio)
|
||||||
return;
|
return 0;
|
||||||
|
|
||||||
|
fbio = bio;
|
||||||
cluster = test_bit(QUEUE_FLAG_CLUSTER, &q->queue_flags);
|
cluster = test_bit(QUEUE_FLAG_CLUSTER, &q->queue_flags);
|
||||||
seg_size = 0;
|
seg_size = 0;
|
||||||
phys_size = nr_phys_segs = 0;
|
phys_size = nr_phys_segs = 0;
|
||||||
rq_for_each_segment(bv, rq, iter) {
|
for_each_bio(bio) {
|
||||||
/*
|
bio_for_each_segment(bv, bio, i) {
|
||||||
* the trick here is making sure that a high page is never
|
/*
|
||||||
* considered part of another segment, since that might
|
* the trick here is making sure that a high page is
|
||||||
* change with the bounce page.
|
* never considered part of another segment, since that
|
||||||
*/
|
* might change with the bounce page.
|
||||||
high = page_to_pfn(bv->bv_page) > q->bounce_pfn;
|
*/
|
||||||
if (high || highprv)
|
high = page_to_pfn(bv->bv_page) > q->bounce_pfn;
|
||||||
goto new_segment;
|
if (high || highprv)
|
||||||
if (cluster) {
|
|
||||||
if (seg_size + bv->bv_len > q->max_segment_size)
|
|
||||||
goto new_segment;
|
|
||||||
if (!BIOVEC_PHYS_MERGEABLE(bvprv, bv))
|
|
||||||
goto new_segment;
|
|
||||||
if (!BIOVEC_SEG_BOUNDARY(q, bvprv, bv))
|
|
||||||
goto new_segment;
|
goto new_segment;
|
||||||
|
if (cluster) {
|
||||||
|
if (seg_size + bv->bv_len > q->max_segment_size)
|
||||||
|
goto new_segment;
|
||||||
|
if (!BIOVEC_PHYS_MERGEABLE(bvprv, bv))
|
||||||
|
goto new_segment;
|
||||||
|
if (!BIOVEC_SEG_BOUNDARY(q, bvprv, bv))
|
||||||
|
goto new_segment;
|
||||||
|
|
||||||
seg_size += bv->bv_len;
|
seg_size += bv->bv_len;
|
||||||
bvprv = bv;
|
bvprv = bv;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
new_segment:
|
new_segment:
|
||||||
if (nr_phys_segs == 1 && seg_size > rq->bio->bi_seg_front_size)
|
if (nr_phys_segs == 1 && seg_size >
|
||||||
rq->bio->bi_seg_front_size = seg_size;
|
fbio->bi_seg_front_size)
|
||||||
|
fbio->bi_seg_front_size = seg_size;
|
||||||
|
|
||||||
nr_phys_segs++;
|
nr_phys_segs++;
|
||||||
bvprv = bv;
|
bvprv = bv;
|
||||||
seg_size = bv->bv_len;
|
seg_size = bv->bv_len;
|
||||||
highprv = high;
|
highprv = high;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nr_phys_segs == 1 && seg_size > rq->bio->bi_seg_front_size)
|
if (seg_size_ptr)
|
||||||
|
*seg_size_ptr = seg_size;
|
||||||
|
|
||||||
|
return nr_phys_segs;
|
||||||
|
}
|
||||||
|
|
||||||
|
void blk_recalc_rq_segments(struct request *rq)
|
||||||
|
{
|
||||||
|
unsigned int seg_size = 0, phys_segs;
|
||||||
|
|
||||||
|
phys_segs = __blk_recalc_rq_segments(rq->q, rq->bio, &seg_size);
|
||||||
|
|
||||||
|
if (phys_segs == 1 && seg_size > rq->bio->bi_seg_front_size)
|
||||||
rq->bio->bi_seg_front_size = seg_size;
|
rq->bio->bi_seg_front_size = seg_size;
|
||||||
if (seg_size > rq->biotail->bi_seg_back_size)
|
if (seg_size > rq->biotail->bi_seg_back_size)
|
||||||
rq->biotail->bi_seg_back_size = seg_size;
|
rq->biotail->bi_seg_back_size = seg_size;
|
||||||
|
|
||||||
rq->nr_phys_segments = nr_phys_segs;
|
rq->nr_phys_segments = phys_segs;
|
||||||
}
|
}
|
||||||
|
|
||||||
void blk_recount_segments(struct request_queue *q, struct bio *bio)
|
void blk_recount_segments(struct request_queue *q, struct bio *bio)
|
||||||
{
|
{
|
||||||
struct request rq;
|
|
||||||
struct bio *nxt = bio->bi_next;
|
struct bio *nxt = bio->bi_next;
|
||||||
rq.q = q;
|
|
||||||
rq.bio = rq.biotail = bio;
|
|
||||||
bio->bi_next = NULL;
|
bio->bi_next = NULL;
|
||||||
blk_recalc_rq_segments(&rq);
|
bio->bi_phys_segments = __blk_recalc_rq_segments(q, bio, NULL);
|
||||||
bio->bi_next = nxt;
|
bio->bi_next = nxt;
|
||||||
bio->bi_phys_segments = rq.nr_phys_segments;
|
|
||||||
bio->bi_flags |= (1 << BIO_SEG_VALID);
|
bio->bi_flags |= (1 << BIO_SEG_VALID);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(blk_recount_segments);
|
EXPORT_SYMBOL(blk_recount_segments);
|
||||||
|
@ -256,6 +256,22 @@ void blkdev_show(struct seq_file *seqf, off_t offset)
|
|||||||
}
|
}
|
||||||
#endif /* CONFIG_PROC_FS */
|
#endif /* CONFIG_PROC_FS */
|
||||||
|
|
||||||
|
/**
|
||||||
|
* register_blkdev - register a new block device
|
||||||
|
*
|
||||||
|
* @major: the requested major device number [1..255]. If @major=0, try to
|
||||||
|
* allocate any unused major number.
|
||||||
|
* @name: the name of the new block device as a zero terminated string
|
||||||
|
*
|
||||||
|
* The @name must be unique within the system.
|
||||||
|
*
|
||||||
|
* The return value depends on the @major input parameter.
|
||||||
|
* - if a major device number was requested in range [1..255] then the
|
||||||
|
* function returns zero on success, or a negative error code
|
||||||
|
* - if any unused major number was requested with @major=0 parameter
|
||||||
|
* then the return value is the allocated major number in range
|
||||||
|
* [1..255] or a negative error code otherwise
|
||||||
|
*/
|
||||||
int register_blkdev(unsigned int major, const char *name)
|
int register_blkdev(unsigned int major, const char *name)
|
||||||
{
|
{
|
||||||
struct blk_major_name **n, *p;
|
struct blk_major_name **n, *p;
|
||||||
|
@ -214,7 +214,7 @@ static void crypto_ahash_show(struct seq_file *m, struct crypto_alg *alg)
|
|||||||
seq_printf(m, "async : %s\n", alg->cra_flags & CRYPTO_ALG_ASYNC ?
|
seq_printf(m, "async : %s\n", alg->cra_flags & CRYPTO_ALG_ASYNC ?
|
||||||
"yes" : "no");
|
"yes" : "no");
|
||||||
seq_printf(m, "blocksize : %u\n", alg->cra_blocksize);
|
seq_printf(m, "blocksize : %u\n", alg->cra_blocksize);
|
||||||
seq_printf(m, "digestsize : %u\n", alg->cra_hash.digestsize);
|
seq_printf(m, "digestsize : %u\n", alg->cra_ahash.digestsize);
|
||||||
}
|
}
|
||||||
|
|
||||||
const struct crypto_type crypto_ahash_type = {
|
const struct crypto_type crypto_ahash_type = {
|
||||||
|
15
crypto/api.c
15
crypto/api.c
@ -215,8 +215,19 @@ struct crypto_alg *crypto_larval_lookup(const char *name, u32 type, u32 mask)
|
|||||||
mask &= ~(CRYPTO_ALG_LARVAL | CRYPTO_ALG_DEAD);
|
mask &= ~(CRYPTO_ALG_LARVAL | CRYPTO_ALG_DEAD);
|
||||||
type &= mask;
|
type &= mask;
|
||||||
|
|
||||||
alg = try_then_request_module(crypto_alg_lookup(name, type, mask),
|
alg = crypto_alg_lookup(name, type, mask);
|
||||||
name);
|
if (!alg) {
|
||||||
|
char tmp[CRYPTO_MAX_ALG_NAME];
|
||||||
|
|
||||||
|
request_module(name);
|
||||||
|
|
||||||
|
if (!((type ^ CRYPTO_ALG_NEED_FALLBACK) & mask) &&
|
||||||
|
snprintf(tmp, sizeof(tmp), "%s-all", name) < sizeof(tmp))
|
||||||
|
request_module(tmp);
|
||||||
|
|
||||||
|
alg = crypto_alg_lookup(name, type, mask);
|
||||||
|
}
|
||||||
|
|
||||||
if (alg)
|
if (alg)
|
||||||
return crypto_is_larval(alg) ? crypto_larval_wait(alg) : alg;
|
return crypto_is_larval(alg) ? crypto_larval_wait(alg) : alg;
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#include <linux/libata.h>
|
#include <linux/libata.h>
|
||||||
|
|
||||||
#define DRV_NAME "pata_amd"
|
#define DRV_NAME "pata_amd"
|
||||||
#define DRV_VERSION "0.3.11"
|
#define DRV_VERSION "0.4.1"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* timing_setup - shared timing computation and load
|
* timing_setup - shared timing computation and load
|
||||||
@ -145,6 +145,13 @@ static int amd_pre_reset(struct ata_link *link, unsigned long deadline)
|
|||||||
return ata_sff_prereset(link, deadline);
|
return ata_sff_prereset(link, deadline);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* amd_cable_detect - report cable type
|
||||||
|
* @ap: port
|
||||||
|
*
|
||||||
|
* AMD controller/BIOS setups record the cable type in word 0x42
|
||||||
|
*/
|
||||||
|
|
||||||
static int amd_cable_detect(struct ata_port *ap)
|
static int amd_cable_detect(struct ata_port *ap)
|
||||||
{
|
{
|
||||||
static const u32 bitmask[2] = {0x03, 0x0C};
|
static const u32 bitmask[2] = {0x03, 0x0C};
|
||||||
@ -157,6 +164,40 @@ static int amd_cable_detect(struct ata_port *ap)
|
|||||||
return ATA_CBL_PATA40;
|
return ATA_CBL_PATA40;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* amd_fifo_setup - set the PIO FIFO for ATA/ATAPI
|
||||||
|
* @ap: ATA interface
|
||||||
|
* @adev: ATA device
|
||||||
|
*
|
||||||
|
* Set the PCI fifo for this device according to the devices present
|
||||||
|
* on the bus at this point in time. We need to turn the post write buffer
|
||||||
|
* off for ATAPI devices as we may need to issue a word sized write to the
|
||||||
|
* device as the final I/O
|
||||||
|
*/
|
||||||
|
|
||||||
|
static void amd_fifo_setup(struct ata_port *ap)
|
||||||
|
{
|
||||||
|
struct ata_device *adev;
|
||||||
|
struct pci_dev *pdev = to_pci_dev(ap->host->dev);
|
||||||
|
static const u8 fifobit[2] = { 0xC0, 0x30};
|
||||||
|
u8 fifo = fifobit[ap->port_no];
|
||||||
|
u8 r;
|
||||||
|
|
||||||
|
|
||||||
|
ata_for_each_dev(adev, &ap->link, ENABLED) {
|
||||||
|
if (adev->class == ATA_DEV_ATAPI)
|
||||||
|
fifo = 0;
|
||||||
|
}
|
||||||
|
if (pdev->device == PCI_DEVICE_ID_AMD_VIPER_7411) /* FIFO is broken */
|
||||||
|
fifo = 0;
|
||||||
|
|
||||||
|
/* On the later chips the read prefetch bits become no-op bits */
|
||||||
|
pci_read_config_byte(pdev, 0x41, &r);
|
||||||
|
r &= ~fifobit[ap->port_no];
|
||||||
|
r |= fifo;
|
||||||
|
pci_write_config_byte(pdev, 0x41, r);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* amd33_set_piomode - set initial PIO mode data
|
* amd33_set_piomode - set initial PIO mode data
|
||||||
* @ap: ATA interface
|
* @ap: ATA interface
|
||||||
@ -167,21 +208,25 @@ static int amd_cable_detect(struct ata_port *ap)
|
|||||||
|
|
||||||
static void amd33_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
static void amd33_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
||||||
{
|
{
|
||||||
|
amd_fifo_setup(ap);
|
||||||
timing_setup(ap, adev, 0x40, adev->pio_mode, 1);
|
timing_setup(ap, adev, 0x40, adev->pio_mode, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void amd66_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
static void amd66_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
||||||
{
|
{
|
||||||
|
amd_fifo_setup(ap);
|
||||||
timing_setup(ap, adev, 0x40, adev->pio_mode, 2);
|
timing_setup(ap, adev, 0x40, adev->pio_mode, 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void amd100_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
static void amd100_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
||||||
{
|
{
|
||||||
|
amd_fifo_setup(ap);
|
||||||
timing_setup(ap, adev, 0x40, adev->pio_mode, 3);
|
timing_setup(ap, adev, 0x40, adev->pio_mode, 3);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void amd133_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
static void amd133_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
||||||
{
|
{
|
||||||
|
amd_fifo_setup(ap);
|
||||||
timing_setup(ap, adev, 0x40, adev->pio_mode, 4);
|
timing_setup(ap, adev, 0x40, adev->pio_mode, 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -397,6 +442,16 @@ static struct ata_port_operations nv133_port_ops = {
|
|||||||
.set_dmamode = nv133_set_dmamode,
|
.set_dmamode = nv133_set_dmamode,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static void amd_clear_fifo(struct pci_dev *pdev)
|
||||||
|
{
|
||||||
|
u8 fifo;
|
||||||
|
/* Disable the FIFO, the FIFO logic will re-enable it as
|
||||||
|
appropriate */
|
||||||
|
pci_read_config_byte(pdev, 0x41, &fifo);
|
||||||
|
fifo &= 0x0F;
|
||||||
|
pci_write_config_byte(pdev, 0x41, fifo);
|
||||||
|
}
|
||||||
|
|
||||||
static int amd_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
|
static int amd_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
|
||||||
{
|
{
|
||||||
static const struct ata_port_info info[10] = {
|
static const struct ata_port_info info[10] = {
|
||||||
@ -503,14 +558,8 @@ static int amd_init_one(struct pci_dev *pdev, const struct pci_device_id *id)
|
|||||||
|
|
||||||
if (type < 3)
|
if (type < 3)
|
||||||
ata_pci_bmdma_clear_simplex(pdev);
|
ata_pci_bmdma_clear_simplex(pdev);
|
||||||
|
if (pdev->vendor == PCI_VENDOR_ID_AMD)
|
||||||
/* Check for AMD7411 */
|
amd_clear_fifo(pdev);
|
||||||
if (type == 3)
|
|
||||||
/* FIFO is broken */
|
|
||||||
pci_write_config_byte(pdev, 0x41, fifo & 0x0F);
|
|
||||||
else
|
|
||||||
pci_write_config_byte(pdev, 0x41, fifo | 0xF0);
|
|
||||||
|
|
||||||
/* Cable detection on Nvidia chips doesn't work too well,
|
/* Cable detection on Nvidia chips doesn't work too well,
|
||||||
* cache BIOS programmed UDMA mode.
|
* cache BIOS programmed UDMA mode.
|
||||||
*/
|
*/
|
||||||
@ -536,18 +585,11 @@ static int amd_reinit_one(struct pci_dev *pdev)
|
|||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
if (pdev->vendor == PCI_VENDOR_ID_AMD) {
|
if (pdev->vendor == PCI_VENDOR_ID_AMD) {
|
||||||
u8 fifo;
|
amd_clear_fifo(pdev);
|
||||||
pci_read_config_byte(pdev, 0x41, &fifo);
|
|
||||||
if (pdev->device == PCI_DEVICE_ID_AMD_VIPER_7411)
|
|
||||||
/* FIFO is broken */
|
|
||||||
pci_write_config_byte(pdev, 0x41, fifo & 0x0F);
|
|
||||||
else
|
|
||||||
pci_write_config_byte(pdev, 0x41, fifo | 0xF0);
|
|
||||||
if (pdev->device == PCI_DEVICE_ID_AMD_VIPER_7409 ||
|
if (pdev->device == PCI_DEVICE_ID_AMD_VIPER_7409 ||
|
||||||
pdev->device == PCI_DEVICE_ID_AMD_COBRA_7401)
|
pdev->device == PCI_DEVICE_ID_AMD_COBRA_7401)
|
||||||
ata_pci_bmdma_clear_simplex(pdev);
|
ata_pci_bmdma_clear_simplex(pdev);
|
||||||
}
|
}
|
||||||
|
|
||||||
ata_host_resume(host);
|
ata_host_resume(host);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -557,6 +557,9 @@ static unsigned int it821x_read_id(struct ata_device *adev,
|
|||||||
id[83] |= 0x4400; /* Word 83 is valid and LBA48 */
|
id[83] |= 0x4400; /* Word 83 is valid and LBA48 */
|
||||||
id[86] |= 0x0400; /* LBA48 on */
|
id[86] |= 0x0400; /* LBA48 on */
|
||||||
id[ATA_ID_MAJOR_VER] |= 0x1F;
|
id[ATA_ID_MAJOR_VER] |= 0x1F;
|
||||||
|
/* Clear the serial number because it's different each boot
|
||||||
|
which breaks validation on resume */
|
||||||
|
memset(&id[ATA_ID_SERNO], 0x20, ATA_ID_SERNO_LEN);
|
||||||
}
|
}
|
||||||
return err_mask;
|
return err_mask;
|
||||||
}
|
}
|
||||||
|
@ -283,9 +283,10 @@ static void pdc20230_set_piomode(struct ata_port *ap, struct ata_device *adev)
|
|||||||
static unsigned int pdc_data_xfer_vlb(struct ata_device *dev,
|
static unsigned int pdc_data_xfer_vlb(struct ata_device *dev,
|
||||||
unsigned char *buf, unsigned int buflen, int rw)
|
unsigned char *buf, unsigned int buflen, int rw)
|
||||||
{
|
{
|
||||||
if (ata_id_has_dword_io(dev->id)) {
|
int slop = buflen & 3;
|
||||||
|
/* 32bit I/O capable *and* we need to write a whole number of dwords */
|
||||||
|
if (ata_id_has_dword_io(dev->id) && (slop == 0 || slop == 3)) {
|
||||||
struct ata_port *ap = dev->link->ap;
|
struct ata_port *ap = dev->link->ap;
|
||||||
int slop = buflen & 3;
|
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_irq_save(flags);
|
||||||
@ -735,7 +736,7 @@ static unsigned int vlb32_data_xfer(struct ata_device *adev, unsigned char *buf,
|
|||||||
struct ata_port *ap = adev->link->ap;
|
struct ata_port *ap = adev->link->ap;
|
||||||
int slop = buflen & 3;
|
int slop = buflen & 3;
|
||||||
|
|
||||||
if (ata_id_has_dword_io(adev->id)) {
|
if (ata_id_has_dword_io(adev->id) && (slop == 0 || slop == 3)) {
|
||||||
if (rw == WRITE)
|
if (rw == WRITE)
|
||||||
iowrite32_rep(ap->ioaddr.data_addr, buf, buflen >> 2);
|
iowrite32_rep(ap->ioaddr.data_addr, buf, buflen >> 2);
|
||||||
else
|
else
|
||||||
|
@ -3114,19 +3114,17 @@ static int mv_init_host(struct ata_host *host, unsigned int board_idx)
|
|||||||
writelfl(0, hc_mmio + HC_IRQ_CAUSE_OFS);
|
writelfl(0, hc_mmio + HC_IRQ_CAUSE_OFS);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!IS_SOC(hpriv)) {
|
/* Clear any currently outstanding host interrupt conditions */
|
||||||
/* Clear any currently outstanding host interrupt conditions */
|
writelfl(0, mmio + hpriv->irq_cause_ofs);
|
||||||
writelfl(0, mmio + hpriv->irq_cause_ofs);
|
|
||||||
|
|
||||||
/* and unmask interrupt generation for host regs */
|
/* and unmask interrupt generation for host regs */
|
||||||
writelfl(hpriv->unmask_all_irqs, mmio + hpriv->irq_mask_ofs);
|
writelfl(hpriv->unmask_all_irqs, mmio + hpriv->irq_mask_ofs);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* enable only global host interrupts for now.
|
* enable only global host interrupts for now.
|
||||||
* The per-port interrupts get done later as ports are set up.
|
* The per-port interrupts get done later as ports are set up.
|
||||||
*/
|
*/
|
||||||
mv_set_main_irq_mask(host, 0, PCI_ERR);
|
mv_set_main_irq_mask(host, 0, PCI_ERR);
|
||||||
}
|
|
||||||
done:
|
done:
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
@ -901,7 +901,7 @@ static int __devinit eeprom_read(struct lanai_dev *lanai)
|
|||||||
clock_l(); udelay(5);
|
clock_l(); udelay(5);
|
||||||
for (i = 128; i != 0; i >>= 1) { /* write command out */
|
for (i = 128; i != 0; i >>= 1) { /* write command out */
|
||||||
tmp = (lanai->conf1 & ~CONFIG1_PROMDATA) |
|
tmp = (lanai->conf1 & ~CONFIG1_PROMDATA) |
|
||||||
(data & i) ? CONFIG1_PROMDATA : 0;
|
((data & i) ? CONFIG1_PROMDATA : 0);
|
||||||
if (lanai->conf1 != tmp) {
|
if (lanai->conf1 != tmp) {
|
||||||
set_config1(tmp);
|
set_config1(tmp);
|
||||||
udelay(5); /* Let new data settle */
|
udelay(5); /* Let new data settle */
|
||||||
|
@ -3611,11 +3611,15 @@ static int __devinit cciss_init_one(struct pci_dev *pdev,
|
|||||||
schedule_timeout_uninterruptible(30*HZ);
|
schedule_timeout_uninterruptible(30*HZ);
|
||||||
|
|
||||||
/* Now try to get the controller to respond to a no-op */
|
/* Now try to get the controller to respond to a no-op */
|
||||||
for (i=0; i<12; i++) {
|
for (i=0; i<30; i++) {
|
||||||
if (cciss_noop(pdev) == 0)
|
if (cciss_noop(pdev) == 0)
|
||||||
break;
|
break;
|
||||||
else
|
|
||||||
printk("cciss: no-op failed%s\n", (i < 11 ? "; re-trying" : ""));
|
schedule_timeout_uninterruptible(HZ);
|
||||||
|
}
|
||||||
|
if (i == 30) {
|
||||||
|
printk(KERN_ERR "cciss: controller seems dead\n");
|
||||||
|
return -EBUSY;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
#include <linux/hdreg.h>
|
#include <linux/hdreg.h>
|
||||||
#include <linux/cdrom.h>
|
#include <linux/cdrom.h>
|
||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
|
#include <linux/scatterlist.h>
|
||||||
|
|
||||||
#include <xen/xenbus.h>
|
#include <xen/xenbus.h>
|
||||||
#include <xen/grant_table.h>
|
#include <xen/grant_table.h>
|
||||||
@ -82,6 +83,7 @@ struct blkfront_info
|
|||||||
enum blkif_state connected;
|
enum blkif_state connected;
|
||||||
int ring_ref;
|
int ring_ref;
|
||||||
struct blkif_front_ring ring;
|
struct blkif_front_ring ring;
|
||||||
|
struct scatterlist sg[BLKIF_MAX_SEGMENTS_PER_REQUEST];
|
||||||
unsigned int evtchn, irq;
|
unsigned int evtchn, irq;
|
||||||
struct request_queue *rq;
|
struct request_queue *rq;
|
||||||
struct work_struct work;
|
struct work_struct work;
|
||||||
@ -204,12 +206,11 @@ static int blkif_queue_request(struct request *req)
|
|||||||
struct blkfront_info *info = req->rq_disk->private_data;
|
struct blkfront_info *info = req->rq_disk->private_data;
|
||||||
unsigned long buffer_mfn;
|
unsigned long buffer_mfn;
|
||||||
struct blkif_request *ring_req;
|
struct blkif_request *ring_req;
|
||||||
struct req_iterator iter;
|
|
||||||
struct bio_vec *bvec;
|
|
||||||
unsigned long id;
|
unsigned long id;
|
||||||
unsigned int fsect, lsect;
|
unsigned int fsect, lsect;
|
||||||
int ref;
|
int i, ref;
|
||||||
grant_ref_t gref_head;
|
grant_ref_t gref_head;
|
||||||
|
struct scatterlist *sg;
|
||||||
|
|
||||||
if (unlikely(info->connected != BLKIF_STATE_CONNECTED))
|
if (unlikely(info->connected != BLKIF_STATE_CONNECTED))
|
||||||
return 1;
|
return 1;
|
||||||
@ -238,12 +239,13 @@ static int blkif_queue_request(struct request *req)
|
|||||||
if (blk_barrier_rq(req))
|
if (blk_barrier_rq(req))
|
||||||
ring_req->operation = BLKIF_OP_WRITE_BARRIER;
|
ring_req->operation = BLKIF_OP_WRITE_BARRIER;
|
||||||
|
|
||||||
ring_req->nr_segments = 0;
|
ring_req->nr_segments = blk_rq_map_sg(req->q, req, info->sg);
|
||||||
rq_for_each_segment(bvec, req, iter) {
|
BUG_ON(ring_req->nr_segments > BLKIF_MAX_SEGMENTS_PER_REQUEST);
|
||||||
BUG_ON(ring_req->nr_segments == BLKIF_MAX_SEGMENTS_PER_REQUEST);
|
|
||||||
buffer_mfn = pfn_to_mfn(page_to_pfn(bvec->bv_page));
|
for_each_sg(info->sg, sg, ring_req->nr_segments, i) {
|
||||||
fsect = bvec->bv_offset >> 9;
|
buffer_mfn = pfn_to_mfn(page_to_pfn(sg_page(sg)));
|
||||||
lsect = fsect + (bvec->bv_len >> 9) - 1;
|
fsect = sg->offset >> 9;
|
||||||
|
lsect = fsect + (sg->length >> 9) - 1;
|
||||||
/* install a grant reference. */
|
/* install a grant reference. */
|
||||||
ref = gnttab_claim_grant_reference(&gref_head);
|
ref = gnttab_claim_grant_reference(&gref_head);
|
||||||
BUG_ON(ref == -ENOSPC);
|
BUG_ON(ref == -ENOSPC);
|
||||||
@ -254,16 +256,12 @@ static int blkif_queue_request(struct request *req)
|
|||||||
buffer_mfn,
|
buffer_mfn,
|
||||||
rq_data_dir(req) );
|
rq_data_dir(req) );
|
||||||
|
|
||||||
info->shadow[id].frame[ring_req->nr_segments] =
|
info->shadow[id].frame[i] = mfn_to_pfn(buffer_mfn);
|
||||||
mfn_to_pfn(buffer_mfn);
|
ring_req->seg[i] =
|
||||||
|
|
||||||
ring_req->seg[ring_req->nr_segments] =
|
|
||||||
(struct blkif_request_segment) {
|
(struct blkif_request_segment) {
|
||||||
.gref = ref,
|
.gref = ref,
|
||||||
.first_sect = fsect,
|
.first_sect = fsect,
|
||||||
.last_sect = lsect };
|
.last_sect = lsect };
|
||||||
|
|
||||||
ring_req->nr_segments++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
info->ring.req_prod_pvt++;
|
info->ring.req_prod_pvt++;
|
||||||
@ -622,6 +620,8 @@ static int setup_blkring(struct xenbus_device *dev,
|
|||||||
SHARED_RING_INIT(sring);
|
SHARED_RING_INIT(sring);
|
||||||
FRONT_RING_INIT(&info->ring, sring, PAGE_SIZE);
|
FRONT_RING_INIT(&info->ring, sring, PAGE_SIZE);
|
||||||
|
|
||||||
|
sg_init_table(info->sg, BLKIF_MAX_SEGMENTS_PER_REQUEST);
|
||||||
|
|
||||||
err = xenbus_grant_ring(dev, virt_to_mfn(info->ring.sring));
|
err = xenbus_grant_ring(dev, virt_to_mfn(info->ring.sring));
|
||||||
if (err < 0) {
|
if (err < 0) {
|
||||||
free_page((unsigned long)sring);
|
free_page((unsigned long)sring);
|
||||||
|
@ -457,10 +457,12 @@ static int init_ixp_crypto(void)
|
|||||||
if (!ctx_pool) {
|
if (!ctx_pool) {
|
||||||
goto err;
|
goto err;
|
||||||
}
|
}
|
||||||
ret = qmgr_request_queue(SEND_QID, NPE_QLEN_TOTAL, 0, 0);
|
ret = qmgr_request_queue(SEND_QID, NPE_QLEN_TOTAL, 0, 0,
|
||||||
|
"ixp_crypto:out", NULL);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err;
|
goto err;
|
||||||
ret = qmgr_request_queue(RECV_QID, NPE_QLEN, 0, 0);
|
ret = qmgr_request_queue(RECV_QID, NPE_QLEN, 0, 0,
|
||||||
|
"ixp_crypto:in", NULL);
|
||||||
if (ret) {
|
if (ret) {
|
||||||
qmgr_release_queue(SEND_QID);
|
qmgr_release_queue(SEND_QID);
|
||||||
goto err;
|
goto err;
|
||||||
|
@ -489,4 +489,4 @@ MODULE_DESCRIPTION("VIA PadLock AES algorithm support");
|
|||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
MODULE_AUTHOR("Michal Ludvig");
|
MODULE_AUTHOR("Michal Ludvig");
|
||||||
|
|
||||||
MODULE_ALIAS("aes");
|
MODULE_ALIAS("aes-all");
|
||||||
|
@ -304,7 +304,7 @@ MODULE_DESCRIPTION("VIA PadLock SHA1/SHA256 algorithms support.");
|
|||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
MODULE_AUTHOR("Michal Ludvig");
|
MODULE_AUTHOR("Michal Ludvig");
|
||||||
|
|
||||||
MODULE_ALIAS("sha1");
|
MODULE_ALIAS("sha1-all");
|
||||||
MODULE_ALIAS("sha256");
|
MODULE_ALIAS("sha256-all");
|
||||||
MODULE_ALIAS("sha1-padlock");
|
MODULE_ALIAS("sha1-padlock");
|
||||||
MODULE_ALIAS("sha256-padlock");
|
MODULE_ALIAS("sha256-padlock");
|
||||||
|
@ -1401,7 +1401,7 @@ MODULE_ALIAS("platform:iop-adma");
|
|||||||
|
|
||||||
static struct platform_driver iop_adma_driver = {
|
static struct platform_driver iop_adma_driver = {
|
||||||
.probe = iop_adma_probe,
|
.probe = iop_adma_probe,
|
||||||
.remove = iop_adma_remove,
|
.remove = __devexit_p(iop_adma_remove),
|
||||||
.driver = {
|
.driver = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.name = "iop-adma",
|
.name = "iop-adma",
|
||||||
|
@ -1287,7 +1287,7 @@ mv_xor_conf_mbus_windows(struct mv_xor_shared_private *msp,
|
|||||||
|
|
||||||
static struct platform_driver mv_xor_driver = {
|
static struct platform_driver mv_xor_driver = {
|
||||||
.probe = mv_xor_probe,
|
.probe = mv_xor_probe,
|
||||||
.remove = mv_xor_remove,
|
.remove = __devexit_p(mv_xor_remove),
|
||||||
.driver = {
|
.driver = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.name = MV_XOR_NAME,
|
.name = MV_XOR_NAME,
|
||||||
|
@ -420,7 +420,7 @@ int drm_rmmap_locked(struct drm_device *dev, drm_local_map_t *map)
|
|||||||
dev->sigdata.lock = NULL;
|
dev->sigdata.lock = NULL;
|
||||||
master->lock.hw_lock = NULL; /* SHM removed */
|
master->lock.hw_lock = NULL; /* SHM removed */
|
||||||
master->lock.file_priv = NULL;
|
master->lock.file_priv = NULL;
|
||||||
wake_up_interruptible(&master->lock.lock_queue);
|
wake_up_interruptible_all(&master->lock.lock_queue);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case _DRM_AGP:
|
case _DRM_AGP:
|
||||||
|
@ -452,6 +452,59 @@ static void drm_setup_crtcs(struct drm_device *dev)
|
|||||||
kfree(modes);
|
kfree(modes);
|
||||||
kfree(enabled);
|
kfree(enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* drm_encoder_crtc_ok - can a given crtc drive a given encoder?
|
||||||
|
* @encoder: encoder to test
|
||||||
|
* @crtc: crtc to test
|
||||||
|
*
|
||||||
|
* Return false if @encoder can't be driven by @crtc, true otherwise.
|
||||||
|
*/
|
||||||
|
static bool drm_encoder_crtc_ok(struct drm_encoder *encoder,
|
||||||
|
struct drm_crtc *crtc)
|
||||||
|
{
|
||||||
|
struct drm_device *dev;
|
||||||
|
struct drm_crtc *tmp;
|
||||||
|
int crtc_mask = 1;
|
||||||
|
|
||||||
|
WARN(!crtc, "checking null crtc?");
|
||||||
|
|
||||||
|
dev = crtc->dev;
|
||||||
|
|
||||||
|
list_for_each_entry(tmp, &dev->mode_config.crtc_list, head) {
|
||||||
|
if (tmp == crtc)
|
||||||
|
break;
|
||||||
|
crtc_mask <<= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (encoder->possible_crtcs & crtc_mask)
|
||||||
|
return true;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check the CRTC we're going to map each output to vs. its current
|
||||||
|
* CRTC. If they don't match, we have to disable the output and the CRTC
|
||||||
|
* since the driver will have to re-route things.
|
||||||
|
*/
|
||||||
|
static void
|
||||||
|
drm_crtc_prepare_encoders(struct drm_device *dev)
|
||||||
|
{
|
||||||
|
struct drm_encoder_helper_funcs *encoder_funcs;
|
||||||
|
struct drm_encoder *encoder;
|
||||||
|
|
||||||
|
list_for_each_entry(encoder, &dev->mode_config.encoder_list, head) {
|
||||||
|
encoder_funcs = encoder->helper_private;
|
||||||
|
/* Disable unused encoders */
|
||||||
|
if (encoder->crtc == NULL)
|
||||||
|
(*encoder_funcs->dpms)(encoder, DRM_MODE_DPMS_OFF);
|
||||||
|
/* Disable encoders whose CRTC is about to change */
|
||||||
|
if (encoder_funcs->get_crtc &&
|
||||||
|
encoder->crtc != (*encoder_funcs->get_crtc)(encoder))
|
||||||
|
(*encoder_funcs->dpms)(encoder, DRM_MODE_DPMS_OFF);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* drm_crtc_set_mode - set a mode
|
* drm_crtc_set_mode - set a mode
|
||||||
* @crtc: CRTC to program
|
* @crtc: CRTC to program
|
||||||
@ -547,6 +600,8 @@ bool drm_crtc_helper_set_mode(struct drm_crtc *crtc,
|
|||||||
encoder_funcs->prepare(encoder);
|
encoder_funcs->prepare(encoder);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
drm_crtc_prepare_encoders(dev);
|
||||||
|
|
||||||
crtc_funcs->prepare(crtc);
|
crtc_funcs->prepare(crtc);
|
||||||
|
|
||||||
/* Set up the DPLL and any encoders state that needs to adjust or depend
|
/* Set up the DPLL and any encoders state that needs to adjust or depend
|
||||||
@ -617,7 +672,7 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
struct drm_device *dev;
|
struct drm_device *dev;
|
||||||
struct drm_crtc **save_crtcs, *new_crtc;
|
struct drm_crtc **save_crtcs, *new_crtc;
|
||||||
struct drm_encoder **save_encoders, *new_encoder;
|
struct drm_encoder **save_encoders, *new_encoder;
|
||||||
struct drm_framebuffer *old_fb;
|
struct drm_framebuffer *old_fb = NULL;
|
||||||
bool save_enabled;
|
bool save_enabled;
|
||||||
bool mode_changed = false;
|
bool mode_changed = false;
|
||||||
bool fb_changed = false;
|
bool fb_changed = false;
|
||||||
@ -668,9 +723,10 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
* and then just flip_or_move it */
|
* and then just flip_or_move it */
|
||||||
if (set->crtc->fb != set->fb) {
|
if (set->crtc->fb != set->fb) {
|
||||||
/* If we have no fb then treat it as a full mode set */
|
/* If we have no fb then treat it as a full mode set */
|
||||||
if (set->crtc->fb == NULL)
|
if (set->crtc->fb == NULL) {
|
||||||
|
DRM_DEBUG("crtc has no fb, full mode set\n");
|
||||||
mode_changed = true;
|
mode_changed = true;
|
||||||
else if ((set->fb->bits_per_pixel !=
|
} else if ((set->fb->bits_per_pixel !=
|
||||||
set->crtc->fb->bits_per_pixel) ||
|
set->crtc->fb->bits_per_pixel) ||
|
||||||
set->fb->depth != set->crtc->fb->depth)
|
set->fb->depth != set->crtc->fb->depth)
|
||||||
fb_changed = true;
|
fb_changed = true;
|
||||||
@ -682,7 +738,7 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
fb_changed = true;
|
fb_changed = true;
|
||||||
|
|
||||||
if (set->mode && !drm_mode_equal(set->mode, &set->crtc->mode)) {
|
if (set->mode && !drm_mode_equal(set->mode, &set->crtc->mode)) {
|
||||||
DRM_DEBUG("modes are different\n");
|
DRM_DEBUG("modes are different, full mode set\n");
|
||||||
drm_mode_debug_printmodeline(&set->crtc->mode);
|
drm_mode_debug_printmodeline(&set->crtc->mode);
|
||||||
drm_mode_debug_printmodeline(set->mode);
|
drm_mode_debug_printmodeline(set->mode);
|
||||||
mode_changed = true;
|
mode_changed = true;
|
||||||
@ -708,6 +764,7 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (new_encoder != connector->encoder) {
|
if (new_encoder != connector->encoder) {
|
||||||
|
DRM_DEBUG("encoder changed, full mode switch\n");
|
||||||
mode_changed = true;
|
mode_changed = true;
|
||||||
connector->encoder = new_encoder;
|
connector->encoder = new_encoder;
|
||||||
}
|
}
|
||||||
@ -734,10 +791,20 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
if (set->connectors[ro] == connector)
|
if (set->connectors[ro] == connector)
|
||||||
new_crtc = set->crtc;
|
new_crtc = set->crtc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* Make sure the new CRTC will work with the encoder */
|
||||||
|
if (new_crtc &&
|
||||||
|
!drm_encoder_crtc_ok(connector->encoder, new_crtc)) {
|
||||||
|
ret = -EINVAL;
|
||||||
|
goto fail_set_mode;
|
||||||
|
}
|
||||||
if (new_crtc != connector->encoder->crtc) {
|
if (new_crtc != connector->encoder->crtc) {
|
||||||
|
DRM_DEBUG("crtc changed, full mode switch\n");
|
||||||
mode_changed = true;
|
mode_changed = true;
|
||||||
connector->encoder->crtc = new_crtc;
|
connector->encoder->crtc = new_crtc;
|
||||||
}
|
}
|
||||||
|
DRM_DEBUG("setting connector %d crtc to %p\n",
|
||||||
|
connector->base.id, new_crtc);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* mode_set_base is not a required function */
|
/* mode_set_base is not a required function */
|
||||||
@ -781,6 +848,7 @@ int drm_crtc_helper_set_config(struct drm_mode_set *set)
|
|||||||
|
|
||||||
fail_set_mode:
|
fail_set_mode:
|
||||||
set->crtc->enabled = save_enabled;
|
set->crtc->enabled = save_enabled;
|
||||||
|
set->crtc->fb = old_fb;
|
||||||
count = 0;
|
count = 0;
|
||||||
list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
|
list_for_each_entry(connector, &dev->mode_config.connector_list, head) {
|
||||||
if (!connector->encoder)
|
if (!connector->encoder)
|
||||||
|
@ -125,7 +125,7 @@ static bool edid_is_valid(struct edid *edid)
|
|||||||
DRM_ERROR("EDID has major version %d, instead of 1\n", edid->version);
|
DRM_ERROR("EDID has major version %d, instead of 1\n", edid->version);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
if (edid->revision <= 0 || edid->revision > 3) {
|
if (edid->revision > 3) {
|
||||||
DRM_ERROR("EDID has minor version %d, which is not between 0-3\n", edid->revision);
|
DRM_ERROR("EDID has minor version %d, which is not between 0-3\n", edid->revision);
|
||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
@ -320,10 +320,10 @@ static struct drm_display_mode *drm_mode_detailed(struct drm_device *dev,
|
|||||||
mode->htotal = mode->hdisplay + ((pt->hblank_hi << 8) | pt->hblank_lo);
|
mode->htotal = mode->hdisplay + ((pt->hblank_hi << 8) | pt->hblank_lo);
|
||||||
|
|
||||||
mode->vdisplay = (pt->vactive_hi << 8) | pt->vactive_lo;
|
mode->vdisplay = (pt->vactive_hi << 8) | pt->vactive_lo;
|
||||||
mode->vsync_start = mode->vdisplay + ((pt->vsync_offset_hi << 8) |
|
mode->vsync_start = mode->vdisplay + ((pt->vsync_offset_hi << 4) |
|
||||||
pt->vsync_offset_lo);
|
pt->vsync_offset_lo);
|
||||||
mode->vsync_end = mode->vsync_start +
|
mode->vsync_end = mode->vsync_start +
|
||||||
((pt->vsync_pulse_width_hi << 8) |
|
((pt->vsync_pulse_width_hi << 4) |
|
||||||
pt->vsync_pulse_width_lo);
|
pt->vsync_pulse_width_lo);
|
||||||
mode->vtotal = mode->vdisplay + ((pt->vblank_hi << 8) | pt->vblank_lo);
|
mode->vtotal = mode->vdisplay + ((pt->vblank_hi << 8) | pt->vblank_lo);
|
||||||
|
|
||||||
|
@ -484,6 +484,7 @@ int drm_release(struct inode *inode, struct file *filp)
|
|||||||
mutex_lock(&dev->struct_mutex);
|
mutex_lock(&dev->struct_mutex);
|
||||||
|
|
||||||
if (file_priv->is_master) {
|
if (file_priv->is_master) {
|
||||||
|
struct drm_master *master = file_priv->master;
|
||||||
struct drm_file *temp;
|
struct drm_file *temp;
|
||||||
list_for_each_entry(temp, &dev->filelist, lhead) {
|
list_for_each_entry(temp, &dev->filelist, lhead) {
|
||||||
if ((temp->master == file_priv->master) &&
|
if ((temp->master == file_priv->master) &&
|
||||||
@ -491,6 +492,19 @@ int drm_release(struct inode *inode, struct file *filp)
|
|||||||
temp->authenticated = 0;
|
temp->authenticated = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Since the master is disappearing, so is the
|
||||||
|
* possibility to lock.
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (master->lock.hw_lock) {
|
||||||
|
if (dev->sigdata.lock == master->lock.hw_lock)
|
||||||
|
dev->sigdata.lock = NULL;
|
||||||
|
master->lock.hw_lock = NULL;
|
||||||
|
master->lock.file_priv = NULL;
|
||||||
|
wake_up_interruptible_all(&master->lock.lock_queue);
|
||||||
|
}
|
||||||
|
|
||||||
if (file_priv->minor->master == file_priv->master) {
|
if (file_priv->minor->master == file_priv->master) {
|
||||||
/* drop the reference held my the minor */
|
/* drop the reference held my the minor */
|
||||||
drm_master_put(&file_priv->minor->master);
|
drm_master_put(&file_priv->minor->master);
|
||||||
|
@ -435,6 +435,8 @@ EXPORT_SYMBOL(drm_vblank_get);
|
|||||||
*/
|
*/
|
||||||
void drm_vblank_put(struct drm_device *dev, int crtc)
|
void drm_vblank_put(struct drm_device *dev, int crtc)
|
||||||
{
|
{
|
||||||
|
BUG_ON (atomic_read (&dev->vblank_refcount[crtc]) == 0);
|
||||||
|
|
||||||
/* Last user schedules interrupt disable */
|
/* Last user schedules interrupt disable */
|
||||||
if (atomic_dec_and_test(&dev->vblank_refcount[crtc]))
|
if (atomic_dec_and_test(&dev->vblank_refcount[crtc]))
|
||||||
mod_timer(&dev->vblank_disable_timer, jiffies + 5*DRM_HZ);
|
mod_timer(&dev->vblank_disable_timer, jiffies + 5*DRM_HZ);
|
||||||
@ -460,8 +462,9 @@ void drm_vblank_pre_modeset(struct drm_device *dev, int crtc)
|
|||||||
* so that interrupts remain enabled in the interim.
|
* so that interrupts remain enabled in the interim.
|
||||||
*/
|
*/
|
||||||
if (!dev->vblank_inmodeset[crtc]) {
|
if (!dev->vblank_inmodeset[crtc]) {
|
||||||
dev->vblank_inmodeset[crtc] = 1;
|
dev->vblank_inmodeset[crtc] = 0x1;
|
||||||
drm_vblank_get(dev, crtc);
|
if (drm_vblank_get(dev, crtc) == 0)
|
||||||
|
dev->vblank_inmodeset[crtc] |= 0x2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_vblank_pre_modeset);
|
EXPORT_SYMBOL(drm_vblank_pre_modeset);
|
||||||
@ -473,9 +476,12 @@ void drm_vblank_post_modeset(struct drm_device *dev, int crtc)
|
|||||||
if (dev->vblank_inmodeset[crtc]) {
|
if (dev->vblank_inmodeset[crtc]) {
|
||||||
spin_lock_irqsave(&dev->vbl_lock, irqflags);
|
spin_lock_irqsave(&dev->vbl_lock, irqflags);
|
||||||
dev->vblank_disable_allowed = 1;
|
dev->vblank_disable_allowed = 1;
|
||||||
dev->vblank_inmodeset[crtc] = 0;
|
|
||||||
spin_unlock_irqrestore(&dev->vbl_lock, irqflags);
|
spin_unlock_irqrestore(&dev->vbl_lock, irqflags);
|
||||||
drm_vblank_put(dev, crtc);
|
|
||||||
|
if (dev->vblank_inmodeset[crtc] & 0x2)
|
||||||
|
drm_vblank_put(dev, crtc);
|
||||||
|
|
||||||
|
dev->vblank_inmodeset[crtc] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL(drm_vblank_post_modeset);
|
EXPORT_SYMBOL(drm_vblank_post_modeset);
|
||||||
|
@ -80,6 +80,7 @@ int drm_lock(struct drm_device *dev, void *data, struct drm_file *file_priv)
|
|||||||
__set_current_state(TASK_INTERRUPTIBLE);
|
__set_current_state(TASK_INTERRUPTIBLE);
|
||||||
if (!master->lock.hw_lock) {
|
if (!master->lock.hw_lock) {
|
||||||
/* Device has been unregistered */
|
/* Device has been unregistered */
|
||||||
|
send_sig(SIGTERM, current, 0);
|
||||||
ret = -EINTR;
|
ret = -EINTR;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -93,7 +94,7 @@ int drm_lock(struct drm_device *dev, void *data, struct drm_file *file_priv)
|
|||||||
/* Contention */
|
/* Contention */
|
||||||
schedule();
|
schedule();
|
||||||
if (signal_pending(current)) {
|
if (signal_pending(current)) {
|
||||||
ret = -ERESTARTSYS;
|
ret = -EINTR;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -146,14 +146,6 @@ static void drm_master_destroy(struct kref *kref)
|
|||||||
|
|
||||||
drm_ht_remove(&master->magiclist);
|
drm_ht_remove(&master->magiclist);
|
||||||
|
|
||||||
if (master->lock.hw_lock) {
|
|
||||||
if (dev->sigdata.lock == master->lock.hw_lock)
|
|
||||||
dev->sigdata.lock = NULL;
|
|
||||||
master->lock.hw_lock = NULL;
|
|
||||||
master->lock.file_priv = NULL;
|
|
||||||
wake_up_interruptible(&master->lock.lock_queue);
|
|
||||||
}
|
|
||||||
|
|
||||||
drm_free(master, sizeof(*master), DRM_MEM_DRIVER);
|
drm_free(master, sizeof(*master), DRM_MEM_DRIVER);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -176,7 +168,7 @@ int drm_setmaster_ioctl(struct drm_device *dev, void *data,
|
|||||||
file_priv->minor->master != file_priv->master) {
|
file_priv->minor->master != file_priv->master) {
|
||||||
mutex_lock(&dev->struct_mutex);
|
mutex_lock(&dev->struct_mutex);
|
||||||
file_priv->minor->master = drm_master_get(file_priv->master);
|
file_priv->minor->master = drm_master_get(file_priv->master);
|
||||||
mutex_lock(&dev->struct_mutex);
|
mutex_unlock(&dev->struct_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -811,7 +811,7 @@ static int i915_set_status_page(struct drm_device *dev, void *data,
|
|||||||
dev_priv->hws_map.flags = 0;
|
dev_priv->hws_map.flags = 0;
|
||||||
dev_priv->hws_map.mtrr = 0;
|
dev_priv->hws_map.mtrr = 0;
|
||||||
|
|
||||||
drm_core_ioremap(&dev_priv->hws_map, dev);
|
drm_core_ioremap_wc(&dev_priv->hws_map, dev);
|
||||||
if (dev_priv->hws_map.handle == NULL) {
|
if (dev_priv->hws_map.handle == NULL) {
|
||||||
i915_dma_cleanup(dev);
|
i915_dma_cleanup(dev);
|
||||||
dev_priv->status_gfx_addr = 0;
|
dev_priv->status_gfx_addr = 0;
|
||||||
@ -1090,6 +1090,11 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
|
|||||||
dev_priv->mm.gtt_mapping =
|
dev_priv->mm.gtt_mapping =
|
||||||
io_mapping_create_wc(dev->agp->base,
|
io_mapping_create_wc(dev->agp->base,
|
||||||
dev->agp->agp_info.aper_size * 1024*1024);
|
dev->agp->agp_info.aper_size * 1024*1024);
|
||||||
|
if (dev_priv->mm.gtt_mapping == NULL) {
|
||||||
|
ret = -EIO;
|
||||||
|
goto out_rmmap;
|
||||||
|
}
|
||||||
|
|
||||||
/* Set up a WC MTRR for non-PAT systems. This is more common than
|
/* Set up a WC MTRR for non-PAT systems. This is more common than
|
||||||
* one would think, because the kernel disables PAT on first
|
* one would think, because the kernel disables PAT on first
|
||||||
* generation Core chips because WC PAT gets overridden by a UC
|
* generation Core chips because WC PAT gets overridden by a UC
|
||||||
@ -1122,7 +1127,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
|
|||||||
if (!I915_NEED_GFX_HWS(dev)) {
|
if (!I915_NEED_GFX_HWS(dev)) {
|
||||||
ret = i915_init_phys_hws(dev);
|
ret = i915_init_phys_hws(dev);
|
||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
goto out_rmmap;
|
goto out_iomapfree;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* On the 945G/GM, the chipset reports the MSI capability on the
|
/* On the 945G/GM, the chipset reports the MSI capability on the
|
||||||
@ -1161,6 +1166,8 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
|
|||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
out_iomapfree:
|
||||||
|
io_mapping_free(dev_priv->mm.gtt_mapping);
|
||||||
out_rmmap:
|
out_rmmap:
|
||||||
iounmap(dev_priv->regs);
|
iounmap(dev_priv->regs);
|
||||||
free_priv:
|
free_priv:
|
||||||
|
@ -68,9 +68,11 @@ static int i915_suspend(struct drm_device *dev, pm_message_t state)
|
|||||||
i915_save_state(dev);
|
i915_save_state(dev);
|
||||||
|
|
||||||
/* If KMS is active, we do the leavevt stuff here */
|
/* If KMS is active, we do the leavevt stuff here */
|
||||||
if (drm_core_check_feature(dev, DRIVER_MODESET) && i915_gem_idle(dev)) {
|
if (drm_core_check_feature(dev, DRIVER_MODESET)) {
|
||||||
dev_err(&dev->pdev->dev, "GEM idle failed, aborting suspend\n");
|
if (i915_gem_idle(dev))
|
||||||
return -EBUSY;
|
dev_err(&dev->pdev->dev,
|
||||||
|
"GEM idle failed, resume may fail\n");
|
||||||
|
drm_irq_uninstall(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
intel_opregion_free(dev);
|
intel_opregion_free(dev);
|
||||||
@ -108,6 +110,8 @@ static int i915_resume(struct drm_device *dev)
|
|||||||
if (ret != 0)
|
if (ret != 0)
|
||||||
ret = -1;
|
ret = -1;
|
||||||
mutex_unlock(&dev->struct_mutex);
|
mutex_unlock(&dev->struct_mutex);
|
||||||
|
|
||||||
|
drm_irq_install(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
|
@ -1051,6 +1051,9 @@ i915_gem_retire_requests(struct drm_device *dev)
|
|||||||
drm_i915_private_t *dev_priv = dev->dev_private;
|
drm_i915_private_t *dev_priv = dev->dev_private;
|
||||||
uint32_t seqno;
|
uint32_t seqno;
|
||||||
|
|
||||||
|
if (!dev_priv->hw_status_page)
|
||||||
|
return;
|
||||||
|
|
||||||
seqno = i915_get_gem_seqno(dev);
|
seqno = i915_get_gem_seqno(dev);
|
||||||
|
|
||||||
while (!list_empty(&dev_priv->mm.request_list)) {
|
while (!list_empty(&dev_priv->mm.request_list)) {
|
||||||
@ -3545,7 +3548,7 @@ i915_gem_phys_pwrite(struct drm_device *dev, struct drm_gem_object *obj,
|
|||||||
user_data = (char __user *) (uintptr_t) args->data_ptr;
|
user_data = (char __user *) (uintptr_t) args->data_ptr;
|
||||||
obj_addr = obj_priv->phys_obj->handle->vaddr + args->offset;
|
obj_addr = obj_priv->phys_obj->handle->vaddr + args->offset;
|
||||||
|
|
||||||
DRM_ERROR("obj_addr %p, %lld\n", obj_addr, args->size);
|
DRM_DEBUG("obj_addr %p, %lld\n", obj_addr, args->size);
|
||||||
ret = copy_from_user(obj_addr, user_data, args->size);
|
ret = copy_from_user(obj_addr, user_data, args->size);
|
||||||
if (ret)
|
if (ret)
|
||||||
return -EFAULT;
|
return -EFAULT;
|
||||||
|
@ -383,12 +383,13 @@ int i915_irq_emit(struct drm_device *dev, void *data,
|
|||||||
drm_i915_irq_emit_t *emit = data;
|
drm_i915_irq_emit_t *emit = data;
|
||||||
int result;
|
int result;
|
||||||
|
|
||||||
RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
|
|
||||||
|
|
||||||
if (!dev_priv) {
|
if (!dev_priv) {
|
||||||
DRM_ERROR("called with no initialization\n");
|
DRM_ERROR("called with no initialization\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RING_LOCK_TEST_WITH_RETURN(dev, file_priv);
|
||||||
|
|
||||||
mutex_lock(&dev->struct_mutex);
|
mutex_lock(&dev->struct_mutex);
|
||||||
result = i915_emit_irq(dev);
|
result = i915_emit_irq(dev);
|
||||||
mutex_unlock(&dev->struct_mutex);
|
mutex_unlock(&dev->struct_mutex);
|
||||||
|
@ -111,6 +111,12 @@ parse_panel_data(struct drm_i915_private *dev_priv, struct bdb_header *bdb)
|
|||||||
panel_fixed_mode->clock = dvo_timing->clock * 10;
|
panel_fixed_mode->clock = dvo_timing->clock * 10;
|
||||||
panel_fixed_mode->type = DRM_MODE_TYPE_PREFERRED;
|
panel_fixed_mode->type = DRM_MODE_TYPE_PREFERRED;
|
||||||
|
|
||||||
|
/* Some VBTs have bogus h/vtotal values */
|
||||||
|
if (panel_fixed_mode->hsync_end > panel_fixed_mode->htotal)
|
||||||
|
panel_fixed_mode->htotal = panel_fixed_mode->hsync_end + 1;
|
||||||
|
if (panel_fixed_mode->vsync_end > panel_fixed_mode->vtotal)
|
||||||
|
panel_fixed_mode->vtotal = panel_fixed_mode->vsync_end + 1;
|
||||||
|
|
||||||
drm_mode_set_name(panel_fixed_mode);
|
drm_mode_set_name(panel_fixed_mode);
|
||||||
|
|
||||||
dev_priv->vbt_mode = panel_fixed_mode;
|
dev_priv->vbt_mode = panel_fixed_mode;
|
||||||
|
@ -217,7 +217,7 @@ bool intel_pipe_has_type (struct drm_crtc *crtc, int type)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define INTELPllInvalid(s) do { DRM_DEBUG(s); return false; } while (0)
|
#define INTELPllInvalid(s) do { /* DRM_DEBUG(s); */ return false; } while (0)
|
||||||
/**
|
/**
|
||||||
* Returns whether the given set of divisors are valid for a given refclk with
|
* Returns whether the given set of divisors are valid for a given refclk with
|
||||||
* the given connectors.
|
* the given connectors.
|
||||||
|
@ -79,10 +79,11 @@ static struct i2c_algo_bit_data ioc_data = {
|
|||||||
.getsda = ioc_getsda,
|
.getsda = ioc_getsda,
|
||||||
.getscl = ioc_getscl,
|
.getscl = ioc_getscl,
|
||||||
.udelay = 80,
|
.udelay = 80,
|
||||||
.timeout = 100
|
.timeout = HZ,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct i2c_adapter ioc_ops = {
|
static struct i2c_adapter ioc_ops = {
|
||||||
|
.nr = 0,
|
||||||
.algo_data = &ioc_data,
|
.algo_data = &ioc_data,
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -90,7 +91,7 @@ static int __init i2c_ioc_init(void)
|
|||||||
{
|
{
|
||||||
force_ones = FORCE_ONES | SCL | SDA;
|
force_ones = FORCE_ONES | SCL | SDA;
|
||||||
|
|
||||||
return i2c_bit_add_bus(&ioc_ops);
|
return i2c_bit_add_numbered_bus(&ioc_ops);
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(i2c_ioc_init);
|
module_init(i2c_ioc_init);
|
||||||
|
@ -72,7 +72,7 @@ static unsigned int amd_ec_wait_write(struct amd_smbus *smbus)
|
|||||||
{
|
{
|
||||||
int timeout = 500;
|
int timeout = 500;
|
||||||
|
|
||||||
while (timeout-- && (inb(smbus->base + AMD_EC_SC) & AMD_EC_SC_IBF))
|
while ((inb(smbus->base + AMD_EC_SC) & AMD_EC_SC_IBF) && --timeout)
|
||||||
udelay(1);
|
udelay(1);
|
||||||
|
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
@ -88,7 +88,7 @@ static unsigned int amd_ec_wait_read(struct amd_smbus *smbus)
|
|||||||
{
|
{
|
||||||
int timeout = 500;
|
int timeout = 500;
|
||||||
|
|
||||||
while (timeout-- && (~inb(smbus->base + AMD_EC_SC) & AMD_EC_SC_OBF))
|
while ((~inb(smbus->base + AMD_EC_SC) & AMD_EC_SC_OBF) && --timeout)
|
||||||
udelay(1);
|
udelay(1);
|
||||||
|
|
||||||
if (!timeout) {
|
if (!timeout) {
|
||||||
|
@ -114,7 +114,7 @@ static int ixp2000_i2c_probe(struct platform_device *plat_dev)
|
|||||||
drv_data->algo_data.getsda = ixp2000_bit_getsda;
|
drv_data->algo_data.getsda = ixp2000_bit_getsda;
|
||||||
drv_data->algo_data.getscl = ixp2000_bit_getscl;
|
drv_data->algo_data.getscl = ixp2000_bit_getscl;
|
||||||
drv_data->algo_data.udelay = 6;
|
drv_data->algo_data.udelay = 6;
|
||||||
drv_data->algo_data.timeout = 100;
|
drv_data->algo_data.timeout = HZ;
|
||||||
|
|
||||||
strlcpy(drv_data->adapter.name, plat_dev->dev.driver->name,
|
strlcpy(drv_data->adapter.name, plat_dev->dev.driver->name,
|
||||||
sizeof(drv_data->adapter.name));
|
sizeof(drv_data->adapter.name));
|
||||||
|
@ -482,7 +482,7 @@ mv64xxx_i2c_map_regs(struct platform_device *pd,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void __devexit
|
static void
|
||||||
mv64xxx_i2c_unmap_regs(struct mv64xxx_i2c_data *drv_data)
|
mv64xxx_i2c_unmap_regs(struct mv64xxx_i2c_data *drv_data)
|
||||||
{
|
{
|
||||||
if (drv_data->reg_base) {
|
if (drv_data->reg_base) {
|
||||||
@ -577,7 +577,7 @@ mv64xxx_i2c_remove(struct platform_device *dev)
|
|||||||
|
|
||||||
static struct platform_driver mv64xxx_i2c_driver = {
|
static struct platform_driver mv64xxx_i2c_driver = {
|
||||||
.probe = mv64xxx_i2c_probe,
|
.probe = mv64xxx_i2c_probe,
|
||||||
.remove = mv64xxx_i2c_remove,
|
.remove = __devexit_p(mv64xxx_i2c_remove),
|
||||||
.driver = {
|
.driver = {
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.name = MV64XXX_I2C_CTLR_NAME,
|
.name = MV64XXX_I2C_CTLR_NAME,
|
||||||
|
@ -644,7 +644,7 @@ static int i2c_pxa_do_pio_xfer(struct pxa_i2c *i2c,
|
|||||||
|
|
||||||
i2c_pxa_start_message(i2c);
|
i2c_pxa_start_message(i2c);
|
||||||
|
|
||||||
while (timeout-- && i2c->msg_num > 0) {
|
while (i2c->msg_num > 0 && --timeout) {
|
||||||
i2c_pxa_handler(0, i2c);
|
i2c_pxa_handler(0, i2c);
|
||||||
udelay(10);
|
udelay(10);
|
||||||
}
|
}
|
||||||
|
@ -76,7 +76,7 @@ static struct i2c_algo_bit_data scx200_i2c_data = {
|
|||||||
.getsda = scx200_i2c_getsda,
|
.getsda = scx200_i2c_getsda,
|
||||||
.getscl = scx200_i2c_getscl,
|
.getscl = scx200_i2c_getscl,
|
||||||
.udelay = 10,
|
.udelay = 10,
|
||||||
.timeout = 100,
|
.timeout = HZ,
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct i2c_adapter scx200_i2c_ops = {
|
static struct i2c_adapter scx200_i2c_ops = {
|
||||||
|
@ -1831,7 +1831,8 @@ static s32 i2c_smbus_xfer_emulated(struct i2c_adapter * adapter, u16 addr,
|
|||||||
case I2C_SMBUS_QUICK:
|
case I2C_SMBUS_QUICK:
|
||||||
msg[0].len = 0;
|
msg[0].len = 0;
|
||||||
/* Special case: The read/write field is used as data */
|
/* Special case: The read/write field is used as data */
|
||||||
msg[0].flags = flags | (read_write==I2C_SMBUS_READ)?I2C_M_RD:0;
|
msg[0].flags = flags | (read_write == I2C_SMBUS_READ ?
|
||||||
|
I2C_M_RD : 0);
|
||||||
num = 1;
|
num = 1;
|
||||||
break;
|
break;
|
||||||
case I2C_SMBUS_BYTE:
|
case I2C_SMBUS_BYTE:
|
||||||
|
@ -35,6 +35,7 @@
|
|||||||
#include <linux/i2c.h>
|
#include <linux/i2c.h>
|
||||||
#include <linux/i2c-dev.h>
|
#include <linux/i2c-dev.h>
|
||||||
#include <linux/smp_lock.h>
|
#include <linux/smp_lock.h>
|
||||||
|
#include <linux/jiffies.h>
|
||||||
#include <asm/uaccess.h>
|
#include <asm/uaccess.h>
|
||||||
|
|
||||||
static struct i2c_driver i2cdev_driver;
|
static struct i2c_driver i2cdev_driver;
|
||||||
@ -422,7 +423,10 @@ static long i2cdev_ioctl(struct file *file, unsigned int cmd, unsigned long arg)
|
|||||||
client->adapter->retries = arg;
|
client->adapter->retries = arg;
|
||||||
break;
|
break;
|
||||||
case I2C_TIMEOUT:
|
case I2C_TIMEOUT:
|
||||||
client->adapter->timeout = arg;
|
/* For historical reasons, user-space sets the timeout
|
||||||
|
* value in units of 10 ms.
|
||||||
|
*/
|
||||||
|
client->adapter->timeout = msecs_to_jiffies(arg * 10);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
/* NOTE: returning a fault code here could cause trouble
|
/* NOTE: returning a fault code here could cause trouble
|
||||||
|
@ -46,7 +46,7 @@ menuconfig IDE
|
|||||||
SMART parameters from disk drives.
|
SMART parameters from disk drives.
|
||||||
|
|
||||||
To compile this driver as a module, choose M here: the
|
To compile this driver as a module, choose M here: the
|
||||||
module will be called ide.
|
module will be called ide-core.ko.
|
||||||
|
|
||||||
For further information, please read <file:Documentation/ide/ide.txt>.
|
For further information, please read <file:Documentation/ide/ide.txt>.
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ static unsigned int init_chipset_amd74xx(struct pci_dev *dev)
|
|||||||
* Check for broken FIFO support.
|
* Check for broken FIFO support.
|
||||||
*/
|
*/
|
||||||
if (dev->vendor == PCI_VENDOR_ID_AMD &&
|
if (dev->vendor == PCI_VENDOR_ID_AMD &&
|
||||||
dev->vendor == PCI_DEVICE_ID_AMD_VIPER_7411)
|
dev->device == PCI_DEVICE_ID_AMD_VIPER_7411)
|
||||||
t &= 0x0f;
|
t &= 0x0f;
|
||||||
else
|
else
|
||||||
t |= 0xf0;
|
t |= 0xf0;
|
||||||
|
@ -52,7 +52,7 @@ static void atiixp_set_pio_mode(ide_drive_t *drive, const u8 pio)
|
|||||||
{
|
{
|
||||||
struct pci_dev *dev = to_pci_dev(drive->hwif->dev);
|
struct pci_dev *dev = to_pci_dev(drive->hwif->dev);
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int timing_shift = (drive->dn & 2) ? 16 : 0 + (drive->dn & 1) ? 0 : 8;
|
int timing_shift = (drive->dn ^ 1) * 8;
|
||||||
u32 pio_timing_data;
|
u32 pio_timing_data;
|
||||||
u16 pio_mode_data;
|
u16 pio_mode_data;
|
||||||
|
|
||||||
@ -85,7 +85,7 @@ static void atiixp_set_dma_mode(ide_drive_t *drive, const u8 speed)
|
|||||||
{
|
{
|
||||||
struct pci_dev *dev = to_pci_dev(drive->hwif->dev);
|
struct pci_dev *dev = to_pci_dev(drive->hwif->dev);
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int timing_shift = (drive->dn & 2) ? 16 : 0 + (drive->dn & 1) ? 0 : 8;
|
int timing_shift = (drive->dn ^ 1) * 8;
|
||||||
u32 tmp32;
|
u32 tmp32;
|
||||||
u16 tmp16;
|
u16 tmp16;
|
||||||
u16 udma_ctl = 0;
|
u16 udma_ctl = 0;
|
||||||
|
@ -55,7 +55,7 @@
|
|||||||
|
|
||||||
static DEFINE_MUTEX(idecd_ref_mutex);
|
static DEFINE_MUTEX(idecd_ref_mutex);
|
||||||
|
|
||||||
static void ide_cd_release(struct kref *);
|
static void ide_cd_release(struct device *);
|
||||||
|
|
||||||
static struct cdrom_info *ide_cd_get(struct gendisk *disk)
|
static struct cdrom_info *ide_cd_get(struct gendisk *disk)
|
||||||
{
|
{
|
||||||
@ -67,7 +67,7 @@ static struct cdrom_info *ide_cd_get(struct gendisk *disk)
|
|||||||
if (ide_device_get(cd->drive))
|
if (ide_device_get(cd->drive))
|
||||||
cd = NULL;
|
cd = NULL;
|
||||||
else
|
else
|
||||||
kref_get(&cd->kref);
|
get_device(&cd->dev);
|
||||||
|
|
||||||
}
|
}
|
||||||
mutex_unlock(&idecd_ref_mutex);
|
mutex_unlock(&idecd_ref_mutex);
|
||||||
@ -79,7 +79,7 @@ static void ide_cd_put(struct cdrom_info *cd)
|
|||||||
ide_drive_t *drive = cd->drive;
|
ide_drive_t *drive = cd->drive;
|
||||||
|
|
||||||
mutex_lock(&idecd_ref_mutex);
|
mutex_lock(&idecd_ref_mutex);
|
||||||
kref_put(&cd->kref, ide_cd_release);
|
put_device(&cd->dev);
|
||||||
ide_device_put(drive);
|
ide_device_put(drive);
|
||||||
mutex_unlock(&idecd_ref_mutex);
|
mutex_unlock(&idecd_ref_mutex);
|
||||||
}
|
}
|
||||||
@ -194,6 +194,14 @@ static void cdrom_analyze_sense_data(ide_drive_t *drive,
|
|||||||
bio_sectors = max(bio_sectors(failed_command->bio), 4U);
|
bio_sectors = max(bio_sectors(failed_command->bio), 4U);
|
||||||
sector &= ~(bio_sectors - 1);
|
sector &= ~(bio_sectors - 1);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The SCSI specification allows for the value
|
||||||
|
* returned by READ CAPACITY to be up to 75 2K
|
||||||
|
* sectors past the last readable block.
|
||||||
|
* Therefore, if we hit a medium error within the
|
||||||
|
* last 75 2K sectors, we decrease the saved size
|
||||||
|
* value.
|
||||||
|
*/
|
||||||
if (sector < get_capacity(info->disk) &&
|
if (sector < get_capacity(info->disk) &&
|
||||||
drive->probed_capacity - sector < 4 * 75)
|
drive->probed_capacity - sector < 4 * 75)
|
||||||
set_capacity(info->disk, sector);
|
set_capacity(info->disk, sector);
|
||||||
@ -1790,15 +1798,17 @@ static void ide_cd_remove(ide_drive_t *drive)
|
|||||||
ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
|
ide_debug_log(IDE_DBG_FUNC, "Call %s\n", __func__);
|
||||||
|
|
||||||
ide_proc_unregister_driver(drive, info->driver);
|
ide_proc_unregister_driver(drive, info->driver);
|
||||||
|
device_del(&info->dev);
|
||||||
del_gendisk(info->disk);
|
del_gendisk(info->disk);
|
||||||
|
|
||||||
ide_cd_put(info);
|
mutex_lock(&idecd_ref_mutex);
|
||||||
|
put_device(&info->dev);
|
||||||
|
mutex_unlock(&idecd_ref_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ide_cd_release(struct kref *kref)
|
static void ide_cd_release(struct device *dev)
|
||||||
{
|
{
|
||||||
struct cdrom_info *info = to_ide_drv(kref, cdrom_info);
|
struct cdrom_info *info = to_ide_drv(dev, cdrom_info);
|
||||||
struct cdrom_device_info *devinfo = &info->devinfo;
|
struct cdrom_device_info *devinfo = &info->devinfo;
|
||||||
ide_drive_t *drive = info->drive;
|
ide_drive_t *drive = info->drive;
|
||||||
struct gendisk *g = info->disk;
|
struct gendisk *g = info->disk;
|
||||||
@ -1997,7 +2007,12 @@ static int ide_cd_probe(ide_drive_t *drive)
|
|||||||
|
|
||||||
ide_init_disk(g, drive);
|
ide_init_disk(g, drive);
|
||||||
|
|
||||||
kref_init(&info->kref);
|
info->dev.parent = &drive->gendev;
|
||||||
|
info->dev.release = ide_cd_release;
|
||||||
|
dev_set_name(&info->dev, dev_name(&drive->gendev));
|
||||||
|
|
||||||
|
if (device_register(&info->dev))
|
||||||
|
goto out_free_disk;
|
||||||
|
|
||||||
info->drive = drive;
|
info->drive = drive;
|
||||||
info->driver = &ide_cdrom_driver;
|
info->driver = &ide_cdrom_driver;
|
||||||
@ -2011,7 +2026,7 @@ static int ide_cd_probe(ide_drive_t *drive)
|
|||||||
g->driverfs_dev = &drive->gendev;
|
g->driverfs_dev = &drive->gendev;
|
||||||
g->flags = GENHD_FL_CD | GENHD_FL_REMOVABLE;
|
g->flags = GENHD_FL_CD | GENHD_FL_REMOVABLE;
|
||||||
if (ide_cdrom_setup(drive)) {
|
if (ide_cdrom_setup(drive)) {
|
||||||
ide_cd_release(&info->kref);
|
put_device(&info->dev);
|
||||||
goto failed;
|
goto failed;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2021,6 +2036,8 @@ static int ide_cd_probe(ide_drive_t *drive)
|
|||||||
add_disk(g);
|
add_disk(g);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
out_free_disk:
|
||||||
|
put_disk(g);
|
||||||
out_free_cd:
|
out_free_cd:
|
||||||
kfree(info);
|
kfree(info);
|
||||||
failed:
|
failed:
|
||||||
|
@ -80,7 +80,7 @@ struct cdrom_info {
|
|||||||
ide_drive_t *drive;
|
ide_drive_t *drive;
|
||||||
struct ide_driver *driver;
|
struct ide_driver *driver;
|
||||||
struct gendisk *disk;
|
struct gendisk *disk;
|
||||||
struct kref kref;
|
struct device dev;
|
||||||
|
|
||||||
/* Buffer for table of contents. NULL if we haven't allocated
|
/* Buffer for table of contents. NULL if we haven't allocated
|
||||||
a TOC buffer for this device yet. */
|
a TOC buffer for this device yet. */
|
||||||
|
@ -25,7 +25,7 @@ module_param(debug_mask, ulong, 0644);
|
|||||||
|
|
||||||
static DEFINE_MUTEX(ide_disk_ref_mutex);
|
static DEFINE_MUTEX(ide_disk_ref_mutex);
|
||||||
|
|
||||||
static void ide_disk_release(struct kref *);
|
static void ide_disk_release(struct device *);
|
||||||
|
|
||||||
static struct ide_disk_obj *ide_disk_get(struct gendisk *disk)
|
static struct ide_disk_obj *ide_disk_get(struct gendisk *disk)
|
||||||
{
|
{
|
||||||
@ -37,7 +37,7 @@ static struct ide_disk_obj *ide_disk_get(struct gendisk *disk)
|
|||||||
if (ide_device_get(idkp->drive))
|
if (ide_device_get(idkp->drive))
|
||||||
idkp = NULL;
|
idkp = NULL;
|
||||||
else
|
else
|
||||||
kref_get(&idkp->kref);
|
get_device(&idkp->dev);
|
||||||
}
|
}
|
||||||
mutex_unlock(&ide_disk_ref_mutex);
|
mutex_unlock(&ide_disk_ref_mutex);
|
||||||
return idkp;
|
return idkp;
|
||||||
@ -48,7 +48,7 @@ static void ide_disk_put(struct ide_disk_obj *idkp)
|
|||||||
ide_drive_t *drive = idkp->drive;
|
ide_drive_t *drive = idkp->drive;
|
||||||
|
|
||||||
mutex_lock(&ide_disk_ref_mutex);
|
mutex_lock(&ide_disk_ref_mutex);
|
||||||
kref_put(&idkp->kref, ide_disk_release);
|
put_device(&idkp->dev);
|
||||||
ide_device_put(drive);
|
ide_device_put(drive);
|
||||||
mutex_unlock(&ide_disk_ref_mutex);
|
mutex_unlock(&ide_disk_ref_mutex);
|
||||||
}
|
}
|
||||||
@ -66,17 +66,18 @@ static void ide_gd_remove(ide_drive_t *drive)
|
|||||||
struct gendisk *g = idkp->disk;
|
struct gendisk *g = idkp->disk;
|
||||||
|
|
||||||
ide_proc_unregister_driver(drive, idkp->driver);
|
ide_proc_unregister_driver(drive, idkp->driver);
|
||||||
|
device_del(&idkp->dev);
|
||||||
del_gendisk(g);
|
del_gendisk(g);
|
||||||
|
|
||||||
drive->disk_ops->flush(drive);
|
drive->disk_ops->flush(drive);
|
||||||
|
|
||||||
ide_disk_put(idkp);
|
mutex_lock(&ide_disk_ref_mutex);
|
||||||
|
put_device(&idkp->dev);
|
||||||
|
mutex_unlock(&ide_disk_ref_mutex);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ide_disk_release(struct kref *kref)
|
static void ide_disk_release(struct device *dev)
|
||||||
{
|
{
|
||||||
struct ide_disk_obj *idkp = to_ide_drv(kref, ide_disk_obj);
|
struct ide_disk_obj *idkp = to_ide_drv(dev, ide_disk_obj);
|
||||||
ide_drive_t *drive = idkp->drive;
|
ide_drive_t *drive = idkp->drive;
|
||||||
struct gendisk *g = idkp->disk;
|
struct gendisk *g = idkp->disk;
|
||||||
|
|
||||||
@ -348,7 +349,12 @@ static int ide_gd_probe(ide_drive_t *drive)
|
|||||||
|
|
||||||
ide_init_disk(g, drive);
|
ide_init_disk(g, drive);
|
||||||
|
|
||||||
kref_init(&idkp->kref);
|
idkp->dev.parent = &drive->gendev;
|
||||||
|
idkp->dev.release = ide_disk_release;
|
||||||
|
dev_set_name(&idkp->dev, dev_name(&drive->gendev));
|
||||||
|
|
||||||
|
if (device_register(&idkp->dev))
|
||||||
|
goto out_free_disk;
|
||||||
|
|
||||||
idkp->drive = drive;
|
idkp->drive = drive;
|
||||||
idkp->driver = &ide_gd_driver;
|
idkp->driver = &ide_gd_driver;
|
||||||
@ -373,6 +379,8 @@ static int ide_gd_probe(ide_drive_t *drive)
|
|||||||
add_disk(g);
|
add_disk(g);
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
out_free_disk:
|
||||||
|
put_disk(g);
|
||||||
out_free_idkp:
|
out_free_idkp:
|
||||||
kfree(idkp);
|
kfree(idkp);
|
||||||
failed:
|
failed:
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user