| * Copyright (c) 2019 Antmicro <www.antmicro.com> |
| * SPDX-License-Identifier: Apache-2.0 |
| #define DT_DRV_COMPAT litex_dna0 |
| #include <drivers/hwinfo.h> |
| ssize_t z_impl_hwinfo_get_device_id(uint8_t *buffer, size_t length) |
| uint32_t volatile *ptr = (uint32_t volatile *)(DT_INST_REG_ADDR(0)); |
| ssize_t end = MIN(length, (DT_INST_REG_SIZE(0) / sizeof(uint32_t))); |
| for (int i = 0; i < end; i++) { |
| /* In LiteX even though registers are 32-bit wide, each one |
| contains meaningful data only in the lowest 8 bits */ |
| buffer[i] = (uint8_t)(ptr[i] & 0xff); |