Commit e9ad9b9b authored by Linus Torvalds's avatar Linus Torvalds

Merge tag 'docs-for-linus' of git://git.lwn.net/linux

Pull Documentation updates from Jon Corbet:
 "A bit busier this time around.

  The most interesting thing (IMO) this time around is some beginning
  infrastructural work to allow documents to be written using
  restructured text.  Maybe someday, in a galaxy far far away, we'll be
  able to eliminate the DocBook dependency and have a much better
  integrated set of kernel docs.  Someday.

  Beyond that, there's a new document on security hardening from Kees,
  the movement of some sample code over to samples/, a number of
  improvements to the serial docs from Geert, and the usual collection
  of corrections, typo fixes, etc"

* tag 'docs-for-linus' of git://git.lwn.net/linux: (55 commits)
  doc: self-protection: provide initial details
  serial: doc: Use port->state instead of info
  serial: doc: Always refer to tty_port->mutex
  Documentation: vm: Spelling s/paltform/platform/g
  Documentation/memcg: update kmem limit doc as codes behavior
  docproc: print a comment about autogeneration for rst output
  docproc: add support for reStructuredText format via --rst option
  docproc: abstract terminating lines at first space
  docproc: abstract docproc directive detection
  docproc: reduce unnecessary indentation
  docproc: add variables for subcommand and filename
  kernel-doc: use rst C domain directives and references for types
  kernel-doc: produce RestructuredText output
  kernel-doc: rewrite usage description, remove duplicated comments
  Doc: correct the location of sysrq.c
  Documentation: fix common spelling mistakes
  samples: v4l: from Documentation to samples directory
  samples: connector: from Documentation to samples directory
  Documentation: xillybus: fix spelling mistake
  Documentation: x86: fix spelling mistakes
  ...
