mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-27 23:22:37 +02:00
Fix the DOS port
Now the DS selector limit is set to 4GB and all mmio accesses goes through DS, the 1:1 mapping is fixed so the _DS base is taken onto account. Plus is that the hwaccess.c needs no change and memcpy etc can be used on mmaped space. Corresponding to flashrom svn r995. Signed-off-by: Rudolf Marek <r.marek@assembler.cz> Acked-by: Carl-Daniel Hailfinger <c-d.hailfinger.devel.2006@gmx.net>
This commit is contained in:
parent
ce1c798c1c
commit
837d810796
4
Makefile
4
Makefile
@ -202,12 +202,8 @@ endif
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
ifeq ($(NEED_PCI), yes)
|
ifeq ($(NEED_PCI), yes)
|
||||||
ifneq ($(OS_ARCH), DOS)
|
|
||||||
# FIXME This workaround is needed until libpci detection can handle
|
|
||||||
# cross-compiling for DOS.
|
|
||||||
CHECK_LIBPCI = yes
|
CHECK_LIBPCI = yes
|
||||||
endif
|
endif
|
||||||
endif
|
|
||||||
|
|
||||||
ifeq ($(NEED_PCI), yes)
|
ifeq ($(NEED_PCI), yes)
|
||||||
FEATURE_CFLAGS += -D'NEED_PCI=1'
|
FEATURE_CFLAGS += -D'NEED_PCI=1'
|
||||||
|
39
hwaccess.c
39
hwaccess.c
@ -54,44 +54,6 @@ void release_io_perms(void)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef __DJGPP__
|
|
||||||
|
|
||||||
extern unsigned short segFS;
|
|
||||||
|
|
||||||
#include <sys/farptr.h>
|
|
||||||
|
|
||||||
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)
|
void mmio_writeb(uint8_t val, void *addr)
|
||||||
{
|
{
|
||||||
*(volatile uint8_t *) addr = val;
|
*(volatile uint8_t *) addr = val;
|
||||||
@ -121,4 +83,3 @@ uint32_t mmio_readl(void *addr)
|
|||||||
{
|
{
|
||||||
return *(volatile uint32_t *) addr;
|
return *(volatile uint32_t *) addr;
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
67
physmap.c
67
physmap.c
@ -30,20 +30,45 @@
|
|||||||
|
|
||||||
#ifdef __DJGPP__
|
#ifdef __DJGPP__
|
||||||
#include <dpmi.h>
|
#include <dpmi.h>
|
||||||
|
#include <sys/nearptr.h>
|
||||||
|
|
||||||
#define MEM_DEV "dpmi"
|
#define MEM_DEV "dpmi"
|
||||||
|
|
||||||
unsigned short segFS = 0;
|
static void *realmem_map;
|
||||||
|
|
||||||
|
static void *map_first_meg(unsigned long phys_addr, size_t len)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (realmem_map) {
|
||||||
|
return realmem_map + phys_addr;
|
||||||
|
}
|
||||||
|
|
||||||
|
realmem_map = valloc(1024 * 1024);
|
||||||
|
|
||||||
|
if (!realmem_map) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (__djgpp_map_physical_memory(realmem_map, (1024 * 1024), 0)) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return realmem_map + phys_addr;
|
||||||
|
}
|
||||||
|
|
||||||
void *sys_physmap(unsigned long phys_addr, size_t len)
|
void *sys_physmap(unsigned long phys_addr, size_t len)
|
||||||
{
|
{
|
||||||
int ret;
|
int ret;
|
||||||
__dpmi_meminfo mi;
|
__dpmi_meminfo mi;
|
||||||
|
|
||||||
if (segFS == 0) {
|
/* enable 4GB limit on DS descriptor */
|
||||||
segFS = __dpmi_allocate_ldt_descriptors (1);
|
if (!__djgpp_nearptr_enable()) {
|
||||||
__dpmi_set_segment_base_address (segFS, 0x0);
|
return NULL;
|
||||||
__dpmi_set_segment_limit (segFS, 0xffffffff);
|
}
|
||||||
|
|
||||||
|
if ((phys_addr + len - 1) < (1024 * 1024)) {
|
||||||
|
/* we need to use another method to map first 1MB */
|
||||||
|
return map_first_meg(phys_addr, len);
|
||||||
}
|
}
|
||||||
|
|
||||||
mi.address = phys_addr;
|
mi.address = phys_addr;
|
||||||
@ -54,42 +79,18 @@ void *sys_physmap(unsigned long phys_addr, size_t len)
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
return (void *) mi.address;
|
return (void *) mi.address + __djgpp_conventional_base;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define sys_physmap_rw_uncached sys_physmap
|
#define sys_physmap_rw_uncached sys_physmap
|
||||||
|
#define sys_physmap_ro_cached sys_physmap
|
||||||
#include <sys/movedata.h>
|
|
||||||
#include <sys/segments.h>
|
|
||||||
#include <go32.h>
|
|
||||||
|
|
||||||
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)
|
void physunmap(void *virt_addr, size_t len)
|
||||||
{
|
{
|
||||||
__dpmi_meminfo mi;
|
__dpmi_meminfo mi;
|
||||||
|
|
||||||
/* we ignore unmaps for our cheat 1MB copy */
|
/* we ignore unmaps for our first 1MB */
|
||||||
if ((virt_addr >= realmem_cpy) && ((virt_addr + len) <= (realmem_cpy + 1024*1024))) {
|
if ((virt_addr >= realmem_map) && ((virt_addr + len) <= (realmem_map + (1024 * 1024)))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user