• Len Brown's avatar
    tools/power turbostat: Fix node and siblings lookup data · 0e2d8f05
    Len Brown authored
    The turbostat code only looks at thread_siblings_list to determine if
    processing units/threads are on the same the core.  This works well on
    Intel systems which have a shared L1 instruction and data cache.  This
    does not work on AMD systems which have shared L1 instruction cache but
    separate L1 data caches.  Other utilities also check sibling's core ID
    to determine if the processing unit shares the same core.
    
    Additionally, the cpu_topology *cpus list used in topology_probe() can
    be used elsewhere in the code to simplify things.
    
    Export *cpus to the entire turbostat code, and add Processing Unit/Thread
    IDs information to each cpu_topology struct.  Confirm that the thread
    is on the same core as indicated by thread_siblings_list.
    
    [v2]: Fixup CPU_* usage that caused gcc malloc error.
    Signed-off-by: default avatarPrarit Bhargava <prarit@redhat.com>
    Signed-off-by: default avatarLen Brown <len.brown@intel.com>
    0e2d8f05
turbostat.c 140 KB