linux下的ioctl函数原型如下:

#include <sys/ioctl.h>

int ioctl(int handle, int cmd, [int *argc, int argv])

函数成功返回0,失败返回-1.

其相关命令接口如下:

类别
Request
说明
数据类型
SIOCATMARK
SIOCSPGRP
SIOCGPGRP
是否位于带外标记
设置套接口的进程ID 或进程组ID
获取套接口的进程ID 或进程组ID
int
int
int
FIONBIO
FIOASYNC
FIONREAD
FIOSETOWN
FIOGETOWN
设置/ 清除非阻塞I/O 标志
设置/ 清除信号驱动异步I/O 标志
获取接收缓存区中的字节数
设置文件的进程ID 或进程组ID
获取文件的进程ID 或进程组ID
int
int
int
int
int
SIOCGIFCONF
SIOCSIFADDR
SIOCGIFADDR
SIOCSIFFLAGS
SIOCGIFFLAGS
SIOCSIFDSTADDR
SIOCGIFDSTADDR
SIOCGIFBRDADDR
SIOCSIFBRDADDR
SIOCGIFNETMASK
SIOCSIFNETMASK
SIOCGIFMETRIC
SIOCSIFMETRIC
SIOCGIFMTU
SIOCxxx
获取所有接口的清单
设置接口地址
获取接口地址
设置接口标志
获取接口标志
设置点到点地址
获取点到点地址
获取广播地址
设置广播地址
获取子网掩码
设置子网掩码
获取接口的测度
设置接口的测度
获取接口MTU
(还有很多取决于系统的实现)
struct ifconf
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
struct ifreq
ARP
SIOCSARP
SIOCGARP
SIOCDARP
创建/ 修改ARP 表项
获取ARP 表项
删除ARP 表项
struct arpreq
struct arpreq
struct arpreq
SIOCADDRT
SIOCDELRT
增加路径
删除路径
struct rtentry
struct rtentry
       

在这里我们需要用到的结构体

#include<netinet/in.h>

struct sockaddr_in {
short sin_family; /* Address family */
unsigned short sin_port; /* Port number */
struct in_addr sin_addr; /* Internet address */
unsigned char sin_zero[8]; /* Same size as struct sockaddr */
};

#include <net/if.h>

struct ifreq
{
#define IFHWADDRLEN 6
union
{
charifrn_name[IFNAMSIZ]; 
} ifr_ifrn;

union {
structsockaddr ifru_addr;
structsockaddr ifru_dstaddr;
structsockaddr ifru_broadaddr;
structsockaddr ifru_netmask;
struct sockaddr ifru_hwaddr;
shortifru_flags;
intifru_ivalue;
intifru_mtu;
struct ifmap ifru_map;
charifru_slave[IFNAMSIZ]; 
charifru_newname[IFNAMSIZ];
void __user * ifru_data;
structif_settings ifru_settings;
} ifr_ifru;
};

#define ifr_name ifr_ifrn.ifrn_name 
#define ifr_hwaddr ifr_ifru.ifru_hwaddr 
#defineifr_addr ifr_ifru.ifru_addr 
#defineifr_dstaddr ifr_ifru.ifru_dstaddr 
#defineifr_broadaddr ifr_ifru.ifru_broadaddr 
#defineifr_netmask ifr_ifru.ifru_netmask
#defineifr_flags ifr_ifru.ifru_flags 
#defineifr_metric ifr_ifru.ifru_ivalue
#defineifr_mtu ifr_ifru.ifru_mtu
#define ifr_map ifr_ifru.ifru_map
#define ifr_slave ifr_ifru.ifru_slave
#defineifr_data ifr_ifru.ifru_data 
#define ifr_ifindex ifr_ifru.ifru_ivalue
#define ifr_bandwidth ifr_ifru.ifru_ivalue 
#define ifr_qlen ifr_ifru.ifru_ivalue
#define ifr_newname ifr_ifru.ifru_newname
#define ifr_settings ifr_ifru.ifru_setting

ioctl函数能获取到IP地址、子网掩码、广播地址、硬件MAC地址等信息,至于网关及路由表比较复杂,在此不讨论。

具体代码如下:(测试通过)

#include <stdio.h>

#include <stdlib.h>

#include <net/if.h>

#include <unistd.h>

#include <sys/ioctl.h>

