Merge pull request #10 "Add Device Electronic Signature support."
Merge remote-tracking branch 'karlp/desig'
This commit is contained in:
52
include/libopencm3/stm32/f1/desig.h
Normal file
52
include/libopencm3/stm32/f1/desig.h
Normal file
@@ -0,0 +1,52 @@
|
||||
/*
|
||||
* This file is part of the libopencm3 project.
|
||||
*
|
||||
* Copyright (C) 2012 Karl Palsson <karlp@tweak.net.au>
|
||||
*
|
||||
* 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 <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
#ifndef LIBOPENCM3_DESIG_H
|
||||
#define LIBOPENCM3_DESIG_H
|
||||
|
||||
#include <libopencm3/stm32/memorymap.h>
|
||||
#include <libopencm3/cm3/common.h>
|
||||
|
||||
/* --- Device Electronic Signature -------------------------------- */
|
||||
|
||||
/* Flash size register */
|
||||
#define DESIG_FLASH_SIZE MMIO16(DESIG_FLASH_SIZE_BASE + 0x00)
|
||||
|
||||
/* Unique ID register (96 bits) */
|
||||
/* Note: ST says these may be accessed in any width if you choose */
|
||||
#define DESIG_UID_15_0 MMIO16(DESIG_UNIQUE_ID_BASE + 0x00)
|
||||
/* Listed as "This field value is also reserved for a future feature" WTH?! */
|
||||
#define DESIG_UID_31_16 MMIO16(DESIG_UNIQUE_ID_BASE + 0x02)
|
||||
#define DESIG_UID_63_32 MMIO32(DESIG_UNIQUE_ID_BASE + 0x04)
|
||||
#define DESIG_UID_95_64 MMIO32(DESIG_UNIQUE_ID_BASE + 0x08)
|
||||
|
||||
/**
|
||||
* Read the onboard flash size
|
||||
* @return flash size in KB
|
||||
*/
|
||||
u16 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 3xu32s (96 bits)
|
||||
*/
|
||||
void desig_get_unique_id(u32 result[]);
|
||||
|
||||
#endif
|
||||
@@ -26,6 +26,7 @@
|
||||
|
||||
/* Memory map for all busses */
|
||||
#define PERIPH_BASE ((u32)0x40000000)
|
||||
#define INFO_BASE ((u32)0x1ffff000)
|
||||
#define PERIPH_BASE_APB1 (PERIPH_BASE + 0x00000)
|
||||
#define PERIPH_BASE_APB2 (PERIPH_BASE + 0x10000)
|
||||
#define PERIPH_BASE_AHB (PERIPH_BASE + 0x18000)
|
||||
@@ -110,4 +111,8 @@
|
||||
/* FSMC */
|
||||
#define FSMC_BASE (PERIPH_BASE + 0x60000000)
|
||||
|
||||
/* Device Electronic Signature */
|
||||
#define DESIG_FLASH_SIZE_BASE (INFO_BASE + 0x7e0)
|
||||
#define DESIG_UNIQUE_ID_BASE (INFO_BASE + 0x7e8)
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user