source: soft/giet_vm/giet_drivers/mmc_driver.h @ 650

Last change on this file since 650 was 615, checked in by bellefin, 9 years ago

Introduce mmc distributed lock
The locks are distributed in the kernel heaps (one lock in each cluster) and there is a global table in the kernel data segment which contains the addresses of all the locks.
The _mmc_boot_mode variable is defined in boot.c and kernel_init.c and defines which kind of lock is used.
The distributed locks are initialized inside the kernel_init() function.

File size: 4.2 KB
RevLine 
[258]1///////////////////////////////////////////////////////////////////////////////////
2// File     : mmc_driver.h
3// Date     : 01/11/2013
4// Author   : alain greiner
5// Copyright (c) UPMC-LIP6
6///////////////////////////////////////////////////////////////////////////////////
7
8#ifndef _GIET_MMC_DRIVERS_H_
9#define _GIET_MMC_DRIVERS_H_
10
[481]11#include <hard_config.h>
[496]12#include <kernel_locks.h>
[615]13#include <kernel_malloc.h>
[481]14
[258]15///////////////////////////////////////////////////////////////////////////////////
16// TSAR Memory Cache configuration registers offsets and commands
17///////////////////////////////////////////////////////////////////////////////////
18
[496]19enum SoclibMemCacheFunc
20{
21    MEMC_CONFIG = 0,
22    MEMC_INSTRM = 1,
23    MEMC_RERROR = 2,
24
25    MEMC_FUNC_SPAN = 0x200
26};
27
[258]28enum SoclibMemCacheConfigRegs
29{
30    MEMC_ADDR_LO,
31    MEMC_ADDR_HI,
32    MEMC_BUF_LENGTH,
33    MEMC_CMD_TYPE
34};
35
36enum SoclibMemCacheConfigCmd
37{
38    MEMC_CMD_NOP,
39    MEMC_CMD_INVAL,
40    MEMC_CMD_SYNC
41};
42
[496]43enum SoclibMemCacheInstrRegs {
[345]44
[496]45    // NUMBER OF LOCAL TRANSACTIONS ON DIRECT NETWORK
[481]46
[496]47    MEMC_LOCAL_READ_LO   = 0x00,
48    MEMC_LOCAL_READ_HI   = 0x01,
49    MEMC_LOCAL_WRITE_LO  = 0x02,
50    MEMC_LOCAL_WRITE_HI  = 0x03,
51    MEMC_LOCAL_LL_LO     = 0x04,
52    MEMC_LOCAL_LL_HI     = 0x05,
53    MEMC_LOCAL_SC_LO     = 0x06,
54    MEMC_LOCAL_SC_HI     = 0x07,
55    MEMC_LOCAL_CAS_LO    = 0x08,
56    MEMC_LOCAL_CAS_HI    = 0x09,
[481]57
[496]58    // NUMBER OF REMOTE TRANSACTIONS ON DIRECT NETWORK
59
60    MEMC_REMOTE_READ_LO  = 0x10,
61    MEMC_REMOTE_READ_HI  = 0x11,
62    MEMC_REMOTE_WRITE_LO = 0x12,
63    MEMC_REMOTE_WRITE_HI = 0x13,
64    MEMC_REMOTE_LL_LO    = 0x14,
65    MEMC_REMOTE_LL_HI    = 0x15,
66    MEMC_REMOTE_SC_LO    = 0x16,
67    MEMC_REMOTE_SC_HI    = 0x17,
68    MEMC_REMOTE_CAS_LO   = 0x18,
69    MEMC_REMOTE_CAS_HI   = 0x19,
70
71    // COST OF TRANSACTIONS ON DIRECT NETWORK
72
73    MEMC_COST_READ_LO    = 0x20,
74    MEMC_COST_READ_HI    = 0x21,
75    MEMC_COST_WRITE_LO   = 0x22,
76    MEMC_COST_WRITE_HI   = 0x23,
77    MEMC_COST_LL_LO      = 0x24,
78    MEMC_COST_LL_HI      = 0x25,
79    MEMC_COST_SC_LO      = 0x26,
80    MEMC_COST_SC_HI      = 0x27,
81    MEMC_COST_CAS_LO     = 0x28,
82    MEMC_COST_CAS_HI     = 0x29,
83
84    // NUMBER OF LOCAL TRANSACTIONS ON CC NETWORK
85
86    MEMC_LOCAL_MUPDATE_LO  = 0x40,
87    MEMC_LOCAL_MUPDATE_HI  = 0x41,
88    MEMC_LOCAL_MINVAL_LO   = 0x42,
89    MEMC_LOCAL_MINVAL_HI   = 0x43,
90    MEMC_LOCAL_CLEANUP_LO  = 0x44,
91    MEMC_LOCAL_CLEANUP_HI  = 0x45,
92
93    // NUMBER OF REMOTE TRANSACTIONS ON CC NETWORK
94
95    MEMC_REMOTE_MUPDATE_LO = 0x50,
96    MEMC_REMOTE_MUPDATE_HI = 0x51,
97    MEMC_REMOTE_MINVAL_LO  = 0x52,
98    MEMC_REMOTE_MINVAL_HI  = 0x53,
99    MEMC_REMOTE_CLEANUP_LO = 0x54,
100    MEMC_REMOTE_CLEANUP_HI = 0x55,
101
102    // COST OF TRANSACTIONS ON CC NETWORK
103
104    MEMC_COST_MUPDATE_LO   = 0x60,
105    MEMC_COST_MUPDATE_HI   = 0x61,
106    MEMC_COST_MINVAL_LO    = 0x62,
107    MEMC_COST_MINVAL_HI    = 0x63,
108    MEMC_COST_CLEANUP_LO   = 0x64,
109    MEMC_COST_CLEANUP_HI   = 0x65,
110
111    // TOTAL
112
113    MEMC_TOTAL_MUPDATE_LO  = 0x68,
114    MEMC_TOTAL_MUPDATE_HI  = 0x69,
115    MEMC_TOTAL_MINVAL_LO   = 0x6A,
116    MEMC_TOTAL_MINVAL_HI   = 0x6B,
117    MEMC_TOTAL_BINVAL_LO   = 0x6C,
118    MEMC_TOTAL_BINVAL_HI   = 0x6D,
119};
120
121#define MMC_REG(func,idx) ((func<<7)|idx)
122
[258]123///////////////////////////////////////////////////////////////////////////////////
124// MEMC access functions (for TSAR architecture)
125///////////////////////////////////////////////////////////////////////////////////
126
[615]127extern void _mmc_init_locks();
128
[496]129extern unsigned int _mmc_instrument( unsigned int x,
130                                     unsigned int y,
131                                     unsigned int reg );
132
[297]133extern void _mmc_inval( unsigned long long buf_paddr, 
134                        unsigned int buf_length );
[258]135
[297]136extern void _mmc_sync(  unsigned long long buf_paddr, 
137                        unsigned int buf_length);
[258]138
[297]139extern void _mmc_isr( unsigned int irq_type,
140                      unsigned int irq_id,
141                      unsigned int channel );
142
[258]143///////////////////////////////////////////////////////////////////////////////////
144
145#endif
146
147// Local Variables:
148// tab-width: 4
149// c-basic-offset: 4
150// c-file-offsets:((innamespace . 0)(inline-open . 0))
151// indent-tabs-mode: nil
152// End:
153// vim: filetype=c:expandtab:shiftwidth=4:tabstop=4:softtabstop=4
154
Note: See TracBrowser for help on using the repository browser.