首页 > 其他分享 >strncpy 出core

strncpy 出core

时间:2023-09-25 14:00:50浏览次数:57  
标签:__ core dhcp6 len status ptr strncpy

core 的堆栈是这样子的:

(gdb) bt
#0  0x00007ffff4a96a7c in pthread_kill () from /lib/x86_64-linux-gnu/libc.so.6
#1  0x00007ffff4a42476 in raise () from /lib/x86_64-linux-gnu/libc.so.6
#2  0x00007ffff4a287f3 in abort () from /lib/x86_64-linux-gnu/libc.so.6
#3  0x00007ffff4a896f6 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#4  0x00007ffff4b3676a in __fortify_fail () from /lib/x86_64-linux-gnu/libc.so.6
#5  0x00007ffff4b350c6 in __chk_fail () from /lib/x86_64-linux-gnu/libc.so.6
#6  0x00007ffff4b34b09 in __strncpy_chk () from /lib/x86_64-linux-gnu/libc.so.6
#7  0x0000555555586c68 in strncpy (__len=38, __src=0x5555555be828 "Some of the addresses are not on link.", __dest=0x55555965bf58 <parp_lc_nsi_pkt_pool+344> "All addresses still on link.")
    at /usr/include/x86_64-linux-gnu/bits/string_fortified.h:95
#8  rx_fr_ge_dhcp6_pkt_00 (dhcp6_hdr=0x55555965bf2e <parp_lc_nsi_pkt_pool+302>, dhcp6_hdr@entry=0x55555965bef4 <parp_lc_nsi_pkt_pool+244>, dhcp6_len=70, dhcp6_len@entry=128,
    rsp_eth_ipv6_pkt=rsp_eth_ipv6_pkt@entry=0x555555619580 <pkt_resp0+256> "\002\020\030dB0", sock_vrf_id=sock_vrf_id@entry=0 '\000') at /home/jenkins/casa/parp/dhcpv6_pkt.c:2382
#9  0x0000555555582583 in rx_fr_ge_dhcp6_pkt_0 (dhcp6_hdr=dhcp6_hdr@entry=0x55555965bef4 <parp_lc_nsi_pkt_pool+244>, dhcp6_len=dhcp6_len@entry=128, sock_vrf_id=sock_vrf_id@entry=0 '\000')
    at /home/jenkins/casa/parp/smm_rx_ipv6.c:192
#10 0x000055555556b34a in lc_nsi_pkt_processing (pkt_desc=pkt_desc@entry=0x55555965be00 <parp_lc_nsi_pkt_pool>) at /home/jenkins/casa/parp/smm_arp_main.c:755
#11 0x00005555555a732a in parp_lc_nsi_msg_queue_thread () at /home/jenkins/casa/parp/smm_arp_queue.c:376


frame 8 里面的代码片段是这样的:

2376                 int orignal_len = ntohs(status_code->dh6_status_len);
2377                 int new_len = strlen(NotOnLink);
2378                 u_int8_t *ptr = (u_int8_t *)&status_code->dh6_status_code;
2379                 signed short offset_len = new_len - (orignal_len - 2);
2380                 status_code->dh6_status_len = htons(new_len + 2);
2381                 memmove(ptr+new_len+2, ptr+orignal_len, dhcp6_len - (ptr+orignal_len -(u_int8_t*)dhcp6_hdr));
2382                 strncpy((char*)(ptr+2), NotOnLink, new_len);     // <===== 挂在这儿
2383                 status_code->dh6_status_code = DH6OPT_STCODE_NOTONLINK;
2384                 dhcp6_len += offset_len;

ptr指向的其实是一个预分配好的全局 buffer,用来构造要发出去的报文
status_code则是这个报文 DHCPv6 的一个 option 头
buffer 大小有2K,ptr 偏移 buffer 头才 300 字节,逻辑上来说,长度完全足够,__src 和 __dest 都没有被破坏
但偏偏就是 strncpy 检查的时候不通过了

看一下 strncpy 的代码:

91 __fortify_function char *
92 __NTH (strncpy (char *__restrict __dest, const char *__restrict __src,
93         size_t __len))
94 {
95   return __builtin___strncpy_chk (__dest, __src, __len,
96                   __glibc_objsize (__dest));
97 }


检查的是 ptr 的长度,想不明白
按上面的分析, ptr 后面剩下的缓存绝对够得

后面算是灵光乍现
因为ptr初始化的时候指向的是status_code中的一个成员地址,strncpy检查它长度的时候是不是按照status_code 的大小来检查了
于是写了一个验证的代码:

 942
 943 uint8_t zyc_buf[1024];
 944
 945 int zyc_dbg()
 946 {
 947
 948     struct dhcp6_status_info *dhcp6 = (struct dhcp6_status_info *)&zyc_buf[100];
 949     char src[128] = "Some of the addresses are not on link.";
 950     uint8_t *ptr;
 951     dhcp6->dh6_status_type = 10;
 952     dhcp6->dh6_status_len = 12;
 953     dhcp6->dh6_status_code = 16;
 954 #if 1
 955     ptr = (uint8_t *)&dhcp6->dh6_status_code;    // ①
 956     strncpy((char *)(ptr + 2), src, strlen(src));
 957     printf("[%s():%d] (%s)\n", __func__, __LINE__, (char *)(ptr + 2));
 958 #else
 959     ptr = (uint8_t *)(dhcp6 + 1);                // ②
 960     strncpy((char *)ptr, src, strlen(src));
 961     printf("[%s():%d] [%s]\n", __func__, __LINE__, (char *)(ptr));
 962 #endif
 963
 964     return 0;
 965 }

