Em Sun, May 31, 2015 at 11:36:23AM +0530, Madhavan Srinivasan escreveu: > commit <fd979c013207> intruduced perf_event_sysfs_show function to display > event_str value of an attr in kernel/event/core.c. But the function returns > the value with a newline char. So, if a event also carries a event.unit file, > when printing the counter data perf tool formatting goes for a spin. > That is, because of the event unit, event name is printed in the newline > because of perf_event_sysfs_show returns with a newline char. > > Now fixing perf core will break API, hencing proposing a fix in the perf tool.
Looks sensible, but please next time add spaces around operators, doing it this time. I.e., it should be: scale[sret - 1] = '\0'; Thanks, - Arnaldo > + if (scale[sret-1] == '\n') > + scale[sret-1] = '\0'; > + else > + scale[sret] = '\0'; > + > /* > * save current locale > */ > @@ -154,7 +158,10 @@ static int perf_pmu__parse_unit(struct perf_pmu_alias > *alias, char *dir, char *n > > close(fd); > > - alias->unit[sret] = '\0'; > + if (alias->unit[sret-1] == '\n') > + alias->unit[sret-1] = '\0'; > + else > + alias->unit[sret] = '\0'; > > return 0; > error: > -- > 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/