|
@@ -743,6 +743,14 @@ static void aspeed_i2c_bus_new_write(AspeedI2CBus *bus, hwaddr offset,
|
|
|
__func__);
|
|
|
break;
|
|
|
|
|
|
+ /*
|
|
|
+ * The AST2700 support the maximum DRAM size is 8 GB.
|
|
|
+ * The DRAM offset range is from 0x0_0000_0000 to
|
|
|
+ * 0x1_FFFF_FFFF and it is enough to use bits [33:0]
|
|
|
+ * saving the dram offset.
|
|
|
+ * Therefore, save the high part physical address bit[1:0]
|
|
|
+ * of Tx/Rx buffer address as dma_dram_offset bit[33:32].
|
|
|
+ */
|
|
|
case A_I2CM_DMA_TX_ADDR_HI:
|
|
|
if (!aic->has_dma64) {
|
|
|
qemu_log_mask(LOG_GUEST_ERROR, "%s: No DMA 64 bits support\n",
|
|
@@ -752,6 +760,8 @@ static void aspeed_i2c_bus_new_write(AspeedI2CBus *bus, hwaddr offset,
|
|
|
bus->regs[R_I2CM_DMA_TX_ADDR_HI] = FIELD_EX32(value,
|
|
|
I2CM_DMA_TX_ADDR_HI,
|
|
|
ADDR_HI);
|
|
|
+ bus->dma_dram_offset = deposit64(bus->dma_dram_offset, 32, 32,
|
|
|
+ extract32(value, 0, 2));
|
|
|
break;
|
|
|
case A_I2CM_DMA_RX_ADDR_HI:
|
|
|
if (!aic->has_dma64) {
|
|
@@ -762,6 +772,8 @@ static void aspeed_i2c_bus_new_write(AspeedI2CBus *bus, hwaddr offset,
|
|
|
bus->regs[R_I2CM_DMA_RX_ADDR_HI] = FIELD_EX32(value,
|
|
|
I2CM_DMA_RX_ADDR_HI,
|
|
|
ADDR_HI);
|
|
|
+ bus->dma_dram_offset = deposit64(bus->dma_dram_offset, 32, 32,
|
|
|
+ extract32(value, 0, 2));
|
|
|
break;
|
|
|
case A_I2CS_DMA_TX_ADDR_HI:
|
|
|
qemu_log_mask(LOG_UNIMP,
|
|
@@ -777,6 +789,8 @@ static void aspeed_i2c_bus_new_write(AspeedI2CBus *bus, hwaddr offset,
|
|
|
bus->regs[R_I2CS_DMA_RX_ADDR_HI] = FIELD_EX32(value,
|
|
|
I2CS_DMA_RX_ADDR_HI,
|
|
|
ADDR_HI);
|
|
|
+ bus->dma_dram_offset = deposit64(bus->dma_dram_offset, 32, 32,
|
|
|
+ extract32(value, 0, 2));
|
|
|
break;
|
|
|
default:
|
|
|
qemu_log_mask(LOG_GUEST_ERROR, "%s: Bad offset 0x%" HWADDR_PRIx "\n",
|