用 955 行的第①种方式来初始化,就复现了这个core
用 959 行的第②种方式来初始化,进程就能顺利跑下去

极其吊诡
后来在我自己的虚拟机上跑了下上面的 验证代码,欸,两种初始化方式都没问题

Google 发现,似乎是 __glibc_objsize 跟编译器有关

问了下别的同事,说是用Linux做cpe,在这台Linux cpe上,用"ifconfig xxx down"把端口down掉的时候,(down掉之前)Linux cpe会发dhcpv6报文通知dhcp server释放这个interface上的IP,
然后dhcp server会回复一个dhcp报文,说 ok已经释放了 ,现在出问题的地方就是parp对这个dhcp server回复的报文做改动的时候

标签:__,core,dhcp6,len,status,ptr,strncpy
From: https://www.cnblogs.com/fallenmoon/p/17727791.html

相关文章

  • 无法在web.xml或使用此应用程序部署的jar文件中解析绝对uri:[http://java.sun.com/jsp/
    今天解决了一个很早之前的问题!!!无法在web.xml或使用此应用程序部署的jar文件中解析绝对uri:[http://java.sun.com/jsp/jstl/core]之前一直以为是jar包不匹配,但是改了jar包之后连uri都分辨不出来了后来在网上查到是tomcat的问题,将tomcat的conf目录下的catalina.properties的tomc......
  • asp.net core 将整个解决方案打包,做成脚手架,可直接安装使用
    自己经过多年开发的沉淀后,开发出一个属于自己的一套Demo项目,亦或是借鉴别人的项目后,优化了一个,然后我们在别的地方使用的时候(可能是下一个公司),如果还想用自己的模板,也可能是供新入职的同事使用,经常会是以下几个办法 1、对比着之前的项目结构,在VistulStudio中手动创建一个空的......
  • # github.com/coreos/etcd/clientv3/balancer/resolver/endpoint
    linux使用go连接etcd集群时报错:#github.com/coreos/etcd/clientv3/balancer/resolver/endpoint/root/go/pkg/mod/github.com/coreos/etcd@v3.3.27+incompatible/clientv3/balancer/resolver/endpoint/endpoint.go:114:87:undefined:resolver.BuildOption/root/go/pkg/mod/g......
  • EF Core 迁移代码
    列重命名需要自定义迁移的一个重要示例就是重命名属性时。例如,如果你将属性从 Name 重命名为 FullName,EFCore将生成以下迁移:migrationBuilder.DropColumn(name:"Name",table:"Customers");migrationBuilder.AddColumn<string>(name:"FullName",......
  • ASP.NET CORE区域LIS医学检验系统源码 SaaS模式B/S架构
    区域LIS系统源码 SaaS模式B/S架构的LIS系统源码区域LIS可促进基层医疗机构条码化检验业务管理,为基层搭建标本采集、标本核收、标本检验、室内质控、报告发布、统计分析的规范流程,同时为医疗机构提供检验诊断知识库提升检验业务水准。技术架构:ASP.NETCORE3.1MVC+SQLserver+R......
  • .netCore 图形验证码,非System.Drawing.Common
    netcore需要跨平台,说白点就是放在windows服务器要能用,放在linux服务器上也能用,甚至macos上。很多时候需要使用到图形验证码,这就有问题了。旧方案1.引入包<PackageReferenceInclude="System.Drawing.Common"Version="5.0.3"/>2.添加引用usingSystem.Drawing;usingSystem......
  • IIS下部署asp.net core应用
    问题描述:IIS下部署asp.netcore应用,windows日志中经常发现如下重启信息:改善办法:每次某应用重启后,发现应用内的缓存都过期了,于是按照如下文章和以下截图将引用程序池做相应设置,该问题得到改善:主要是将启动模式改成:AlwaysRunning,将闲置时间改成0;参考文章:https://www.mo......
  • C#集成ViewFaceCore人脸检测识别库
    前言人脸检测与识别现在已经很成熟了,C#上有ViewFaceCore这个很方便的库,但这种涉及到native调用的库,一般会有一些坑,本文记录一下开发和部署的过程。本文的项目是AIHub,关于本项目的开发过程,可以参考之前的文章:项目完成小结:使用Blazor和gRPC开发大模型客户端而且经过最近一......
  • AS-2020?TSN CoreSolution直接拿下!
    协议简介  IEEE802.1AS是一个网络时间同步协议,它是IEEE802.1工作组的一部分,主要用于支持时间敏感的应用在桥接网络中的时间同步。802.1AS协议专门为了满足TSN网络中设备的时间同步需求而设计。TSN是一种网络技术,它可以提供精确的时间同步和低延迟,从而保障音视频、传感器、......
  • asp.Net Core 改变响应值的几种方法
    1.中间件usingMicrosoft.AspNetCore.Mvc;usingSystem.Text;varbuilder=WebApplication.CreateBuilder(args);builder.Services.AddControllers();varapp=builder.Build();app.UseMiddleware<ReplaceMiddleware>();app.MapControllers();app.Run();public......