[LTP] [PATCH] open_posix_testsuite: add set_affinity_single()
Jan Stancek
jstancek@redhat.com
Thu Nov 12 14:41:15 CET 2015
----- Original Message -----
> From: "Cyril Hrubis" <chrubis@suse.cz>
> To: "Jan Stancek" <jstancek@redhat.com>
> Cc: ltp@lists.linux.it
> Sent: Thursday, 12 November, 2015 2:09:52 PM
> Subject: Re: [LTP] [PATCH] open_posix_testsuite: add set_affinity_single()
>
> Hi!
> > +static int get_present_cpu_from_sysfs(void)
> > +{
> > + FILE *f;
> > + int cpu = -1;
> > +
> > + f = fopen("/sys/devices/system/cpu/present", "r");
> > + if (!f)
> > + return -1;
> > + fscanf(f, "%d", &cpu);
> > + fclose(f);
> > +
> > + return cpu;
> > +}
> > +
> > +static int get_present_cpu_from_cpuinfo(void)
> > +{
> > + FILE *f;
> > + int cpu = -1;
> > + char line[4096];
> > +
> > + f = fopen("/proc/cpuinfo", "r");
> > + if (!f)
> > + return -1;
> > +
> > + while (!feof(f)) {
> > + if (!fgets(line, sizeof(line), f))
> > + return -1;
> > + /*
> > + * cpuinfo output is not consistent across all archictures,
> > + * it can be "processor : N", but for example on s390
> > + * it's: "processor N: ...", so ignore any non-number
> > + * after "processor"
> > + */
> > + if (sscanf(line, "processor%*[^0123456789]%d", &cpu) == 1)
> > + break;
> > + }
> > + fclose(f);
> > +
> > + return cpu;
> > +}
> > +
> > +static int set_affinity_single(void)
> > +{
> > + int cpu;
> > +
> > + cpu = get_present_cpu_from_sysfs();
> > + if (cpu < 0)
> > + cpu = get_present_cpu_from_cpuinfo();
>
> We should probably fallback here to cpu = 0 in case that we have failed
> to parse the cpuinfo. Not that it's likely to happen.
>
> So I would do here:
>
> cpu = get_present_cpu_from_sysfs();
>
> if (cpu >= 0)
> goto set_affinity;
>
> cpu = get_present_cpu_from_cpuinfo();
>
> if (cpu >= 0)
> goto set_affinity;
>
> fprintf(stderr, "WARNING: Failed to detect present cpu using cpu=0\n");
>
> cpu = 0;
>
> set_affinity:
> return set_affinity(cpu);
>
> > + return set_affinity(cpu);
> > +}
> > +
> > #else
> > static int set_affinity(int cpu)
> ^
> You should also rename this stub for
> non-linux OSes.
>
> Otherwise it looks good, acked.
Pushed with changes you suggested.
Regards,
Jan
>
> --
> Cyril Hrubis
> chrubis@suse.cz
>
More information about the Ltp
mailing list