POD create component: Difference between revisions

From ArmadeusWiki
No edit summary
No edit summary
Line 13: Line 13:
* Driver template files.
* Driver template files.
* Documentation files.
* Documentation files.
== Choose/create library ==
== Choose/create library ==
A component must be created in a library. Then, the first things to do is to choose the library. Official library can be use, but using personal library is encouraged. To add a personal library in POD, create a directory then add it in the configuration file (~/.podrc by default):
<source lang="xml">
<?xml version="1.0" encoding="utf-8"?>
<podconfig>
    <libraries>
        <lib path="path_to_my_lib/my_lib" />
    </libraries>       
</source>
This can be done in ''library'' POD environment :
<pre class="host">
$ pod
POD>library
POD.library> addlibrary path_to_my_lib/my_lib
POD.library> load my_lib
POD.library:my_lib>
</pre>
== Creating component ==
== Creating component ==
Component name must have exactly the same name as entity name of the top HDL component.
===By hand===
To create component «by hand» make directory with component name in library director and mandatory subdirectory as follow :
<pre class="host">
    my_lib
    |-- doc
    |-- hdl
</pre>
Then create xml file in component directory with name of version. Different version can be added for component description, it usefull when the same HDL code is used for différent interface configured with generics.
<source lang="XML">
<?xml version="1.0" encoding="utf-8"?>
<component name="my_component" version="1.0">
<description>
A simple button ip
</description>
</component>
</source>
=== With POD ===
First select your working library as indicated in first paragraph then create component :
<pre class="host">
POD.library> load my_lib
POD.library:my_lib> component my_component
[INFO]  : No component named my_component in podvirginlib component created
POD.library:podvirginlib.my_component>
</pre>
Then description can be set with setdescription command:
<pre class="host">
TODO
</pre>
== Add HDL files ==
== Add HDL files ==
First things to do when a component is created is to add HDL files. Beginning with TOP HDL file.
=== By hand ===
Adding vhdl files names in xml :
<source lang="xml">
<hdl_files>
    <hdl_file filename="hdl/my_component_top.vhd" scope="all" istop="1" />
    <hdl_file filename="hdl/my_component_bottom.vhd" scope="all" />
</hdl_files>
</source>
Then adding files in hdl directory:
<pre class="host">
hdl/
|-- my_component_bottom.vhd
`-- my_component_top.vhd
</pre>
=== With POD ===
TODO
== Create interfaces ==
== Create interfaces ==
Interfaces are used to group ports of same category.
=== By hand ===
Interfaces are described in <interfaces> node :
<source lang="xml">
<interfaces>
<interface name="int_button" class="GLS" />
<interface name="clock_and_reset" class="CLK_RST" />
<interface name="swb16" class="SLAVE" bus="wishbone16" clockandreset="clock_and_reset" />
</interfaces>
</source>
=== With POD ===
TODO
== Create ports ==
== Create ports ==
Ports are defined by a size and interface used.
=== By hand ===
Open the <interface> node where port must be integrated then use <ports> node to list each port:
<source lang="xml">
<interface name="int_button" class="GLS" >
    <ports>
    <port name="button" type="EXPORT" size="1" dir="in" />
<port name="irq" type="EXPORT" size="1" dir="out" />
</ports>
</interface>
</source>
=== With POD ===
TODO
== Assign pins ==
== Assign pins ==
=== By hand ===
=== With POD ===
== Adding driver templates files ==
== Adding driver templates files ==
Template files are used for a specific BSP also named "architecture".
=== By hand ===
Use driver_files node to describe driver_templates files used. One driver_templates node for each architecture.
<source lang="xml">
<driver_files>
    <driver_templates architecture="armadeus">
        <support version="3" />
<file name="Makefile" />
<file name="my_component.c" />
        <file name="my_component.h" />
    </driver_templates>
</driver_files>
</source>
And copy each file in directory with name of architecture
<pre host="xml">
drivers_templates/
`-- armadeus
    |--  Makefile
    |--  my_component.c
    `--  my_component.h
</pre>
=== With POD ===
TODO
== Describe generics ==
== Describe generics ==
Generics are found automatically by the parser of POD, but sometimes, others generic are necessary for drivers side then others generic must be added. And all generics must be configured by the develloper to define some caracteristics.
=== By hand ===
Add generic in <generics> node:
<source lang="xml">
      <generic name="id" public="true" value="1" match="\d+" type="natural" destination="both" />
</source>
=== With POD ===
TODO
== Add interruption ==
== Add interruption ==
== Describe register ==
 
In some component a port is used to generate interruption.
 
=== By hand ===
 
Use node <interrupts> to designate interface.port that generate interruption.
 
<source lang="xml">
<interrupts>
<interrupt interface="int_button" port="irq" />
</interrupts>
</source>
 
=== With POD ===
 
TODO
 
== Describe registers ==
 
Slave busses interfaces has registers that must be described.
 
=== By hand ===
 
<registers> node is included in slave bus interface :
 
<source lang="xml">
<interface clockandreset="candr" name="swb16" class="SLAVE" bus="wishbone16" >
    <registers>
        <register name="id" offset="0x00" size="16" rows="1" />
<register name="reg_button" offset="0x01" size="16" rows="1" />
</registers>
    ...
</interface>
</source>
 
=== With POD ===
 
TODO
 
[[Category:POD]]

Revision as of 16:31, 4 May 2009

Page under construction... 

Construction.png Informations on this page are not guaranteed !!

This chapter describe how-to create a component for a POD library. There is two way to create a component:

  • By hand : create directory and xml description with your favorite text editor and file manager.
  • With POD : using library environnement and its commands to generate the component.

Whatever method used, some stuff are required :

Required:

  • HDL top file : the top description of the component, with the external interface. POD library commands will parse interface to ease component creation.

Optional:

  • All other HDL files.
  • Driver template files.
  • Documentation files.

Choose/create library

A component must be created in a library. Then, the first things to do is to choose the library. Official library can be use, but using personal library is encouraged. To add a personal library in POD, create a directory then add it in the configuration file (~/.podrc by default):

<?xml version="1.0" encoding="utf-8"?>
<podconfig>
    <libraries>
        <lib path="path_to_my_lib/my_lib" />
    </libraries>

This can be done in library POD environment :

$ pod
POD>library
POD.library> addlibrary path_to_my_lib/my_lib
POD.library> load my_lib
POD.library:my_lib>

Creating component

Component name must have exactly the same name as entity name of the top HDL component.

By hand

To create component «by hand» make directory with component name in library director and mandatory subdirectory as follow :

    my_lib
    |-- doc
    |-- hdl

Then create xml file in component directory with name of version. Different version can be added for component description, it usefull when the same HDL code is used for différent interface configured with generics.

<?xml version="1.0" encoding="utf-8"?>
<component name="my_component" version="1.0">
	<description>
		A simple button ip
	</description>
</component>

With POD

First select your working library as indicated in first paragraph then create component :

POD.library> load my_lib
POD.library:my_lib> component my_component
[INFO]   : No component named my_component in podvirginlib component created
POD.library:podvirginlib.my_component>

Then description can be set with setdescription command:

TODO

Add HDL files

First things to do when a component is created is to add HDL files. Beginning with TOP HDL file.

By hand

Adding vhdl files names in xml :

<hdl_files>
    <hdl_file filename="hdl/my_component_top.vhd" scope="all" istop="1" />
    <hdl_file filename="hdl/my_component_bottom.vhd" scope="all" />
</hdl_files>

Then adding files in hdl directory:

hdl/
|-- my_component_bottom.vhd
`-- my_component_top.vhd

