从goahead代码的bug看aarch64平台的移位操作

2024-02-24 15:38

本文主要是介绍从goahead代码的bug看aarch64平台的移位操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

假设在32位arm平台的一个移位操作

int bit = 1<<30;

这是合法的。

那么平台换成了64位arm,

int bit = 1 << 34;

合法吗,显然不合法,因为int的长度就是32 比特,不管32位arm还是64位arm上。要移动34位显然超出了它的表示范围。

我们知道在aarch64架构下,long是64位的,那么改成:

long bit = 1 << 34 合法吗。并不。因为这里的1 其实是个int型,默认的嘛。长度仍然是32位!所以对一个32位的int型移位34 显然也不合法。

那么只有改成:

long bit = (long)1 << 34

才是正确的。

 

 

这个BUG始于这几天调试的goahead。平台是aarch64 海思。

一旦创建了很多VPSS,也就是创建了很多文件描述符,那么goahead监听的文件描述符就可能很大,goahead做select掩码的时候,不仅仅掩码类型是int,连特么移位的1 也是保持默认的int型。这样整个goahead服务已启动就会不停的select退出,这个服务沙雕。

贴出原有代码:

PUBLIC int socketSelect(int sid, int timeout)

{

WebsSocket *sp;

struct timeval tv;

fd_mask *readFds, *writeFds, *exceptFds;

int all, len, nwords, index, bit, nEvents;

 

/*

Allocate and zero the select masks

*/

nwords = (socketHighestFd + NFDBITS) / NFDBITS;

len = nwords * sizeof(fd_mask);

 

readFds = walloc(len);

memset(readFds, 0, len);

writeFds = walloc(len);

memset(writeFds, 0, len);

exceptFds = walloc(len);

memset(exceptFds, 0, len);

 

tv.tv_sec = timeout / 1000;

tv.tv_usec = (timeout % 1000) * 1000;

 

/*

Set the select event masks for events to watch

*/

all = nEvents = 0;

 

if (sid < 0) {

all++;

sid = 0;

}

 

for (; sid < socketMax; sid++) {

if ((sp = socketList[sid]) == NULL) {

if (all == 0) {

break;

} else {

continue;

}

}

assert(sp);

/*

Initialize the ready masks and compute the mask offsets.

*/

index = sp->sock / (NBBY * sizeof(fd_mask));

bit = 1 << (sp->sock % (NBBY * sizeof(fd_mask)));

if (sp->handlerMask & SOCKET_READABLE) {

readFds[index] |= bit;

}

if (sp->handlerMask & SOCKET_WRITABLE) {

writeFds[index] |= bit;

}

if (sp->handlerMask & SOCKET_EXCEPTION) {

exceptFds[index] |= bit;

}

if (sp->flags & SOCKET_RESERVICE) {

tv.tv_sec = 0;

tv.tv_usec = 0;

}

.................................

注意看加粗部分。bit用于计算掩码位,index用于计算字节数。aarch64上NBBY 和

sizeof(fd_mask)都是8.可见这里bit计算必定会出篓子,自己是int型,用于移位的1也是默认的int.

 

那么如何修改呢?简单,把bit设为long, 1 也强制转换成long 就行了。:

 

long all, len, nwords, index, bit, nEvents;

....

index = sp->sock / (NBBY * sizeof(fd_mask));

bit = (long)1 << (sp->sock % (NBBY * sizeof(fd_mask)));

这样就解决了。

 

 

这篇关于从goahead代码的bug看aarch64平台的移位操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/742563

相关文章

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

深入理解Apache Kafka(分布式流处理平台)

《深入理解ApacheKafka(分布式流处理平台)》ApacheKafka作为现代分布式系统中的核心中间件,为构建高吞吐量、低延迟的数据管道提供了强大支持,本文将深入探讨Kafka的核心概念、架构... 目录引言一、Apache Kafka概述1.1 什么是Kafka?1.2 Kafka的核心概念二、Ka