cgen: support `-profile -` and `-profile x.txt`
parent
eecf92cdb0
commit
4bcdf11743
|
@ -65,8 +65,15 @@ The build flags are shared by the build and run commands:
|
||||||
-prod
|
-prod
|
||||||
Compile the executable in production mode where most optimizations are enabled.
|
Compile the executable in production mode where most optimizations are enabled.
|
||||||
|
|
||||||
-prof, -profile
|
-prof, -profile <file.txt>
|
||||||
Compile the executable with all functions profiled.
|
Compile the executable with all functions profiled.
|
||||||
|
The profile results will be stored in `file.txt`.
|
||||||
|
The format is 4 fields, separated by a space, for each v function:
|
||||||
|
a) how many times it was called
|
||||||
|
b) how much *nanoseconds in total* it took
|
||||||
|
c) an average for each function (i.e. (b) / (a) )
|
||||||
|
d) the function name
|
||||||
|
NB: if you want to output the profile info to stdout, use `-profile -`.
|
||||||
|
|
||||||
-stats
|
-stats
|
||||||
Enable more detailed statistics reporting, while compiling test files.
|
Enable more detailed statistics reporting, while compiling test files.
|
||||||
|
|
|
@ -146,7 +146,9 @@ fn parse_args(args []string) (&pref.Preferences, string) {
|
||||||
res.is_bare = true
|
res.is_bare = true
|
||||||
}
|
}
|
||||||
'-prof', '-profile' {
|
'-prof', '-profile' {
|
||||||
|
res.profile_file = cmdline.option(current_args, '-profile', '-')
|
||||||
res.is_prof = true
|
res.is_prof = true
|
||||||
|
i++
|
||||||
}
|
}
|
||||||
'-prod' {
|
'-prod' {
|
||||||
res.is_prod = true
|
res.is_prod = true
|
||||||
|
|
|
@ -141,8 +141,17 @@ fn (mut g Gen) gen_fn_decl(it ast.FnDecl) {
|
||||||
if is_main {
|
if is_main {
|
||||||
if g.pref.is_prof {
|
if g.pref.is_prof {
|
||||||
g.pcs_declarations.writeln('void vprint_profile_stats(){')
|
g.pcs_declarations.writeln('void vprint_profile_stats(){')
|
||||||
for pfn_name, pcounter_name in g.pcs {
|
if g.pref.profile_file == '-' {
|
||||||
g.pcs_declarations.writeln('\tif (${pcounter_name}_calls) printf("%llu %f %f ${pfn_name} \\n", ${pcounter_name}_calls, $pcounter_name, $pcounter_name / ${pcounter_name}_calls );')
|
for pfn_name, pcounter_name in g.pcs {
|
||||||
|
g.pcs_declarations.writeln('\tif (${pcounter_name}_calls) printf("%llu %f %f ${pfn_name} \\n", ${pcounter_name}_calls, $pcounter_name, $pcounter_name / ${pcounter_name}_calls );')
|
||||||
|
}
|
||||||
|
}else{
|
||||||
|
g.pcs_declarations.writeln('\tFILE * fp;')
|
||||||
|
g.pcs_declarations.writeln('\tfp = fopen ("${g.pref.profile_file}", "w+");')
|
||||||
|
for pfn_name, pcounter_name in g.pcs {
|
||||||
|
g.pcs_declarations.writeln('\tif (${pcounter_name}_calls) fprintf(fp, "%llu %f %f ${pfn_name} \\n", ${pcounter_name}_calls, $pcounter_name, $pcounter_name / ${pcounter_name}_calls );')
|
||||||
|
}
|
||||||
|
g.pcs_declarations.writeln('\tfclose(fp);')
|
||||||
}
|
}
|
||||||
g.pcs_declarations.writeln('}')
|
g.pcs_declarations.writeln('}')
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,6 +31,7 @@ pub mut:
|
||||||
is_live bool // main program that contains live/hot code
|
is_live bool // main program that contains live/hot code
|
||||||
is_shared bool // an ordinary shared library, -shared, no matter if it is live or not
|
is_shared bool // an ordinary shared library, -shared, no matter if it is live or not
|
||||||
is_prof bool // benchmark every function
|
is_prof bool // benchmark every function
|
||||||
|
profile_file string // the profile results will be stored inside profile_file
|
||||||
translated bool // `v translate doom.v` are we running V code translated from C? allow globals, ++ expressions, etc
|
translated bool // `v translate doom.v` are we running V code translated from C? allow globals, ++ expressions, etc
|
||||||
is_prod bool // use "-O2"
|
is_prod bool // use "-O2"
|
||||||
obfuscate bool // `v -obf program.v`, renames functions to "f_XXX"
|
obfuscate bool // `v -obf program.v`, renames functions to "f_XXX"
|
||||||
|
|
Loading…
Reference in New Issue