From 03ae5c117a66e4db4ed6b55c789aa2ff8b3e244d Mon Sep 17 00:00:00 2001 From: Rudolf Marek Date: Tue, 16 Mar 2010 23:59:19 +0000 Subject: Add MS-DOS crosscompilation support Tested, works fine. Part 1: Code changes. Corresponding to flashrom svn r944. Signed-off-by: Rudolf Marek Acked-by: Carl-Daniel Hailfinger --- hwaccess.c | 43 +++++++++++++++++++++++++++++++++++- hwaccess.h | 18 ++++++++++++++++ physmap.c | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 3 files changed, 132 insertions(+), 2 deletions(-) diff --git a/hwaccess.c b/hwaccess.c index 7f7b805..10e67bd 100644 --- a/hwaccess.c +++ b/hwaccess.c @@ -36,7 +36,9 @@ void get_io_perms(void) if (sysi86(SI86V86, V86SC_IOPL, PS_IOPL) != 0) { #elif defined(__FreeBSD__) || defined (__DragonFly__) if ((io_fd = open("/dev/io", O_RDWR)) < 0) { -#else +#elif __DJGPP__ + if (0) { +#else if (iopl(3) != 0) { #endif fprintf(stderr, "ERROR: Could not get I/O privileges (%s).\n" @@ -52,6 +54,44 @@ void release_io_perms(void) #endif } +#ifdef __DJGPP__ + +extern unsigned short segFS; + +#include + +void mmio_writeb(uint8_t val, void *addr) +{ + _farpokeb(segFS, (unsigned long) addr, val); +} + +void mmio_writew(uint16_t val, void *addr) +{ + _farpokew(segFS, (unsigned long) addr, val); +} + +void mmio_writel(uint32_t val, void *addr) +{ + _farpokel(segFS, (unsigned long) addr, val); +} + +uint8_t mmio_readb(void *addr) +{ + return _farpeekb(segFS, (unsigned long) addr); +} + +uint16_t mmio_readw(void *addr) +{ + return _farpeekw(segFS, (unsigned long) addr); +} + +uint32_t mmio_readl(void *addr) +{ + return _farpeekl(segFS, (unsigned long) addr); +} + +#else + void mmio_writeb(uint8_t val, void *addr) { *(volatile uint8_t *) addr = val; @@ -81,3 +121,4 @@ uint32_t mmio_readl(void *addr) { return *(volatile uint32_t *) addr; } +#endif diff --git a/hwaccess.h b/hwaccess.h index 06817ab..7a76925 100644 --- a/hwaccess.h +++ b/hwaccess.h @@ -68,12 +68,30 @@ #define INW inw #define INL inl #else + +#ifdef __DJGPP__ + +#include + + #define OUTB(x,y) outportb(y, x) + #define OUTW(x,y) outportw(y, x) + #define OUTL(x,y) outportl(y, x) + + #define INB inportb + #define INW inportw + #define INL inportl + +#else + #define OUTB outb #define OUTW outw #define OUTL outl #define INB inb #define INW inw #define INL inl + +#endif + #endif #endif diff --git a/physmap.c b/physmap.c index fba7a53..38a395c 100644 --- a/physmap.c +++ b/physmap.c @@ -4,6 +4,7 @@ * Copyright (C) 2009 Peter Stuge * Copyright (C) 2009 coresystems GmbH * Copyright (C) 2010 Carl-Daniel Hailfinger + * Copyright (C) 2010 Rudolf Marek * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -27,7 +28,77 @@ #include #include "flash.h" -#ifdef __DARWIN__ +#ifdef __DJGPP__ +#include + +#define MEM_DEV "dpmi" + +unsigned short segFS = 0; + +void *sys_physmap(unsigned long phys_addr, size_t len) +{ + int ret; + __dpmi_meminfo mi; + + if (segFS == 0) { + segFS = __dpmi_allocate_ldt_descriptors (1); + __dpmi_set_segment_base_address (segFS, 0x0); + __dpmi_set_segment_limit (segFS, 0xffffffff); + } + + mi.address = phys_addr; + mi.size = len; + ret = __dpmi_physical_address_mapping (&mi); + + if (ret != 0) { + return NULL; + } + + return (void *) mi.address; +} + +#define sys_physmap_rw_uncached sys_physmap + +#include +#include +#include + +static void *realmem_cpy; + +void *sys_physmap_ro_cached(unsigned long phys_addr, size_t len) +{ + /* no support for not a 1MB of mem */ + if ((phys_addr + len) > 1024*1024) + return NULL; + + if (realmem_cpy) + return realmem_cpy + phys_addr; + + realmem_cpy = valloc(1024*1024); + + if (!realmem_cpy) + return NULL; + + movedata(_dos_ds, 0, _my_ds(), (unsigned long) realmem_cpy, 1024*1024); + return realmem_cpy + phys_addr; +} + + +void physunmap(void *virt_addr, size_t len) +{ + __dpmi_meminfo mi; + + /* we ignore unmaps for our cheat 1MB copy */ + if ((virt_addr >= realmem_cpy) && ((virt_addr + len) <= (realmem_cpy + 1024*1024))) { + return; + } + + mi.address = (unsigned long) virt_addr; + __dpmi_free_physical_address_mapping(&mi); +} + +#elif defined(__DARWIN__) + #include #define MEM_DEV "DirectIO" -- cgit v1.1