Nginx源码分析之-auto/types/value和auto/types/uintptr_t

微信公众号:Nginx源码分析
关注可了解更多的Nginx知识。任何问题或建议,请公众号留言;
关注公众号,有趣有内涵的文章第一时间送达!

回顾

在上周分析过了auto/types/typedef脚本,以及auto/types/sizeof脚本。我们简单的回忆一下这两个脚本的作用:

  • auto/types/typedef: 判断数据类型是否存在,如果不存在则生成相应的typedef语句。
  • auto/types/sizeof:判断特定操作系统上某个数据类型的长度,然后把获取的长度写入到c源文件中(通过auto/types/value脚本,我们稍后就会分析这个脚本).
    辅助脚本

    今天呢,我们就继续分析auto/types中剩余的两个脚本:auto/types/uintptr_tauto/types/value
    下面开始我们的表演:

auto/types/uintptr_t 脚本

这个脚本的作用是判断uintptr_t类型是否存在,如果不存在,那么根据其他条件生成相应的tyepdef语句。
Talk is cheap, show me you code,多说无益,直接撸代码。

参数

无,此脚本没有输入参数

功能

判断uintptr_t类型是否存在。如果不存在的话,生成相应的typedef

脚本内容

下面是该脚本的内容:

echo $ngx_n "checking for uintptr_t ...$ngx_c"
echo >> $NGX_ERR
echo "checking for uintptr_t" >> $NGX_ERR

found=no

cat << END > $NGX_AUTOTEST.c

#include <sys/types.h>
$NGX_INTTYPES_H

int main() {
    uintptr_t i = 0;
    return 0;
}

END

eval "$CC -o $NGX_AUTOTEST $NGX_AUTOTEST.c >> $NGX_ERR 2>&1"

if [ -x $NGX_AUTOTEST ]; then
    echo " uintptr_t found"
    found=yes
else
    echo $ngx_n " uintptr_t not found" $ngx_c
fi

rm $NGX_AUTOTEST*


if [ $found = no ]; then
    found="uint`expr 8 \* $ngx_ptr_size`_t"
    echo ", $found used"

    echo "typedef $found  uintptr_t;"                   >> $NGX_AUTO_CONFIG_H
    echo "typedef $found  intptr_t;" | sed -e 's/u//g'  >> $NGX_AUTO_CONFIG_H
fi
脚本分析

1). 首先是向控制台输出信息

   echo $ngx_n "checking for uintptr_t ...$ngx_c" 

我们在终端上可以看到如下内容:

checking for uintptr_t ...

2).NGX_AUTOTEST中生成内容。

cat << END > $NGX_AUTOTEST.c

#include <sys/types.h>
$NGX_INTTYPES_H

int main() {
    uintptr_t i = 0;
    return 0;
}

END

这里其实生成了一个c源文件,我们可以输出这个源文件的内容看一下,如下:

#include <sys/types.h>
#include <inttypes.h>

int main() {
    uintptr_t i = 0;
    return 0;
}

我们看到这个c源文件其实并没有任何的实质性的功能代码,只有一条变量声明和赋值语句,功能非常简单。如果uintptr_t类型存在的话,那么这个c源文件是可以被成功编译并且执行的,如果该类型不存在,那么编译的时候就会出错。

3). 编译上面生成的源文件

eval "$CC -o $NGX_AUTOTEST $NGX_AUTOTEST.c >> $NGX_ERR 2>&1"

我们已经在前面的文章中介绍了很多次这行代码的功能。如果不懂得话,可以看看前面几篇文章。

4). 执行可执行程序

if [ -x $NGX_AUTOTEST ]; then
    echo " uintptr_t found"
    found=yes
else
    echo $ngx_n " uintptr_t not found" $ngx_c
fi

如果编译后成功,那么说明uintptr_t类型是存在的。found变量的值就会被设置为yes.

5).删除目标文件

rm -f $NGX_AUTOTEST

