File: metainfo-driver.xml

package info (click to toggle)
appstream 1.1.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 18,408 kB
  • sloc: ansic: 51,906; xml: 10,459; cpp: 4,721; python: 538; sh: 260; makefile: 24
file content (106 lines) | stat: -rw-r--r-- 3,525 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<?xml version='1.0' encoding='utf-8' ?>
<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
<!ENTITY % BOOK_ENTITIES SYSTEM "AppStream.ent">
%BOOK_ENTITIES;
]>

<section id="sect-Metadata-Driver">
	<title>Driver</title>

	<section id="spec-driver-introduction">
		<title>Introduction</title>
		<para>
			The <literal>driver</literal> component type describes drivers for hardware devices as well as other Linux kernel
			drivers for e.g. virtualization support.
			It usually <literal>provides</literal> one or multiple modaliases.
		</para>
		<para>
			Drivers can ship one or more files in <filename>/usr/share/metainfo/%{id}.metainfo.xml</filename>.
		</para>
	</section>

	<section id="spec-driver-example">
		<title>Example file</title>
		<para>
			A driver metainfo file can look like this:
		</para>
		<programlisting language="XML">
<![CDATA[<?xml version="1.0" encoding="UTF-8"?>
<component type="driver">
  <id>com.nvidia.GeForce</id>
  <name>NVIDIA GeForce</name>
  <summary>NVIDIA Graphics Driver</summary>
  <description>
    <p>
      The NVIDIA Accelerated Linux Graphics Driver brings accelerated 2D
      functionality and high-performance OpenGL support to Linux x86 with the
      use of NVIDIA graphics processing units.
    </p>
    ...
  </description>
  <url type="homepage">http://www.nvidia.com/Download/index.aspx</url>
  <metadata_license>CC0-1.0</metadata_license>
  <project_license>LicenseRef-proprietary:NVIDIA</project_license>

  <developer id="nvidia.com">
    <name>NVIDIA Corporation</name>
  </developer>

  <provides>
    <modalias>pci:v000010DEd*sv*sd*bc03sc00i00*</modalias>
    ...
  </provides>
</component>]]></programlisting>

	</section>

	<section id="spec-driver-filespec">
		<title>File specification</title>
		<para>
			Note that the XML root must have the <literal>type</literal> property set to <code>driver</code>.
			This clearly identifies this metainfo document as describing a driver.
		</para>

		<variablelist>
			<varlistentry id="tag-id-driver">
			<term>&lt;id/&gt;</term>
			<listitem>
				<para>
					For drivers, the value of the <code>&lt;id/&gt;</code> tag must follow the reverse-DNS scheme as described for generic components.
					It is sometimes useful to suffix the ID with <literal>.driver</literal> to make it more unique.
				</para>
			</listitem>
			</varlistentry>

			<varlistentry id="tag-driver-provides">
			<term>&lt;provides/&gt; ↪ &lt;modalias/&gt;</term>
			<listitem>
				<para>
					The <literal>provides/modalias</literal> tags contain all the modaliases the described driver supports and allow
					to automatically offer installation of the described driver on systems where hardware matching the modalias has been
					detected.
				</para>
				<para>
					Using wildcards for modaliases is permitted.
				</para>
				<para>
					Example:
				</para>
				<programlisting language="XML"><![CDATA[<provides>
  <modalias>pci:v000010DEd00001194sv*sd*bc03sc*i*</modalias>
  <modalias>pci:v000010DEd00001199sv*sd*bc03sc*i*</modalias>
</provides>]]></programlisting>

			</listitem>
			</varlistentry>

		</variablelist>

		<para>
			For a component of type <literal>driver</literal>, the following tags are required and must be present for a valid document:
			<xref linkend="tag-id-driver"/>, <xref linkend="tag-name"/>, <xref linkend="tag-summary"/>,
			<xref linkend="tag-metadata_license"/>, <xref linkend="tag-driver-provides"/>.
		</para>

	</section>
</section>