2018-04-16 19:03:33 +02:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Ken Rabold
|
|
|
|
*
|
|
|
|
* This file is subject to the terms and conditions of the GNU Lesser
|
|
|
|
* General Public License v2.1. See the file LICENSE in the top level
|
|
|
|
* directory for more details.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ingroup cpu_fe310
|
|
|
|
* @{
|
|
|
|
*
|
|
|
|
* @file cpuid.c
|
|
|
|
* @brief Low-level CPUID driver implementation
|
|
|
|
*
|
|
|
|
* @author Ken Rabold
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <string.h>
|
|
|
|
|
|
|
|
#include "periph/cpuid.h"
|
|
|
|
#include "cpu.h"
|
2020-09-09 21:37:15 +02:00
|
|
|
#include "vendor/riscv_csr.h"
|
2018-04-16 22:35:32 +02:00
|
|
|
#include "vendor/platform.h"
|
2018-04-16 19:03:33 +02:00
|
|
|
|
|
|
|
void cpuid_get(void *id)
|
|
|
|
{
|
|
|
|
uint32_t result[5];
|
|
|
|
|
|
|
|
/* Read RISC-V CSRs for CPU ID */
|
|
|
|
result[0] = read_csr(mvendorid);
|
|
|
|
result[1] = read_csr(marchid);
|
|
|
|
result[2] = read_csr(mimpid);
|
|
|
|
|
|
|
|
memcpy(id, &result[0], CPUID_LEN);
|
|
|
|
}
|