Nginx会在运行完可执行文件之后就将该文件删除,所以实际上我们在Nginx的目录中是不能看到这些文件的,它们都是临时文件。

6).如果类型不存在的话,怎么办?
这里面牵涉到一个变量ngx_ptr_size变量。我们先瞅瞅这个变量是干啥滴。
auto/unix文件中,有如下代码:

ngx_type="void *"; . auto/types/sizeof; ngx_ptr_size=$ngx_size

根据我们前面分析的auto/types/sizeof脚本可以知道ngx_ptr_size的值就是 sizeof(void *)的值。在我自己的Centos上面,这个值是8.

下面我们就看看auto/types/uintptr_t中如何处理这种情况的。

if [ $found = no ]; then
    found="uint`expr 8 \* $ngx_ptr_size`_t"
    echo ", $found used"

    echo "typedef $found  uintptr_t;"                   >> $NGX_AUTO_CONFIG_H
    echo "typedef $found  intptr_t;" | sed -e 's/u//g'  >> $NGX_AUTO_CONFIG_H
fi

如果 found = no的话,就说明uintptr_t类型不存在,那么应该咋办呢?
首先我们看一下found的赋值。

found="uint`expr 8 \* $ngx_ptr_size`_t"

上面的脚本中exprshell中数值计算的命令,所以expr 8 \* $ngx_ptr_size 就是 64(对于我自己的Centos,不同的宿主计算机,该值可能不同)。所以found的值为uint64_t
紧接着会生成两个typedef语句。

echo "typedef $found  uintptr_t;" >> $NGX_AUTO_CONFIG_H

这里就是向auto_config.h文件中写入:

typedef uint64_t uintptr_t;

而另一条脚本:

echo "typedef $found  intptr_t;" | sed -e 's/u//g'  >> $NGX_AUTO_CONFIG_H

这行脚本则是写入如下语句:

typedef int64_t intptr_t; 

脚本中的sed语句是把所有的字母u替换为空。所以最终就是上面的代码。

到此为止,我们已经分析完了auto/types/uintptr_t脚本。

auto/types/value 脚本

auto_config.h文件中define一些变量。

参数

ngx_param: define的变量名
ngx_value: define的变量值

功能

auto_config.h文件中,生成一条define语句。
其中名称就是ngx_param,值就是ngx_value

示例

这个脚本很多情况下都是和auto/types/sizeof脚本一起使用,前者得到一些变量的值,后者把值写入到c的源文件中。
我们在auto/unix中找到了一个例子,如下:

ngx_type="void *"; . auto/types/sizeof; ngx_ptr_size=$ngx_size
ngx_param=NGX_PTR_SIZE; ngx_value=$ngx_size; . auto/types/value

这个例子就是上面分析auto/types/uintptr_t脚本时提到的ngx_ptr_size变量。
第一行脚本得到void *的长度,保存到ngx_size变量中。
第二行脚本将变量的值写入到auto_config.h中。

脚本内容
cat << END >> $NGX_AUTO_CONFIG_H

#ifndef $ngx_param
#define $ngx_param  $ngx_value
#endif

END
脚本分析

我们以示例中的代码分析这个脚本。

ngx_param=NGX_PTR_SIZE; ngx_value=$ngx_size; . auto/types/value

假设ngx_size的值是8,那么最终在auto_config.h文件中就会生成如下的define代码:

#ifndef NGX_PTR_SIZE
#define NGX_PTR_SIZE  8
#endif

这个脚本很简单,我们就粗略的分析一下。

总结

到此为止,我们已经分析了auto/types中的所有脚本,现在简单的总结一下这几个脚本的作用。
auto/types/sizeof:判断一个变量类型的长度。
auto/types/typedef:判断指定变量类型是否存在,生成相应的typedef代码。
auto/types/uintptr_t:判断uintptr_t类型是否存在。
auto/types/values:向auto_config.h文件中自动生成define语句。

后面的文章我们会接着分析nginx的源码,敬请期待。顺便关注我的个公众号(Nginx源码分析)。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容