#include <arpa/inet.h>

#include <sys/stat.h>

#include <sys/types.h>

#include <errno.h>

#include <fcntl.h>

#include <netinet/in.h>

#include <net/route.h>

#include <string.h>

#include <net/if_arp.h>

int main()

{

struct sockaddr_in *sin;

struct ifreq ifr;

FILE *dns;

FILE *gw;

char *ip = new char(16);

char *netmask = new char(16);

char *broadcast = new char(16);

//char *ip = (char *)malloc(16);

char *mac = new  char(32);

//char *mac = (char *)malloc(32);

int socket_fd;

if((socket_fd = socket(AF_INET, SOCK_DGRAM, 0)) < 0){

perror("socket");

exit(1);

}

memset(&ifr, 0, sizeof(ifr));

strcpy(ifr.ifr_name, "eth0");

memset(&sin, 0, sizeof(sin));

//获取IP地址

if(ioctl(socket_fd, SIOCGIFADDR, &ifr) != -1){

sin = (struct sockaddr_in *)&ifr.ifr_addr;

strcpy(ip, inet_ntoa(sin->sin_addr));

printf("IP address is %s\n", ip);

}

//获取广播地址

if(ioctl(socket_fd, SIOCGIFBRDADDR, &ifr) != -1){

sin = (struct sockaddr_in *)&ifr.ifr_broadaddr;

strcpy(broadcast, inet_ntoa(sin->sin_addr));

printf("Broadcast is %s\n", broadcast);

}

//获取子网掩码

if(ioctl(socket_fd, SIOCGIFNETMASK, &ifr) != -1){

sin = (struct sockaddr_in *)&ifr.ifr_broadaddr;

strcpy(netmask, inet_ntoa(sin->sin_addr));

printf("Net-mask is %s\n", netmask);

}

//获取硬件MAC地址

if(ioctl(socket_fd, SIOCGIFHWADDR, &ifr) != -1){

sin = (struct sockaddr_in *)&ifr.ifr_netmask;

sprintf(mac, "%02x:%02x:%02x:%02x:%02x:%02x",

(unsigned char)ifr.ifr_netmask.sa_data[0],

(unsigned char)ifr.ifr_netmask.sa_data[1],

(unsigned char)ifr.ifr_netmask.sa_data[2],

(unsigned char)ifr.ifr_netmask.sa_data[3],

(unsigned char)ifr.ifr_netmask.sa_data[4],

(unsigned char)ifr.ifr_netmask.sa_data[5]);

printf("Mac address is %s\n", mac);

}

return 0;

}

至于获取网关以及DNS,我是通过相关命令获得的。

主要代码如下:

//获取网关,利用route -n 命令可以看到相关的网关。连接标志是‘UG’

if(gw_fd = popen("route -n | grep 'UG'", "r")){

fread(temp,1,128, gw_fd);

sscanf(temp, "%*s%s", szNetGate);

printf("Gateway is %s\n", szNetGate);

}

//获取DNS;一般DNS保存在/etc/reslov.conf文件中。具体获得方法要根据实际情况而定。

我的配置文件中是这样的

root@nill:/home/arm-none-linux# cat /etc/resolv.conf

# Dynamic resolv.conf(5) file for glibc resolver(3) generated by resolvconf(8)

#     DO NOT EDIT THIS FILE BY HAND -- YOUR CHANGES WILL BE OVERWRITTEN

nameserver 202.96.134.133

上面的202.96.134.133就是我需要获取的主DNS,没有备用DNS

if(dns_fd = popen("cat /etc/reslov.conf | grep 'nameserver'", "r")){

fread(temp,1,128, gw_fd);

sscanf(temp, "%*s%s%*s%s", szDNS1,szDNS2);

printf("DNS1 is %s",szDNS1);

printf("DNS2is %s", szDNS2);

}

转载于:https://www.cnblogs.com/LxwEmbedded/p/4728150.html

