summaryrefslogblamecommitdiffstats
path: root/c/src/lib/libbsp/sparc/leon3/smp/getcpuid.c
blob: 099a83b9256d2fff758aa7e1837c36054c647978 (plain) (tree)
1
2
3
4
5
6
7
8
9
   


                                          




                                                    
  


                                                           

   


                                               
 
              




                                                                
/**
 * @file
 * @ingroup sparc_leon3
 * @brief 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.
 */

#include <rtems/score/cpu.h>

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

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