With POD

TODO

Create interfaces

Interfaces are used to group ports of same category.

By hand

Interfaces are described in <interfaces> node :

<interfaces>
		<interface name="int_button" class="GLS" />
		<interface name="clock_and_reset" class="CLK_RST" />
		<interface name="swb16" class="SLAVE" bus="wishbone16" clockandreset="clock_and_reset" />
</interfaces>


With POD

TODO

Create ports

Ports are defined by a size and interface used.

By hand

Open the <interface> node where port must be integrated then use <ports> node to list each port:

<interface name="int_button" class="GLS" >
    <ports>
	    <port name="button" type="EXPORT" size="1" dir="in" />
		<port name="irq" type="EXPORT" size="1" dir="out" />
	</ports>
</interface>

With POD

TODO

Assign pins

By hand

With POD

Adding driver templates files

Template files are used for a specific BSP also named "architecture".

By hand

Use driver_files node to describe driver_templates files used. One driver_templates node for each architecture.

<driver_files>
    <driver_templates architecture="armadeus">
        <support version="3" />
		<file name="Makefile" />
		<file name="my_component.c" />
        <file name="my_component.h" />
    </driver_templates>
</driver_files>

And copy each file in directory with name of architecture

drivers_templates/
`-- armadeus
    |--  Makefile
    |--  my_component.c
    `--  my_component.h

With POD

TODO

Describe generics

Generics are found automatically by the parser of POD, but sometimes, others generic are necessary for drivers side then others generic must be added. And all generics must be configured by the develloper to define some caracteristics.

By hand

Add generic in <generics> node:

      <generic name="id" public="true" value="1" match="\d+" type="natural" destination="both" />

With POD

TODO

Add interruption

In some component a port is used to generate interruption.

By hand

Use node <interrupts> to designate interface.port that generate interruption.

<interrupts>
	<interrupt interface="int_button" port="irq" />
</interrupts>

With POD

TODO

Describe registers

Slave busses interfaces has registers that must be described.

By hand

<registers> node is included in slave bus interface :

<interface clockandreset="candr" name="swb16" class="SLAVE" bus="wishbone16" >
    <registers>
        <register name="id" offset="0x00" size="16" rows="1" />
		<register name="reg_button" offset="0x01" size="16" rows="1" />
	</registers>
    ...
</interface>

With POD

TODO