

# Contents

|                                                                           |          |
|---------------------------------------------------------------------------|----------|
| <b>Bridge Index</b>                                                       | <b>1</b> |
| <b>Bridge: CSV-Based AXI4 Crossbar Generator - Specification</b> <b>1</b> |          |
| Document Organization . . . . .                                           | 2        |
| Chapter 0: Quick Start . . . . .                                          | 2        |
| Chapter 1: Overview . . . . .                                             | 2        |
| Chapter 2: Internal Block Architecture . . . . .                          | 2        |
| Chapter 3: AXI4 Interface Reference . . . . .                             | 2        |
| Chapter 4: CSV Generator . . . . .                                        | 3        |
| Chapter 5: Generated RTL . . . . .                                        | 3        |
| Chapter 6: Usage Examples . . . . .                                       | 3        |
| Quick Navigation . . . . .                                                | 4        |
| For RTL Designers . . . . .                                               | 4        |
| For System Architects . . . . .                                           | 4        |
| For Verification Engineers . . . . .                                      | 4        |
| For Protocol Reference . . . . .                                          | 4        |
| Key Features Documented . . . . .                                         | 4        |
| Phase 1 Features (Complete) . . . . .                                     | 4        |
| Phase 2 Features (Complete) . . . . .                                     | 4        |
| Phase 2+ Features (Complete - 2025-11-10) . . . . .                       | 5        |
| Future Enhancements (Planned) . . . . .                                   | 5        |
| Document Conventions . . . . .                                            | 5        |
| Notation . . . . .                                                        | 5        |
| Signal Naming . . . . .                                                   | 5        |
| CSV Notation . . . . .                                                    | 6        |
| Version History . . . . .                                                 | 6        |
| Related Documentation . . . . .                                           | 6        |

## Bridge Index

**Generated:** 2025-11-14

## Bridge: CSV-Based AXI4 Crossbar Generator - Specification

**Component:** Bridge - CSV-Based AXI4 Crossbar Generator **Version:** 0.90 **Last Updated:** 2025-11-14 **Status:** Phase 2+ Complete  
- Bridge ID Tracking Fully Implemented

---

## **Document Organization**

This specification documents the Bridge CSV-based AXI4 crossbar generator, which creates parameterized SystemVerilog crossbars from human-readable CSV configuration files.

### **Chapter 0: Quick Start**

**Location:** ch00\_quick\_start/

- 01\_installation.md - Installation and setup
- 02\_first\_bridge.md - Creating your first bridge
- 03\_simulation.md - Simulating the bridge
- 04\_integration.md - Integration into designs

### **Chapter 1: Overview**

**Location:** ch01\_overview/

- 01\_overview.md - What is Bridge, key features, and applications
- 02\_architecture.md - System architecture and design philosophy
- 03\_clocks\_and\_reset.md - Clocking and reset strategy
- 04\_acronyms.md - Acronyms and terminology
- 05\_references.md - References and related documents

### **Chapter 2: Internal Block Architecture**

**Location:** ch02\_blocks/

This chapter documents the internal functional blocks that make up the AXI4 bridge crossbar.

- 01\_master\_adapter.md - Master interface adaptation and ID extension
- 02\_slave\_router.md - Address decoding and slave selection
- 03\_crossbar\_core.md - Core switching fabric architecture
- 04\_arbitration.md - Multi-master arbitration schemes
- 05\_id\_management.md - Transaction ID tracking (CAM/FIFO)
- 06\_width\_conversion.md - Data width conversion logic
- 07\_protocol\_conversion.md - AXI4-to-APB protocol conversion
- 08\_response\_routing.md - Response path routing and merging
- 09\_error\_handling.md - Error detection and handling

### **Chapter 3: AXI4 Interface Reference**

**Location:** ch03\_interfaces/

Complete reference for all AXI4 signals, timing, and protocol rules used in the bridge.

- 01\_axi4\_signals.md - Write Address Channel (AW) detailed reference
- 02\_write\_data.md - Write Data Channel (W) specification
- 03\_write\_response.md - Write Response Channel (B) specification
- 04\_read\_address.md - Read Address Channel (AR) detailed reference
- 05\_read\_data.md - Read Data and Response Channel (R) specification

## **Chapter 4: CSV Generator**

**Location:** ch02\_csv\_generator/

- 04\_channel\_specific.md - Channel-specific masters (wr/rd/rw)

## **Chapter 5: Generated RTL**

**Location:** ch03\_generated\_rtl/

- 01\_module\_structure.md - Generated module organization
- 02\_arbiter\_fsms.md - AW/AR arbiter finite state machines
- 07\_bridge\_id\_tracking.md - Bridge ID tracking for multi-master response routing

