sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
阅读:3198回复:26

在WDM驱动中调用PnP Bios 提供的函数接口(DMI 操作)的方法讨论

楼主#
更多 发布于:2005-05-18 16:45
背景:现在已知在某系统内存处会存储以下信息,其signature为 $PnP,从以下可得到对应函数的16 bit的 real /protected mode seg & offset的值。现在我已经能够在内存中找到$PnP,和函数地址的seg & offset值。

问题:
1)现在我想在WDM 驱动中调用该函数,也就是说我如何将16 bit的seg & offset 值转化为wdm 中32位的函数地址
2)大家还有什么好的方法,在WDM中搜索内存空间指定的内容?我是通过驱动将指定的物理地址映射到用户内存空间,让后再此空间查找

实现写 DMI 操作的 C 代码我已经实现,

Field               Offset   Length    Value

Signature          00h       4 BYTES   $PnP (ASCII)

Version            04h       BYTE      10h

Length             05h       BYTE      21h

Controlfield       06h       WORD     Varies

Checksum           08h       BYTE     Varies

Eventaddress       09h       DWORD    Varies

Real Mode 16-bit offset to entry point   0Dh   WORD   Varies

Real Mode 16-bit code segment address    0Fh   WORD   Varies

16BitProtectedModeoffset to entry point  11h   WORD   Varies

16BitProtectedModecode segment base addr 13h   DWORD  Varies
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
沙发#
发布于:2005-05-23 09:41
TO:sharpor
 
我这边主要是用来修改DMI信息的,
DOS下的代码,我写过了,是可以的。可在Windows下,我这就不行了,能否提供代码给我参考,谢谢了
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
板凳#
发布于:2005-05-23 11:43
TO:sharpor

DMI信息是从 存储bios的flash 中load到内存中的,你的那种方法虽然能该,当只能改当前内存中的信息,机器一重起,那DMI信息不由恢复原来的数据了。

如果通过调用PnP bios的接口函数可以将 存储bios的flash中的DMI信息给改变(因为BIOS源码中那PnP 接口就是修改flash中的数据),这样才会永久的修改的 。

所以希望能在Windows中调用 PnP BIOS 提供的接口。

因此问题也就是:在 Windows下如何调用指定物理地址上对应的函数?
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
地板#
发布于:2005-05-24 11:07
TO:sharpor

很受启发,谢谢

可我们这边的BIOS编译就用vc7和masm,asl,vc7不是32位的编译器吗,怎么编译生成的BIOS是16位的代码(其实我也不能确定该BIOS代码是不是16位的)?

因此我的问题是:用一个编译器,如何使编译生成的代码是16位和32位,大哥能否告知,或举个例子,不胜感激!!!
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
地下室#
发布于:2005-05-24 14:08
不会吧。如果正常的话,我是上不了qq的,我用了一个代理软件(服务器在国外)上的(通常都是下午下班之后才上的)。
你在哪里啊?
偶在上海
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
5楼#
发布于:2005-05-24 14:13
顺便说说,
Intel? Platform Innovation Framework for EFI (“the Framework”) Base Training will be held in Shanghai
at 8:30 AM on June 8(.9.10) on the 2F of ShanghaiMart.
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
6楼#
发布于:2005-05-24 15:45
对啊,马上要上efi了。你要参加吗?
――――――――――――――――
肯定去啊,也是我们老大叫我们去的,可以上三天的课


不知道上海有哪些公司在做bios,
我只知道phoenix有个分部在上海。
我在深圳。你那边行情如何
――――――――――――――――
对了,phoenxi是在上海是有分部,
在上海还很需要做BIOS的,不过大部分都是
一些台湾的代工PC,notebook,server工厂招人。
你是在做主板BIOS,还在哪家专门做BIOS的公司

[编辑 -  5/24/05 by  sunvan]
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
7楼#
发布于:2005-05-24 17:28
是啊,最近的一个项目是EFI的。
我们也是OEM的。上海很缺BIOS的人,我们部门也是的,
有没上qq,啊,我在qq上,想跟你交流交流
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
8楼#
发布于:2005-05-25 10:25
我在我们的文档上看到,下面的东东,

Slot 1  AD____25___ INTAPIRQ_B___, INTBPIRQ__C___, INTCPIRQ__D___, INTDPIRQ__A___


请问 Slot 1  AD____25___  这个AD是什么意思?我问了一个同事,听说是地址,看看PCI系统结构的书就知道了,可我现在还不知道?
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
9楼#
发布于:2005-05-25 12:28
你的意思:是指那个AD对应着PCI插槽上的AD[31::00]?

1)这个地址是由硬件直接连线得到的?还是由BIOS设定的?
如果是BIOS设定的,我可通过什么知道该值?

2)那下面这个是不是也是同样的意思:
AGP Slot___ on bord ____, AD____16_____, INTA PIRQ___A___
就对应着AGP 插槽上的AD
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
10楼#
发布于:2005-05-25 13:57
发邮件给我啊!最近策划走人
sharpor@163.com
 



你想不想来我们公司,我们老大老早就叫我找找看,有没厉害的,如果你想来的话,发 mail 过来
sunvan
驱动牛犊
驱动牛犊
  • 注册日期2004-03-12
  • 最后登录2011-07-06
  • 粉丝0
  • 关注0
  • 积分-100分
  • 威望-9点
  • 贡献值0点
  • 好评度0点
  • 原创分0分
  • 专家分0分
11楼#
发布于:2005-05-25 14:59
Slot 1 AD____25___ INTAPIRQ_B___, INTBPIRQ__C___, INTCPIRQ__D___, INTDPIRQ__A___

1)INTAPIRQ_B___, INTBPIRQ__C___, INTCPIRQ__D___, INTDPIRQ__A___
  这个我明白,是设备的INTA --D 连到南桥PIRQ A--H上的,从硬件的电路图能看得出来。

2)我不明白的就是前面的: Slot 1 AD____25___,我就是不知道该25 是怎么得到的?
  A:是硬件直接连线的?如果是,怎么能看得出,也就是说给你硬件的电路图,你怎么在电路图上判断该值是25或其它值
  B:是BIOS设置的吗?如果是,BIOS根据什么规范来设在该地址?

麻烦你再告诉我一下
游客

返回顶部