chipinfo: chip database extracted from MSP430.DLL.
This commit is contained in:
parent
83f0d66597
commit
8ec807fe20
1
Makefile
1
Makefile
|
@ -118,6 +118,7 @@ OBJ=\
|
||||||
util/demangle.o \
|
util/demangle.o \
|
||||||
util/powerbuf.o \
|
util/powerbuf.o \
|
||||||
util/ctrlc.o \
|
util/ctrlc.o \
|
||||||
|
util/chipinfo.o \
|
||||||
transport/cp210x.o \
|
transport/cp210x.o \
|
||||||
transport/cdc_acm.o \
|
transport/cdc_acm.o \
|
||||||
transport/ftdi.o \
|
transport/ftdi.o \
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,98 @@
|
||||||
|
/* MSPDebug - debugging tool for MSP430 MCUs
|
||||||
|
* Copyright (C) 2009-2013 Daniel Beer
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stddef.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include "chipinfo.h"
|
||||||
|
#include "../chipinfo.db"
|
||||||
|
|
||||||
|
static int is_match(const struct chipinfo_id *a,
|
||||||
|
const struct chipinfo_id *b,
|
||||||
|
const struct chipinfo_id *mask)
|
||||||
|
{
|
||||||
|
if ((a->ver_id ^ b->ver_id) & mask->ver_id)
|
||||||
|
return 0;
|
||||||
|
if ((a->ver_sub_id ^ b->ver_sub_id) & mask->ver_sub_id)
|
||||||
|
return 0;
|
||||||
|
if ((a->revision ^ b->revision) & mask->revision)
|
||||||
|
return 0;
|
||||||
|
if ((a->fab ^ b->fab) & mask->fab)
|
||||||
|
return 0;
|
||||||
|
if ((a->self ^ b->self) & mask->self)
|
||||||
|
return 0;
|
||||||
|
if ((a->config ^ b->config) & mask->config)
|
||||||
|
return 0;
|
||||||
|
if ((a->fuses ^ b->fuses) & mask->fuses)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
const struct chipinfo *chipinfo_find_by_id(const struct chipinfo_id *id)
|
||||||
|
{
|
||||||
|
const struct chipinfo *i;
|
||||||
|
|
||||||
|
for (i = chipinfo_db; i->name; i++)
|
||||||
|
if (is_match(&i->id, id, &i->id_mask))
|
||||||
|
return i;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
const struct chipinfo *chipinfo_find_by_name(const char *name)
|
||||||
|
{
|
||||||
|
const struct chipinfo *i;
|
||||||
|
|
||||||
|
for (i = chipinfo_db; i->name; i++)
|
||||||
|
if (!strcasecmp(name, i->name))
|
||||||
|
return i;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
const struct chipinfo_memory *chipinfo_find_mem_by_name
|
||||||
|
(const struct chipinfo *info, const char *name)
|
||||||
|
{
|
||||||
|
const struct chipinfo_memory *m;
|
||||||
|
|
||||||
|
for (m = info->memory; m->name; m++)
|
||||||
|
if (!strcasecmp(m->name, name))
|
||||||
|
return m;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
const struct chipinfo_memory *chipinfo_find_mem_by_addr
|
||||||
|
(const struct chipinfo *info, uint32_t offset)
|
||||||
|
{
|
||||||
|
const struct chipinfo_memory *m;
|
||||||
|
const struct chipinfo_memory *best = NULL;
|
||||||
|
|
||||||
|
for (m = info->memory; m->name; m++) {
|
||||||
|
if (!m->mapped)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (m->offset + m->size <= offset)
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (!best || (m->offset < best->offset))
|
||||||
|
best = m;
|
||||||
|
}
|
||||||
|
|
||||||
|
return best;
|
||||||
|
}
|
|
@ -0,0 +1,169 @@
|
||||||
|
/* MSPDebug - debugging tool for MSP430 MCUs
|
||||||
|
* Copyright (C) 2009-2013 Daniel Beer
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; either version 2 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program 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 General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef CHIPINFO_H_
|
||||||
|
#define CHIPINFO_H_
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
struct chipinfo_funclet {
|
||||||
|
uint16_t code_size;
|
||||||
|
uint16_t max_payload;
|
||||||
|
uint16_t entry_point;
|
||||||
|
uint16_t code[512];
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHIPINFO_PSA_REGULAR,
|
||||||
|
CHIPINFO_PSA_ENHANCED
|
||||||
|
} chipinfo_psa_t;
|
||||||
|
|
||||||
|
struct chipinfo_id {
|
||||||
|
uint16_t ver_id;
|
||||||
|
uint16_t ver_sub_id;
|
||||||
|
uint8_t revision;
|
||||||
|
uint8_t fab;
|
||||||
|
uint16_t self;
|
||||||
|
uint8_t config;
|
||||||
|
uint8_t fuses;
|
||||||
|
uint32_t activation_key;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct chipinfo_eem {
|
||||||
|
uint8_t state_storage;
|
||||||
|
uint8_t cycle_counter;
|
||||||
|
uint8_t cycle_counter_ops;
|
||||||
|
uint8_t trig_emulation_level;
|
||||||
|
uint8_t trig_mem;
|
||||||
|
uint8_t trig_reg;
|
||||||
|
uint8_t trig_combinations;
|
||||||
|
uint8_t trig_options;
|
||||||
|
uint8_t trig_dma;
|
||||||
|
uint8_t trig_read_write;
|
||||||
|
uint8_t trig_reg_ops;
|
||||||
|
uint8_t trig_comp_level;
|
||||||
|
uint8_t trig_mem_cond_level;
|
||||||
|
uint8_t trig_mem_umask_level;
|
||||||
|
uint8_t seq_states;
|
||||||
|
uint8_t seq_start;
|
||||||
|
uint8_t seq_end;
|
||||||
|
uint8_t seq_reset;
|
||||||
|
uint8_t seq_blocked;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct chipinfo_voltage {
|
||||||
|
uint16_t vcc_min;
|
||||||
|
uint16_t vcc_max;
|
||||||
|
uint16_t vcc_flash_min;
|
||||||
|
uint16_t vcc_secure_min;
|
||||||
|
uint16_t vpp_secure_min;
|
||||||
|
uint16_t vpp_secure_max;
|
||||||
|
uint8_t has_test_vpp;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct chipinfo_power {
|
||||||
|
uint32_t reg_mask;
|
||||||
|
uint32_t enable_lpm5;
|
||||||
|
uint32_t disable_lpm5;
|
||||||
|
uint32_t reg_mask_3v;
|
||||||
|
uint32_t enable_lpm5_3v;
|
||||||
|
uint32_t disable_lpm5_3v;
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHIPINFO_CLOCK_SYS_BC_1XX,
|
||||||
|
CHIPINFO_CLOCK_SYS_BC_2XX,
|
||||||
|
CHIPINFO_CLOCK_SYS_FLL_PLUS,
|
||||||
|
CHIPINFO_CLOCK_SYS_MOD_OSC
|
||||||
|
} chipinfo_clock_sys_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHIPINFO_FEATURE_I2C = 0x0001,
|
||||||
|
CHIPINFO_FEATURE_LCFE = 0x0002,
|
||||||
|
CHIPINFO_FEATURE_QUICK_MEM_READ = 0x0004,
|
||||||
|
CHIPINFO_FEATURE_SFLLDH = 0x0008,
|
||||||
|
CHIPINFO_FEATURE_FRAM = 0x0010,
|
||||||
|
CHIPINFO_FEATURE_NO_BSL = 0x0020,
|
||||||
|
CHIPINFO_FEATURE_TMR = 0x0040,
|
||||||
|
CHIPINFO_FEATURE_JTAG = 0x0080,
|
||||||
|
CHIPINFO_FEATURE_DTC = 0x0100,
|
||||||
|
CHIPINFO_FEATURE_SYNC = 0x0200,
|
||||||
|
CHIPINFO_FEATURE_INSTR = 0x0400,
|
||||||
|
CHIPINFO_FEATURE_1337 = 0x0800,
|
||||||
|
CHIPINFO_FEATURE_PSACH = 0x1000
|
||||||
|
} chipinfo_features_t;
|
||||||
|
|
||||||
|
typedef enum {
|
||||||
|
CHIPINFO_MEMTYPE_ROM,
|
||||||
|
CHIPINFO_MEMTYPE_RAM,
|
||||||
|
CHIPINFO_MEMTYPE_FLASH,
|
||||||
|
CHIPINFO_MEMTYPE_REGISTER
|
||||||
|
} chipinfo_memtype_t;
|
||||||
|
|
||||||
|
struct chipinfo_memory {
|
||||||
|
const char *name;
|
||||||
|
chipinfo_memtype_t type;
|
||||||
|
unsigned int bits;
|
||||||
|
unsigned int mapped;
|
||||||
|
unsigned int size;
|
||||||
|
uint32_t offset;
|
||||||
|
unsigned int seg_size;
|
||||||
|
unsigned int bank_size;
|
||||||
|
unsigned int banks;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct chipinfo_clockmap {
|
||||||
|
const char *name;
|
||||||
|
uint8_t value;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct chipinfo {
|
||||||
|
const char *name;
|
||||||
|
|
||||||
|
unsigned int bits;
|
||||||
|
chipinfo_psa_t psa;
|
||||||
|
uint8_t clock_control;
|
||||||
|
uint16_t mclk_control;
|
||||||
|
chipinfo_clock_sys_t clock_sys;
|
||||||
|
chipinfo_features_t features;
|
||||||
|
|
||||||
|
struct chipinfo_id id;
|
||||||
|
struct chipinfo_id id_mask;
|
||||||
|
struct chipinfo_eem eem;
|
||||||
|
struct chipinfo_voltage voltage;
|
||||||
|
struct chipinfo_power power;
|
||||||
|
struct chipinfo_memory memory[16];
|
||||||
|
struct chipinfo_clockmap clock_map[32];
|
||||||
|
|
||||||
|
uint8_t v3_functions[128];
|
||||||
|
const struct chipinfo_funclet *v3_erase;
|
||||||
|
const struct chipinfo_funclet *v3_write;
|
||||||
|
const struct chipinfo_funclet *v3_unlock;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern const struct chipinfo chipinfo_db[];
|
||||||
|
|
||||||
|
const struct chipinfo *chipinfo_find_by_id(const struct chipinfo_id *id);
|
||||||
|
const struct chipinfo *chipinfo_find_by_name(const char *name);
|
||||||
|
|
||||||
|
const struct chipinfo_memory *chipinfo_find_mem_by_addr
|
||||||
|
(const struct chipinfo *info, uint32_t offset);
|
||||||
|
const struct chipinfo_memory *chipinfo_find_mem_by_name
|
||||||
|
(const struct chipinfo *info, const char *name);
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue