]> jspc29.x-matter.uni-frankfurt.de Git - mvdsensorcontrol.git/commitdiff
added first TrbNet specification and XML schema
authorJan Michel <j.michel@gsi.de>
Thu, 27 Jun 2013 12:27:05 +0000 (14:27 +0200)
committerJan Michel <j.michel@gsi.de>
Thu, 27 Jun 2013 12:27:05 +0000 (14:27 +0200)
.gitignore
xml_spielwiese/TrbNetspec.xsd [new file with mode: 0644]
xml_spielwiese/jtag_registers_SPEC.xml

index 253e3f544e51e3395debfd56ec3317383c20bfb9..d97a6bc15b6122e2ce42c5170d5e027eed34d079 100644 (file)
@@ -4,3 +4,4 @@ devel
 .kateproject
 temp
 .kateproject.d/
+*swp
diff --git a/xml_spielwiese/TrbNetspec.xsd b/xml_spielwiese/TrbNetspec.xsd
new file mode 100644 (file)
index 0000000..0c2b23d
--- /dev/null
@@ -0,0 +1,125 @@
+<?xml version="1.0" encoding="utf-8" ?>
+<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema">
+
+
+<xs:simpleType name="addresstype">
+  <xs:restriction base="xs:string">
+    <xs:pattern value="[0-9a-fA-F]{4}"/>
+  </xs:restriction>
+</xs:simpleType> 
+
+<xs:simpleType name="valuetype">
+  <xs:restriction base="xs:string">
+    <xs:pattern value="[0-9a-fA-F]+"/>
+  </xs:restriction>
+</xs:simpleType> 
+
+
+
+<xs:element name="description" type="xs:string" />
+<xs:attribute name="name"         type="xs:string" />
+<xs:attribute name="address"      type="addresstype" />
+<xs:attribute name="offset"       type="addresstype" />
+<xs:attribute name="mode"         type="xs:string"  />
+<xs:attribute name="type"         type="xs:string" />
+<xs:attribute name="function"     type="xs:string" />
+<xs:attribute name="start"        type="xs:positiveInteger" />
+<xs:attribute name="size"         type="xs:positiveInteger" />
+<xs:attribute name="defaultValue" type="valuetype" />
+<xs:attribute name="value"        type="valuetype" />
+<xs:attribute name="format"       type="xs:string" />
+<xs:attribute name="continuous"   type="xs:boolean" />
+
+
+<xs:element name="TrbNet">
+  <xs:complexType>
+    <xs:choice maxOccurs="unbounded">
+      <xs:element   ref="description" maxOccurs="1" />
+      <xs:element   ref="group"       maxOccurs="unbounded" />
+      <xs:element   ref="register"    maxOccurs="unbounded" />
+      <xs:element   ref="memory"      maxOccurs="unbounded" />
+      <xs:element   ref="fifo"        maxOccurs="unbounded" />
+    </xs:choice>
+    <xs:attribute ref="type" />
+    <xs:attribute ref="offset" />
+  </xs:complexType>
+</xs:element>
+
+<xs:element name="group">
+  <xs:complexType>
+    <xs:choice maxOccurs="unbounded">
+      <xs:element   ref="group"       maxOccurs="unbounded" />
+      <xs:element   ref="description" maxOccurs="1" />
+      <xs:element   ref="register"    maxOccurs="unbounded" />
+      <xs:element   ref="memory"      maxOccurs="unbounded" />
+      <xs:element   ref="fifo"        maxOccurs="unbounded" />
+    </xs:choice>
+    <xs:attribute ref="name" use="required" />
+    <xs:attribute ref="address" />
+    <xs:attribute ref="size" />
+    <xs:attribute ref="type" />
+    <xs:attribute ref="continuous" />
+    <xs:attribute ref="defaultValue" />
+    <xs:attribute ref="format" />
+  </xs:complexType>
+</xs:element> 
+
+
+<xs:element name="field">
+  <xs:complexType>
+    <xs:all>
+      <xs:element   ref="description" maxOccurs="1" />
+    </xs:all>
+    <xs:attribute ref="name" />
+    <xs:attribute ref="start" />
+    <xs:attribute ref="size" />
+    <xs:attribute ref="type" />
+    <xs:attribute ref="defaultValue" />
+    <xs:attribute ref="format" />
+  </xs:complexType>
+</xs:element> 
+
+
+<xs:element name="register">
+  <xs:complexType>
+    <xs:choice maxOccurs="unbounded">
+      <xs:element   ref="field" />
+      <xs:element   ref="description" maxOccurs="1" />
+    </xs:choice>
+    <xs:attribute ref="name" />
+    <xs:attribute ref="address" />
+    <xs:attribute ref="mode" />
+    <xs:attribute ref="function" />
+  </xs:complexType>
+</xs:element> 
+
+<xs:element name="memory">
+  <xs:complexType>
+    <xs:choice maxOccurs="unbounded">
+      <xs:element   ref="field" />
+      <xs:element   ref="description" maxOccurs="1" />
+    </xs:choice>
+    <xs:attribute ref="name" />
+    <xs:attribute ref="address" />
+    <xs:attribute ref="size" />
+    <xs:attribute ref="mode" />
+    <xs:attribute ref="function" />
+  </xs:complexType>
+</xs:element> 
+
+<xs:element name="fifo">
+  <xs:complexType>
+    <xs:choice maxOccurs="unbounded">
+      <xs:element   ref="field" />
+      <xs:element   ref="description" maxOccurs="1" />
+    </xs:choice>
+    <xs:attribute ref="name" />
+    <xs:attribute ref="address" />
+    <xs:attribute ref="mode" />
+    <xs:attribute ref="function" />
+  </xs:complexType>
+</xs:element> 
+
+
+</xs:schema> 
+  
index 71d0eab988700995e3090dc6f6b706e670e91731..1b5822c57cb3f6e4aee820891ddbdccf2643a8d1 100644 (file)
@@ -1,19 +1,15 @@
 <?xml version="1.0"?>
-<TrbNet 
+<TrbNet xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
+xsi:noNamespaceSchemaLocation="spec.xsd"
   type="JtagController"
   offset="1000"
   >
-<group 
-  name
-  addr
-  width
-  continuous="yes"
-  >  
+
 <register
   name="TriggerAllchainsInitSeq"
   address="0003"
   mode="w"
-  type =""
+  function ="configuration"
   >
   <description>
 Start initialization sequence for all connected sensor chains    
@@ -27,5 +23,5 @@ Start initialization sequence for all connected sensor chains
   <description>Reserved, Not Used </description>
 </field>
 </register>
-</group>
+
 </TrbNet>
\ No newline at end of file