/* * This file is part of the libopencm3 project. * * Copyright (C) 2012 Karl Palsson * * This library is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this library. If not, see . */ #ifndef LIBOPENCM3_DESIG_H #define LIBOPENCM3_DESIG_H #include #include /* --- Device Electronic Signature -------------------------------- */ BEGIN_DECLS /** * Read the on board flash size * @return flash size in KB */ uint16_t desig_get_flash_size(void); /** * Read the full 96 bit unique identifier * Note: ST specifies that bits 31..16 are _also_ reserved for future use * @param result pointer to at least 3xuint32_ts (96 bits) */ void desig_get_unique_id(uint32_t *result); /** * Read the full 96 bit unique identifier and return it as a * zero-terminated string * @param string memory region to write the result to * @param string_len the size of string in bytes */ void desig_get_unique_id_as_string(char *string, unsigned int string_len); /** * Generate the same serial number from the unique id registers as * the DFU bootloader. * * This document: http://www.usb.org/developers/docs/devclass_docs/usbmassbulk_10.pdf * says that the serial number has to be at least 12 digits long and that * the last 12 digits need to be unique. It also stipulates that the valid * character set is that of upper-case hexadecimal digits. * The onboard DFU bootloader produces a 12-digit serial based on the * 96-bit unique ID. Show the serial with ```dfu-util -l``` while the * MCU is in DFU mode. * @see https://my.st.com/52d187b7 for the algorithim used. * @param string pointer to store serial in, must be at least 13 bytes */ void desig_get_unique_id_as_dfu(char *string); END_DECLS #endif