Linux下利用ioctl函数获取网卡信息相关推荐

  1. Linux下通过gettimeofday函数获取程序段执行时间

    在Linux下计算某个程序段执行的时间一般使用gettimeofday函数,此函数的声明在sys/time.h文件中.此函数接收两个结构体参数,分别为timeval.timezone.         ...

  2. linux ioctl命令,关于LINUX下的ioctl函数

    驱动程序中ioctl函数的函数原型如下: int (*ioctl)(struct inode *inode, struct file *filp,unsigned int cmd, unsigned ...

  3. Linux下使用system函数获取命令执行返回结果

    在Linux C语言中,需要获取设备挂载和空间容量信息,这时候最简单的方式就是使用命令工具进行查询,但是system函数调用之能返回进行执行的状态,不能返回执行的结果:所以这里自己实现system函数 ...

  4. linux getline参数,Linux下的getline函数

    最近在做国嵌的mp3项目,在mp3主控程序中用到了这个函数,挺好使的,在这里记录一下.注意是linux下的,不是C++中的. 函数原型 ssize_t getline(char **lineptr, ...

  5. 嵌入式 linux下利用backtrace追踪函数调用堆栈以及定位段错误

    嵌入式 linux下利用backtrace追踪函数调用堆栈以及定位段错误 2015-05-27 14:19 184人阅读 评论(0) 收藏 举报  分类: 嵌入式(928)  一般察看函数运行时堆栈的 ...

  6. linux fb应用例子,Linux下利用framebuffer画点的程序小例子

    Linux下利用framebuffer画点的程序小例子: /* * ================================================================== ...

  7. Linux下利用共享空间来实现两个没有亲缘关系的进程间通信

    Linux下利用共享空间来实现两个没有亲缘关系的进程间通信 功能需求: 1.打开一个Linux命令窗口作为写入端->客户端(client) 2.打开另一个Linux命令窗口作为读取端->服 ...

  8. python将Linux下使用top命令获取的进程信息进行分析做可视化展示

    python将Linux下使用top命令获取的进程信息进行分析做可视化展示 版本 版本 作者 日期 备注 v1.0 ZY 2020.11.10 初版完成 文章目录 python将Linux下使用top ...

  9. [转帖]关于Linux下的icotl函数

    关于Linux下的icotl函数 最近接触android开发,因为有时间所以就关注了下android的源码,在跟踪源码过程中到最后都会遇到icotl函数,虽然在Symbian中曾经遇到过RSocket ...

  10. linux在指定行添加内容,linux下利用shell在指定的行添加内容的方法

    linux下利用shell在指定的行添加内容的方法 在linux的一些配置中总会要进行某个文件中的某行的操作,进行增加,修改,删除等操作. 而这里主要是进行的是指定的行添加数据的操作: 脚本如下: s ...

最新文章

  1. 算法炒房三月亏20多亿!房地产巨头大翻车:房价水太深,AI根本把握不住
  2. error C2873: “Matrix2r”: 符号不能用在 using 声明中
  3. day20-----------IO流(传智视频)
  4. VS2013(Visual Studio 2013)官方中文旗舰版安装激活方法
  5. k3运行linux,首个Kubernetes操作系统k3OS,附主要功能介绍
  6. jquery学习手记(8)遍历
  7. 15、Power Query-行列管理实例应用
  8. PHP定界符的使用既注意事项
  9. python绘制国际象棋_python使用turtle绘制国际象棋棋盘
  10. mongodb数据结构学习1--增删改查
  11. 如何利用网管软件管控SNMP协议的网络设备
  12. FlashFXP 破解版下载地址
  13. [视频相关2]网址解析接口
  14. 中国好SaaS广州站:Fundebug勇夺两大奖项
  15. 手机APP支付--整合银联支付控件
  16. 测绘资质升级申请条件有哪些要求?
  17. Python的学习(二十一)----Python的静态变量
  18. 如何使用ABBYY FineReader 14填写表格
  19. 纯前端分页实现(vue)
  20. 写一个微信小程序的代码

热门文章

  1. java list 排序_java 对list进行排序
  2. MAC VSCODE配置C语言开发环境
  3. 面试题--------4、数据类型
  4. linux还原系统_Linux Kernel 5.5 最终删除 SYSCTL 系统调用
  5. 【渝粤教育】国家开放大学2018年春季 0550-21T素描(一) 参考试题
  6. 【渝粤教育】国家开放大学2018年春季 3722-21T燃气输配工程 参考试题
  7. 【渝粤教育】电大中专电商运营实操 (16)作业 题库
  8. firefox 插件配置
  9. ACM 学习笔记(二) 位运算、并查集、模拟、枚举、递推、递归
  10. 矩阵分析 (五) 矩阵的分解