annotate src/core/ngx_cpuinfo.c @ 660:d0f7a625f27c NGINX_1_1_14

nginx 1.1.14 *) Feature: multiple "limit_req" limits may be used simultaneously. *) Bugfix: in error handling while connecting to a backend. Thanks to Piotr Sikora. *) Bugfix: in AIO error handling on FreeBSD. *) Bugfix: in the OpenSSL library initialization. *) Bugfix: the "proxy_redirect" directives might not be correctly inherited. *) Bugfix: memory leak during reconfiguration if the "pcre_jit" directive was used.
author Igor Sysoev <http://sysoev.ru>
date Mon, 30 Jan 2012 00:00:00 +0400
parents 56baf312c1b5
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
660
d0f7a625f27c nginx 1.1.14
Igor Sysoev <http://sysoev.ru>
parents: 468
diff changeset
4 * Copyright (C) Nginx, Inc.
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 #if (( __i386__ || __amd64__ ) && ( __GNUC__ || __INTEL_COMPILER ))
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 static ngx_inline void ngx_cpuid(uint32_t i, uint32_t *buf);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17
166
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
18 #if ( __i386__ )
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
19
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
20 static ngx_inline void
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
21 ngx_cpuid(uint32_t i, uint32_t *buf)
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
22 {
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
23
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
24 /*
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
25 * we could not use %ebx as output parameter if gcc builds PIC,
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
26 * and we could not save %ebx on stack, because %esp is used,
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
27 * when the -fomit-frame-pointer optimization is specified.
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
28 */
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
29
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
30 __asm__ (
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
31
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
32 " mov %%ebx, %%esi; "
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
33
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
34 " cpuid; "
200
d2ae1c9f1fd3 nginx 0.3.47
Igor Sysoev <http://sysoev.ru>
parents: 166
diff changeset
35 " mov %%eax, (%1); "
d2ae1c9f1fd3 nginx 0.3.47
Igor Sysoev <http://sysoev.ru>
parents: 166
diff changeset
36 " mov %%ebx, 4(%1); "
d2ae1c9f1fd3 nginx 0.3.47
Igor Sysoev <http://sysoev.ru>
parents: 166
diff changeset
37 " mov %%edx, 8(%1); "
d2ae1c9f1fd3 nginx 0.3.47
Igor Sysoev <http://sysoev.ru>
parents: 166
diff changeset
38 " mov %%ecx, 12(%1); "
166
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
39
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
40 " mov %%esi, %%ebx; "
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
41
200
d2ae1c9f1fd3 nginx 0.3.47
Igor Sysoev <http://sysoev.ru>
parents: 166
diff changeset
42 : : "a" (i), "D" (buf) : "ecx", "edx", "esi", "memory" );
166
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
43 }
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
44
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
45
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
46 #else /* __amd64__ */
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
47
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
48
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 static ngx_inline void
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 ngx_cpuid(uint32_t i, uint32_t *buf)
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51 {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52 uint32_t eax, ebx, ecx, edx;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54 __asm__ (
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56 "cpuid"
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 : "=a" (eax), "=b" (ebx), "=c" (ecx), "=d" (edx) : "a" (i) );
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 buf[0] = eax;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61 buf[1] = ebx;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 buf[2] = edx;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 buf[3] = ecx;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
65
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
66
166
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
67 #endif
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
68
fef68f68bcfd nginx 0.3.30
Igor Sysoev <http://sysoev.ru>
parents: 160
diff changeset
69
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 /* auto detect the L2 cache line size of modern and widespread CPUs */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72 void
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73 ngx_cpuinfo(void)
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74 {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 u_char *vendor;
468
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 364
diff changeset
76 uint32_t vbuf[5], cpu[4], model;
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78 vbuf[0] = 0;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79 vbuf[1] = 0;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 vbuf[2] = 0;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 vbuf[3] = 0;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82 vbuf[4] = 0;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84 ngx_cpuid(0, vbuf);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
86 vendor = (u_char *) &vbuf[1];
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
87
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
88 if (vbuf[0] == 0) {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
89 return;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
90 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
91
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 ngx_cpuid(1, cpu);
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
93
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94 if (ngx_strcmp(vendor, "GenuineIntel") == 0) {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95
364
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
96 switch ((cpu[0] & 0xf00) >> 8) {
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
98 /* Pentium */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 case 5:
364
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
100 ngx_cacheline_size = 32;
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
101 break;
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
102
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 /* Pentium Pro, II, III */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104 case 6:
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105 ngx_cacheline_size = 32;
364
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
106
468
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 364
diff changeset
107 model = ((cpu[0] & 0xf0000) >> 8) | (cpu[0] & 0xf0);
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 364
diff changeset
108
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 364
diff changeset
109 if (model >= 0xd0) {
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 364
diff changeset
110 /* Intel Core, Core 2, Atom */
364
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
111 ngx_cacheline_size = 64;
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
112 }
a39aab45a53f nginx 0.6.26
Igor Sysoev <http://sysoev.ru>
parents: 200
diff changeset
113
160
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114 break;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
116 /*
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
117 * Pentium 4, although its cache line size is 64 bytes,
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
118 * it prefetches up to two cache lines during memory read
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
119 */
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
120 case 15:
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121 ngx_cacheline_size = 128;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
122 break;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
124
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125 } else if (ngx_strcmp(vendor, "AuthenticAMD") == 0) {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
126 ngx_cacheline_size = 64;
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
127 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
128 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
129
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
130 #else
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
131
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
132
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
133 void
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
134 ngx_cpuinfo(void)
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
135 {
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
136 }
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
137
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
138
73e8476f9142 nginx 0.3.27
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
139 #endif