[PATCH 4/6] arm: Clean up asm/io.h

Andre Przywara andre.przywara at arm.com
Sun Jan 9 22:39:03 CET 2022


On Sun,  9 Jan 2022 17:30:07 +0000
Andre Przywara <andre.przywara at arm.com> wrote:

Hi Rick, Leo:

> asm/io.h is the header file containing the central MMIO accessor macros.
> Judging by the header and the comments, it was apparently once copied
> from the Linux kernel, but has deviated since then *heavily*. There is
> absolutely no point in staying close to the original Linux code anymore,
> so just remove the old cruft, by:
> - removing pointless Linux history
> - removing commented code
> - removing outdated comments
> - removing unused definitions (for mem_isa)
> 
> This massively improves the readability of the file.

it looks like arch/risc-v/include/asm/io.h is a copy of the ARM
version, and includes the same pointless legacy. You might want to
remove those parts there as well.

Cheers,
Andre

> Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> ---
>  arch/arm/include/asm/io.h | 98 +--------------------------------------
>  1 file changed, 2 insertions(+), 96 deletions(-)
> 
> diff --git a/arch/arm/include/asm/io.h b/arch/arm/include/asm/io.h
> index 36b840378a9..89b1015bc4d 100644
> --- a/arch/arm/include/asm/io.h
> +++ b/arch/arm/include/asm/io.h
> @@ -1,45 +1,26 @@
>  /*
> - *  linux/include/asm-arm/io.h
> + * I/O device access primitives. Based on early versions from the Linux kernel.
>   *
>   *  Copyright (C) 1996-2000 Russell King
>   *
>   * This program is free software; you can redistribute it and/or modify
>   * it under the terms of the GNU General Public License version 2 as
>   * published by the Free Software Foundation.
> - *
> - * Modifications:
> - *  16-Sep-1996	RMK	Inlined the inx/outx functions & optimised for both
> - *			constant addresses and variable addresses.
> - *  04-Dec-1997	RMK	Moved a lot of this stuff to the new architecture
> - *			specific IO header files.
> - *  27-Mar-1999	PJB	Second parameter of memcpy_toio is const..
> - *  04-Apr-1999	PJB	Added check_signature.
> - *  12-Dec-1999	RMK	More cleanups
> - *  18-Jun-2000 RMK	Removed virt_to_* and friends definitions
>   */
>  #ifndef __ASM_ARM_IO_H
>  #define __ASM_ARM_IO_H
>  
> -#ifdef __KERNEL__
> -
>  #include <linux/types.h>
>  #include <linux/kernel.h>
>  #include <asm/byteorder.h>
>  #include <asm/memory.h>
>  #include <asm/barriers.h>
> -#if 0	/* XXX###XXX */
> -#include <asm/arch/hardware.h>
> -#endif	/* XXX###XXX */
>  
>  static inline void sync(void)
>  {
>  }
>  
> -/*
> - * Generic virtual read/write.  Note that we don't support half-word
> - * read/writes.  We define __arch_*[bl] here, and leave __arch_*w
> - * to the architecture specific code.
> - */
> +/* Generic virtual read/write. */
>  #define __arch_getb(a)			(*(volatile unsigned char *)(a))
>  #define __arch_getw(a)			(*(volatile unsigned short *)(a))
>  #define __arch_getl(a)			(*(volatile unsigned int *)(a))
> @@ -247,13 +228,6 @@ static inline void __raw_readsl(unsigned long addr, void *data, int longlen)
>  #define setbits_64(addr, set) setbits(64, addr, set)
>  #define clrsetbits_64(addr, clear, set) clrsetbits(64, addr, clear, set)
>  
> -/*
> - * Now, pick up the machine-defined IO definitions
> - */
> -#if 0	/* XXX###XXX */
> -#include <asm/arch/io.h>
> -#endif	/* XXX###XXX */
> -
>  /*
>   *  IO port access primitives
>   *  -------------------------
> @@ -317,16 +291,6 @@ static inline void __raw_readsl(unsigned long addr, void *data, int longlen)
>  #define writesb(a, d, s)	__raw_writesb((unsigned long)a, d, s)
>  #define readsb(a, d, s)		__raw_readsb((unsigned long)a, d, s)
>  
> -/*
> - * DMA-consistent mapping functions.  These allocate/free a region of
> - * uncached, unwrite-buffered mapped memory space for use with DMA
> - * devices.  This is the "generic" version.  The PCI specific version
> - * is in pci.h
> - */
> -extern void *consistent_alloc(int gfp, size_t size, dma_addr_t *handle);
> -extern void consistent_free(void *vaddr, size_t size, dma_addr_t handle);
> -extern void consistent_sync(void *vaddr, size_t size, int rw);
> -
>  /*
>   * String version of IO memory access ops:
>   */
> @@ -334,8 +298,6 @@ extern void _memcpy_fromio(void *, unsigned long, size_t);
>  extern void _memcpy_toio(unsigned long, const void *, size_t);
>  extern void _memset_io(unsigned long, int, size_t);
>  
> -extern void __readwrite_bug(const char *fn);
> -
>  /* Optimized copy functions to read from/write to IO sapce */
>  #ifdef CONFIG_ARM64
>  #include <cpu_func.h>
> @@ -441,62 +403,6 @@ void __memset_io(volatile void __iomem *dst, int c, size_t count)
>  #define memcpy_toio(a, b, c)		memcpy((void *)(a), (b), (c))
>  #endif
>  
> -/*
> - * If this architecture has ISA IO, then define the isa_read/isa_write
> - * macros.
> - */
> -#ifdef __mem_isa
> -
> -#define isa_readb(addr)			__raw_readb(__mem_isa(addr))
> -#define isa_readw(addr)			__raw_readw(__mem_isa(addr))
> -#define isa_readl(addr)			__raw_readl(__mem_isa(addr))
> -#define isa_writeb(val,addr)		__raw_writeb(val,__mem_isa(addr))
> -#define isa_writew(val,addr)		__raw_writew(val,__mem_isa(addr))
> -#define isa_writel(val,addr)		__raw_writel(val,__mem_isa(addr))
> -#define isa_memset_io(a,b,c)		_memset_io(__mem_isa(a),(b),(c))
> -#define isa_memcpy_fromio(a,b,c)	_memcpy_fromio((a),__mem_isa(b),(c))
> -#define isa_memcpy_toio(a,b,c)		_memcpy_toio(__mem_isa((a)),(b),(c))
> -
> -#define isa_eth_io_copy_and_sum(a,b,c,d) \
> -				eth_copy_and_sum((a),__mem_isa(b),(c),(d))
> -
> -static inline int
> -isa_check_signature(unsigned long io_addr, const unsigned char *signature,
> -		    int length)
> -{
> -	int retval = 0;
> -	do {
> -		if (isa_readb(io_addr) != *signature)
> -			goto out;
> -		io_addr++;
> -		signature++;
> -		length--;
> -	} while (length);
> -	retval = 1;
> -out:
> -	return retval;
> -}
> -
> -#else	/* __mem_isa */
> -
> -#define isa_readb(addr)			(__readwrite_bug("isa_readb"),0)
> -#define isa_readw(addr)			(__readwrite_bug("isa_readw"),0)
> -#define isa_readl(addr)			(__readwrite_bug("isa_readl"),0)
> -#define isa_writeb(val,addr)		__readwrite_bug("isa_writeb")
> -#define isa_writew(val,addr)		__readwrite_bug("isa_writew")
> -#define isa_writel(val,addr)		__readwrite_bug("isa_writel")
> -#define isa_memset_io(a,b,c)		__readwrite_bug("isa_memset_io")
> -#define isa_memcpy_fromio(a,b,c)	__readwrite_bug("isa_memcpy_fromio")
> -#define isa_memcpy_toio(a,b,c)		__readwrite_bug("isa_memcpy_toio")
> -
> -#define isa_eth_io_copy_and_sum(a,b,c,d) \
> -				__readwrite_bug("isa_eth_io_copy_and_sum")
> -
> -#define isa_check_signature(io,sig,len)	(0)
> -
> -#endif	/* __mem_isa */
> -#endif	/* __KERNEL__ */
> -
>  #include <asm-generic/io.h>
>  #include <iotrace.h>
>  



More information about the U-Boot mailing list