Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 | /* * This file is subject to the terms and conditions of the GNU General Public * License. See the file "COPYING" in the main directory of this archive * for more details. * * Low level I/O functions for Jazz family machines. * * Copyright (C) 1997 by Ralf Baechle. */ #include <linux/string.h> #include <linux/spinlock.h> #include <asm/addrspace.h> #include <asm/system.h> #include <asm/jazz.h> /* * Map an 16mb segment of the EISA address space to 0xe3000000; */ static inline void map_eisa_address(unsigned long address) { /* XXX */ /* We've got an wired entry in the TLB. We just need to modify it. fast and clean. But since we want to get rid of wired entries things are a little bit more complicated ... */ } static unsigned char jazz_readb(unsigned long addr) { unsigned char res; map_eisa_address(addr); addr &= 0xffffff; res = *(volatile unsigned char *) (JAZZ_EISA_BASE + addr); return res; } static unsigned short jazz_readw(unsigned long addr) { unsigned short res; map_eisa_address(addr); addr &= 0xffffff; res = *(volatile unsigned char *) (JAZZ_EISA_BASE + addr); return res; } static unsigned int jazz_readl(unsigned long addr) { unsigned int res; map_eisa_address(addr); addr &= 0xffffff; res = *(volatile unsigned char *) (JAZZ_EISA_BASE + addr); return res; } static void jazz_writeb(unsigned char val, unsigned long addr) { map_eisa_address(addr); addr &= 0xffffff; *(volatile unsigned char *) (JAZZ_EISA_BASE + addr) = val; } static void jazz_writew(unsigned short val, unsigned long addr) { map_eisa_address(addr); addr &= 0xffffff; *(volatile unsigned char *) (JAZZ_EISA_BASE + addr) = val; } static void jazz_writel(unsigned int val, unsigned long addr) { map_eisa_address(addr); addr &= 0xffffff; *(volatile unsigned char *) (JAZZ_EISA_BASE + addr) = val; } static void jazz_memset_io(unsigned long addr, int val, unsigned long len) { unsigned long waddr; waddr = JAZZ_EISA_BASE | (addr & 0xffffff); while(len) { unsigned long fraglen; fraglen = (~addr + 1) & 0xffffff; fraglen = (fraglen < len) ? fraglen : len; map_eisa_address(addr); memset((char *)waddr, val, fraglen); addr += fraglen; waddr = waddr + fraglen - 0x1000000; len -= fraglen; } } static void jazz_memcpy_fromio(unsigned long to, unsigned long from, unsigned long len) { unsigned long waddr; waddr = JAZZ_EISA_BASE | (from & 0xffffff); while(len) { unsigned long fraglen; fraglen = (~from + 1) & 0xffffff; fraglen = (fraglen < len) ? fraglen : len; map_eisa_address(from); memcpy((void *)to, (void *)waddr, fraglen); to += fraglen; from += fraglen; waddr = waddr + fraglen - 0x1000000; len -= fraglen; } } static void jazz_memcpy_toio(unsigned long to, unsigned long from, unsigned long len) { unsigned long waddr; waddr = JAZZ_EISA_BASE | (to & 0xffffff); while(len) { unsigned long fraglen; fraglen = (~to + 1) & 0xffffff; fraglen = (fraglen < len) ? fraglen : len; map_eisa_address(to); memcpy((char *)to + JAZZ_EISA_BASE, (void *)from, fraglen); to += fraglen; from += fraglen; waddr = waddr + fraglen - 0x1000000; len -= fraglen; } } |