wiki:mmc_driver

Version 5 (modified by alain, 10 years ago) (diff)

--

GIET_VM / MMC Driver

The mmc_driver.c and mmc_driver.h files define the MMC driver.

The vci_mem_cache component is a L2 cache controller specifically designed for the TSAR architecture. It contains 3 types of addressable registers:

  • configuration registers support coherence between L2 and L3 caches.
  • instrumentation registers define various hardware event counters.
  • error report registers contain informations on address errors reported by the L2 cache.

The MMC component is a replicated peripheral, as it exist one MMC component per cluster.

The virtual base address of the segment associated to the component is:

vbase = SEG_MMC_BASE + cluster_xy * PERI_CLUSTER_INCREMENT

The SEG_MMC_BASE and PERI_CLUSTER_INCREMENT variables must be defined in the hard_config.h file.

The addressable registers map and command codes are defined here.

Configuration registers

void _mmc_inval( unsigned long long buf_paddr, unsigned int buf_length )

This function invalidates all cache lines covering a memory buffer defined by the physical base address, and the length. The buffer address MSB are used to compute the cluster index.

void _mmc_sync( unsigned long long buf_paddr, unsigned int buf_length)

This function copies to external RAM all cache lines covering a memory buffer defined by the physical base address, and the length, if they are dirty. The buffer address MSB are used to compute the cluster index.

Instrumentation registers

unsigned int _mmc_get_instrument( unsigned int x, unsigned int y, unsigned int reg )

This function returns the value contained in a specific register of a specific L2 cache.

  • x cluster X coordinate
  • y cluster Y coordinate
  • reg register index

Error registers

void _mmc_isr( unsigned int irq_type, unsigned int irq_id, unsigned int channel )

This Interrupt Service Routine should access the vci_mem_cache component to get the faulty physical address and the associated SRCID, and acknowledges the IRQ... but it is not fully implemented yet...