**PlantUML Diagrams:** assets/puml/

- aw\_arbiter\_fsm.puml - AW channel arbiter FSM
- ar\_arbiter\_fsm.puml - AR channel arbiter FSM

**Graphviz Block Diagrams:** assets/graphviz/

- bridge\_2x2.gv - 2 master × 2 slave configuration
- bridge\_1x4.gv - 1 master × 4 slave configuration

## **Chapter 6: Usage Examples**

**Location:** ch04\_usage\_examples/

(To be documented - examples of bridge configuration and usage)

---

## **Quick Navigation**

### **For RTL Designers**

- Start with Quick Start Guide
- Review Overview
- Study Internal Blocks
- Reference AXI4 Signals

### **For System Architects**

- Start with Architecture Overview
- Review Crossbar Core
- Study Arbitration
- Review ID Management

### **For Verification Engineers**

- Start with Internal Blocks
- Review Error Handling
- Study AXI4 Protocol
- Review Generated RTL

### **For Protocol Reference**

- Complete AXI4 Signal Reference
  - Understand Channel Interactions
  - Study Out-of-Order Behavior
- 

## **Key Features Documented**

### **Phase 1 Features (Complete)**

- CSV configuration parsing
- Custom signal prefixes per port
- Mixed AXI4/APB protocol support
- Mixed data widths
- Partial connectivity matrices
- Automatic converter identification
- Port generation with custom prefixes

### **Phase 2 Features (Complete)**

- **Channel-Specific Masters** - Write-only (wr), read-only (rd), full (rw)

- Conditional AXI4 channel generation
- Optimized width converter instantiation
- Channel-aware direct connections
- Resource optimization for dedicated masters

### **Phase 2+ Features (Complete - 2025-11-10)**

- **Bridge ID Tracking** - Multi-master response routing with `bridge_id`
- Per-master unique BRIDGE\_ID parameter
- Slave adapter CAM/FIFO transaction tracking
- Configurable out-of-order support per slave (`enable_ooo`)
- Crossbar `bridge_id`-based response routing
- Zero-latency FIFO mode for in-order slaves
- 1-cycle CAM mode for out-of-order slaves

### **Future Enhancements (Planned)**

- **Monitored Interface Versions:** AXI4/AXIL4 master/slave monitor ports for debugging
    - `axi4_master_rd_mon.sv` / `axi4_master_wr_mon.sv`
    - `axi4_slave_rd_mon.sv` / `axi4_slave_wr_mon.sv`
    - `axil4_master_rd_mon.sv` / `axil4_master_wr_mon.sv`
    - `axil4_slave_rd_mon.sv` / `axil4_slave_wr_mon.sv`
    - monbus aggregation (similar to stream component `monbus_axil_group.sv`)
  - APB converter placeholder implementation
  - Slave-side width converter downsize
  - Variable-width crossbar internal data path
  - Performance monitoring integration
- 

## **Document Conventions**

### **Notation**

- **bold** - Important terms, file names
- `code` - CSV fields, signal names, commands
- *italic* - Emphasis, notes

### **Signal Naming**

- `{prefix}awaddr` - AXI4 Write Address channel address
- `{prefix}araddr` - AXI4 Read Address channel address
- `{prefix}paddr` - APB address

- `aclk` - AXI4 clock
- `aresetn` - AXI4 active-low reset
- `pclk` - APB clock
- `presetn` - APB active-low reset

## CSV Notation

- `port_name` - Unique identifier for port
  - `channels` - Channel specification: `rw/wr/rd`
  - `N/A` - Not applicable field value
- 

## Version History

| Version | Date       | Changes                                                                    |
|---------|------------|----------------------------------------------------------------------------|
| 1.0     | 2025-10-19 | Initial specification with Phase 1 features                                |
| 1.1     | 2025-10-26 | Added channel-specific master support (Phase 2)                            |
| 1.2     | 2025-11-10 | Added bridge ID tracking for multi-master routing (Phase 2+)               |
| 0.90    | 2025-11-14 | Added Chapter 2 (Internal Blocks) and Chapter 3 (AXI4 Interface Reference) |

---

## Related Documentation

- `../PRD.md` - Product Requirements Document
  - `../CLAUDE.md` - AI integration guide
  - `../CSV_BRIDGE_STATUS.md` - Implementation status and phase tracking
  - `../TASKS.md` - Development tasks
  - `../bin/bridge_csv_generator.py` - Generator source code
- 

**Next:** Chapter 0 - Quick Start or Chapter 1 - Overview