riscv-openocd/tcl/target/snps_hsdk_4xd.cfg

51 lines
1.1 KiB
INI

# SPDX-License-Identifier: GPL-2.0-or-later
# Copyright (C) 2023 Synopsys, Inc.
# Artemiy Volkov <artemiy@synopsys.com>
# Adapted from tcl/target/snps_hsdk.cfg.
#
# HS Development Kit SoC.
#
# Contains quad-core ARC HS47D.
#
source [find cpu/arc/hs.tcl]
set _coreid 0
set _dbgbase [expr {$_coreid << 13}]
# CHIPNAME will be used to choose core family (600, 700 or EM). As far as
# OpenOCD is concerned EM and HS are identical.
set _CHIPNAME arc-em
proc setup_cpu {core_index expected_id} {
global _coreid
global _dbgbase
global _CHIPNAME
set _TARGETNAME $_CHIPNAME.cpu$core_index
jtag newtap $_CHIPNAME cpu$core_index -irlen 4 -ircapture 0x1 -expected-id $expected_id
target create $_TARGETNAME arcv2 -chain-position $_TARGETNAME
$_TARGETNAME configure -coreid $_coreid
$_TARGETNAME configure -dbgbase $_dbgbase
$_TARGETNAME configure -event reset-assert "arc_hs_reset $_TARGETNAME"
arc_hs_init_regs
$_TARGETNAME arc cache l2 auto 1
set _coreid [expr {$_coreid + 1}]
set _dbgbase [expr {$_coreid << 13}]
}
# OpenOCD discovers JTAG TAPs in reverse order.
setup_cpu 4 0x100c54b1
setup_cpu 3 0x100854b1
setup_cpu 2 0x100454b1
setup_cpu 1 0x100054b1