summaryrefslogtreecommitdiffstats
path: root/c/src/lib/libbsp/sparc/leon3/smp/getcpuid.c
blob: 5678fd4962625209a426a6c18d839d94456b50fe (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
/**
 *  @file
 *
 *  LEON3 SMP Obtain CPU Core Number
 */

/*
 *  COPYRIGHT (c) 1989-2011.
 *  On-Line Applications Research Corporation (OAR).
 *
 *  The license and distribution terms for this file may be
 *  found in the file LICENSE in this distribution or at
 *  http://www.rtems.com/license/LICENSE.
 */

int bsp_smp_processor_id(void)
{
  unsigned int id;
  __asm__ __volatile__( "rd     %%asr17,%0\n\t" : "=r" (id) : );

  return ((id >> 28) & 0xff);
}