2011-01-26 110 views
3

我正在为一个硬件分配编写一个Linux引导程序,我知道我需要创建一个函数来读写内存中的一个字。我无法确定我是否在正确的轨道上,并且任何帮助都很大。我会测试这些功能,但目前对我来说是不可能的,因为我需要在构建核心功能之前开展工作,然后才能将所有功能放在一起。我得到了get_byte(段偏移量)/ put_byte(焦炭,段偏移量)被证实由我的老师一起工作,从汇编语言编写,并出口到C.C Linux从内存读取/写入字段(段,偏移量)

unsigned short get_word(unsigned short segment, unsigned short offset) 
{ 
unsigned short word, low, hi; 
    low = get_byte(segment, offset); 
    high = get_byte(segment, offset+1); 
    word = low+hi; 
    return word; 
} 

我不知道,如果上面是正确。我知道嗨和低需要结合,可以添加,或者我应该只是做低&嗨,然后返回该结果?如果我完全脱离基地,请告诉我。偏移量无符号短还是int应该是正确的?

int put_word(unsigned short word, unsigned short segment, unsigned short offset) 
{ 
    unsigned short low, hi; 
    low = word | offset; 
    hi = word | offset+1 
    put_byte(segment, low); 
    put_byte(segment, hi); 
    return 0; 
} 

我不知道上面的代码是否接近正确,但这是我最好的猜测。

任何人都知道解决方案或有任何提示?这些功能应该是非常基本的,但我被卡住了,需要开始我的任务的实际部分。

UPDATE(12:46):修正put_byte(),如下所述,只接受两个参数是没有意义的,修正了这个问题。我为我的错误道歉。

+0

男人我很想看看在Linux上工作的get_byte和put_byte。 – Joshua 2011-01-26 21:02:19

回答

3

get_word()

word = (high << 8) | low 

put_word()

low = word & 0xff; 
hi = word >> 8; 
put_byte(low, segment, offset); 
put_byte(hi, segment, offset+1; 

我怀疑put_byte只需要两个参数,如你所说。这是没有道理的。

+0

被殴打几秒..;) – BlackBear 2011-01-26 20:44:55

+0

是的 - 实际上,字节序由get_byte/put_byte处理,所以他排序了那一个。计算低/高时它不起作用。 – 2011-01-26 20:47:22

2

他们错了。为了使一个字开始用2个字节,你必须:

word = (byte2 << 8) | byte1 

假设字节2内存如下字节1,你想在小尾数“格式”你的话。 要在2个字节分成一个字,你必须:

byte1 = word & 0xff 
byte2 = word >> 8 

随着上述考虑。