From 5516a49696b21a13e1b606f38d99d9d7d97f1667 Mon Sep 17 00:00:00 2001 From: Florent Kermarrec Date: Wed, 6 May 2015 03:51:02 +0200 Subject: [PATCH] litesata: add doc for frontend --- .../doc/source/docs/frontend/index.rst | 90 +++++++++++++++++- .../doc/source/docs/frontend/packets.dia | Bin 0 -> 3328 bytes .../doc/source/docs/frontend/packets.png | Bin 0 -> 3700 bytes 3 files changed, 88 insertions(+), 2 deletions(-) create mode 100644 misoclib/mem/litesata/doc/source/docs/frontend/packets.dia create mode 100644 misoclib/mem/litesata/doc/source/docs/frontend/packets.png diff --git a/misoclib/mem/litesata/doc/source/docs/frontend/index.rst b/misoclib/mem/litesata/doc/source/docs/frontend/index.rst index d112402ee..51f0c6daf 100644 --- a/misoclib/mem/litesata/doc/source/docs/frontend/index.rst +++ b/misoclib/mem/litesata/doc/source/docs/frontend/index.rst @@ -3,5 +3,91 @@ ======================== Frontend ======================== -.. note:: - Please contribute to this document, or support us financially to write it. + +Crossbar and user ports +======================= + +LiteSATA provides a crossbar to let the user request the number of port he needs. +Ports are automatically arbitrated and dispatched to and from the core. In the +following example we create a core and get a port from the crossbar: + +.. code-block:: python + + self.submodules.sata_phy = LiteSATAPHY(platform.device, + platform.request("sata"), + "sata_gen2", + clk_freq) + self.submodules.sata = LiteSATA(self.sata_phy) + user_port = self.sata.crossbar.get_port() + +Our user_port has 2 endpoints: + + - A Sink used to send commands and write data. + - A Source used to receive commands acknowledges and receive read data. + +Packets description +=================== + +Sink and Source are packets with additional parameters. A packet has the following signals: + + - stb: Strobe signal indicates that command or data is valid. + - sop: Start Of Packet signal indicates that current command or data is the first of the packet. + - eop: End Of Packet signal indicates that current command or data is the last of the packet. + - ack: Response from the endpoint indicates that core is able to accept our command or data. + - data: Current data of the packet. + +.. figure:: packets.png + :scale: 30 % + :align: center + + An example of packet transaction between endpoints. + +.. tip:: + + - When a packet only has a command or data, sop and eop must be set to 1 on the same clock cycle. + - A data is accepted when stb=1 and ack=1. + +User Commands +============= + +All HDD transfers are initiated using the Sink endpoint which has the following signals: + + - write: 1 bit signal indicates if we want to write data to the HDD. + - read: 1 bit signal indicaties if we want to read data from the HDD. + - identify: 1 bit signal indicates if command is an identify device command (use to get HDD informations). + - sector: 48 bits signal, the sector number we are going to write or read. + - count: 16 bits signal, the number of sectors we are going to write or read. + - data: 32 bits signal, the write data. + +.. tip:: + + - write, read, identify, sector, count are parameters so remain constant for a packet duration. + - sector, count are ignored during an identify command. + - data is ignored during a read or identify command. + +User Responses +============== + +HDD responses are obtained from the Source endpoint which has the following signals: + + - write: 1 bit signal indicates if command was a write. + - read: 1 bit signal indicaties if command was a read. + - identify: 1 bit signal indicates if command was an identify device command. + - last: 1 bit signal indicates if this is the last packet of the response. (A Response can be return in several packets) + - failed: 1 bit signal identicates if an error was detected in the response (CRC, FIS...) + - data: 32 bits signal, the read data + +.. tip:: + + - write, read, identify, last are parameters so remain constant for a packet duration. + - data can be ignored in the case of a write or identify command. + - in case of a read command, read data packets are presented followed by an empty packet indicating the end of the transaction (last=1). + +Examples +======== + +A BIST_ (Data generator and checker) design is provided. It can be used to understand how to connect +your logic to the user_port provided by the crossbar. (See LiteSATABISTGenerator, LiteSATABISTChecker and LiteSATABISTIdentify) + +.. _BIST: https://github.com/m-labs/misoc/blob/master/misoclib/mem/litesata/frontend/bist.py + diff --git a/misoclib/mem/litesata/doc/source/docs/frontend/packets.dia b/misoclib/mem/litesata/doc/source/docs/frontend/packets.dia new file mode 100644 index 0000000000000000000000000000000000000000..d4804e2b1829fa1234922c28a0bd82c5b7f80850 GIT binary patch literal 3328 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 K?rPmMz5oFD)K{7S literal 0 HcmV?d00001 diff --git a/misoclib/mem/litesata/doc/source/docs/frontend/packets.png b/misoclib/mem/litesata/doc/source/docs/frontend/packets.png new file mode 100644 index 0000000000000000000000000000000000000000..adb18e8aca31c67011b21c21c76578e2d5f16744 GIT binary patch literal 3700 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 literal 0 HcmV?d00001