| Both sides previous revision
Previous revision
Next revision | Previous revision | 
                        
                | usersguide [2021/12/24 00:31] dpisuperadmin [Theory of Operation]
 | — (current) | 
        
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
| ==== What Are Software Defined Peripherals (SDP)? ==== |  | 
| In the world of robotics and automation a peripheral is a device used for communication or for sensing and control.  Communication peripherals include Inter-Integrated Circuit (I2C), Serial Peripheral Interface (SPI), asynchronous serial interfaces, and Ethernet interfaces.   Counter and timer peripherals can implement pulse width modulation (PWM) for servo control and for DC motor control.  Peripherals are generally hard-wired into the computer or microcontroller and can not be changed after the chip is built. |  | 
| Software defined peripherals typically built on a Field Programmable Gate Array (FPGA).  As the name implies, an FPGA has a huge array of gates and flip-flops.  How the gates and flip-flops are interconnected is controlled by RAM that is set (or programmed) by the user (in the field).  All peripherals are built using gates, flip-flops, registers, and RAM.   When you think of software, you probably think of lines of code executed in sequence on a Von Neumann CPU.  FPGAs are not CPUs and do not execute sequential lines of code.  Peripherals built using an FPGA are dedicated gates and registers designed to fill the intent of the peripheral.  Many peripheral designers use schematics for their designs but a more common approach is to use a hardware description lanuage such as Verilog or VHDL.  In the same sense that HTML describes how to render a page, Verilog describes the interconnect of gates, registers, and external pins that make up a peripheral.  The Verilog sources are compiled into binary file that is loaded into the FPGA to implement the desired logic.  Just as a PC has hardware that is independent of the OS loaded, so software defined peripherals must be divieded into the hardware and the binary FPGA image.  Your Baseboard4 is the hardware.  DPCore is the FPGA image you load onto the Baseboard.  We will refer to the FPGA binary in DPCore as the "SDP image" to make clear that it implements a set of software defined peripherals. |  | 
|  |  | 
| ==== Architectures for Software Defined Peripherals ==== |  | 
| Figure 1 shows the internal architecture of DPCore with some typical peripherals.  The areas in gray are built into every DPCore.  The peripherals in white can change from one DPCore to the next.  Later you will see how to build DPCore with your own selection of peripherals.  Each peripheral is assigned a slot that has four dedicated FPGA pins.  (Slot 10 has 3 pins.)  The address bus in DPCore has 12 bits.  The high 4 bits select the peripheral making the low 8 bits are available to the peripheral.  Peripheral #0 is the enumerator, a read-only memory that has a list of the peripherals in the SDP image.  At system start the host reads the enumerator to find what peripherals are available.  The host can read and write peripherals on the bus by sending a command packet to DPCore.  The command packet is decoded by the Command Parser and converted to read and write bus cycles.  Commands can read or write to sequential addresses or can read or write to one address if a FIFO.  Command packet are encapsulated using SLIP even though the packets are not IP packets. |  | 
| ===== Software Defined Peripherals on the Baseboard4 ===== |  | 
|  |  | 
| ==== Physical Arrangement of Cards ==== |  | 
|  |  | 
| ==== Generating a DPCore Binary ==== |  | 
|  |  | 
| ==== Loading and Running dpdaemon ==== |  | 
|  |  | 
| ==== The dpdaemon API ==== |  | 
|  |  | 
| ===== Build a Robot Using a Baseboard4 ===== |  | 
| ==== Mechanical Build of a SDP Based Robot ==== |  | 
|  |  | 
| === Parts List === |  | 
|  |  | 
| === Assembly and Test === |  | 
|  |  | 
| ===== Use sdpdaemon to Control Your Robot ===== |  | 
|  |  | 
| ===== Use ROS2 to Control Your Robot ===== |  | 
| ==== ROS2 Installation ==== |  | 
|  |  | 
| ===== Use MicroROS to Control Your Robot ===== |  | 
|  |  | 
| ===== How to Write a  Peripheral Driver Module ===== |  | 
|  |  | 
| ===== How to Write a Verilog Peripheral ===== |  | 
|  |  |