Primary Git Repository for the Zephyr Project. Zephyr is a new generation, scalable, optimized, secure RTOS for multiple hardware architectures.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

32 lines
758 B

/*
* Copyright (c) 2019 Antmicro <www.antmicro.com>
*
* SPDX-License-Identifier: Apache-2.0
*/
#define DT_DRV_COMPAT litex_dna0
#include <zephyr/drivers/hwinfo.h>
#include <soc.h>
#include <string.h>
#include <zephyr/device.h>
#include <zephyr/sys/util.h>
ssize_t z_impl_hwinfo_get_device_id(uint8_t *buffer, size_t length)
{
uint32_t addr = DT_INST_REG_ADDR(0);
ssize_t end = MIN(length, DT_INST_REG_SIZE(0) / 4 *
CONFIG_LITEX_CSR_DATA_WIDTH / 8);
for (int i = 0; i < end; i++) {
#if CONFIG_LITEX_CSR_DATA_WIDTH == 8
buffer[i] = litex_read8(addr);
addr += 4;
#elif CONFIG_LITEX_CSR_DATA_WIDTH == 32
buffer[i] = (uint8_t)(litex_read32(addr) >> (addr % 4 * 8));
addr += 1;
#else
#error Unsupported CSR data width
#endif
}
return end;
}