目前在测试IPV6 DNS解析的时候发现一个问题,这里记录一下
问题是:当dhcpv6服务器分配的IPV6 dns是fe80类型的dns时,无法发送dns请求,抓包看不到有目标地址为fe80::1的dns报文
首先我这边使用dumpsys netd查看了下是否有fe80::1这个dns设置到系统中
发现是有设置到系统中的,而且可以看到dns请求的数据统计都是internal errors,那么表示错误产生在内部,并未实际发出dns报文
接下来只能查dns解析接口getaddrinfo了,看其中是否有会挡住fe80::1为目标地址的请求的地方
分析getaddrinfo流程时,发现一段代码的注释挺可疑的(注释写的好真的很有帮助),就让我锁定了目标
cp = strchr(hostname, SCOPE_DELIMITER);
if (cp == NULL)
return explore_numeric(pai, hostname, servname, res, hostname);
/*
* Handle special case of <scoped_address><delimiter><scope id>
*/
hostname2 = strdup(hostname);
if (hostname2 == NULL)
return EAI_MEMORY;
/* terminate at the delimiter */
hostname2[cp - hostname] =