superIO在Linux下的设备,X86 Linux ITE SuperIO GPIO Control

Superio概述

​ Super I/O芯片也叫I/O芯片。在486以上档次的主板上都有I/O控制电路。因为在南桥这样的高速设备和串行、并行接口、软盘驱动器及键盘鼠标等大量低速设备之间必定存在资源的不匹配,而需要经过转换和管理。而Super I/O芯片则完成了该功能。

​ 通常在硬件监控芯片硬件监控芯片中会整合超级I/O功能,可用于监控受监控对象的电压、温度、转速等。主板在附件中会提供某种软件,它和主板上的硬件配合使用就能实现对电压、温度、风扇转速等的监控,一旦检测到这些参数超出设定的指标时,它会自动作出调整,以保护元件的安全。

以上内容均为copy自互联网。

使用的SIO为ITE的IT8786E,预留的GPIO端口为GP80~GP87

IT8786芯片在主板的实物图如下:

ce9511248ccc4e591609abe0fee7e833.png

本人对SuperIO也不懂,主要是参考linux内核中gpio-it87驱动代码和github上的其他项目摸索出来的,文中可能会有一些错误!

大概的流程:

以下的数据都来源于芯片手册:

SuperIO控制器地址端口index=2Eh,数据端口index=2Fh(实际的物理内存地址);

SuperIO芯片功能入口:87h,01h,55h,55h;

GPIO LDN逻辑设备号:07h;

GP80-GP87:寄存器地址index=2Ch,Default=89h;

GPIO Output/Input Selection: index=CFh;

GPIO Simple I/O Base Address MSB/LSB Register:Index=62h/63h, Default=00h;

进入IO配置空间

设置IO属性

设置输入输出模式

当IO输出时设置高低电平

退出IO配置空间

实现代码:1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69#include

#include

#include

/* IO Ports */

#define REG0x2e

#define VAL0x2f

/* Logical device Numbers */

#define LDNREG0x07

/* GPIO Configuration Registers */

#define GPIOLDN0x07

static int superio_inw(int reg)

{

int val;

outb(reg++, REG);

val = inb(VAL) << 8;

outb(reg, REG);

val |= inb(VAL);

return val;

}

int main(void)

{

unsigned short int io_base;

//修改端口权限为可读写

int ret = iopl(3);

if(ret == -1)

{

printf("iopl error.\n");

return -1;

}

//进入IO配置空间

outb(0x87, REG);

outb(0x01, REG);

outb(0x55, REG);

outb(0x55, REG);

//设置IO属性

outb(LDNREG, REG);

outb(GPIOLDN, VAL);

//Speecial Function Selection Register3(Index=2Ch, Default=89h)

outb(0x2c, REG);

outb(0x89, VAL);

//Simple I/O Base Address MSB/LSB Register index=62h/63h

//获取GPIO基地址(16位),高位0x62|低位0x63组合起来

io_base = superio_inw(0x62);

printf("gpio base addr:%02x\n", io_base);

//设置输入输出模式Output/Input Selection (Index CFh)

//0xcf 控制GP80~87 作为输入还是输出

outb(0xcf, REG);

//bit0对应GP80,bit1对应GP81,以此类推。以下是把所有IO作为输出

outb(0xff, VAL);

//当IO作为输出时,拉高、或拉低设置

//使用的第8组GPIO,这里地址是基地址+7

//控制GP80~87输出高还是低,相应的BIT 设为0拉低,设为1拉高

//bit0对应GP80,bit1对应GP81,以此类推。这里所有IO设置为高电平

outb(0xff,io_base+7);

//设置完后退出IO配置空间

outb(0x02, REG);

outb(0x02, VAL);

//恢复端口权限

iopl(0);

return 0;

}

编译后执行需要root权限,可以直接上LED测试,下图接线是低电平点亮

0bfd56ea432ab7f0f005ca38b0fa3c89.png

另外还实现了一种方法,直接写成驱动的方式,创建一个misc设备,实现ioctl函数,利用ioctl通信在用户空间操作GPIO,这里就不贴代码了

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值