mirror of
https://github.com/darlinghq/darling-gdb.git
synced 2025-01-08 04:50:51 +00:00
ef016f835f
This can boot Das U-Boot and a Linux kernel. It also supports Linux userspace FLAT and FDPIC (dynamic and static) ELFs. Signed-off-by: Mike Frysinger <vapier@gentoo.org>
101 lines
3.0 KiB
C
101 lines
3.0 KiB
C
/* Blackfin One-Time Programmable Memory (OTP) model
|
|
|
|
Copyright (C) 2010-2011 Free Software Foundation, Inc.
|
|
Contributed by Analog Devices, Inc.
|
|
|
|
This file is part of simulators.
|
|
|
|
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 3 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, see <http://www.gnu.org/licenses/>. */
|
|
|
|
#ifndef DV_BFIN_OTP_H
|
|
#define DV_BFIN_OTP_H
|
|
|
|
/* XXX: This should be pushed into the model data. */
|
|
/* XXX: Not exactly true; it's two sets of 4 regs near each other:
|
|
0xFFC03600 0x10 - Control
|
|
0xFFC03680 0x10 - Data */
|
|
#define BFIN_MMR_OTP_SIZE 0xa0
|
|
|
|
/* OTP Defined Pages. */
|
|
#define FPS00 0x004
|
|
#define FPS01 0x005
|
|
#define FPS02 0x006
|
|
#define FPS03 0x007
|
|
#define FPS04 0x008
|
|
#define FPS05 0x009
|
|
#define FPS06 0x00A
|
|
#define FPS07 0x00B
|
|
#define FPS08 0x00C
|
|
#define FPS09 0x00D
|
|
#define FPS10 0x00E
|
|
#define FPS11 0x00F
|
|
#define CPS00 0x010
|
|
#define CPS01 0x011
|
|
#define CPS02 0x012
|
|
#define CPS03 0x013
|
|
#define CPS04 0x014
|
|
#define CPS05 0x015
|
|
#define CPS06 0x016
|
|
#define CPS07 0x017
|
|
#define PBS00 0x018
|
|
#define PBS01 0x019
|
|
#define PBS02 0x01A
|
|
#define PBS03 0x01B
|
|
#define PUB000 0x01C
|
|
#define PUBCRC000 0x0E0
|
|
#define PRIV000 0x110
|
|
#define PRIVCRC000 0x1E0
|
|
|
|
/* FPS03 Part values. */
|
|
#define FPS03_BF51XF(n) (FPS03_BF##n | 0xF000)
|
|
#define FPS03_BF512 0x0200
|
|
#define FPS03_BF512F FPS03_BF51XF(512)
|
|
#define FPS03_BF514 0x0202
|
|
#define FPS03_BF514F FPS03_BF51XF(514)
|
|
#define FPS03_BF516 0x0204
|
|
#define FPS03_BF516F FPS03_BF51XF(516)
|
|
#define FPS03_BF518 0x0206
|
|
#define FPS03_BF518F FPS03_BF51XF(518)
|
|
#define FPS03_BF52X_C1(n) (FPS03_BF##n | 0x8000)
|
|
#define FPS03_BF52X_C2(n) (FPS03_BF##n | 0x4000)
|
|
#define FPS03_BF522 0x020A
|
|
#define FPS03_BF522_C1 FPS03_BF52X_C1(522)
|
|
#define FPS03_BF522_C2 FPS03_BF52X_C2(522)
|
|
#define FPS03_BF523 0x020B
|
|
#define FPS03_BF523_C1 FPS03_BF52X_C1(523)
|
|
#define FPS03_BF523_C2 FPS03_BF52X_C2(523)
|
|
#define FPS03_BF524 0x020C
|
|
#define FPS03_BF524_C1 FPS03_BF52X_C1(524)
|
|
#define FPS03_BF524_C2 FPS03_BF52X_C2(524)
|
|
#define FPS03_BF525 0x020D
|
|
#define FPS03_BF525_C1 FPS03_BF52X_C1(525)
|
|
#define FPS03_BF525_C2 FPS03_BF52X_C2(525)
|
|
#define FPS03_BF526 0x020E
|
|
#define FPS03_BF526_C1 FPS03_BF52X_C1(526)
|
|
#define FPS03_BF526_C2 FPS03_BF52X_C2(526)
|
|
#define FPS03_BF527 0x020F
|
|
#define FPS03_BF527_C1 FPS03_BF52X_C1(527)
|
|
#define FPS03_BF527_C2 FPS03_BF52X_C2(527)
|
|
|
|
/* OTP_CONTROL masks. */
|
|
#define PAGE_ADDR (0x1FF)
|
|
#define DO_READ (1 << 14)
|
|
#define DO_WRITE (1 << 15)
|
|
|
|
/* OTP_STATUS masks. */
|
|
#define STATUS_DONE (1 << 0)
|
|
#define STATUS_ERR (1 << 1)
|
|
|
|
#endif
|