/* * Copyright (c) 2019 Antmicro * * SPDX-License-Identifier: Apache-2.0 */ #define DT_DRV_COMPAT litex_dna0 #include #include #include #include #include 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_ADDR(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; }