| /* |
| * Copyright 1999 Egbert Eich |
| * |
| * Permission to use, copy, modify, distribute, and sell this software and its |
| * documentation for any purpose is hereby granted without fee, provided that |
| * the above copyright notice appear in all copies and that both that |
| * copyright notice and this permission notice appear in supporting |
| * documentation, and that the name of the authors not be used in |
| * advertising or publicity pertaining to distribution of the software without |
| * specific, written prior permission. The authors makes no representations |
| * about the suitability of this software for any purpose. It is provided |
| * "as is" without express or implied warranty. |
| * |
| * THE AUTHORS DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, |
| * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO |
| * EVENT SHALL THE AUTHORS BE LIABLE FOR ANY SPECIAL, INDIRECT OR |
| * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, |
| * DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER |
| * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR |
| * PERFORMANCE OF THIS SOFTWARE. |
| */ |
| #include "debug.h" |
| #include "v86bios.h" |
| #include "x86emu.h" |
| |
| #ifdef __alpha__ |
| |
| void* vram_map = 0; |
| int sparse_shift = 5; |
| |
| #define mem_barrier() __asm__ __volatile__("mb" : : : "memory") |
| |
| #define vuip volatile unsigned int * |
| |
| CARD8 |
| mem_rb(CARD32 addr) |
| { |
| unsigned long result, shift; |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| shift = (addr & 0x3) * 8; |
| result = *(vuip) ((unsigned long)vram_map + (addr << sparse_shift)); |
| result >>= shift; |
| return 0xffUL & result; |
| } else |
| #endif |
| return rdb(addr); |
| } |
| |
| CARD16 |
| mem_rw(CARD32 addr) |
| { |
| unsigned long result, shift; |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| shift = (addr & 0x2) * 8; |
| result = *(vuip)((unsigned long)vram_map+(addr<<sparse_shift) |
| +(1<<(sparse_shift-2))); |
| result >>= shift; |
| return 0xffffUL & result; |
| } else |
| #endif |
| return rdw(addr); |
| } |
| |
| CARD32 |
| mem_rl(CARD32 addr) |
| { |
| unsigned long result; |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| result = *(vuip)((unsigned long)vram_map+(addr<<sparse_shift)+(3<<(sparse_shift-2))); |
| return result; |
| } else |
| #endif |
| return rdl(addr); |
| } |
| |
| void |
| mem_wb(CARD32 addr, CARD8 val) |
| { |
| unsigned int b = val & 0xffU; |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| *(vuip) ((unsigned long)vram_map + (addr << sparse_shift)) = b * 0x01010101; |
| mem_barrier(); |
| } else |
| #endif |
| wrb(addr,val); |
| } |
| |
| void |
| mem_ww(CARD32 addr, CARD16 val) |
| { |
| unsigned int w = val & 0xffffU; |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| *(vuip)((unsigned long)vram_map+(addr<<sparse_shift) |
| +(1<<(sparse_shift-2))) = w * 0x00010001; |
| mem_barrier(); |
| } else |
| #endif |
| wrw(addr,val); |
| } |
| |
| void |
| mem_wl(CARD32 addr, CARD32 val) |
| { |
| #if 1 |
| if (addr >= 0xA0000 && addr <= 0xBFFFF) { |
| addr -= 0xA0000; |
| *(vuip)((unsigned long)vram_map+(addr<<sparse_shift) |
| +(3<<(sparse_shift-2))) = val; |
| mem_barrier(); |
| } else |
| #endif |
| wrl(addr,val); |
| } |
| #endif |
| |
| |