On 4/19/2017 2:53 AM, Jiri Olsa wrote:
On Wed, Apr 12, 2017 at 06:21:06AM +0800, Jin Yao wrote:

SNIP

+static int branch_type_str(struct branch_type_stat *stat,
+                          char *bf, int bfsize)
+{
+       int i, j = 0, printed = 0;
+       u64 total = 0;
+
+       for (i = 0; i < PERF_BR_MAX; i++)
+               total += stat->counts[i];
+
+       if (total == 0)
+               return 0;
+
+       printed += scnprintf(bf + printed, bfsize - printed, " (");
+
+       if (stat->jcc_fwd > 0) {
+               j++;
+               printed += scnprintf(bf + printed, bfsize - printed,
+                                    "JCC forward");
+       }
+
+       if (stat->jcc_bwd > 0) {
+               if (j++)
+                       printed += scnprintf(bf + printed, bfsize - printed,
+                                            " JCC backward");
+               else
+                       printed += scnprintf(bf + printed, bfsize - printed,
+                                            "JCC backward");
+       }
+
+       if (stat->cross_4k > 0) {
+               if (j++)
+                       printed += scnprintf(bf + printed, bfsize - printed,
+                                            " CROSS_4K");
+               else
+                       printed += scnprintf(bf + printed, bfsize - printed,
+                                            "CROSS_4K");
+       }
could that 2 legs if be shortened to just one scnprintf like (untested):

    printed += scnprintf(bf + printed, bfsize - printed, "%s%s", j++ ? " " : "", 
"CROSS_4K");

I'd also probably use some kind of macro or function
with all that similar code, but I dont insist ;-)

thanks,
jirka

Thanks for this suggestion. I will use this kind of code. Of course, I will test. :)

Thanks
Jin Yao


Reply via email to