 898305806a
			
		
	
	
	898305806a
	
	
	
		
			
			This patch fixes the many sparse errors and warnings contained in the
initial submission of the Altera Triple Speed Ethernet driver, and a
few minor cppcheck warnings. Changes are tested on ARM and NIOS2
example designs, and compile tested against multiple architectures.
Typical issues addressed were as follows:
altera_tse_ethtool.c:136:19: warning: incorrect type in argument
    1 (different address spaces)
altera_tse_ethtool.c:136:19:    expected void const volatile
    [noderef] <asn:2>*addr
altera_tse_ethtool.c:136:19:    got unsigned int *<noident>
...
altera_sgdma.c:129:31: warning: cast removes address space of
    expression
Signed-off-by: Vince Bridgers <vbridgers2013@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
		
	
			
		
			
				
	
	
		
			44 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| /* Altera TSE SGDMA and MSGDMA Linux driver
 | |
|  * Copyright (C) 2014 Altera Corporation. All rights reserved
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or modify it
 | |
|  * under the terms and conditions of the GNU General Public License,
 | |
|  * version 2, as published by the Free Software Foundation.
 | |
|  *
 | |
|  * This program is distributed in the hope it will be useful, but WITHOUT
 | |
|  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 | |
|  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 | |
|  * more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License along with
 | |
|  * this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #include "altera_tse.h"
 | |
| #include "altera_utils.h"
 | |
| 
 | |
| void tse_set_bit(void __iomem *ioaddr, size_t offs, u32 bit_mask)
 | |
| {
 | |
| 	u32 value = csrrd32(ioaddr, offs);
 | |
| 	value |= bit_mask;
 | |
| 	csrwr32(value, ioaddr, offs);
 | |
| }
 | |
| 
 | |
| void tse_clear_bit(void __iomem *ioaddr, size_t offs, u32 bit_mask)
 | |
| {
 | |
| 	u32 value = csrrd32(ioaddr, offs);
 | |
| 	value &= ~bit_mask;
 | |
| 	csrwr32(value, ioaddr, offs);
 | |
| }
 | |
| 
 | |
| int tse_bit_is_set(void __iomem *ioaddr, size_t offs, u32 bit_mask)
 | |
| {
 | |
| 	u32 value = csrrd32(ioaddr, offs);
 | |
| 	return (value & bit_mask) ? 1 : 0;
 | |
| }
 | |
| 
 | |
| int tse_bit_is_clear(void __iomem *ioaddr, size_t offs, u32 bit_mask)
 | |
| {
 | |
| 	u32 value = csrrd32(ioaddr, offs);
 | |
| 	return (value & bit_mask) ? 0 : 1;
 | |
| }
 |