Assorted fixes, the Compaq Presario 7100 486 no longer crashes on CTRL+ALT+DEL.
This commit is contained in:
@@ -270,6 +270,8 @@ hb4_smram(hb4_t *dev)
|
||||
}
|
||||
|
||||
umc_smram_recalc(dev->smram_base >> 12, 1);
|
||||
|
||||
flushmmucache();
|
||||
}
|
||||
|
||||
static void
|
||||
@@ -398,55 +400,6 @@ hb4_close(void *priv)
|
||||
free(dev);
|
||||
}
|
||||
|
||||
static void
|
||||
ims8848_write(uint16_t addr, uint8_t val, void *priv)
|
||||
{
|
||||
hb4_t *dev = (hb4_t *) priv;
|
||||
|
||||
switch (addr) {
|
||||
case 0x22:
|
||||
dev->idx = val;
|
||||
break;
|
||||
case 0x23:
|
||||
if (((val & 0x0f) == ((dev->idx >> 4) & 0x0f)) && ((val & 0xf0) == ((dev->idx << 4) & 0xf0)))
|
||||
dev->access_data = 1;
|
||||
break;
|
||||
case 0x24:
|
||||
if (dev->access_data)
|
||||
dev->access_data = 0;
|
||||
break;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static uint8_t
|
||||
ims8848_read(uint16_t addr, void *priv)
|
||||
{
|
||||
uint8_t ret = 0xff;
|
||||
hb4_t *dev = (hb4_t *) priv;
|
||||
|
||||
switch (addr) {
|
||||
case 0x22:
|
||||
ret = dev->idx;
|
||||
break;
|
||||
case 0x23:
|
||||
ret = (dev->idx >> 4) | (dev->idx << 4);
|
||||
break;
|
||||
case 0x24:
|
||||
if (dev->access_data) {
|
||||
ret = dev->pci_conf[dev->idx];
|
||||
dev->access_data = 0;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
static void *
|
||||
hb4_init(UNUSED(const device_t *info))
|
||||
{
|
||||
@@ -463,8 +416,6 @@ hb4_init(UNUSED(const device_t *info))
|
||||
dev->smram_base = 0x000a0000;
|
||||
hb4_reset(dev);
|
||||
|
||||
io_sethandler(0x0022, 0x0003, ims8848_read, NULL, NULL, ims8848_write, NULL, NULL, dev);
|
||||
|
||||
return dev;
|
||||
}
|
||||
|
||||
|
||||
@@ -830,7 +830,9 @@ write_p2(atkbc_t *dev, uint8_t val)
|
||||
softresetx86(); /* Pulse reset! */
|
||||
cpu_set_edx();
|
||||
flushmmucache();
|
||||
if ((kbc_ven == KBC_VEN_ALI) || !strcmp(machine_get_internal_name(), "spc7700plw"))
|
||||
if ((kbc_ven == KBC_VEN_ALI) ||
|
||||
!strcmp(machine_get_internal_name(), "spc7700plw") ||
|
||||
!strcmp(machine_get_internal_name(), "pl4600c"))
|
||||
smbase = 0x00030000;
|
||||
|
||||
/* Yes, this is a hack, but until someone gets ahold of the real PCD-2L
|
||||
|
||||
@@ -2994,10 +2994,12 @@ mem_init(void)
|
||||
}
|
||||
|
||||
static void
|
||||
umc_page_recalc(uint32_t c, int set)
|
||||
umc_page_recalc(uint32_t c, uint32_t phys, int set)
|
||||
{
|
||||
uint32_t target = set ? phys : c;
|
||||
|
||||
if (set) {
|
||||
pages[c].mem = &ram[(c & 0xff) << 12];
|
||||
pages[c].mem = &ram[(target & 0xff) << 12];
|
||||
pages[c].write_b = mem_write_ramb_page;
|
||||
pages[c].write_w = mem_write_ramw_page;
|
||||
pages[c].write_l = mem_write_raml_page;
|
||||
@@ -3010,8 +3012,8 @@ umc_page_recalc(uint32_t c, int set)
|
||||
|
||||
#ifdef USE_NEW_DYNAREC
|
||||
pages[c].evict_prev = EVICT_NOT_IN_LIST;
|
||||
pages[c].byte_dirty_mask = &byte_dirty_mask[(c & 0xff) * 64];
|
||||
pages[c].byte_code_present_mask = &byte_code_present_mask[(c & 0xff) * 64];
|
||||
pages[c].byte_dirty_mask = &byte_dirty_mask[(target & 0xff) * 64];
|
||||
pages[c].byte_code_present_mask = &byte_code_present_mask[(target & 0xff) * 64];
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -3019,7 +3021,7 @@ void
|
||||
umc_smram_recalc(uint32_t start, int set)
|
||||
{
|
||||
for (uint32_t c = start; c < (start + 0x0020); c++)
|
||||
umc_page_recalc(c, set);
|
||||
umc_page_recalc(c, c - start + 0x000a0000, set);
|
||||
}
|
||||
|
||||
static void
|
||||
|
||||
@@ -59,9 +59,12 @@ smram_read(uint32_t addr, void *priv)
|
||||
const smram_t *dev = (smram_t *) priv;
|
||||
uint32_t new_addr = addr - dev->host_base + dev->ram_base;
|
||||
|
||||
#if (!(defined __amd64__ || defined _M_X64 || defined __aarch64__ || defined _M_ARM64))
|
||||
if (new_addr >= (1 << 30))
|
||||
return mem_read_ram_2gb(new_addr, priv);
|
||||
else if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
else
|
||||
#endif
|
||||
if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
return mem_read_ram(new_addr, priv);
|
||||
else
|
||||
return dev->mapping.exec[addr - dev->host_base];
|
||||
@@ -73,9 +76,12 @@ smram_readw(uint32_t addr, void *priv)
|
||||
smram_t *dev = (smram_t *) priv;
|
||||
uint32_t new_addr = addr - dev->host_base + dev->ram_base;
|
||||
|
||||
#if (!(defined __amd64__ || defined _M_X64 || defined __aarch64__ || defined _M_ARM64))
|
||||
if (new_addr >= (1 << 30))
|
||||
return mem_read_ram_2gbw(new_addr, priv);
|
||||
else if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
else
|
||||
#endif
|
||||
if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
return mem_read_ramw(new_addr, priv);
|
||||
else
|
||||
return *(uint16_t *) &(dev->mapping.exec[addr - dev->host_base]);
|
||||
@@ -87,9 +93,12 @@ smram_readl(uint32_t addr, void *priv)
|
||||
smram_t *dev = (smram_t *) priv;
|
||||
uint32_t new_addr = addr - dev->host_base + dev->ram_base;
|
||||
|
||||
#if (!(defined __amd64__ || defined _M_X64 || defined __aarch64__ || defined _M_ARM64))
|
||||
if (new_addr >= (1 << 30))
|
||||
return mem_read_ram_2gbl(new_addr, priv);
|
||||
else if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
else
|
||||
#endif
|
||||
if (!use_separate_smram || (new_addr >= 0xa0000))
|
||||
return mem_read_raml(new_addr, priv);
|
||||
else
|
||||
return *(uint32_t *) &(dev->mapping.exec[addr - dev->host_base]);
|
||||
|
||||
Reference in New Issue
Block a user