parents 78975f23 9f803664
...@@ -3,9 +3,10 @@ Date: Mai 2012 ...@@ -3,9 +3,10 @@ Date: Mai 2012
Contact: Stefan Achatz <erazor_de@users.sourceforge.net> Contact: Stefan Achatz <erazor_de@users.sourceforge.net>
Description: The mouse can store 5 profiles which can be switched by the Description: The mouse can store 5 profiles which can be switched by the
press of a button. A profile is split into general settings and press of a button. A profile is split into general settings and
button settings. buttons holds informations about button layout. button settings. The buttons variable holds information about
When written, this file lets one write the respective profile button layout. When written, this file lets one write the
buttons to the mouse. The data has to be 47 bytes long. respective profile buttons to the mouse. The data has to be
47 bytes long.
The mouse will reject invalid data. The mouse will reject invalid data.
Which profile to write is determined by the profile number Which profile to write is determined by the profile number
contained in the data. contained in the data.
...@@ -26,8 +27,8 @@ Date: Mai 2012 ...@@ -26,8 +27,8 @@ Date: Mai 2012
Contact: Stefan Achatz <erazor_de@users.sourceforge.net> Contact: Stefan Achatz <erazor_de@users.sourceforge.net>
Description: The mouse can store 5 profiles which can be switched by the Description: The mouse can store 5 profiles which can be switched by the
press of a button. A profile is split into general settings and press of a button. A profile is split into general settings and
button settings. profile holds informations like resolution, sensitivity button settings. A profile holds information like resolution,
and light effects. sensitivity and light effects.
When written, this file lets one write the respective profile When written, this file lets one write the respective profile
settings back to the mouse. The data has to be 43 bytes long. settings back to the mouse. The data has to be 43 bytes long.
The mouse will reject invalid data. The mouse will reject invalid data.
......
...@@ -4,7 +4,7 @@ Contact: Linux on PowerPC Developer List <linuxppc-dev@lists.ozlabs.org> ...@@ -4,7 +4,7 @@ Contact: Linux on PowerPC Developer List <linuxppc-dev@lists.ozlabs.org>
Description: Description:
Provides access to the binary "24x7 catalog" provided by the Provides access to the binary "24x7 catalog" provided by the
hypervisor on POWER7 and 8 systems. This catalog lists events hypervisor on POWER7 and 8 systems. This catalog lists events
avaliable from the powerpc "hv_24x7" pmu. Its format is available from the powerpc "hv_24x7" pmu. Its format is
documented here: documented here:
https://raw.githubusercontent.com/jmesmon/catalog-24x7/master/hv-24x7-catalog.h https://raw.githubusercontent.com/jmesmon/catalog-24x7/master/hv-24x7-catalog.h
......
...@@ -39,5 +39,5 @@ Description: Make it possible to adjust defio refresh rate. ...@@ -39,5 +39,5 @@ Description: Make it possible to adjust defio refresh rate.
Note: As device can barely do 2 complete refreshes a second Note: As device can barely do 2 complete refreshes a second
it only makes sense to adjust this value if only one or two it only makes sense to adjust this value if only one or two
tiles get changed and it's not appropriate to expect the application tiles get changed and it's not appropriate to expect the application
to flush it's tiny changes explicitely at higher than default rate. to flush its tiny changes explicitly at higher than default rate.
...@@ -169,7 +169,7 @@ Description: ...@@ -169,7 +169,7 @@ Description:
to enable/disable/clear ACPI interrupts in user space, which can be to enable/disable/clear ACPI interrupts in user space, which can be
used to debug some ACPI interrupt storm issues. used to debug some ACPI interrupt storm issues.
Note that only writting to VALID GPE/Fixed Event is allowed, Note that only writing to VALID GPE/Fixed Event is allowed,
i.e. user can only change the status of runtime GPE and i.e. user can only change the status of runtime GPE and
Fixed Event with event handler installed. Fixed Event with event handler installed.
......
...@@ -2841,7 +2841,7 @@ for a GOP and keep it below or equal the set bitrate target. Otherwise the rate ...@@ -2841,7 +2841,7 @@ for a GOP and keep it below or equal the set bitrate target. Otherwise the rate
overall average bitrate for the stream and keeps it below or equal to the set bitrate. In the first case overall average bitrate for the stream and keeps it below or equal to the set bitrate. In the first case
the average bitrate for the whole stream will be smaller then the set bitrate. This is caused because the the average bitrate for the whole stream will be smaller then the set bitrate. This is caused because the
average is calculated for smaller number of frames, on the other hand enabling this setting will ensure that average is calculated for smaller number of frames, on the other hand enabling this setting will ensure that
the stream will meet tight bandwidth contraints. Applicable to encoders. the stream will meet tight bandwidth constraints. Applicable to encoders.
</entry> </entry>
</row> </row>
<row><entry></entry></row> <row><entry></entry></row>
......
...@@ -85,7 +85,7 @@ initialize all fields of the &v4l2-vbi-format; ...@@ -85,7 +85,7 @@ initialize all fields of the &v4l2-vbi-format;
results of <constant>VIDIOC_G_FMT</constant>, and call the results of <constant>VIDIOC_G_FMT</constant>, and call the
&VIDIOC-S-FMT; ioctl with a pointer to this structure. Drivers return &VIDIOC-S-FMT; ioctl with a pointer to this structure. Drivers return
an &EINVAL; only when the given parameters are ambiguous, otherwise an &EINVAL; only when the given parameters are ambiguous, otherwise
they modify the parameters according to the hardware capabilites and they modify the parameters according to the hardware capabilities and
return the actual parameters. When the driver allocates resources at return the actual parameters. When the driver allocates resources at
this point, it may return an &EBUSY; to indicate the returned this point, it may return an &EBUSY; to indicate the returned
parameters are valid but the required resources are currently not parameters are valid but the required resources are currently not
......
...@@ -216,7 +216,7 @@ or the <structfield>flags</structfield> argument is not valid.</para> ...@@ -216,7 +216,7 @@ or the <structfield>flags</structfield> argument is not valid.</para>
<term><errorcode>ERANGE</errorcode></term> <term><errorcode>ERANGE</errorcode></term>
<listitem> <listitem>
<para>It is not possible to adjust &v4l2-rect; <structfield> <para>It is not possible to adjust &v4l2-rect; <structfield>
r</structfield> rectangle to satisfy all contraints given in the r</structfield> rectangle to satisfy all constraints given in the
<structfield>flags</structfield> argument.</para> <structfield>flags</structfield> argument.</para>
</listitem> </listitem>
</varlistentry> </varlistentry>
......
...@@ -70,6 +70,7 @@ of the reverse map types are described below: ...@@ -70,6 +70,7 @@ of the reverse map types are described below:
==== Linear ==== ==== Linear ====
irq_domain_add_linear() irq_domain_add_linear()
irq_domain_create_linear()
The linear reverse map maintains a fixed size table indexed by the The linear reverse map maintains a fixed size table indexed by the
hwirq number. When a hwirq is mapped, an irq_desc is allocated for hwirq number. When a hwirq is mapped, an irq_desc is allocated for
...@@ -81,10 +82,16 @@ map are fixed time lookup for IRQ numbers, and irq_descs are only ...@@ -81,10 +82,16 @@ map are fixed time lookup for IRQ numbers, and irq_descs are only
allocated for in-use IRQs. The disadvantage is that the table must be allocated for in-use IRQs. The disadvantage is that the table must be
as large as the largest possible hwirq number. as large as the largest possible hwirq number.
irq_domain_add_linear() and irq_domain_create_linear() are functionally
equivalent, except for the first argument is different - the former
accepts an Open Firmware specific 'struct device_node', while the latter
accepts a more general abstraction 'struct fwnode_handle'.
The majority of drivers should use the linear map. The majority of drivers should use the linear map.
==== Tree ==== ==== Tree ====
irq_domain_add_tree() irq_domain_add_tree()
irq_domain_create_tree()
The irq_domain maintains a radix tree map from hwirq numbers to Linux The irq_domain maintains a radix tree map from hwirq numbers to Linux
IRQs. When an hwirq is mapped, an irq_desc is allocated and the IRQs. When an hwirq is mapped, an irq_desc is allocated and the
...@@ -95,6 +102,11 @@ since it doesn't need to allocate a table as large as the largest ...@@ -95,6 +102,11 @@ since it doesn't need to allocate a table as large as the largest
hwirq number. The disadvantage is that hwirq to IRQ number lookup is hwirq number. The disadvantage is that hwirq to IRQ number lookup is
dependent on how many entries are in the table. dependent on how many entries are in the table.
irq_domain_add_tree() and irq_domain_create_tree() are functionally
equivalent, except for the first argument is different - the former
accepts an Open Firmware specific 'struct device_node', while the latter
accepts a more general abstraction 'struct fwnode_handle'.
Very few drivers should need this mapping. Very few drivers should need this mapping.
==== No Map ===- ==== No Map ===-
......
subdir-y := accounting auxdisplay blackfin connector \ subdir-y := accounting auxdisplay blackfin \
filesystems filesystems ia64 laptops mic misc-devices \ filesystems filesystems ia64 laptops mic misc-devices \
networking pcmcia prctl ptp timers vDSO watchdog networking pcmcia prctl ptp timers vDSO watchdog
...@@ -176,13 +176,13 @@ a history of how Linux changed RCU more than RCU changed Linux ...@@ -176,13 +176,13 @@ a history of how Linux changed RCU more than RCU changed Linux
which Mathieu Desnoyers is now maintaining [MathieuDesnoyers2009URCU] which Mathieu Desnoyers is now maintaining [MathieuDesnoyers2009URCU]
[MathieuDesnoyersPhD]. TINY_RCU [PaulEMcKenney2009BloatWatchRCU] made [MathieuDesnoyersPhD]. TINY_RCU [PaulEMcKenney2009BloatWatchRCU] made
its appearance, as did expedited RCU [PaulEMcKenney2009expeditedRCU]. its appearance, as did expedited RCU [PaulEMcKenney2009expeditedRCU].
The problem of resizeable RCU-protected hash tables may now be on a path The problem of resizable RCU-protected hash tables may now be on a path
to a solution [JoshTriplett2009RPHash]. A few academic researchers are now to a solution [JoshTriplett2009RPHash]. A few academic researchers are now
using RCU to solve their parallel problems [HariKannan2009DynamicAnalysisRCU]. using RCU to solve their parallel problems [HariKannan2009DynamicAnalysisRCU].
2010 produced a simpler preemptible-RCU implementation 2010 produced a simpler preemptible-RCU implementation
based on TREE_RCU [PaulEMcKenney2010SimpleOptRCU], lockdep-RCU based on TREE_RCU [PaulEMcKenney2010SimpleOptRCU], lockdep-RCU
[PaulEMcKenney2010LockdepRCU], another resizeable RCU-protected hash [PaulEMcKenney2010LockdepRCU], another resizable RCU-protected hash
table [HerbertXu2010RCUResizeHash] (this one consuming more memory, table [HerbertXu2010RCUResizeHash] (this one consuming more memory,
but allowing arbitrary changes in hash function, as required for DoS but allowing arbitrary changes in hash function, as required for DoS
avoidance in the networking code), realization of the 2009 RCU-protected avoidance in the networking code), realization of the 2009 RCU-protected
...@@ -193,7 +193,7 @@ the RCU API [PaulEMcKenney2010RCUAPI]. ...@@ -193,7 +193,7 @@ the RCU API [PaulEMcKenney2010RCUAPI].
[LinusTorvalds2011Linux2:6:38:rc1:NPigginVFS], an RCU-protected red-black [LinusTorvalds2011Linux2:6:38:rc1:NPigginVFS], an RCU-protected red-black
tree using software transactional memory to protect concurrent updates tree using software transactional memory to protect concurrent updates
(strange, but true!) [PhilHoward2011RCUTMRBTree], yet another variant of (strange, but true!) [PhilHoward2011RCUTMRBTree], yet another variant of
RCU-protected resizeable hash tables [Triplett:2011:RPHash], the 3.0 RCU RCU-protected resizable hash tables [Triplett:2011:RPHash], the 3.0 RCU
trainwreck [PaulEMcKenney2011RCU3.0trainwreck], and Neil Brown's "Meet the trainwreck [PaulEMcKenney2011RCU3.0trainwreck], and Neil Brown's "Meet the
Lockers" LWN article [NeilBrown2011MeetTheLockers]. Some academic Lockers" LWN article [NeilBrown2011MeetTheLockers]. Some academic
work looked at debugging uses of RCU [Seyster:2011:RFA:2075416.2075425]. work looked at debugging uses of RCU [Seyster:2011:RFA:2075416.2075425].
......
...@@ -136,7 +136,7 @@ an fxyzzy(3) operation for free: ...@@ -136,7 +136,7 @@ an fxyzzy(3) operation for free:
- xyzzyat(fd, "", ..., AT_EMPTY_PATH) is equivalent to fxyzzy(fd, ...) - xyzzyat(fd, "", ..., AT_EMPTY_PATH) is equivalent to fxyzzy(fd, ...)
(For more details on the rationale of the *at() calls, see the openat(2) man (For more details on the rationale of the *at() calls, see the openat(2) man
page; for an example of AT_EMPTY_PATH, see the statat(2) man page.) page; for an example of AT_EMPTY_PATH, see the fstatat(2) man page.)
If your new xyzzy(2) system call involves a parameter describing an offset If your new xyzzy(2) system call involves a parameter describing an offset
within a file, make its type loff_t so that 64-bit offsets can be supported within a file, make its type loff_t so that 64-bit offsets can be supported
......
...@@ -214,7 +214,7 @@ RedBoot scripting ...@@ -214,7 +214,7 @@ RedBoot scripting
----------------- -----------------
All the commands above aren't so useful if they have to be typed in every All the commands above aren't so useful if they have to be typed in every
time the Assabet is rebooted. Therefore it's possible to automatize the boot time the Assabet is rebooted. Therefore it's possible to automate the boot
process using RedBoot's scripting capability. process using RedBoot's scripting capability.
For example, I use this to boot Linux with both the kernel and the ramdisk For example, I use this to boot Linux with both the kernel and the ramdisk
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
- This file - This file
biodoc.txt biodoc.txt
- Notes on the Generic Block Layer Rewrite in Linux 2.5 - Notes on the Generic Block Layer Rewrite in Linux 2.5
biovecs.txt
- Immutable biovecs and biovec iterators
capability.txt capability.txt
- Generic Block Device Capability (/sys/block/<device>/capability) - Generic Block Device Capability (/sys/block/<device>/capability)
cfq-iosched.txt cfq-iosched.txt
...@@ -14,6 +16,8 @@ deadline-iosched.txt ...@@ -14,6 +16,8 @@ deadline-iosched.txt
- Deadline IO scheduler tunables - Deadline IO scheduler tunables
ioprio.txt ioprio.txt
- Block io priorities (in CFQ scheduler) - Block io priorities (in CFQ scheduler)
pr.txt
- Block layer support for Persistent Reservations
null_blk.txt null_blk.txt
- Null block for block-layer benchmarking. - Null block for block-layer benchmarking.
queue-sysfs.txt queue-sysfs.txt
......
...@@ -280,17 +280,9 @@ the amount of kernel memory used by the system. Kernel memory is fundamentally ...@@ -280,17 +280,9 @@ the amount of kernel memory used by the system. Kernel memory is fundamentally
different than user memory, since it can't be swapped out, which makes it different than user memory, since it can't be swapped out, which makes it
possible to DoS the system by consuming too much of this precious resource. possible to DoS the system by consuming too much of this precious resource.
Kernel memory won't be accounted at all until limit on a group is set. This Kernel memory accounting is enabled for all memory cgroups by default. But
allows for existing setups to continue working without disruption. The limit it can be disabled system-wide by passing cgroup.memory=nokmem to the kernel
cannot be set if the cgroup have children, or if there are already tasks in the at boot time. In this case, kernel memory will not be accounted at all.
cgroup. Attempting to set the limit under those conditions will return -EBUSY.
When use_hierarchy == 1 and a group is accounted, its children will
automatically be accounted regardless of their limit value.
After a group is first limited, it will be kept being accounted until it
is removed. The memory limitation itself, can of course be removed by writing
-1 to memory.kmem.limit_in_bytes. In this case, kmem will be accounted, but not
limited.
Kernel memory limits are not imposed for the root cgroup. Usage for the root Kernel memory limits are not imposed for the root cgroup. Usage for the root
cgroup may or may not be accounted. The memory used is accumulated into cgroup may or may not be accounted. The memory used is accumulated into
......
...@@ -186,3 +186,11 @@ only cn_test.c test module used it. ...@@ -186,3 +186,11 @@ only cn_test.c test module used it.
Some work in netlink area is still being done, so things can be changed in Some work in netlink area is still being done, so things can be changed in
2.6.15 timeframe, if it will happen, documentation will be updated for that 2.6.15 timeframe, if it will happen, documentation will be updated for that
kernel. kernel.
/*****************************************/
Code samples
/*****************************************/
Sample code for a connector test module and user space can be found
in samples/connector/. To build this code, enable CONFIG_CONNECTOR
and CONFIG_SAMPLES.
Cirrus Logic/Wolfson Microelectronics Arizona class audio SoCs Cirrus Logic/Wolfson Microelectronics Arizona class audio SoCs
These devices are audio SoCs with extensive digital capabilites and a range These devices are audio SoCs with extensive digital capabilities and a range
of analogue I/O. of analogue I/O.
Required properties: Required properties:
......
...@@ -268,6 +268,9 @@ IIO ...@@ -268,6 +268,9 @@ IIO
devm_iio_trigger_alloc() devm_iio_trigger_alloc()
devm_iio_trigger_free() devm_iio_trigger_free()
INPUT
devm_input_allocate_device()
IO region IO region
devm_release_mem_region() devm_release_mem_region()
devm_release_region() devm_release_region()
......
...@@ -272,7 +272,7 @@ A partial list of the supported mount options follows: ...@@ -272,7 +272,7 @@ A partial list of the supported mount options follows:
same domain (e.g. running winbind or nss_ldap) and same domain (e.g. running winbind or nss_ldap) and
the server supports the Unix Extensions then the uid the server supports the Unix Extensions then the uid
and gid can be retrieved from the server (and uid and gid can be retrieved from the server (and uid
and gid would not have to be specifed on the mount. and gid would not have to be specified on the mount.
For servers which do not support the CIFS Unix For servers which do not support the CIFS Unix
extensions, the default uid (and gid) returned on lookup extensions, the default uid (and gid) returned on lookup
of existing files will be the uid (gid) of the person of existing files will be the uid (gid) of the person
......
...@@ -29,7 +29,7 @@ Main features of this FS include: ...@@ -29,7 +29,7 @@ Main features of this FS include:
* Read request (data read, directory listing, lookup requests) balancing between multiple servers. * Read request (data read, directory listing, lookup requests) balancing between multiple servers.
* Write requests are replicated to multiple servers and completed only when all of them are acked. * Write requests are replicated to multiple servers and completed only when all of them are acked.
* Ability to add and/or remove servers from the working set at run-time. * Ability to add and/or remove servers from the working set at run-time.
* Strong authentification and possible data encryption in network channel. * Strong authentication and possible data encryption in network channel.
* Extended attributes support. * Extended attributes support.
POHMELFS is based on transactions, which are potentially long-standing objects that live POHMELFS is based on transactions, which are potentially long-standing objects that live
......
...@@ -16,7 +16,7 @@ qnx6fs shares many properties with traditional Unix filesystems. It has the ...@@ -16,7 +16,7 @@ qnx6fs shares many properties with traditional Unix filesystems. It has the
concepts of blocks, inodes and directories. concepts of blocks, inodes and directories.
On QNX it is possible to create little endian and big endian qnx6 filesystems. On QNX it is possible to create little endian and big endian qnx6 filesystems.
This feature makes it possible to create and use a different endianness fs This feature makes it possible to create and use a different endianness fs
for the target (QNX is used on quite a range of embedded systems) plattform for the target (QNX is used on quite a range of embedded systems) platform
running on a different endianness. running on a different endianness.
The Linux driver handles endianness transparently. (LE and BE) The Linux driver handles endianness transparently. (LE and BE)
......
...@@ -20,7 +20,7 @@ ...@@ -20,7 +20,7 @@
1), kernel(driver): 1), kernel(driver):
- calls request_firmware(&fw_entry, $FIRMWARE, device) - calls request_firmware(&fw_entry, $FIRMWARE, device)
- kernel searchs the fimware image with name $FIRMWARE directly - kernel searches the firmware image with name $FIRMWARE directly
in the below search path of root filesystem: in the below search path of root filesystem:
User customized search path by module parameter 'path'[1] User customized search path by module parameter 'path'[1]
"/lib/firmware/updates/" UTS_RELEASE, "/lib/firmware/updates/" UTS_RELEASE,
......
...@@ -25,7 +25,7 @@ Supported chips: ...@@ -25,7 +25,7 @@ Supported chips:
1) For revisions 2 and 3 uGuru's the driver can autodetect the 1) For revisions 2 and 3 uGuru's the driver can autodetect the
sensortype (Volt or Temp) for bank1 sensors, for revision 1 uGuru's sensortype (Volt or Temp) for bank1 sensors, for revision 1 uGuru's
this doesnot always work. For these uGuru's the autodection can this doesnot always work. For these uGuru's the autodection can
be overriden with the bank1_types module param. For all 3 known be overridden with the bank1_types module param. For all 3 known
revison 1 motherboards the correct use of this param is: revison 1 motherboards the correct use of this param is:
bank1_types=1,1,0,0,0,0,0,2,0,0,0,0,2,0,0,1 bank1_types=1,1,0,0,0,0,0,2,0,0,0,0,2,0,0,1
You may also need to specify the fan_sensors option for these boards You may also need to specify the fan_sensors option for these boards
......
...@@ -25,7 +25,7 @@ Partitions and P_Keys ...@@ -25,7 +25,7 @@ Partitions and P_Keys
main interface for a subinterface is in "parent." main interface for a subinterface is in "parent."
Child interface create/delete can also be done using IPoIB's Child interface create/delete can also be done using IPoIB's
rtnl_link_ops, where childs created using either way behave the same. rtnl_link_ops, where children created using either way behave the same.
Datagram vs Connected modes Datagram vs Connected modes
......
...@@ -290,12 +290,6 @@ Linux カーネルの開発プロセスは現在幾つかの異なるメイン ...@@ -290,12 +290,6 @@ Linux カーネルの開発プロセスは現在幾つかの異なるメイン
- このプロセスはカーネルが 「準備ができた」と考えられるまで継続しま - このプロセスはカーネルが 「準備ができた」と考えられるまで継続しま
す。このプロセスはだいたい 6週間継続します。 す。このプロセスはだいたい 6週間継続します。
- 各リリースでの既知の後戻り問題(regression: このリリースの中で新規
に作り込まれた問題を指す) はその都度 Linux-kernel メーリングリスト
に投稿されます。ゴールとしては、カーネルが 「準備ができた」と宣言
する前にこのリストの長さをゼロに減らすことですが、現実には、数個の
後戻り問題がリリース時にたびたび残ってしまいます。
Andrew Morton が Linux-kernel メーリングリストにカーネルリリースについ Andrew Morton が Linux-kernel メーリングリストにカーネルリリースについ
て書いたことをここで言っておくことは価値があります- て書いたことをここで言っておくことは価値があります-
「カーネルがいつリリースされるかは誰も知りません。なぜなら、これは現 「カーネルがいつリリースされるかは誰も知りません。なぜなら、これは現
......
...@@ -194,15 +194,15 @@ ...@@ -194,15 +194,15 @@
simple---most of the complexity (other than talking to the simple---most of the complexity (other than talking to the
hardware) involves managing network packets in memory". hardware) involves managing network packets in memory".
* Title: "Writing Linux Device Drivers" * Title: "Linux Kernel Hackers' Guide"
Author: Michael K. Johnson. Author: Michael K. Johnson.
URL: http://users.evitech.fi/~tk/rtos/writing_linux_device_d.html URL: http://www.tldp.org/LDP/khg/HyperNews/get/khg.html
Keywords: files, VFS, file operations, kernel interface, character Keywords: device drivers, files, VFS, kernel interface, character vs
vs block devices, I/O access, hardware interrupts, DMA, access to block devices, hardware interrupts, scsi, DMA, access to user memory,
user memory, memory allocation, timers. memory allocation, timers.
Description: Introductory 50-minutes (sic) tutorial on writing Description: A guide designed to help you get up to speed on the
device drivers. 12 pages written by the same author of the "Kernel concepts that are not intuitevly obvious, and to document the internal
Hackers' Guide" which give a very good overview of the topic. structures of Linux.
* Title: "The Venus kernel interface" * Title: "The Venus kernel interface"
Author: Peter J. Braam. Author: Peter J. Braam.
...@@ -250,7 +250,7 @@ ...@@ -250,7 +250,7 @@
* Title: "Analysis of the Ext2fs structure" * Title: "Analysis of the Ext2fs structure"
Author: Louis-Dominique Dubeau. Author: Louis-Dominique Dubeau.
URL: http://www.nondot.org/sabre/os/files/FileSystems/ext2fs/ URL: http://teaching.csse.uwa.edu.au/units/CITS2002/fs-ext2/
Keywords: ext2, filesystem, ext2fs. Keywords: ext2, filesystem, ext2fs.
Description: Description of ext2's blocks, directories, inodes, Description: Description of ext2's blocks, directories, inodes,
bitmaps, invariants... bitmaps, invariants...
...@@ -266,14 +266,14 @@ ...@@ -266,14 +266,14 @@
* Title: "Kernel API changes from 2.0 to 2.2" * Title: "Kernel API changes from 2.0 to 2.2"
Author: Richard Gooch. Author: Richard Gooch.
URL: URL: http://www.safe-mbox.com/~rgooch/linux/docs/porting-to-2.2.html
http://www.linuxhq.com/guides/LKMPG/node28.html
Keywords: 2.2, changes. Keywords: 2.2, changes.
Description: Kernel functions/structures/variables which changed Description: Kernel functions/structures/variables which changed
from 2.0.x to 2.2.x. from 2.0.x to 2.2.x.
* Title: "Kernel API changes from 2.2 to 2.4" * Title: "Kernel API changes from 2.2 to 2.4"
Author: Richard Gooch. Author: Richard Gooch.
URL: http://www.safe-mbox.com/~rgooch/linux/docs/porting-to-2.4.html
Keywords: 2.4, changes. Keywords: 2.4, changes.
Description: Kernel functions/structures/variables which changed Description: Kernel functions/structures/variables which changed
from 2.2.x to 2.4.x. from 2.2.x to 2.4.x.
...@@ -609,6 +609,13 @@ ...@@ -609,6 +609,13 @@
Pages: 432. Pages: 432.
ISBN: 0-201-63338-8 ISBN: 0-201-63338-8
* Title: "Linux Kernel Development, 3rd Edition"
Author: Robert Love
Publisher: Addison-Wesley.
Date: July, 2010
Pages: 440
ISBN: 978-0672329463
MISCELLANEOUS: MISCELLANEOUS:
* Name: linux/Documentation * Name: linux/Documentation
......
...@@ -236,9 +236,9 @@ Documentation/DocBook/ 디렉토리 내에서 만들어지며 PDF, Postscript, H ...@@ -236,9 +236,9 @@ Documentation/DocBook/ 디렉토리 내에서 만들어지며 PDF, Postscript, H
- 새로운 커널이 배포되자마자 2주의 시간이 주어진다. 이 기간동은 - 새로운 커널이 배포되자마자 2주의 시간이 주어진다. 이 기간동은
메인테이너들은 큰 diff들을 Linus에게 제출할 수 있다. 대개 이 패치들은 메인테이너들은 큰 diff들을 Linus에게 제출할 수 있다. 대개 이 패치들은
몇 주 동안 -next 커널내에 이미 있었던 것들이다. 큰 변경들을 제출하는 데 몇 주 동안 -next 커널내에 이미 있었던 것들이다. 큰 변경들을 제출하는 데
선호되는 방법은 git(커널의 소스 관리 툴, 더 많은 정보들은 http://git.or.cz/ 선호되는 방법은 git(커널의 소스 관리 툴, 더 많은 정보들은
에서 참조할 수 있다)를 사용하는 것이지만 순수한 패치파일의 형식으로 보내는 http://git-scm.com/ 에서 참조할 수 있다)를 사용하는 것이지만 순수한
것도 무관하다. 패치파일의 형식으로 보내는 것도 무관하다.
- 2주 후에 -rc1 커널이 배포되며 지금부터는 전체 커널의 안정성에 영향을 - 2주 후에 -rc1 커널이 배포되며 지금부터는 전체 커널의 안정성에 영향을
미칠수 있는 새로운 기능들을 포함하지 않는 패치들만이 추가될 수 있다. 미칠수 있는 새로운 기능들을 포함하지 않는 패치들만이 추가될 수 있다.
완전히 새로운 드라이버(혹은 파일시스템)는 -rc1 이후에만 받아들여진다는 완전히 새로운 드라이버(혹은 파일시스템)는 -rc1 이후에만 받아들여진다는
...@@ -253,8 +253,6 @@ Documentation/DocBook/ 디렉토리 내에서 만들어지며 PDF, Postscript, H ...@@ -253,8 +253,6 @@ Documentation/DocBook/ 디렉토리 내에서 만들어지며 PDF, Postscript, H
것이다. 것이다.
- 이러한 프로세스는 커널이 "준비(ready)"되었다고 여겨질때까지 계속된다. - 이러한 프로세스는 커널이 "준비(ready)"되었다고 여겨질때까지 계속된다.
프로세스는 대체로 6주간 지속된다. 프로세스는 대체로 6주간 지속된다.
- 각 -rc 배포에 있는 알려진 회귀의 목록들은 다음 URI에 남겨진다.
http://kernelnewbies.org/known_regressions
커널 배포에 있어서 언급할만한 가치가 있는 리눅스 커널 메일링 리스트의 커널 배포에 있어서 언급할만한 가치가 있는 리눅스 커널 메일링 리스트의
Andrew Morton의 글이 있다. Andrew Morton의 글이 있다.
......
...@@ -19,7 +19,7 @@ Author: Azael Avalos <coproscefalo@gmail.com> ...@@ -19,7 +19,7 @@ Author: Azael Avalos <coproscefalo@gmail.com>
-------------- --------------
This driver provides support for the accelerometer found in various Toshiba This driver provides support for the accelerometer found in various Toshiba
laptops, being called "Toshiba HDD Protection - Shock Sensor" officialy, laptops, being called "Toshiba HDD Protection - Shock Sensor" officially,
and detects laptops automatically with this device. and detects laptops automatically with this device.
On Windows, Toshiba provided software monitors this device and provides On Windows, Toshiba provided software monitors this device and provides
automatic HDD protection (head unload) on sudden moves or harsh vibrations, automatic HDD protection (head unload) on sudden moves or harsh vibrations,
......
...@@ -69,9 +69,9 @@ Description ...@@ -69,9 +69,9 @@ Description
IMPORTANT NOTE : in the code some length checks are missing because certain IMPORTANT NOTE : in the code some length checks are missing because certain
instructions are called under the assumption that a certain number of bytes instructions are called under the assumption that a certain number of bytes
follow because it has already been garanteed before parsing the instructions. follow because it has already been guaranteed before parsing the instructions.
They just have to "refill" this credit if they consume extra bytes. This is They just have to "refill" this credit if they consume extra bytes. This is
an implementation design choice independant on the algorithm or encoding. an implementation design choice independent on the algorithm or encoding.
Byte sequences Byte sequences
......
...@@ -6,3 +6,5 @@ mmc-dev-parts.txt ...@@ -6,3 +6,5 @@ mmc-dev-parts.txt
- info on SD and MMC device partitions - info on SD and MMC device partitions
mmc-async-req.txt mmc-async-req.txt
- info on mmc asynchronous requests - info on mmc asynchronous requests
mmc-tools.txt
- info on mmc-utils tools
MMC tools introduction
======================
There is one MMC test tools called mmc-utils, which is maintained by Chris Ball,
you can find it at the below public git repository:
http://git.kernel.org/cgit/linux/kernel/git/cjb/mmc-utils.git/
Functions
=========
The mmc-utils tools can do the following:
- Print and parse extcsd data.
- Determine the eMMC writeprotect status.
- Set the eMMC writeprotect status.
- Set the eMMC data sector size to 4KB by disabling emulation.
- Create general purpose partition.
- Enable the enhanced user area.
- Enable write reliability per partition.
- Print the response to STATUS_SEND (CMD13).
- Enable the boot partition.
- Set Boot Bus Conditions.
- Enable the eMMC BKOPS feature.
- Permanently enable the eMMC H/W Reset feature.
- Permanently disable the eMMC H/W Reset feature.
- Send Sanitize command.
- Program authentication key for the device.
- Counter value for the rpmb device will be read to stdout.
- Read from rpmb device to output.
- Write to rpmb device from data file.
- Enable the eMMC cache feature.
- Disable the eMMC cache feature.
- Print and parse CID data.
- Print and parse CSD data.
- Print and parse SCR data.
...@@ -1256,7 +1256,7 @@ solution for a couple of reasons: ...@@ -1256,7 +1256,7 @@ solution for a couple of reasons:
7. SocketCAN resources 7. SocketCAN resources
----------------------- -----------------------
The Linux CAN / SocketCAN project ressources (project site / mailing list) The Linux CAN / SocketCAN project resources (project site / mailing list)
are referenced in the MAINTAINERS file in the Linux source tree. are referenced in the MAINTAINERS file in the Linux source tree.
Search for CAN NETWORK [LAYERS|DRIVERS]. Search for CAN NETWORK [LAYERS|DRIVERS].
......
...@@ -230,7 +230,7 @@ opcodes as defined in linux/filter.h stand for: ...@@ -230,7 +230,7 @@ opcodes as defined in linux/filter.h stand for:
mul 0, 4 A * <x> mul 0, 4 A * <x>
div 0, 4 A / <x> div 0, 4 A / <x>
mod 0, 4 A % <x> mod 0, 4 A % <x>
neg 0, 4 !A neg !A
and 0, 4 A & <x> and 0, 4 A & <x>
or 0, 4 A | <x> or 0, 4 A | <x>
xor 0, 4 A ^ <x> xor 0, 4 A ^ <x>
......
...@@ -98,7 +98,7 @@ pps_source_info_s as follows: ...@@ -98,7 +98,7 @@ pps_source_info_s as follows:
}; };
and then calling the function pps_register_source() in your and then calling the function pps_register_source() in your
intialization routine as follows: initialization routine as follows:
source = pps_register_source(&pps_ktimer_info, source = pps_register_source(&pps_ktimer_info,
PPS_CAPTUREASSERT | PPS_OFFSETASSERT); PPS_CAPTUREASSERT | PPS_OFFSETASSERT);
......
...@@ -126,9 +126,9 @@ vma based method: ...@@ -126,9 +126,9 @@ vma based method:
- no VM changes are needed - 'struct address_space' is left alone. - no VM changes are needed - 'struct address_space' is left alone.
- no registration of individual locks is needed: robust mutexes dont - no registration of individual locks is needed: robust mutexes don't
need any extra per-lock syscalls. Robust mutexes thus become a very need any extra per-lock syscalls. Robust mutexes thus become a very
lightweight primitive - so they dont force the application designer lightweight primitive - so they don't force the application designer
to do a hard choice between performance and robustness - robust to do a hard choice between performance and robustness - robust
mutexes are just as fast. mutexes are just as fast.
...@@ -202,7 +202,7 @@ and the remaining bits are for the TID. ...@@ -202,7 +202,7 @@ and the remaining bits are for the TID.
Testing, architecture support Testing, architecture support
----------------------------- -----------------------------
i've tested the new syscalls on x86 and x86_64, and have made sure the I've tested the new syscalls on x86 and x86_64, and have made sure the
parsing of the userspace list is robust [ ;-) ] even if the list is parsing of the userspace list is robust [ ;-) ] even if the list is
deliberately corrupted. deliberately corrupted.
......
...@@ -63,7 +63,7 @@ Release Date : Sat. Feb 9, 2013 17:00:00 PST 2013 - ...@@ -63,7 +63,7 @@ Release Date : Sat. Feb 9, 2013 17:00:00 PST 2013 -
Current Version : 06.506.00.00-rc1 Current Version : 06.506.00.00-rc1
Old Version : 06.504.01.00-rc1 Old Version : 06.504.01.00-rc1
1. Add 4k FastPath DIF support. 1. Add 4k FastPath DIF support.
2. Dont load DevHandle unless FastPath enabled. 2. Don't load DevHandle unless FastPath enabled.
3. Version and Changelog update. 3. Version and Changelog update.
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
Release Date : Mon. Oct 1, 2012 17:00:00 PST 2012 - Release Date : Mon. Oct 1, 2012 17:00:00 PST 2012 -
...@@ -105,7 +105,7 @@ Old Version : 00.00.06.12-rc1 ...@@ -105,7 +105,7 @@ Old Version : 00.00.06.12-rc1
1. Fix reglockFlags for degraded raid5/6 for MR 9360/9380. 1. Fix reglockFlags for degraded raid5/6 for MR 9360/9380.
2. Mask off flags in ioctl path to prevent memory scribble with older 2. Mask off flags in ioctl path to prevent memory scribble with older
MegaCLI versions. MegaCLI versions.
3. Remove poll_mode_io module paramater, sysfs node, and associated code. 3. Remove poll_mode_io module parameter, sysfs node, and associated code.
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
Release Date : Wed. Oct 5, 2011 17:00:00 PST 2010 - Release Date : Wed. Oct 5, 2011 17:00:00 PST 2010 -
(emaild-id:megaraidlinux@lsi.com) (emaild-id:megaraidlinux@lsi.com)
...@@ -199,7 +199,7 @@ Old Version : 00.00.04.31-rc1 ...@@ -199,7 +199,7 @@ Old Version : 00.00.04.31-rc1
1. Add the Online Controller Reset (OCR) to the Driver. 1. Add the Online Controller Reset (OCR) to the Driver.
OCR is the new feature for megaraid_sas driver which OCR is the new feature for megaraid_sas driver which
will allow the fw to do the chip reset which will not will allow the fw to do the chip reset which will not
affact the OS behavious. affect the OS behavior.
To add the OCR support, driver need to do: To add the OCR support, driver need to do:
a). reset the controller chips -- Xscale and Gen2 which a). reset the controller chips -- Xscale and Gen2 which
...@@ -233,7 +233,7 @@ Old Version : 00.00.04.31-rc1 ...@@ -233,7 +233,7 @@ Old Version : 00.00.04.31-rc1
failed state. Driver will kill adapter if can't bring back FW after the failed state. Driver will kill adapter if can't bring back FW after the
this three times reset. this three times reset.
4. Add the input parameter max_sectors to 1MB support to our GEN2 controller. 4. Add the input parameter max_sectors to 1MB support to our GEN2 controller.
customer can use the input paramenter max_sectors to add 1MB support to GEN2 customer can use the input parameter max_sectors to add 1MB support to GEN2
controller. controller.
1 Release Date : Thur. Oct 29, 2009 09:12:45 PST 2009 - 1 Release Date : Thur. Oct 29, 2009 09:12:45 PST 2009 -
...@@ -584,9 +584,9 @@ ii. Bug fix : Disable controller interrupt before firing INIT cmd to FW. ...@@ -584,9 +584,9 @@ ii. Bug fix : Disable controller interrupt before firing INIT cmd to FW.
2 Current Version : 00.00.02.04 2 Current Version : 00.00.02.04
3 Older Version : 00.00.02.04 3 Older Version : 00.00.02.04
i. Remove superflous instance_lock i. Remove superfluous instance_lock
gets rid of the otherwise superflous instance_lock and avoids an unsave gets rid of the otherwise superfluous instance_lock and avoids an unsafe
unsynchronized access in the error handler. unsynchronized access in the error handler.
- Christoph Hellwig <hch@lst.de> - Christoph Hellwig <hch@lst.de>
...@@ -620,7 +620,7 @@ i. Register 16 byte CDB capability with scsi midlayer ...@@ -620,7 +620,7 @@ i. Register 16 byte CDB capability with scsi midlayer
3 Older Version : 00.00.02.01 3 Older Version : 00.00.02.01
i. New template defined to represent each family of controllers (identified by processor used). i. New template defined to represent each family of controllers (identified by processor used).
The template will have defintions that will be initialised to appropritae values for a specific family of controllers. The template definition has four function pointers. During driver initialisation the function pointers will be set based on the controller family type. This change is done to support new controllers that has different processors and thus different register set. The template will have definitions that will be initialised to appropriate values for a specific family of controllers. The template definition has four function pointers. During driver initialisation the function pointers will be set based on the controller family type. This change is done to support new controllers that has different processors and thus different register set.
-Sumant Patro <Sumant.Patro@lsil.com> -Sumant Patro <Sumant.Patro@lsil.com>
...@@ -630,7 +630,7 @@ i. New template defined to represent each family of controllers (identified by p ...@@ -630,7 +630,7 @@ i. New template defined to represent each family of controllers (identified by p
i. Code reorganized to remove code duplication in megasas_build_cmd. i. Code reorganized to remove code duplication in megasas_build_cmd.
"There's a lot of duplicate code megasas_build_cmd. Move that out of the different codepathes and merge the reminder of megasas_build_cmd into megasas_queue_command" "There's a lot of duplicate code megasas_build_cmd. Move that out of the different codepaths and merge the reminder of megasas_build_cmd into megasas_queue_command"
- Christoph Hellwig <hch@lst.de> - Christoph Hellwig <hch@lst.de>
......
...@@ -50,7 +50,7 @@ be found at: ...@@ -50,7 +50,7 @@ be found at:
http://www.brocade.com/services-support/drivers-downloads/adapters/Linux.page http://www.brocade.com/services-support/drivers-downloads/adapters/Linux.page
and then click following respective util pacakge link and then click following respective util package link
Version Link Version Link
......
# Kernel Self-Protection
Kernel self-protection is the design and implementation of systems and
structures within the Linux kernel to protect against security flaws in
the kernel itself. This covers a wide range of issues, including removing
entire classes of bugs, blocking security flaw exploitation methods,
and actively detecting attack attempts. Not all topics are explored in
this document, but it should serve as a reasonable starting point and
answer any frequently asked questions. (Patches welcome, of course!)
In the worst-case scenario, we assume an unprivileged local attacker
has arbitrary read and write access to the kernel's memory. In many
cases, bugs being exploited will not provide this level of access,
but with systems in place that defend against the worst case we'll
cover the more limited cases as well. A higher bar, and one that should
still be kept in mind, is protecting the kernel against a _privileged_
local attacker, since the root user has access to a vastly increased
attack surface. (Especially when they have the ability to load arbitrary
kernel modules.)
The goals for successful self-protection systems would be that they
are effective, on by default, require no opt-in by developers, have no
performance impact, do not impede kernel debugging, and have tests. It
is uncommon that all these goals can be met, but it is worth explicitly
mentioning them, since these aspects need to be explored, dealt with,
and/or accepted.
## Attack Surface Reduction
The most fundamental defense against security exploits is to reduce the
areas of the kernel that can be used to redirect execution. This ranges
from limiting the exposed APIs available to userspace, making in-kernel
APIs hard to use incorrectly, minimizing the areas of writable kernel
memory, etc.
### Strict kernel memory permissions
When all of kernel memory is writable, it becomes trivial for attacks
to redirect execution flow. To reduce the availability of these targets
the kernel needs to protect its memory with a tight set of permissions.
#### Executable code and read-only data must not be writable
Any areas of the kernel with executable memory must not be writable.
While this obviously includes the kernel text itself, we must consider
all additional places too: kernel modules, JIT memory, etc. (There are
temporary exceptions to this rule to support things like instruction
alternatives, breakpoints, kprobes, etc. If these must exist in a
kernel, they are implemented in a way where the memory is temporarily
made writable during the update, and then returned to the original
permissions.)
In support of this are (the poorly named) CONFIG_DEBUG_RODATA and
CONFIG_DEBUG_SET_MODULE_RONX, which seek to make sure that code is not
writable, data is not executable, and read-only data is neither writable
nor executable.
#### Function pointers and sensitive variables must not be writable
Vast areas of kernel memory contain function pointers that are looked
up by the kernel and used to continue execution (e.g. descriptor/vector
tables, file/network/etc operation structures, etc). The number of these
variables must be reduced to an absolute minimum.
Many such variables can be made read-only by setting them "const"
so that they live in the .rodata section instead of the .data section
of the kernel, gaining the protection of the kernel's strict memory
permissions as described above.
For variables that are initialized once at __init time, these can
be marked with the (new and under development) __ro_after_init
attribute.
What remains are variables that are updated rarely (e.g. GDT). These
will need another infrastructure (similar to the temporary exceptions
made to kernel code mentioned above) that allow them to spend the rest
of their lifetime read-only. (For example, when being updated, only the
CPU thread performing the update would be given uninterruptible write
access to the memory.)
#### Segregation of kernel memory from userspace memory
The kernel must never execute userspace memory. The kernel must also never
access userspace memory without explicit expectation to do so. These
rules can be enforced either by support of hardware-based restrictions
(x86's SMEP/SMAP, ARM's PXN/PAN) or via emulation (ARM's Memory Domains).
By blocking userspace memory in this way, execution and data parsing
cannot be passed to trivially-controlled userspace memory, forcing
attacks to operate entirely in kernel memory.
### Reduced access to syscalls
One trivial way to eliminate many syscalls for 64-bit systems is building
without CONFIG_COMPAT. However, this is rarely a feasible scenario.
The "seccomp" system provides an opt-in feature made available to
userspace, which provides a way to reduce the number of kernel entry
points available to a running process. This limits the breadth of kernel
code that can be reached, possibly reducing the availability of a given
bug to an attack.
An area of improvement would be creating viable ways to keep access to
things like compat, user namespaces, BPF creation, and perf limited only
to trusted processes. This would keep the scope of kernel entry points
restricted to the more regular set of normally available to unprivileged
userspace.
### Restricting access to kernel modules
The kernel should never allow an unprivileged user the ability to
load specific kernel modules, since that would provide a facility to
unexpectedly extend the available attack surface. (The on-demand loading
of modules via their predefined subsystems, e.g. MODULE_ALIAS_*, is
considered "expected" here, though additional consideration should be
given even to these.) For example, loading a filesystem module via an
unprivileged socket API is nonsense: only the root or physically local
user should trigger filesystem module loading. (And even this can be up
for debate in some scenarios.)
To protect against even privileged users, systems may need to either
disable module loading entirely (e.g. monolithic kernel builds or
modules_disabled sysctl), or provide signed modules (e.g.
CONFIG_MODULE_SIG_FORCE, or dm-crypt with LoadPin), to keep from having
root load arbitrary kernel code via the module loader interface.
## Memory integrity
There are many memory structures in the kernel that are regularly abused
to gain execution control during an attack, By far the most commonly
understood is that of the stack buffer overflow in which the return
address stored on the stack is overwritten. Many other examples of this
kind of attack exist, and protections exist to defend against them.
### Stack buffer overflow
The classic stack buffer overflow involves writing past the expected end
of a variable stored on the stack, ultimately writing a controlled value
to the stack frame's stored return address. The most widely used defense
is the presence of a stack canary between the stack variables and the
return address (CONFIG_CC_STACKPROTECTOR), which is verified just before
the function returns. Other defenses include things like shadow stacks.
### Stack depth overflow
A less well understood attack is using a bug that triggers the
kernel to consume stack memory with deep function calls or large stack
allocations. With this attack it is possible to write beyond the end of
the kernel's preallocated stack space and into sensitive structures. Two
important changes need to be made for better protections: moving the
sensitive thread_info structure elsewhere, and adding a faulting memory
hole at the bottom of the stack to catch these overflows.
### Heap memory integrity
The structures used to track heap free lists can be sanity-checked during
allocation and freeing to make sure they aren't being used to manipulate
other memory areas.
### Counter integrity
Many places in the kernel use atomic counters to track object references
or perform similar lifetime management. When these counters can be made
to wrap (over or under) this traditionally exposes a use-after-free
flaw. By trapping atomic wrapping, this class of bug vanishes.
### Size calculation overflow detection
Similar to counter overflow, integer overflows (usually size calculations)
need to be detected at runtime to kill this class of bug, which
traditionally leads to being able to write past the end of kernel buffers.
## Statistical defenses
While many protections can be considered deterministic (e.g. read-only
memory cannot be written to), some protections provide only statistical
defense, in that an attack must gather enough information about a
running system to overcome the defense. While not perfect, these do
provide meaningful defenses.
### Canaries, blinding, and other secrets
It should be noted that things like the stack canary discussed earlier
are technically statistical defenses, since they rely on a (leakable)
secret value.
Blinding literal values for things like JITs, where the executable
contents may be partially under the control of userspace, need a similar
secret value.
It is critical that the secret values used must be separate (e.g.
different canary per stack) and high entropy (e.g. is the RNG actually
working?) in order to maximize their success.
### Kernel Address Space Layout Randomization (KASLR)
Since the location of kernel memory is almost always instrumental in
mounting a successful attack, making the location non-deterministic
raises the difficulty of an exploit. (Note that this in turn makes
the value of leaks higher, since they may be used to discover desired
memory locations.)
#### Text and module base
By relocating the physical and virtual base address of the kernel at
boot-time (CONFIG_RANDOMIZE_BASE), attacks needing kernel code will be
frustrated. Additionally, offsetting the module loading base address
means that even systems that load the same set of modules in the same
order every boot will not share a common base address with the rest of
the kernel text.
#### Stack base
If the base address of the kernel stack is not the same between processes,
or even not the same between syscalls, targets on or beyond the stack
become more difficult to locate.
#### Dynamic memory base
Much of the kernel's dynamic memory (e.g. kmalloc, vmalloc, etc) ends up
being relatively deterministic in layout due to the order of early-boot
initializations. If the base address of these areas is not the same
between boots, targeting them is frustrated, requiring a leak specific
to the region.
## Preventing Leaks
Since the locations of sensitive structures are the primary target for
attacks, it is important to defend against leaks of both kernel memory
addresses and kernel memory contents (since they may contain kernel
addresses or other sensitive things like canary values).
### Unique identifiers
Kernel memory addresses must never be used as identifiers exposed to
userspace. Instead, use an atomic counter, an idr, or similar unique
identifier.
### Memory initialization
Memory copied to userspace must always be fully initialized. If not
explicitly memset(), this will require changes to the compiler to make
sure structure holes are cleared.
### Memory poisoning
When releasing memory, it is best to poison the contents (clear stack on
syscall return, wipe heap memory on a free), to avoid reuse attacks that
rely on the old contents of memory. This frustrates many uninitialized
variable attacks, stack info leaks, heap info leaks, and use-after-free
attacks.
### Destination tracking
To help kill classes of bugs that result in kernel addresses being
written to userspace, the destination of writes needs to be tracked. If
the buffer is destined for userspace (e.g. seq_file backed /proc files),
it should automatically censor sensitive values.
...@@ -28,7 +28,7 @@ The serial core provides a few helper functions. This includes identifing ...@@ -28,7 +28,7 @@ The serial core provides a few helper functions. This includes identifing
the correct port structure (via uart_get_console) and decoding command line the correct port structure (via uart_get_console) and decoding command line
arguments (uart_parse_options). arguments (uart_parse_options).
There is also a helper function (uart_write_console) which performs a There is also a helper function (uart_console_write) which performs a
character by character write, translating newlines to CRLF sequences. character by character write, translating newlines to CRLF sequences.
Driver writers are recommended to use this function rather than implementing Driver writers are recommended to use this function rather than implementing
their own version. their own version.
...@@ -41,27 +41,23 @@ It is the responsibility of the low level hardware driver to perform the ...@@ -41,27 +41,23 @@ It is the responsibility of the low level hardware driver to perform the
necessary locking using port->lock. There are some exceptions (which necessary locking using port->lock. There are some exceptions (which
are described in the uart_ops listing below.) are described in the uart_ops listing below.)
There are three locks. A per-port spinlock, a per-port tmpbuf semaphore, There are two locks. A per-port spinlock, and an overall semaphore.
and an overall semaphore.
From the core driver perspective, the port->lock locks the following From the core driver perspective, the port->lock locks the following
data: data:
port->mctrl port->mctrl
port->icount port->icount
info->xmit.head (circ->head) port->state->xmit.head (circ_buf->head)
info->xmit.tail (circ->tail) port->state->xmit.tail (circ_buf->tail)
The low level driver is free to use this lock to provide any additional The low level driver is free to use this lock to provide any additional
locking. locking.
The core driver uses the info->tmpbuf_sem lock to prevent multi-threaded
access to the info->tmpbuf bouncebuffer used for port writes.
The port_sem semaphore is used to protect against ports being added/ The port_sem semaphore is used to protect against ports being added/
removed or reconfigured at inappropriate times. Since v2.6.27, this removed or reconfigured at inappropriate times. Since v2.6.27, this
semaphore has been the 'mutex' member of the tty_port struct, and semaphore has been the 'mutex' member of the tty_port struct, and
commonly referred to as the port mutex (or port->mutex). commonly referred to as the port mutex.
uart_ops uart_ops
...@@ -135,6 +131,24 @@ hardware. ...@@ -135,6 +131,24 @@ hardware.
Interrupts: locally disabled. Interrupts: locally disabled.
This call must not sleep This call must not sleep
throttle(port)
Notify the serial driver that input buffers for the line discipline are
close to full, and it should somehow signal that no more characters
should be sent to the serial port.
This will be called only if hardware assisted flow control is enabled.
Locking: serialized with .unthrottle() and termios modification by the
tty layer.
unthrottle(port)
Notify the serial driver that characters can now be sent to the serial
port without fear of overrunning the input buffers of the line
disciplines.
This will be called only if hardware assisted flow control is enabled.
Locking: serialized with .throttle() and termios modification by the
tty layer.
send_xchar(port,ch) send_xchar(port,ch)
Transmit a high priority character, even if the port is stopped. Transmit a high priority character, even if the port is stopped.
This is used to implement XON/XOFF flow control and tcflow(). If This is used to implement XON/XOFF flow control and tcflow(). If
...@@ -172,9 +186,7 @@ hardware. ...@@ -172,9 +186,7 @@ hardware.
should be terminated when another call is made with a zero should be terminated when another call is made with a zero
ctl. ctl.
Locking: none. Locking: caller holds tty_port->mutex
Interrupts: caller dependent.
This call must not sleep
startup(port) startup(port)
Grab any interrupt resources and initialise any low level driver Grab any interrupt resources and initialise any low level driver
...@@ -192,7 +204,7 @@ hardware. ...@@ -192,7 +204,7 @@ hardware.
RTS nor DTR; this will have already been done via a separate RTS nor DTR; this will have already been done via a separate
call to set_mctrl. call to set_mctrl.
Drivers must not access port->info once this call has completed. Drivers must not access port->state once this call has completed.
This method will only be called when there are no more users of This method will only be called when there are no more users of
this port. this port.
...@@ -204,7 +216,7 @@ hardware. ...@@ -204,7 +216,7 @@ hardware.
Flush any write buffers, reset any DMA state and stop any Flush any write buffers, reset any DMA state and stop any
ongoing DMA transfers. ongoing DMA transfers.
This will be called whenever the port->info->xmit circular This will be called whenever the port->state->xmit circular
buffer is cleared. buffer is cleared.
Locking: port->lock taken. Locking: port->lock taken.
...@@ -250,10 +262,15 @@ hardware. ...@@ -250,10 +262,15 @@ hardware.
Other flags may be used (eg, xon/xoff characters) if your Other flags may be used (eg, xon/xoff characters) if your
hardware supports hardware "soft" flow control. hardware supports hardware "soft" flow control.
Locking: caller holds port->mutex Locking: caller holds tty_port->mutex
Interrupts: caller dependent. Interrupts: caller dependent.
This call must not sleep This call must not sleep
set_ldisc(port,termios)
Notifier for discipline change. See Documentation/serial/tty.txt.
Locking: caller holds tty_port->mutex
pm(port,state,oldstate) pm(port,state,oldstate)
Perform any power management related activities on the specified Perform any power management related activities on the specified
port. State indicates the new state (defined by port. State indicates the new state (defined by
...@@ -371,7 +388,7 @@ uart_get_baud_rate(port,termios,old,min,max) ...@@ -371,7 +388,7 @@ uart_get_baud_rate(port,termios,old,min,max)
Interrupts: n/a Interrupts: n/a
uart_get_divisor(port,baud) uart_get_divisor(port,baud)
Return the divsor (baud_base / baud) for the specified baud Return the divisor (baud_base / baud) for the specified baud
rate, appropriately rounded. rate, appropriately rounded.
If 38400 baud and custom divisor is selected, return the If 38400 baud and custom divisor is selected, return the
...@@ -449,11 +466,12 @@ mctrl_gpio_init(port, idx): ...@@ -449,11 +466,12 @@ mctrl_gpio_init(port, idx):
mctrl_gpio_free(dev, gpios): mctrl_gpio_free(dev, gpios):
This will free the requested gpios in mctrl_gpio_init(). This will free the requested gpios in mctrl_gpio_init().
As devm_* function are used, there's generally no need to call As devm_* functions are used, there's generally no need to call
this function. this function.
mctrl_gpio_to_gpiod(gpios, gidx) mctrl_gpio_to_gpiod(gpios, gidx)
This returns the gpio structure associated to the modem line index. This returns the gpio_desc structure associated to the modem line
index.
mctrl_gpio_set(gpios, mctrl): mctrl_gpio_set(gpios, mctrl):
This will sets the gpios according to the mctrl state. This will sets the gpios according to the mctrl state.
......
...@@ -212,7 +212,7 @@ it is currently registered in that slot. This is in case the slot has been ...@@ -212,7 +212,7 @@ it is currently registered in that slot. This is in case the slot has been
overwritten since you registered it. overwritten since you registered it.
The Magic SysRQ system works by registering key operations against a key op The Magic SysRQ system works by registering key operations against a key op
lookup table, which is defined in 'drivers/char/sysrq.c'. This key table has lookup table, which is defined in 'drivers/tty/sysrq.c'. This key table has
a number of operations registered into it at compile time, but is mutable, a number of operations registered into it at compile time, but is mutable,
and 2 functions are exported for interface to it: and 2 functions are exported for interface to it:
register_sysrq_key and unregister_sysrq_key. register_sysrq_key and unregister_sysrq_key.
......
...@@ -28,9 +28,9 @@ several reasons why such integration is hard/impossible: ...@@ -28,9 +28,9 @@ several reasons why such integration is hard/impossible:
- the unpredictable [O(N)] overhead of cascading leads to delays which - the unpredictable [O(N)] overhead of cascading leads to delays which
necessitate a more complex handling of high resolution timers, which necessitate a more complex handling of high resolution timers, which
in turn decreases robustness. Such a design still led to rather large in turn decreases robustness. Such a design still leads to rather large
timing inaccuracies. Cascading is a fundamental property of the timer timing inaccuracies. Cascading is a fundamental property of the timer
wheel concept, it cannot be 'designed out' without unevitably wheel concept, it cannot be 'designed out' without inevitably
degrading other portions of the timers.c code in an unacceptable way. degrading other portions of the timers.c code in an unacceptable way.
- the implementation of the current posix-timer subsystem on top of - the implementation of the current posix-timer subsystem on top of
...@@ -119,7 +119,7 @@ was not really a win, due to the different data structures. Also, the ...@@ -119,7 +119,7 @@ was not really a win, due to the different data structures. Also, the
hrtimer functions now have clearer behavior and clearer names - such as hrtimer functions now have clearer behavior and clearer names - such as
hrtimer_try_to_cancel() and hrtimer_cancel() [which are roughly hrtimer_try_to_cancel() and hrtimer_cancel() [which are roughly
equivalent to del_timer() and del_timer_sync()] - so there's no direct equivalent to del_timer() and del_timer_sync()] - so there's no direct
1:1 mapping between them on the algorithmical level, and thus no real 1:1 mapping between them on the algorithmic level, and thus no real
potential for code sharing either. potential for code sharing either.
Basic data types: every time value, absolute or relative, is in a Basic data types: every time value, absolute or relative, is in a
......
...@@ -50,7 +50,7 @@ the driver. What to do then? ...@@ -50,7 +50,7 @@ the driver. What to do then?
cx88-cards.c. If that worked, mail me your changes as unified cx88-cards.c. If that worked, mail me your changes as unified
diff ("diff -u"). diff ("diff -u").
(3) Or you can mail me the config information. I need at least the (3) Or you can mail me the config information. I need at least the
following informations to add the card: following information to add the card:
* the PCI Subsystem ID ("0070:3400" from the line above, * the PCI Subsystem ID ("0070:3400" from the line above,
"lspci -v" output is fine too). "lspci -v" output is fine too).
......
...@@ -55,7 +55,7 @@ receiver chips. Some boards use the i2c bus instead of the gpio pins ...@@ -55,7 +55,7 @@ receiver chips. Some boards use the i2c bus instead of the gpio pins
to connect the mux chip. to connect the mux chip.
As mentioned above, there is a array which holds the required As mentioned above, there is a array which holds the required
informations for each known board. You basically have to create a new information for each known board. You basically have to create a new
line for your board. The important fields are these two: line for your board. The important fields are these two:
struct tvcard struct tvcard
......
...@@ -220,7 +220,7 @@ resulting effect on persistent huge page allocation is as follows: ...@@ -220,7 +220,7 @@ resulting effect on persistent huge page allocation is as follows:
node list of "all" with numactl --interleave or --membind [-m] to achieve node list of "all" with numactl --interleave or --membind [-m] to achieve
interleaving over all nodes in the system or cpuset. interleaving over all nodes in the system or cpuset.
4) Any task mempolicy specifed--e.g., using numactl--will be constrained by 4) Any task mempolicy specified--e.g., using numactl--will be constrained by
the resource limits of any cpuset in which the task runs. Thus, there will the resource limits of any cpuset in which the task runs. Thus, there will
be no way for a task with non-default policy running in a cpuset with a be no way for a task with non-default policy running in a cpuset with a
subset of the system nodes to allocate huge pages outside the cpuset subset of the system nodes to allocate huge pages outside the cpuset
...@@ -275,10 +275,10 @@ This command mounts a (pseudo) filesystem of type hugetlbfs on the directory ...@@ -275,10 +275,10 @@ This command mounts a (pseudo) filesystem of type hugetlbfs on the directory
options sets the owner and group of the root of the file system. By default options sets the owner and group of the root of the file system. By default
the uid and gid of the current process are taken. The mode option sets the the uid and gid of the current process are taken. The mode option sets the
mode of root of file system to value & 01777. This value is given in octal. mode of root of file system to value & 01777. This value is given in octal.
By default the value 0755 is picked. If the paltform supports multiple huge By default the value 0755 is picked. If the platform supports multiple huge
page sizes, the pagesize option can be used to specify the huge page size and page sizes, the pagesize option can be used to specify the huge page size and
associated pool. pagesize is specified in bytes. If pagesize is not specified associated pool. pagesize is specified in bytes. If pagesize is not specified
the paltform's default huge page size and associated pool will be used. The the platform's default huge page size and associated pool will be used. The
size option sets the maximum value of memory (huge pages) allowed for that size option sets the maximum value of memory (huge pages) allowed for that
filesystem (/mnt/huge). The size option can be specified in bytes, or as a filesystem (/mnt/huge). The size option can be specified in bytes, or as a
percentage of the specified huge page pool (nr_hugepages). The size is percentage of the specified huge page pool (nr_hugepages). The size is
......
...@@ -62,7 +62,7 @@ There are four components to pagemap: ...@@ -62,7 +62,7 @@ There are four components to pagemap:
14. SWAPBACKED 14. SWAPBACKED
15. COMPOUND_HEAD 15. COMPOUND_HEAD
16. COMPOUND_TAIL 16. COMPOUND_TAIL
16. HUGE 17. HUGE
18. UNEVICTABLE 18. UNEVICTABLE
19. HWPOISON 19. HWPOISON
20. NOPAGE 20. NOPAGE
......
...@@ -136,7 +136,7 @@ A: MPX-enabled application will possibly create a lot of bounds tables in ...@@ -136,7 +136,7 @@ A: MPX-enabled application will possibly create a lot of bounds tables in
If we were to preallocate them for the 128TB of user virtual address If we were to preallocate them for the 128TB of user virtual address
space, we would need to reserve 512TB+2GB, which is larger than the space, we would need to reserve 512TB+2GB, which is larger than the
entire virtual address space today. This means they can not be reserved entire virtual address space today. This means they can not be reserved
ahead of time. Also, a single process's pre-popualated bounds directory ahead of time. Also, a single process's pre-populated bounds directory
consumes 2GB of virtual *AND* physical memory. IOW, it's completely consumes 2GB of virtual *AND* physical memory. IOW, it's completely
infeasible to prepopulate bounds directories. infeasible to prepopulate bounds directories.
...@@ -151,7 +151,7 @@ A: This would work if we could hook the site of each and every memory ...@@ -151,7 +151,7 @@ A: This would work if we could hook the site of each and every memory
these calls. these calls.
Q: Could a bounds fault be handed to userspace and the tables allocated Q: Could a bounds fault be handed to userspace and the tables allocated
there in a signal handler intead of in the kernel? there in a signal handler instead of in the kernel?
A: mmap() is not on the list of safe async handler functions and even A: mmap() is not on the list of safe async handler functions and even
if mmap() would work it still requires locking or nasty tricks to if mmap() would work it still requires locking or nasty tricks to
keep track of the allocation state there. keep track of the allocation state there.
......
...@@ -215,7 +215,7 @@ in xillybus_core.c as follows: ...@@ -215,7 +215,7 @@ in xillybus_core.c as follows:
choice is a non-zero value, to match standard UNIX behavior. choice is a non-zero value, to match standard UNIX behavior.
* synchronous: A non-zero value means that the pipe is synchronous. See * synchronous: A non-zero value means that the pipe is synchronous. See
Syncronization above. Synchronization above.
* bufsize: Each DMA buffer's size. Always a power of two. * bufsize: Each DMA buffer's size. Always a power of two.
......
...@@ -207,7 +207,7 @@ kernel.org网站的pub/linux/kernel/v2.6/目录下找到它。它的开发遵循 ...@@ -207,7 +207,7 @@ kernel.org网站的pub/linux/kernel/v2.6/目录下找到它。它的开发遵循
- 每当一个新版本的内核被发布,为期两周的集成窗口将被打开。在这段时间里 - 每当一个新版本的内核被发布,为期两周的集成窗口将被打开。在这段时间里
维护者可以向Linus提交大段的修改,通常这些修改已经被放到-mm内核中几个 维护者可以向Linus提交大段的修改,通常这些修改已经被放到-mm内核中几个
星期了。提交大量修改的首选方式是使用git工具(内核的代码版本管理工具 星期了。提交大量修改的首选方式是使用git工具(内核的代码版本管理工具
,更多的信息可以在http://git.or.cz/获取),不过使用普通补丁也是可以 ,更多的信息可以在http://git-scm.com/获取),不过使用普通补丁也是可以
的。 的。
- 两个星期以后-rc1版本内核发布。之后只有不包含可能影响整个内核稳定性的 - 两个星期以后-rc1版本内核发布。之后只有不包含可能影响整个内核稳定性的
新功能的补丁才可能被接受。请注意一个全新的驱动程序(或者文件系统)有 新功能的补丁才可能被接受。请注意一个全新的驱动程序(或者文件系统)有
...@@ -218,8 +218,6 @@ kernel.org网站的pub/linux/kernel/v2.6/目录下找到它。它的开发遵循 ...@@ -218,8 +218,6 @@ kernel.org网站的pub/linux/kernel/v2.6/目录下找到它。它的开发遵循
时,一个新的-rc版本就会被发布。计划是每周都发布新的-rc版本。 时,一个新的-rc版本就会被发布。计划是每周都发布新的-rc版本。
- 这个过程一直持续下去直到内核被认为达到足够稳定的状态,持续时间大概是 - 这个过程一直持续下去直到内核被认为达到足够稳定的状态,持续时间大概是
6个星期。 6个星期。
- 以下地址跟踪了在每个-rc发布中发现的退步列表:
http://kernelnewbies.org/known_regressions
关于内核发布,值得一提的是Andrew Morton在linux-kernel邮件列表中如是说: 关于内核发布,值得一提的是Andrew Morton在linux-kernel邮件列表中如是说:
“没有人知道新内核何时会被发布,因为发布是根据已知bug的情况来决定 “没有人知道新内核何时会被发布,因为发布是根据已知bug的情况来决定
......
...@@ -8,7 +8,7 @@ or if there is a problem with the translation. ...@@ -8,7 +8,7 @@ or if there is a problem with the translation.
M: Will Deacon <will.deacon@arm.com> M: Will Deacon <will.deacon@arm.com>
zh_CN: Fu Wei <wefu@redhat.com> zh_CN: Fu Wei <wefu@redhat.com>
C: 1926e54f115725a9248d0c4c65c22acaf94de4c4 C: 55f058e7574c3615dea4615573a19bdb258696c6
--------------------------------------------------------------------- ---------------------------------------------------------------------
Documentation/arm64/booting.txt 的中文翻译 Documentation/arm64/booting.txt 的中文翻译
...@@ -20,7 +20,7 @@ Documentation/arm64/booting.txt 的中文翻译 ...@@ -20,7 +20,7 @@ Documentation/arm64/booting.txt 的中文翻译
中文版维护者: 傅炜 Fu Wei <wefu@redhat.com> 中文版维护者: 傅炜 Fu Wei <wefu@redhat.com>
中文版翻译者: 傅炜 Fu Wei <wefu@redhat.com> 中文版翻译者: 傅炜 Fu Wei <wefu@redhat.com>
中文版校译者: 傅炜 Fu Wei <wefu@redhat.com> 中文版校译者: 傅炜 Fu Wei <wefu@redhat.com>
本文翻译提交时的 Git 检出点为: 1926e54f115725a9248d0c4c65c22acaf94de4c4 本文翻译提交时的 Git 检出点为: 55f058e7574c3615dea4615573a19bdb258696c6
以下为正文 以下为正文
--------------------------------------------------------------------- ---------------------------------------------------------------------
...@@ -125,18 +125,22 @@ AArch64 内核当前没有提供自解压代码,因此如果使用了压缩内 ...@@ -125,18 +125,22 @@ AArch64 内核当前没有提供自解压代码,因此如果使用了压缩内
1 - 4K 1 - 4K
2 - 16K 2 - 16K
3 - 64K 3 - 64K
位 3-63: 保留。 位 3: 内核物理位置
0 - 2MB 对齐基址应尽量靠近内存起始处,因为
其基址以下的内存无法通过线性映射访问
1 - 2MB 对齐基址可以在物理内存的任意位置
位 4-63: 保留。
- 当 image_size 为零时,引导装载程序应试图在内核映像末尾之后尽可能 - 当 image_size 为零时,引导装载程序应试图在内核映像末尾之后尽可能
多地保留空闲内存供内核直接使用。对内存空间的需求量因所选定的内核 多地保留空闲内存供内核直接使用。对内存空间的需求量因所选定的内核
特性而异, 并无实际限制。 特性而异, 并无实际限制。
内核映像必须被放置在靠近可用系统内存起始的 2MB 对齐为基址的 内核映像必须被放置在任意一个可用系统内存 2MB 对齐基址的 text_offset
text_offset 字节处,并从该处被调用。当前,对 Linux 来说在此基址以下的 字节处,并从该处被调用。2MB 对齐基址和内核映像起始地址之间的区域对于
内存是无法使用的,因此强烈建议将系统内存的起始作为这个基址。2MB 对齐 内核来说没有特殊意义,且可能被用于其他目的。
基址和内核映像起始地址之间的区域对于内核来说没有特殊意义,且可能被
用于其他目的。
从映像起始地址算起,最少必须准备 image_size 字节的空闲内存供内核使用。 从映像起始地址算起,最少必须准备 image_size 字节的空闲内存供内核使用。
注: v4.6 之前的版本无法使用内核映像物理偏移以下的内存,所以当时建议
将映像尽量放置在靠近系统内存起始的地方。
任何提供给内核的内存(甚至在映像起始地址之前),若未从内核中标记为保留 任何提供给内核的内存(甚至在映像起始地址之前),若未从内核中标记为保留
(如在设备树(dtb)的 memreserve 区域),都将被认为对内核是可用。 (如在设备树(dtb)的 memreserve 区域),都将被认为对内核是可用。
......
...@@ -76,4 +76,13 @@ config SAMPLE_CONFIGFS ...@@ -76,4 +76,13 @@ config SAMPLE_CONFIGFS
help help
Builds a sample configfs interface. Builds a sample configfs interface.
config SAMPLE_CONNECTOR
tristate "Build connector sample -- loadable modules only"
depends on CONNECTOR && m
help
When enabled, this builds both a sample kernel module for
the connector interface and a user space tool to communicate
with it.
See also Documentation/connector/connector.txt
endif # SAMPLES endif # SAMPLES
...@@ -2,4 +2,4 @@ ...@@ -2,4 +2,4 @@
obj-$(CONFIG_SAMPLES) += kobject/ kprobes/ trace_events/ livepatch/ \ obj-$(CONFIG_SAMPLES) += kobject/ kprobes/ trace_events/ livepatch/ \
hw_breakpoint/ kfifo/ kdb/ hidraw/ rpmsg/ seccomp/ \ hw_breakpoint/ kfifo/ kdb/ hidraw/ rpmsg/ seccomp/ \
configfs/ v4l/ configfs/ connector/ v4l/
ifneq ($(CONFIG_CONNECTOR),) obj-$(CONFIG_SAMPLE_CONNECTOR) += cn_test.o
obj-m += cn_test.o
endif
# List of programs to build # List of programs to build
ifdef CONFIG_SAMPLE_CONNECTOR
hostprogs-y := ucon hostprogs-y := ucon
endif
# Tell kbuild to always build the programs # Tell kbuild to always build the programs
always := $(hostprogs-y) always := $(hostprogs-y)
......
...@@ -42,8 +42,10 @@ ...@@ -42,8 +42,10 @@
#include <unistd.h> #include <unistd.h>
#include <limits.h> #include <limits.h>
#include <errno.h> #include <errno.h>
#include <getopt.h>
#include <sys/types.h> #include <sys/types.h>
#include <sys/wait.h> #include <sys/wait.h>
#include <time.h>
/* exitstatus is used to keep track of any failing calls to kernel-doc, /* exitstatus is used to keep track of any failing calls to kernel-doc,
* but execution continues. */ * but execution continues. */
...@@ -68,12 +70,23 @@ FILELINE * docsection; ...@@ -68,12 +70,23 @@ FILELINE * docsection;
#define KERNELDOCPATH "scripts/" #define KERNELDOCPATH "scripts/"
#define KERNELDOC "kernel-doc" #define KERNELDOC "kernel-doc"
#define DOCBOOK "-docbook" #define DOCBOOK "-docbook"
#define RST "-rst"
#define LIST "-list" #define LIST "-list"
#define FUNCTION "-function" #define FUNCTION "-function"
#define NOFUNCTION "-nofunction" #define NOFUNCTION "-nofunction"
#define NODOCSECTIONS "-no-doc-sections" #define NODOCSECTIONS "-no-doc-sections"
#define SHOWNOTFOUND "-show-not-found" #define SHOWNOTFOUND "-show-not-found"
enum file_format {
FORMAT_AUTO,
FORMAT_DOCBOOK,
FORMAT_RST,
};
static enum file_format file_format = FORMAT_AUTO;
#define KERNELDOC_FORMAT (file_format == FORMAT_RST ? RST : DOCBOOK)
static char *srctree, *kernsrctree; static char *srctree, *kernsrctree;
static char **all_list = NULL; static char **all_list = NULL;
...@@ -95,7 +108,7 @@ static void consume_symbol(const char *sym) ...@@ -95,7 +108,7 @@ static void consume_symbol(const char *sym)
static void usage (void) static void usage (void)
{ {
fprintf(stderr, "Usage: docproc {doc|depend} file\n"); fprintf(stderr, "Usage: docproc [{--docbook|--rst}] {doc|depend} file\n");
fprintf(stderr, "Input is read from file.tmpl. Output is sent to stdout\n"); fprintf(stderr, "Input is read from file.tmpl. Output is sent to stdout\n");
fprintf(stderr, "doc: frontend when generating kernel documentation\n"); fprintf(stderr, "doc: frontend when generating kernel documentation\n");
fprintf(stderr, "depend: generate list of files referenced within file\n"); fprintf(stderr, "depend: generate list of files referenced within file\n");
...@@ -242,7 +255,7 @@ static void find_export_symbols(char * filename) ...@@ -242,7 +255,7 @@ static void find_export_symbols(char * filename)
/* /*
* Document all external or internal functions in a file. * Document all external or internal functions in a file.
* Call kernel-doc with following parameters: * Call kernel-doc with following parameters:
* kernel-doc -docbook -nofunction function_name1 filename * kernel-doc [-docbook|-rst] -nofunction function_name1 filename
* Function names are obtained from all the src files * Function names are obtained from all the src files
* by find_export_symbols. * by find_export_symbols.
* intfunc uses -nofunction * intfunc uses -nofunction
...@@ -263,7 +276,7 @@ static void docfunctions(char * filename, char * type) ...@@ -263,7 +276,7 @@ static void docfunctions(char * filename, char * type)
exit(1); exit(1);
} }
vec[idx++] = KERNELDOC; vec[idx++] = KERNELDOC;
vec[idx++] = DOCBOOK; vec[idx++] = KERNELDOC_FORMAT;
vec[idx++] = NODOCSECTIONS; vec[idx++] = NODOCSECTIONS;
for (i=0; i < symfilecnt; i++) { for (i=0; i < symfilecnt; i++) {
struct symfile * sym = &symfilelist[i]; struct symfile * sym = &symfilelist[i];
...@@ -275,6 +288,9 @@ static void docfunctions(char * filename, char * type) ...@@ -275,6 +288,9 @@ static void docfunctions(char * filename, char * type)
} }
vec[idx++] = filename; vec[idx++] = filename;
vec[idx] = NULL; vec[idx] = NULL;
if (file_format == FORMAT_RST)
printf(".. %s\n", filename);
else
printf("<!-- %s -->\n", filename); printf("<!-- %s -->\n", filename);
exec_kernel_doc(vec); exec_kernel_doc(vec);
fflush(stdout); fflush(stdout);
...@@ -294,7 +310,7 @@ static void singfunc(char * filename, char * line) ...@@ -294,7 +310,7 @@ static void singfunc(char * filename, char * line)
int i, idx = 0; int i, idx = 0;
int startofsym = 1; int startofsym = 1;
vec[idx++] = KERNELDOC; vec[idx++] = KERNELDOC;
vec[idx++] = DOCBOOK; vec[idx++] = KERNELDOC_FORMAT;
vec[idx++] = SHOWNOTFOUND; vec[idx++] = SHOWNOTFOUND;
/* Split line up in individual parameters preceded by FUNCTION */ /* Split line up in individual parameters preceded by FUNCTION */
...@@ -343,7 +359,7 @@ static void docsect(char *filename, char *line) ...@@ -343,7 +359,7 @@ static void docsect(char *filename, char *line)
free(s); free(s);
vec[0] = KERNELDOC; vec[0] = KERNELDOC;
vec[1] = DOCBOOK; vec[1] = KERNELDOC_FORMAT;
vec[2] = SHOWNOTFOUND; vec[2] = SHOWNOTFOUND;
vec[3] = FUNCTION; vec[3] = FUNCTION;
vec[4] = line; vec[4] = line;
...@@ -430,6 +446,32 @@ static void find_all_symbols(char *filename) ...@@ -430,6 +446,32 @@ static void find_all_symbols(char *filename)
} }
} }
/*
* Terminate s at first space, if any. If there was a space, return pointer to
* the character after that. Otherwise, return pointer to the terminating NUL.
*/
static char *chomp(char *s)
{
while (*s && !isspace(*s))
s++;
if (*s)
*s++ = '\0';
return s;
}
/* Return pointer to directive content, or NULL if not a directive. */
static char *is_directive(char *line)
{
if (file_format == FORMAT_DOCBOOK && line[0] == '!')
return line + 1;
else if (file_format == FORMAT_RST && !strncmp(line, ".. !", 4))
return line + 4;
return NULL;
}
/* /*
* Parse file, calling action specific functions for: * Parse file, calling action specific functions for:
* 1) Lines containing !E * 1) Lines containing !E
...@@ -443,63 +485,75 @@ static void find_all_symbols(char *filename) ...@@ -443,63 +485,75 @@ static void find_all_symbols(char *filename)
static void parse_file(FILE *infile) static void parse_file(FILE *infile)
{ {
char line[MAXLINESZ]; char line[MAXLINESZ];
char * s; char *p, *s;
while (fgets(line, MAXLINESZ, infile)) { while (fgets(line, MAXLINESZ, infile)) {
if (line[0] == '!') { p = is_directive(line);
s = line + 2; if (!p) {
switch (line[1]) { defaultline(line);
continue;
}
switch (*p++) {
case 'E': case 'E':
while (*s && !isspace(*s)) s++; chomp(p);
*s = '\0'; externalfunctions(p);
externalfunctions(line+2);
break; break;
case 'I': case 'I':
while (*s && !isspace(*s)) s++; chomp(p);
*s = '\0'; internalfunctions(p);
internalfunctions(line+2);
break; break;
case 'D': case 'D':
while (*s && !isspace(*s)) s++; chomp(p);
*s = '\0'; symbolsonly(p);
symbolsonly(line+2);
break; break;
case 'F': case 'F':
/* filename */ /* filename */
while (*s && !isspace(*s)) s++; s = chomp(p);
*s++ = '\0';
/* function names */ /* function names */
while (isspace(*s)) while (isspace(*s))
s++; s++;
singlefunctions(line +2, s); singlefunctions(p, s);
break; break;
case 'P': case 'P':
/* filename */ /* filename */
while (*s && !isspace(*s)) s++; s = chomp(p);
*s++ = '\0';
/* DOC: section name */ /* DOC: section name */
while (isspace(*s)) while (isspace(*s))
s++; s++;
docsection(line + 2, s); docsection(p, s);
break; break;
case 'C': case 'C':
while (*s && !isspace(*s)) s++; chomp(p);
*s = '\0';
if (findall) if (findall)
findall(line+2); findall(p);
break; break;
default: default:
defaultline(line); defaultline(line);
} }
} else {
defaultline(line);
}
} }
fflush(stdout); fflush(stdout);
} }
/*
* Is this a RestructuredText template? Answer the question by seeing if its
* name ends in ".rst".
*/
static int is_rst(const char *file)
{
char *dot = strrchr(file, '.');
return dot && !strcmp(dot + 1, "rst");
}
enum opts {
OPT_DOCBOOK,
OPT_RST,
OPT_HELP,
};
int main(int argc, char *argv[]) int main(int argc, char *argv[])
{ {
const char *subcommand, *filename;
FILE * infile; FILE * infile;
int i; int i;
...@@ -509,19 +563,66 @@ int main(int argc, char *argv[]) ...@@ -509,19 +563,66 @@ int main(int argc, char *argv[])
kernsrctree = getenv("KBUILD_SRC"); kernsrctree = getenv("KBUILD_SRC");
if (!kernsrctree || !*kernsrctree) if (!kernsrctree || !*kernsrctree)
kernsrctree = srctree; kernsrctree = srctree;
if (argc != 3) {
for (;;) {
int c;
struct option opts[] = {
{ "docbook", no_argument, NULL, OPT_DOCBOOK },
{ "rst", no_argument, NULL, OPT_RST },
{ "help", no_argument, NULL, OPT_HELP },
{}
};
c = getopt_long_only(argc, argv, "", opts, NULL);
if (c == -1)
break;
switch (c) {
case OPT_DOCBOOK:
file_format = FORMAT_DOCBOOK;
break;
case OPT_RST:
file_format = FORMAT_RST;
break;
case OPT_HELP:
usage();
return 0;
default:
case '?':
usage();
return 1;
}
}
argc -= optind;
argv += optind;
if (argc != 2) {
usage(); usage();
exit(1); exit(1);
} }
subcommand = argv[0];
filename = argv[1];
if (file_format == FORMAT_AUTO)
file_format = is_rst(filename) ? FORMAT_RST : FORMAT_DOCBOOK;
/* Open file, exit on error */ /* Open file, exit on error */
infile = fopen(argv[2], "r"); infile = fopen(filename, "r");
if (infile == NULL) { if (infile == NULL) {
fprintf(stderr, "docproc: "); fprintf(stderr, "docproc: ");
perror(argv[2]); perror(filename);
exit(2); exit(2);
} }
if (strcmp("doc", argv[1]) == 0) { if (strcmp("doc", subcommand) == 0) {
if (file_format == FORMAT_RST) {
time_t t = time(NULL);
printf(".. generated from %s by docproc %s\n",
filename, ctime(&t));
}
/* Need to do this in two passes. /* Need to do this in two passes.
* First pass is used to collect all symbols exported * First pass is used to collect all symbols exported
* in the various files; * in the various files;
...@@ -557,10 +658,10 @@ int main(int argc, char *argv[]) ...@@ -557,10 +658,10 @@ int main(int argc, char *argv[])
fprintf(stderr, "Warning: didn't use docs for %s\n", fprintf(stderr, "Warning: didn't use docs for %s\n",
all_list[i]); all_list[i]);
} }
} else if (strcmp("depend", argv[1]) == 0) { } else if (strcmp("depend", subcommand) == 0) {
/* Create first part of dependency chain /* Create first part of dependency chain
* file.tmpl */ * file.tmpl */
printf("%s\t", argv[2]); printf("%s\t", filename);
defaultline = noaction; defaultline = noaction;
internalfunctions = adddep; internalfunctions = adddep;
externalfunctions = adddep; externalfunctions = adddep;
...@@ -571,7 +672,7 @@ int main(int argc, char *argv[]) ...@@ -571,7 +672,7 @@ int main(int argc, char *argv[])
parse_file(infile); parse_file(infile);
printf("\n"); printf("\n");
} else { } else {
fprintf(stderr, "Unknown option: %s\n", argv[1]); fprintf(stderr, "Unknown option: %s\n", subcommand);
exit(1); exit(1);
} }
fclose(infile); fclose(infile);
......
...@@ -39,41 +39,44 @@ use strict; ...@@ -39,41 +39,44 @@ use strict;
# 25/07/2012 - Added support for HTML5 # 25/07/2012 - Added support for HTML5
# -- Dan Luedtke <mail@danrl.de> # -- Dan Luedtke <mail@danrl.de>
# sub usage {
# This will read a 'c' file and scan for embedded comments in the my $message = <<"EOF";
# style of gnome comments (+minor extensions - see below). Usage: $0 [OPTION ...] FILE ...
#
Read C language source or header FILEs, extract embedded documentation comments,
# Note: This only supports 'c'. and print formatted documentation to standard output.
# usage: The documentation comments are identified by "/**" opening comment mark. See
# kernel-doc [ -docbook | -html | -html5 | -text | -man | -list ] Documentation/kernel-doc-nano-HOWTO.txt for the documentation comment syntax.
# [ -no-doc-sections ]
# [ -function funcname [ -function funcname ...] ] Output format selection (mutually exclusive):
# c file(s)s > outputfile -docbook Output DocBook format.
# or -html Output HTML format.
# [ -nofunction funcname [ -function funcname ...] ] -html5 Output HTML5 format.
# c file(s)s > outputfile -list Output symbol list format. This is for use by docproc.
# -man Output troff manual page format. This is the default.
# Set output format using one of -docbook -html -html5 -text or -man. -rst Output reStructuredText format.
# Default is man. -text Output plain text format.
# The -list format is for internal use by docproc.
# Output selection (mutually exclusive):
# -no-doc-sections -function NAME Only output documentation for the given function(s)
# Do not output DOC: sections or DOC: section title(s). All other functions and DOC:
# sections are ignored. May be specified multiple times.
# -function funcname -nofunction NAME Do NOT output documentation for the given function(s);
# If set, then only generate documentation for the given function(s) or only output documentation for the other functions and
# DOC: section titles. All other functions and DOC: sections are ignored. DOC: sections. May be specified multiple times.
#
# -nofunction funcname Output selection modifiers:
# If set, then only generate documentation for the other function(s)/DOC: -no-doc-sections Do not output DOC: sections.
# sections. Cannot be used together with -function (yes, that's a bug --
# perl hackers can fix it 8)) Other parameters:
# -v Verbose output, more warnings and other information.
# c files - list of 'c' files to process -h Print this help.
#
# All output goes to stdout, with errors to stderr. EOF
print $message;
exit 1;
}
# #
# format of comments. # format of comments.
...@@ -201,6 +204,8 @@ my $type_param = '\@(\w+)'; ...@@ -201,6 +204,8 @@ my $type_param = '\@(\w+)';
my $type_struct = '\&((struct\s*)*[_\w]+)'; my $type_struct = '\&((struct\s*)*[_\w]+)';
my $type_struct_xml = '\\&amp;((struct\s*)*[_\w]+)'; my $type_struct_xml = '\\&amp;((struct\s*)*[_\w]+)';
my $type_env = '(\$\w+)'; my $type_env = '(\$\w+)';
my $type_enum_full = '\&(enum)\s*([_\w]+)';
my $type_struct_full = '\&(struct)\s*([_\w]+)';
# Output conversion substitutions. # Output conversion substitutions.
# One for each output format # One for each output format
...@@ -266,6 +271,17 @@ my @highlights_text = ( ...@@ -266,6 +271,17 @@ my @highlights_text = (
); );
my $blankline_text = ""; my $blankline_text = "";
# rst-mode
my @highlights_rst = (
[$type_constant, "``\$1``"],
[$type_func, "\\:c\\:func\\:`\$1`"],
[$type_struct_full, "\\:c\\:type\\:`\$1 \$2 <\$2>`"],
[$type_enum_full, "\\:c\\:type\\:`\$1 \$2 <\$2>`"],
[$type_struct, "\\:c\\:type\\:`struct \$1 <\$1>`"],
[$type_param, "**\$1**"]
);
my $blankline_rst = "\n";
# list mode # list mode
my @highlights_list = ( my @highlights_list = (
[$type_constant, "\$1"], [$type_constant, "\$1"],
...@@ -402,6 +418,10 @@ while ($ARGV[0] =~ m/^-(.*)/) { ...@@ -402,6 +418,10 @@ while ($ARGV[0] =~ m/^-(.*)/) {
$output_mode = "text"; $output_mode = "text";
@highlights = @highlights_text; @highlights = @highlights_text;
$blankline = $blankline_text; $blankline = $blankline_text;
} elsif ($cmd eq "-rst") {
$output_mode = "rst";
@highlights = @highlights_rst;
$blankline = $blankline_rst;
} elsif ($cmd eq "-docbook") { } elsif ($cmd eq "-docbook") {
$output_mode = "xml"; $output_mode = "xml";
@highlights = @highlights_xml; @highlights = @highlights_xml;
...@@ -437,17 +457,6 @@ while ($ARGV[0] =~ m/^-(.*)/) { ...@@ -437,17 +457,6 @@ while ($ARGV[0] =~ m/^-(.*)/) {
# continue execution near EOF; # continue execution near EOF;
sub usage {
print "Usage: $0 [ -docbook | -html | -html5 | -text | -man | -list ]\n";
print " [ -no-doc-sections ]\n";
print " [ -function funcname [ -function funcname ...] ]\n";
print " [ -nofunction funcname [ -nofunction funcname ...] ]\n";
print " [ -v ]\n";
print " c source file(s) > outputfile\n";
print " -v : verbose output, more warnings & other info listed\n";
exit 1;
}
# get kernel version from env # get kernel version from env
sub get_kernel_version() { sub get_kernel_version() {
my $version = 'unknown kernel version'; my $version = 'unknown kernel version';
...@@ -1713,6 +1722,208 @@ sub output_blockhead_text(%) { ...@@ -1713,6 +1722,208 @@ sub output_blockhead_text(%) {
} }
} }
##
# output in restructured text
#
#
# This could use some work; it's used to output the DOC: sections, and
# starts by putting out the name of the doc section itself, but that tends
# to duplicate a header already in the template file.
#
sub output_blockhead_rst(%) {
my %args = %{$_[0]};
my ($parameter, $section);
foreach $section (@{$args{'sectionlist'}}) {
print "**$section**\n\n";
output_highlight_rst($args{'sections'}{$section});
print "\n";
}
}
sub output_highlight_rst {
my $contents = join "\n",@_;
my $line;
# undo the evil effects of xml_escape() earlier
$contents = xml_unescape($contents);
eval $dohighlight;
die $@ if $@;
foreach $line (split "\n", $contents) {
if ($line eq "") {
print $lineprefix, $blankline;
} else {
$line =~ s/\\\\\\/\&/g;
print $lineprefix, $line;
}
print "\n";
}
}
sub output_function_rst(%) {
my %args = %{$_[0]};
my ($parameter, $section);
my $start;
print ".. c:function:: ";
if ($args{'functiontype'} ne "") {
$start = $args{'functiontype'} . " " . $args{'function'} . " (";
} else {
$start = $args{'function'} . " (";
}
print $start;
my $count = 0;
foreach my $parameter (@{$args{'parameterlist'}}) {
if ($count ne 0) {
print ", ";
}
$count++;
$type = $args{'parametertypes'}{$parameter};
if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
# pointer-to-function
print $1 . $parameter . ") (" . $2;
} else {
print $type . " " . $parameter;
}
}
print ")\n\n " . $args{'purpose'} . "\n\n";
print ":Parameters:\n\n";
foreach $parameter (@{$args{'parameterlist'}}) {
my $parameter_name = $parameter;
#$parameter_name =~ s/\[.*//;
$type = $args{'parametertypes'}{$parameter};
if ($type ne "") {
print " ``$type $parameter``\n";
} else {
print " ``$parameter``\n";
}
if ($args{'parameterdescs'}{$parameter_name} ne $undescribed) {
my $oldprefix = $lineprefix;
$lineprefix = " ";
output_highlight_rst($args{'parameterdescs'}{$parameter_name});
$lineprefix = $oldprefix;
} else {
print "\n _undescribed_\n";
}
print "\n";
}
output_section_rst(@_);
}
sub output_section_rst(%) {
my %args = %{$_[0]};
my $section;
my $oldprefix = $lineprefix;
$lineprefix = " ";
foreach $section (@{$args{'sectionlist'}}) {
print ":$section:\n\n";
output_highlight_rst($args{'sections'}{$section});
print "\n";
}
print "\n";
$lineprefix = $oldprefix;
}
sub output_enum_rst(%) {
my %args = %{$_[0]};
my ($parameter);
my $count;
my $name = "enum " . $args{'enum'};
print "\n\n.. c:type:: " . $name . "\n\n";
print " " . $args{'purpose'} . "\n\n";
print "..\n\n:Constants:\n\n";
my $oldprefix = $lineprefix;
$lineprefix = " ";
foreach $parameter (@{$args{'parameterlist'}}) {
print " `$parameter`\n";
if ($args{'parameterdescs'}{$parameter} ne $undescribed) {
output_highlight_rst($args{'parameterdescs'}{$parameter});
} else {
print " undescribed\n";
}
print "\n";
}
$lineprefix = $oldprefix;
output_section_rst(@_);
}
sub output_typedef_rst(%) {
my %args = %{$_[0]};
my ($parameter);
my $count;
my $name = "typedef " . $args{'typedef'};
### FIXME: should the name below contain "typedef" or not?
print "\n\n.. c:type:: " . $name . "\n\n";
print " " . $args{'purpose'} . "\n\n";
output_section_rst(@_);
}
sub output_struct_rst(%) {
my %args = %{$_[0]};
my ($parameter);
my $name = $args{'type'} . " " . $args{'struct'};
print "\n\n.. c:type:: " . $name . "\n\n";
print " " . $args{'purpose'} . "\n\n";
print ":Definition:\n\n";
print " ::\n\n";
print " " . $args{'type'} . " " . $args{'struct'} . " {\n";
foreach $parameter (@{$args{'parameterlist'}}) {
if ($parameter =~ /^#/) {
print " " . "$parameter\n";
next;
}
my $parameter_name = $parameter;
$parameter_name =~ s/\[.*//;
($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
$type = $args{'parametertypes'}{$parameter};
if ($type =~ m/([^\(]*\(\*)\s*\)\s*\(([^\)]*)\)/) {
# pointer-to-function
print " $1 $parameter) ($2);\n";
} elsif ($type =~ m/^(.*?)\s*(:.*)/) {
# bitfield
print " $1 $parameter$2;\n";
} else {
print " " . $type . " " . $parameter . ";\n";
}
}
print " };\n\n";
print ":Members:\n\n";
foreach $parameter (@{$args{'parameterlist'}}) {
($parameter =~ /^#/) && next;
my $parameter_name = $parameter;
$parameter_name =~ s/\[.*//;
($args{'parameterdescs'}{$parameter_name} ne $undescribed) || next;
$type = $args{'parametertypes'}{$parameter};
print " `$type $parameter`" . "\n";
my $oldprefix = $lineprefix;
$lineprefix = " ";
output_highlight_rst($args{'parameterdescs'}{$parameter_name});
$lineprefix = $oldprefix;
print "\n";
}
print "\n";
output_section_rst(@_);
}
## list mode output functions ## list mode output functions
sub output_function_list(%) { sub output_function_list(%) {
...@@ -2414,6 +2625,18 @@ sub xml_escape($) { ...@@ -2414,6 +2625,18 @@ sub xml_escape($) {
return $text; return $text;
} }
# xml_unescape: reverse the effects of xml_escape
sub xml_unescape($) {
my $text = shift;
if (($output_mode eq "text") || ($output_mode eq "man")) {
return $text;
}
$text =~ s/\\\\\\amp;/\&/g;
$text =~ s/\\\\\\lt;/</g;
$text =~ s/\\\\\\gt;/>/g;
return $text;
}
# convert local escape strings to html # convert local escape strings to html
# local escape strings look like: '\\\\menmonic:' (that's 4 backslashes) # local escape strings look like: '\\\\menmonic:' (that's 4 backslashes)
sub local_unescape($) { sub local_unescape($) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment