CPU字长与存储器位宽不一致处理
在背景篇中提到,本文特意选择了一个与CPU字长不一致的存储芯片,就是为了进行本节的讨论,解决CPU字长与存储器位宽不一致的情况。80186的字长为16,而NVRAM的位宽为8,在这种情况下,我们需要为NVRAM提供读写字节、字的接口,如下:
typedef unsigned char BYTE; typedef unsigned int WORD; /* 函数功能:读NVRAM中字节 * 参数:wOffset,读取位置相对NVRAM基地址的偏移 * 返回:读取到的字节值 */ extern BYTE ReadByteNVRAM(WORD wOffset) { LPBYTE lpAddr = (BYTE*)(NVRAM + wOffset * 2); /* 为什么偏移要×2? */
return *lpAddr; }
/* 函数功能:读NVRAM中字 * 参数:wOffset,读取位置相对NVRAM基地址的偏移 * 返回:读取到的字 */ extern WORD ReadWordNVRAM(WORD wOffset) { WORD wTmp = 0; LPBYTE lpAddr; /* 读取高位字节 */ lpAddr = (BYTE*)(NVRAM + wOffset * 2); /* 为什么偏移要×2? */ wTmp += (*lpAddr)*256; /* 读取低位字节 */ lpAddr = (BYTE*)(NVRAM + (wOffset +1) * 2); /* 为什么偏移要×2? */ wTmp += *lpAddr; return wTmp; }
/* 函数功能:向NVRAM中写一个字节 *参数:wOffset,写入位置相对NVRAM基地址的偏移 * byData,欲写入的字节 */ extern void WriteByteNVRAM(WORD wOffset, BYTE byData) { … }
/* 函数功能:向NVRAM中写一个字 */ *参数:wOffset,写入位置相对NVRAM基地址的偏移 * wData,欲写入的字 */ extern void WriteWordNVRAM(WORD wOffset, WORD wData) { … }
问曰:Why偏移要乘以2?
曰:16位80186与8位NVRAM之间互连只能以地址线A1对其A0,CPU本身的A0与NVRAM不连接。因此,NVRAM的地址只能是偶数地址,故每次以0x10为单位前进!
再问:So why 80186的地址线A0不与NVRAM的A0连接?
请看《IT论语》之《微机原理篇》,那里面讲述了关于计算机组成的圣人之道。 |