**Generic list – Internal Logic Analyzer Core**



| Number | Generic Parameter | Description | Type | Default Value |
| --- | --- | --- | --- | --- |
|  | record\_depth\_g | Determine the number of bits that will be recorded for each signal | positive | 256 |
|  | num\_of\_signals\_g | Determine the number of signals that will be recorded | positive | 8 |
|  | reset\_polarity\_g | Reset polarity:  '1': Active high  '0': Active low | std\_logic | '0' |
|  | data\_width\_g | The width of the basic 'word' of wishbone interface | positive | 8 |
|  | add\_width\_g | The address width of wishbone interface | positive | 8 |
|  | single\_ram\_depth\_g | Number of lines in the basic RAM used in the core | positive | 10 |
|  | single\_ram\_width\_g | The width of the basic 'word' of the basic RAM used in the core | positive | 8 |

![](data:image/x-wmf;base64,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)

Pin table of core parts:

|  |  |  |  |
| --- | --- | --- | --- |
| Description | Width | Direction | Pin Name |
| Clock | 1 | In | Clk |
| Synchronous reset signal | 1 | In | Reset |
| Signal used for capturing data | 1 | In | trigger |
| The input signals which will be recorded | Num\_of\_signals\_g | in | input\_data |
|  |  |  | WBS |
|  |  |  | WBM |

|  |  |
| --- | --- |
| ~~Size(bit)~~ | ~~outputs~~ |
| ~~?~~ | ~~Wbm~~ |
| ~~[0..7]~~ | ~~Signals (recorded)~~ |

Write controller:

Get the recording configuration from the Gui, and record the data according it.

|  |  |  |  |
| --- | --- | --- | --- |
| Description | Width | Direction | Pin Name |
| Clock | 1 | In | Clk |
| Synchronous reset signal | 1 | In | Reset |
| Identify the trigger type in order to find it in the incoming signal | 5 | In | Trigger\_type |
| The percent from the recorded data that will appear before the trigger | 7 | in | Trigger\_position |
| 0-system off, we don't search for trigger rise (set at the beginning to 0 until all other registers are ready, change in second time after the trigger was found- don't continue to search for trigger rise)  1- system on, start search for trigger rise (changed by write controller after all other registers are in the right mode). | 1 | In\out | System\_status |
| Counts the number of clk cycles that passed since the system started working until trigger raised | 8 | out | Clk\_to\_start |
| Check in the RAM for trigger rise and determine according the trigger position the start and the end addresses of the recording data |  | in | RAM\_to\_wc |
| the start and the end addresses of the recorded data |  | out | Wc\_to\_rc |

|  |  |
| --- | --- |
| outputs | Size(bit) |
| Register\_3(system status) | [0..4] |
| Register\_4(start) | 5 |
| Read controller | [6.. |
| RAM | ? |

**Read controller:**

This is the unit which sends the data out through the WBM according the resent configuration.

|  |  |  |
| --- | --- | --- |
| Inputs | Size[bite] | Description |
| clk | 0 |  |
| reset | 1 |  |
| Register\_3(system status) | [2..6] |  |
| Register\_4(start) | 7 |  |
| Write controller | [8.. | Received the Address of the trigger and the recording depth, and with the trigger position register, find in the RAM the data that needs to send out |

|  |  |  |
| --- | --- | --- |
| Output | Size[bite] | Description |
| Register\_4(start) | 0 |  |
| Register\_3(system status) | [1..5] |  |
| Data\_out | [6..13] | Send the data out to the WBM |
| WBM | ? |  |

**RAM:**

The memory unit. The RAM is recording the incoming signals all the time, and when we find the correct configuration, the read controller read the data from the RAM.

|  |  |  |
| --- | --- | --- |
| Inputs | Size(bit) | Description |
| Clk | 0 |  |
| Reset | 1 | Din\_valid |
| Signals\_in | [2..9] | Incoming data to record (data in) |
| Write controller | [10..19] | Address in. put the incoming data in that address |
| Read controller | [20..28] | Address out. Take the output data from that address |

|  |  |  |
| --- | --- | --- |
| Outputs | Size(bit) | Description |
| Data\_out | [0..15]\*(# RAM) | output data to send out |
| Dout\_valid | 16 | '1' if the output data is valid |

שאלות

* האם לממש RAM קטן יותר או להשתמש ביחידה הבסיסית אפילו אם ההקלטה קטנה יותר (ביחידה בסיסית 4096 ביטים להקלטה)

יש GENERIC-ים לטובת הגודל והרוחב של ה- RAM הבסיסי.

* האם לקבוע גודל מקסימלי של הקלטה או שהמשתמש יכול להקליט כל מספר ביטים שהוא רוצה?

יש GENERIC, והכול צריך להיות תלוי ב- GENERICS-ים.

איך מייצגים את הבעיה כאשר צריך לשלוח את עומק ההקלטה בין היחידות במערכת (לדוגמא רוחב הפס בין READ-WRITE -> מצריך שליחת כתובת, תלוי ברוחב ההקלטה)

הכול צריך להיות תלוי ב- GENERIC-ים, ואם חסר GENERIC-ים שלא חשבנו עליהם אז יש להוסיף. ה- USER צריך לקבל גמישות מלאה.

* האם לRAM יש כניסת שעון וRESET

כן.

בהקצאת המקום עבור רגיסטר- SYSTEM STATUS לדוגמא, האם למרות שזה רגיסטר שרוחבו 8 ביט, בגלל שאנחנו משתמשים רק בביט אחד שלו אפשר להגיד שרוחבו 1 או שנידרש להקצות את כל רוחב הרגיסטר?(כרגע מוקצה לו רק ביט אחד)