~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/arch/nios2/mm/dma-mapping.c

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /arch/nios2/mm/dma-mapping.c (Version linux-6.12-rc7) and /arch/ppc/mm/dma-mapping.c (Version linux-4.19.323)


  1 /*                                                  1 
  2  * Copyright (C) 2011 Tobias Klauser <tklauser    
  3  * Copyright (C) 2009 Wind River Systems Inc      
  4  *  Implemented by fredrik.markstrom@gmail.com    
  5  *                                                
  6  * Based on DMA code from MIPS.                   
  7  *                                                
  8  * This file is subject to the terms and condi    
  9  * License.  See the file "COPYING" in the mai    
 10  * for more details.                              
 11  */                                               
 12                                                   
 13 #include <linux/types.h>                          
 14 #include <linux/mm.h>                             
 15 #include <linux/string.h>                         
 16 #include <linux/dma-mapping.h>                    
 17 #include <linux/io.h>                             
 18 #include <linux/cache.h>                          
 19 #include <asm/cacheflush.h>                       
 20                                                   
 21 void arch_sync_dma_for_device(phys_addr_t padd    
 22                 enum dma_data_direction dir)      
 23 {                                                 
 24         void *vaddr = phys_to_virt(paddr);        
 25                                                   
 26         switch (dir) {                            
 27         case DMA_FROM_DEVICE:                     
 28                 invalidate_dcache_range((unsig    
 29                         (unsigned long)(vaddr     
 30                 break;                            
 31         case DMA_TO_DEVICE:                       
 32                 /*                                
 33                  * We just need to flush the c    
 34                  * instruction will do both wr    
 35                  */                               
 36         case DMA_BIDIRECTIONAL: /* flush and i    
 37                 flush_dcache_range((unsigned l    
 38                         (unsigned long)(vaddr     
 39                 break;                            
 40         default:                                  
 41                 BUG();                            
 42         }                                         
 43 }                                                 
 44                                                   
 45 void arch_sync_dma_for_cpu(phys_addr_t paddr,     
 46                 enum dma_data_direction dir)      
 47 {                                                 
 48         void *vaddr = phys_to_virt(paddr);        
 49                                                   
 50         switch (dir) {                            
 51         case DMA_BIDIRECTIONAL:                   
 52         case DMA_FROM_DEVICE:                     
 53                 invalidate_dcache_range((unsig    
 54                         (unsigned long)(vaddr     
 55                 break;                            
 56         case DMA_TO_DEVICE:                       
 57                 break;                            
 58         default:                                  
 59                 BUG();                            
 60         }                                         
 61 }                                                 
 62                                                   
 63 void arch_dma_prep_coherent(struct page *page,    
 64 {                                                 
 65         unsigned long start = (unsigned long)p    
 66                                                   
 67         flush_dcache_range(start, start + size    
 68 }                                                 
 69                                                   
 70 void *arch_dma_set_uncached(void *ptr, size_t     
 71 {                                                 
 72         unsigned long addr = (unsigned long)pt    
 73                                                   
 74         addr |= CONFIG_NIOS2_IO_REGION_BASE;      
 75                                                   
 76         return (void *)ptr;                       
 77 }                                                 
 78                                                   

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php