2 "$schema": "https://json-schema.org/draft/2020-12/schema",
3 "$id": "https://nvidia.com/dw/app-config.schema.json",
4 "title": "DW Application Config Descriptor",
5 "description": "The descriptor to override the configuration of a DriveWorks application. The keys in JSON should appear in the same order as the properties are documented in the schema.",
7 "additionalProperties": false,
10 "description": "In a manually written JSON file this field can contain an arbitrary text. When the JSON file is generated, the tool should include its own name and optionally reference the authoritive source of information.",
13 "componentParameters": {
14 "description": "The component parameters to override. The order should be alphabetical.",
16 "additionalProperties": false,
17 "patternProperties": {
18 "^([a-z][a-zA-Z0-9]*(\\.[a-z][a-zA-Z0-9]*)*)?$": {
19 "description": "The key is the fully qualified name of the subcomponent (in the form of 1 or multiple 'subcomponentInstanceName' separated by dots). An empty key refers to the parameters of the application. The order should be alphabetical. The value contains a mapping from parameter names to parameter values.",
21 "additionalProperties": false,
22 "patternProperties": {
23 "^[a-z][a-zA-Z0-9_]*(\\.[a-z][a-zA-Z0-9_]*)?$": {
24 "description": "The key is the parameter name from the component. The value is the parameter value which must match the type of the parameter defined in the component descriptor. The order should be alphabetical.",
37 "description": "The nodes to skip from being scheduled. The order should be alphabetical.",
39 "additionalProperties": false,
40 "patternProperties": {
41 "^[a-z][a-zA-Z0-9]*(\\.[a-z][a-zA-Z0-9]*)*$": {
42 "description": "The key is the fully qualified name of the node. Refering to a graphlet implicitly refers to all recursive nodes. The value identifies the 'stmSchedules' the skip applies to (and empty list means skipping the node in all schedules).",
46 "pattern": "[a-z][a-zA-Z0-9_]*$"
53 "description": "The key is a STM schedule identifier, value is the STM schedule. Only hyperepoch and epoch periods can be modified. The order should be alphabetical.",
55 "additionalProperties": false,
56 "patternProperties": {
57 "^[a-z][a-zA-Z0-9_]*": {
58 "description": "The information needed to modify the STM schedule.",
63 "additionalProperties": false,
66 "description": "The hyperepochs. The order should be alphabetical.",
68 "additionalProperties": false,
69 "patternProperties": {
70 "^[a-z][a-zA-Z0-9_]*$": {
71 "description": "The key is the name of the hyperepoch (in camelCase) which must be unique within the collection of hyperepochs in this schedule. The value describes the hyperepoch itself.",
76 "additionalProperties": false,
79 "description": "The period length of the hyperepoch (in nanoseconds).",
84 "description": "The pfm monitoring threshold of the hyperepoch (in nanoseconds).",
89 "description": "The epochs. The order should be alphabetical.",
91 "additionalProperties": false,
92 "patternProperties": {
93 "^[a-z][a-zA-Z0-9_]*$": {
94 "description": "The key is the name of the epoch (in camelCase) which must be unique within the hyperepoch. The value describes the epoch itself.",
99 "additionalProperties": false,
102 "description": "The period length of the epoch (in nanoseconds)",
119 "description": "The process attributes to override. The order should be alphabetical.",
121 "additionalProperties": false,
122 "patternProperties": {
123 "^[a-zA-Z][a-zA-Z0-9_]*$": {
124 "description": "The key is the name of the process (in snake_case). The value describes the process itself.",
125 "additionalProperties": false,
128 "description": "The absolute path of the directory (without a trailing slash) to override where the executable (identified by the basename of the 'executable' value) is located.",
132 "description": "The command line arguments passed to the executable",
134 "additionalProperties": false,
135 "patternProperties": {
136 "^[a-zA-Z0-9_-]+$": {
137 "description": "The key is one command line argument. The value is not used (if it is the boolean value true), a second argument (if it is a string), multiple additional arguments (if it is an array of strings). If the value is 'null' value the key is removed and not passed to the process.",
162 "description": "The provided content is combined with the base application using JSON merge patch",
170 "description": "The required sensors to remove or update. The order is user defined.",
172 "additionalProperties": false,
173 "patternProperties": {
174 "^[a-zA-Z][a-zA-Z0-9 .:_-]*$": {
175 "description": "The key is the required sensor name which could be either rig sensor name or a key of sensor mappings. The value is either a json null to remove this required sensor or an object to update this required sensor attributes.",
181 "description": "Attributes for each required sensor. Only support \"typeIndex\" attribute currently. For those sensor types of which sensor is unique in the app, \"typeIndex\" can be ignored.",
183 "additionalProperties": false,
186 "description": "The sensor index of certain sensor type, applied in the app.",
191 "description": "An array containing the machine names this sensor is connected to (machine0, machine1 ... machineN).",
195 "pattern": "^[a-zA-Z][a-zA-Z0-9_]*$"
205 "description": "DEPRECATED! Override key-value pairs from the extraInfo JSON file",
209 "description": "Parameters for the Recorder",
213 "description": "Parameters for the RoadCast service",