Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
B
brpc
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
brpc
Commits
aed68f46
Commit
aed68f46
authored
Sep 17, 2018
by
Ruan Kunliang
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refcator read_cpu_frequency_from_brand_string
parent
5eabd9ac
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
45 additions
and
38 deletions
+45
-38
time.cpp
src/butil/time.cpp
+45
-38
No files found.
src/butil/time.cpp
View file @
aed68f46
...
@@ -121,43 +121,6 @@ static int64_t read_cpu_current_frequency(char* buf, ssize_t n) {
...
@@ -121,43 +121,6 @@ static int64_t read_cpu_current_frequency(char* buf, ssize_t n) {
return
result
;
return
result
;
}
}
static
int64_t
read_cpu_frequency_from_brand_string
(
char
*
buf
,
ssize_t
n
)
{
/* We read the information from the /proc filesystem. It may contains at
least one line like
model name : Intel(R) Xeon(R) CPU E5-2620 v2 @ 2.10GHz
We search for this line and convert the number in an integer. */
char
*
brand
=
static_cast
<
char
*>
(
memmem
(
buf
,
n
,
"model name"
,
10
));
if
(
brand
==
NULL
)
{
return
0
;
}
char
*
end
=
buf
+
n
;
char
*
num_str
=
brand
+
10
;
while
(
num_str
!=
end
&&
*
num_str
!=
'@'
)
{
if
(
*
num_str
++
==
'\n'
)
{
return
0
;
}
}
while
(
num_str
!=
end
&&
!
isdigit
(
*
num_str
))
{
num_str
++
;
}
//expect x.xxGhz
//FSB may be 0.10GHz or 0.133...GHz
if
(
end
-
num_str
<
7
||
num_str
[
1
]
!=
'.'
||
!
isdigit
(
num_str
[
2
])
||
!
isdigit
(
num_str
[
3
])
||
num_str
[
4
]
!=
'G'
)
{
return
0
;
}
int64_t
result
=
(
num_str
[
0
]
-
'0'
)
*
10
+
(
num_str
[
2
]
-
'0'
);
int64_t
last
=
num_str
[
3
]
-
'0'
;
if
(
last
==
7
)
{
last
=
6
;
}
for
(
int
i
=
0
;
i
<
8
;
i
++
)
{
result
=
result
*
10
+
last
;
}
return
result
;
}
#if defined(__x86_64__) || defined(__i386__)
#if defined(__x86_64__) || defined(__i386__)
#if defined(__pic__) && defined(__i386__)
#if defined(__pic__) && defined(__i386__)
static
void
__cpuid
(
uint32_t
reg
[
4
],
uint32_t
code
)
{
static
void
__cpuid
(
uint32_t
reg
[
4
],
uint32_t
code
)
{
...
@@ -179,6 +142,7 @@ static void __cpuid(uint32_t reg[4], uint32_t code) {
...
@@ -179,6 +142,7 @@ static void __cpuid(uint32_t reg[4], uint32_t code) {
}
}
#endif
#endif
#endif
#endif
static
int64_t
read_cpu_frequency_by_cpuid
()
{
static
int64_t
read_cpu_frequency_by_cpuid
()
{
int64_t
result
=
0
;
int64_t
result
=
0
;
#if defined(__x86_64__) || defined(__i386__)
#if defined(__x86_64__) || defined(__i386__)
...
@@ -193,6 +157,49 @@ static int64_t read_cpu_frequency_by_cpuid() {
...
@@ -193,6 +157,49 @@ static int64_t read_cpu_frequency_by_cpuid() {
return
result
;
return
result
;
}
}
static
int64_t
read_cpu_frequency_from_brand_string
()
{
int64_t
result
=
0
;
#if defined(__x86_64__) || defined(__i386__)
union
{
char
brand
[
48
];
uint32_t
reg
[
12
];
}
buf
;
__cpuid
(
buf
.
reg
,
0x80000000
);
if
(
buf
.
reg
[
0
]
<
0x80000004
)
{
return
0
;
}
__cpuid
(
buf
.
reg
,
0x80000002
);
__cpuid
(
buf
.
reg
+
4
,
0x80000003
);
__cpuid
(
buf
.
reg
+
8
,
0x80000004
);
//Get something like: Intel(R) Xeon(R) CPU E5-2620 v2 @ 2.10GHz
char
*
end
=
buf
.
brand
+
sizeof
(
buf
.
brand
);
char
*
p
=
buf
.
brand
;
while
(
p
!=
end
&&
*
p
!=
'@'
)
{
if
(
*
p
++
==
'\n'
)
{
return
0
;
}
}
while
(
p
!=
end
&&
!
isdigit
(
*
p
))
{
p
++
;
}
//expect x.xxGhz
//FSB may be 0.10GHz or 0.133...GHz
if
(
end
-
p
<
7
||
p
[
1
]
!=
'.'
||
!
isdigit
(
p
[
2
])
||
!
isdigit
(
p
[
3
])
||
p
[
4
]
!=
'G'
)
{
return
0
;
}
result
=
(
p
[
0
]
-
'0'
)
*
10
+
(
p
[
2
]
-
'0'
);
int64_t
last
=
p
[
3
]
-
'0'
;
if
(
last
==
7
)
{
last
=
6
;
}
for
(
int
i
=
0
;
i
<
8
;
i
++
)
{
result
=
result
*
10
+
last
;
}
#endif
return
result
;
}
// read_cpu_frequency() is modified from source code of glibc.
// read_cpu_frequency() is modified from source code of glibc.
int64_t
read_cpu_frequency
(
bool
*
invariant_tsc
)
{
int64_t
read_cpu_frequency
(
bool
*
invariant_tsc
)
{
const
int
fd
=
open
(
"/proc/cpuinfo"
,
O_RDONLY
);
const
int
fd
=
open
(
"/proc/cpuinfo"
,
O_RDONLY
);
...
@@ -214,7 +221,7 @@ int64_t read_cpu_frequency(bool* invariant_tsc) {
...
@@ -214,7 +221,7 @@ int64_t read_cpu_frequency(bool* invariant_tsc) {
&&
memmem
(
flags_pos
,
buf
+
n
-
flags_pos
,
"nonstop_tsc"
,
11
))
{
&&
memmem
(
flags_pos
,
buf
+
n
-
flags_pos
,
"nonstop_tsc"
,
11
))
{
int64_t
result
=
read_cpu_frequency_by_cpuid
();
int64_t
result
=
read_cpu_frequency_by_cpuid
();
if
(
result
<=
0
)
{
if
(
result
<=
0
)
{
result
=
read_cpu_frequency_from_brand_string
(
buf
,
n
);
result
=
read_cpu_frequency_from_brand_string
();
}
}
if
(
result
>
0
)
{
if
(
result
>
0
)
{
*
invariant_tsc
=
true
;
*
invariant_tsc
=
true
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment