A newer version of this document is available. Customers should click here to go to the newest version.
                                                            
                                                            
                                                                
                                                                
                                                                    3.3.6.1.1. Machine Status Register (mstatus)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    3.3.6.1.2. Machine Trap-Vector Base-Address Register (mtvec)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    3.3.6.1.3. Machine Interrupt Register (mip and mie)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    3.3.6.1.4. Machine Exception Program Counter Register (mepc)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    3.3.6.1.5. Machine Cause Register (mcause)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    3.3.6.1.6. Machine Trap Value Register (mtval)
                                                                
                                                                
                                                            
                                                        
                                                    
                                    
                                    
                                        
                                        
                                            4.3.1. General-Purpose Register File
                                        
                                        
                                    
                                        
                                            4.3.2. Shadow Register
                                        
                                        
                                        
                                    
                                        
                                        
                                            4.3.3. Arithmetic Logic Unit
                                        
                                        
                                    
                                        
                                        
                                            4.3.4. Multipy and Divide Units
                                        
                                        
                                    
                                        
                                            4.3.5. Floating-Point Unit
                                        
                                        
                                        
                                    
                                        
                                        
                                            4.3.6. Custom Instruction
                                        
                                        
                                    
                                        
                                        
                                            4.3.7. Instruction Cycles
                                        
                                        
                                    
                                        
                                        
                                            4.3.8. Reset and Debug Signals
                                        
                                        
                                    
                                        
                                        
                                            4.3.9. Control and Status Registers
                                        
                                        
                                    
                                        
                                            4.3.10. Trap Controller (CLINT)
                                        
                                        
                                        
                                    
                                        
                                            4.3.11. Trap Controller (CLIC)
                                        
                                        
                                        
                                    
                                        
                                            4.3.12. Memory and I/O Organization
                                        
                                        
                                        
                                    
                                        
                                            4.3.13. RISC-V based Debug Module
                                        
                                        
                                        
                                    
                                        
                                            4.3.14. Error Correction Code (ECC)
                                        
                                        
                                        
                                    
                                        
                                        
                                            4.3.15. Branch Prediction
                                        
                                        
                                    
                                        
                                        
                                            4.3.16. Lockstep Module
                                        
                                        
                                    
                                
                            
                                                            
                                                            
                                                                
                                                                
                                                                    4.3.10.1.1. Machine Status Register (mstatus)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.2. Machine Trap-Vector Base-Address Register (mtvec)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.3. Machine Interrupt Register (mip and mie)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.4. Machine Exception Program Counter Register (mepc)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.5. Machine Cause Register (mcause)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.6. Machine Trap Value Register (mtval)
                                                                
                                                                
                                                            
                                                                
                                                                
                                                                    4.3.10.1.7. Machine Second Trap Value Register (mtval2)
                                                                
                                                                
                                                            
                                                        
                                                    
                                                                        
                                                                        
                                                                            
                                                                            
                                                                                4.3.11.1.3.1. Machine Trap-handler Vector Table base address Register (mtvt)
                                                                            
                                                                            
                                                                        
                                                                            
                                                                            
                                                                                4.3.11.1.3.2. Machine Next Interrupt Handler Address and Interrupt Enable Register (mnxti)
                                                                            
                                                                            
                                                                        
                                                                            
                                                                            
                                                                                4.3.11.1.3.3. Machine Interrupt Status Register (mintstatus)
                                                                            
                                                                            
                                                                        
                                                                            
                                                                            
                                                                                4.3.11.1.3.4. Machine Interrupt-Level Threshold Register (mintthresh)
                                                                            
                                                                            
                                                                        
                                                                            
                                                                            
                                                                                4.3.11.1.3.5. Machine Scratch Swap for Interrupt-Level Register (mscratchcswl)
                                                                            
                                                                            
                                                                        
                                                                    
                                                                4.3.12.4.3. Using Tightly Coupled Memory Effectively
 A system can use TCM to achieve maximum performance for accessing a specific code or data section. For example, interrupt-intensive applications can place exception handler code into a TCM to minimize interrupt latency. Similarly, compute-intensive digital signal processing (DSP) applications can place data buffers into TCM for the fastest possible data access. 
  
 
  You can implement one or more of the following functions or modules using TCMs to enhance the performance of your system:
- Constant access time with no arbitration delays.
- Separate exception stack for use only while handling interrupts.
- Fast data buffers
- Fast sections of code: 
    - Fast interrupt handler
- Critical loop
 
If the application’s memory requirements are small enough to fit entirely on-chip, it is possible to use tightly coupled memory exclusively for code and data. Larger applications must selectively choose what to include in tightly coupled memory to maximize the cost-performance trade-off.
Consider the following design when using TCMs:
- Strike a balance between the speed enhancement from caches with the higher speed enhancement from TCMs.
- Divide the on-chip memory resources equitably for the best combination of TCMs and cache.
- Locating any information (code or data) within TCMs eliminates cache overhead such as cache flushing, loading, or invalidating.
   Note: You can connect  Nios® V processor data manager to instruction TCM subordinate port. Like  Nios® II processor, the Instruction TCM can map into the processor's data region for memory debugging. 
  
 
 
   Related Information