Commit Graph

12465 Commits

Author SHA1 Message Date
wangyanwen 5bca8adec0 src/target: init current_target_name for nuclei smp etrace
Change-Id: I6a0c25075f4ed467dbb7d80b3585695f73c4abaf
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen 6845d34ae3 src/target/riscv: add more nuclei customized CSRs
Change-Id: I1b826007d73c965f1eb6f4fbd6b2c3e606e1ac7e
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 30bbf4dabc target/riscv: fix close fileio and free temp when conditions are met
- When `fileio` is valid, close it;
- When `temp` exists, free its memory;
- This ensures proper resource management.

Change-Id: I66be66e3945415f2e970ea47c077942be5977541
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 2c8bf769e0 target/riscv: only dump etrace when size is not zero
Change-Id: Ica8d5f23d4e990d597e1210e8d390d2dc1b69e3c
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 5fc851f469 target/riscv: make nuclei etrace command always return E_OK for IDE
IDE didn't catch the error code, so it should just return E_OK, but
print error log in openocd log, so user can investigate it

Change-Id: I082c32214472c43fa30eb532b7fc498ff7f73583
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
wangyanwen e96358db0b src/target/riscv: fix nuclei etrace trigger find and dump trace
Change-Id: I325844a96b608cfff9ed977910f237d097883305
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen 7259995361 target/riscv: fix bug in riscv_openocd_poll() function
This code forced all harts to halt when they reported a mixture of
halted and non-halted status. This breaks long-running algorithms run
on a single core under SMP, because the first poll will force the core
executing the algorithm to halt.

Fix by adding an exception when all running cores are running under
debugger control (target->status == 4). Do not force harts to halt in
this case.

Change-Id: I940172926ed9b80b95891d8aecbd10897e148585

Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 6b47fe31ff src/target/riscv: update RISC-V memory access handling for live watch
- Check target state before MMU query
- Force sysbus access during runtime writes
- Restore original settings after access

Change-Id: Idf244be0425d5c1584d092e1c2693ad11c941d12
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 29cb3fdfd5 src/target/riscv: Update nuclei command handling and logging improvements
- Ensure commands expect correct parameters.
- Use consistent error messages.

Change-Id: Ib1e637d4ea319567d792da45628b624a298ec72e
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang c917af5e16 src/target/riscv: conditionally log priv register read failures
- Only log error if target is not running or in debug running state.
- Refine logging for consistency across functions.

Change-Id: Ic1a8b0e379dca06f01786feb9aa9ef5892e1d789
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
wangyanwen 745eaa7c63 src/target/riscv: fix nuclei etrace in smp debug mode
Change-Id: I44bb1d7e813270f916cd252f8d7ecf5cd0b5e350
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen c22d5f5190 doc: update nuclei changelog in Changelog_Nuclei.md
Change-Id: I6ac0f6a300e23ca4f566e13a4818a09759d89488
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen 57d3a0f8fa src/target/riscv: fix etrace and hardware breakpoint conflicts
Change-Id: Ieb74fd2631a7dc9b0c9fd901153136164653c29e
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen c710f09fb5 src/target/riscv: optimize debug map reg display message
Change-Id: Ib0b1255c05fff1a9bfa4b167eb8f15c2116a463e
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
wangyanwen f1837d84c4 src/flash/nor: fix custom flash driver when bank->size is 0
Change-Id: I1ef6cd6dad81a62902cf72372bc11bb0437bfeb6
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 3a1152c290 src/target/riscv: add mbatch command for live watch usage
It can be used for reading/writing multiple non-contiguous
chunks of memory with minimum latency using sba method

based on a0a1aed80f

Change-Id: If52bf14875f36229e315970643d11983ae2e539d
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang c991a6f621 src/target/riscv: suppress log when do debug step for 0.11 debug
Change-Id: I495ed57656ae896f98dda391f49f685fed48e504
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
方华启 d41e1cf36d ci: fix incorrect openocd install path
Change-Id: I31080a46456b8342c920d1817b70b0ba25d90331
2025-01-16 17:20:18 +08:00
wangyanwen 71b32bc43e Revert "server/gdb_server.c: support unavailable registers"
This reverts commit 236c54c94a.

Change-Id: I59ac4e3907547356e08c567fc2c8f50a13902bd9
2025-01-16 17:20:18 +08:00
方华启 56dab6ce0c ci: Enable gitlab ci for Nuclei OpenOCD build
The following changes are added

Change-Id: I1c185d6017674c756871812effffd3ece7e43fc4

ci: split deploy_openocd job to deploy and link two jobs

- deploy job will only install openocd into share environment
- link job will link this version of openocd to latest

Change-Id: I9e6f524cb8237bbed146f50ebb8f342f7549ad4a
Signed-off-by: Huaqi Fang <578567190@qq.com>

ci: install openocd zip into share environment when deploy

Change-Id: I34726e72edc1db29c3bea5ca6aacb69c959d6d75
Signed-off-by: Huaqi Fang <578567190@qq.com>

ci: optimize deploy job and upload deploy zip into artifacts

Change-Id: I7f2e4182077acf193c3c4ab851643cf6ca6d6759
Signed-off-by: Huaqi Fang <578567190@qq.com>

ci: git submodule update should not use with --remote for ci repo update

see https://git-scm.com/book/en/v2/Git-Tools-Submodules

Change-Id: I38d57199f79b1eee6d312140d46fa0e8568dec9c
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
JackChenHR 61759141a6 src/flash: add gd32vw55x flash driver (#12)
Change-Id: Id179ee96303e5b7caf5f920843968e8564983752
Signed-off-by: JackChenHR <chran12345@163.com>
2025-01-16 17:20:18 +08:00
Huaqi Fang 2fbb887163 ci: fix github ci build for nuclei openocd (#13)
Change-Id: Id644958753ee29694824032eaf54df4eab1428bd
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:20:18 +08:00
wangyanwen 18627364f9 tcl:add nuclei-evalsoc.cfg
Change-Id: I9c19465b50ec07afdc3da9d4b6ed9c4ee8fdb5b2
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:27 +08:00
wangyanwen dbe10987e1 src/target/riscv:mfp16mode rename to mmisc_ctl1
Change-Id: Ica701881b96a9fe774de76d7fb22d03c443af0e0
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:27 +08:00
wangyanwen 6e9854400e src/target/riscv: add nuclei group commands for nuclei targets
These commands below are added now

1. nuclei cpuinfo command
2. nuclei etrace command group
3. nuclei debug map command
4. nuclei cti command group

Change-Id: I8e7c9b5e31a0a822fa184a997cafe4875d955d8b
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:21 +08:00
wangyanwen 4665a40ac9 src/target/riscv: R/W vector register workaround when vslide1down_vx not present
In Nuclei RISC-V Processor, Vector Module can be configured to lite version
which vslide1down_vx instruction maybe not present, so we need to find other
ways to read and write vector registers, this commit is a workaround to do this.

Change-Id: I6e01666ec49d2876942b09b7e5d14c3fcc76854f
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
wangyanwen 3ac078f0f5 jtag/drivers: add nuclei 2-wire nscan1_mode support in fdti
Change-Id: I352ec90386412027bab5bfc8718de8d0c09462ae
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
wangyanwen 2f7f61f402 target/riscv: add nuclei customized init resethalt command
init resethalt is used to halt the cpu when reset

Change-Id: I5c504599c10da204c0e9f933d33f61fe75ed033c
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
wangyanwen 22ac8c3d68 target/riscv: add nuclei custom csrs in encoding.h
Change-Id: I335be71f5d8ff837998edece2947ea6e48f0dbf3
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
wangyanwen cecc60d0cb flash/nor: add support for more norflash devices
Change-Id: I92153b8e511755f1d5a1176b87413707fb875147
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
wangyanwen ef8184f193 flash/nor: add cm32m4xxr/nuspi/custom flash driver
- cm32m4xxr flash driver is for cm32m4xxr devices
- nuspi flash driver is for nuclei evalsoc devices
- custom flash driver is for customized flash driver
  without modify openocd source code, see https://github.com/riscv-mcu/openflashloader

Change-Id: I86c4f0298707b5cfdfb77b6d8f4cbed3a189ddf0
Signed-off-by: wangyanwen <wangyanwen@nucleisys.com>
2025-01-16 17:13:20 +08:00
Huaqi Fang 285f810ce3 src/flash/nor: redirect fespi to nuspi for hbird and hbirdv2 SoC
Change-Id: I3d7d58971e7739b5e1104c9595952005c840a5dc
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 17:13:20 +08:00
wangyanwen aa75e393d2 src/jtag: add ftdi/libusb driver support for windows
Change-Id: Ibadb41463bbe16c453ab6de19f49643e18514e28
2025-01-16 17:13:08 +08:00
wangyanwen 2c2e861b34 Revert "openocd: remove command line flag -p/--pipe deprecated in v0.5.0"
This reverts commit d02e29daba.

Change-Id: I356854dd624d63439c673998f0e61b1bbca8a73b
2025-01-16 14:38:25 +08:00
Huaqi Fang b3b8ad2257 src/jtag: workaround for build xlnx-pcie-xvc.c using centos 6
see https://github.com/riscv-collab/riscv-openocd/issues/1185

Change-Id: Iedf8f494d693c40353e5e6c3f06cdbdb2f14a109
Signed-off-by: Huaqi Fang <578567190@qq.com>
2025-01-16 14:35:33 +08:00
Evgeniy Naydanov f82c5a7c04
Merge pull request #1186 from en-sc/en-sc/from_upstream
Merge up to 133dd9d669 from  upstream
2024-12-20 12:08:03 +03:00
Evgeniy Naydanov 4b9fb1972f Merge up to 133dd9d669 from upstream
Change-Id: Iaaf234da839cbed61684f4615135c9a42213c56a
2024-12-18 12:41:19 +03:00
Evgeniy Naydanov cf9963ad81
Merge pull request #1181 from en-sc/en-sc/reg-invalidate
target/riscv: clean-up register invalidation
2024-12-11 16:40:20 +03:00
Evgeniy Naydanov 8dfc806fe3
Merge pull request #1183 from fk-sc/fk-sc/ternary-operator
target/riscv: replaced repeating ternary operator with variable
2024-12-11 16:39:54 +03:00
Evgeniy Naydanov de20c2ad5f target/riscv: clean-up register invalidation
* Registers were not invalidated if the hart became unavailable.
* Improved logging in the case register invalidation involves loss of
  information.

Change-Id: Icfb5e190dd6dcb1a97e4d314d802466cab7a01e4
Signed-off-by: Evgeniy Naydanov <evgeniy.naydanov@syntacore.com>
2024-12-10 15:25:22 +03:00
Farid Khaydari d5c2604418 target/riscv: replaced repeating ternary operator with variable
Replaced repeating ternary operator with variable

Signed-off-by: Farid Khaydari <f.khaydari@syntacore.com>
2024-12-10 13:40:08 +03:00
Evgeniy Naydanov ea8f9d5195
Merge pull request #1173 from fk-sc/buf-get
target/riscv: use buf_get_uXX instead of manual bit shift
2024-12-06 15:03:47 +03:00
Farid Khaydari 4dcd80164a target/riscv: use buf_get_uXX instead of manual bit shift
Replaced manual bit shift with buf_get_u64/buf_get_u32

Signed-off-by: Farid Khaydari <f.khaydari@syntacore.com>
2024-12-04 22:56:05 +03:00
Anatoly Parshintsev c430c24330
Merge pull request #1167 from fk-sc/fk-sc/rwargs
target/riscv: pass memory access info in struct, move write_memory pointer
2024-12-04 21:04:56 +03:00
Anatoly Parshintsev ca80920157
Merge pull request #1176 from aap-sc/aap-sc/csr_as_hex_regression_fixup
fix incorrect parsing of names for custom csr registers
2024-11-29 18:26:19 +03:00
Farid Khaydari eb4e717a3b target/riscv: pass memory access info in struct, move write_memory pointer
This changes will allow to unite read_memory/write_memory fucntions
to one access function

(1) Replaced read/write functions arguments with one structure
(2) Unified read_memory/write_memory function pointers
    to be stored in same structure

Signed-off-by: Farid Khaydari <f.khaydari@syntacore.com>
2024-11-29 18:12:53 +03:00
Anatoly Parshintsev 0f0302b029
Merge pull request #1174 from fk-sc/fk-sc/checker-fix
target/riscv: fix memory access result type checker function return in case of assertion
2024-11-29 01:23:37 +03:00
Parshintsev Anatoly 109646c09d fix incorrect parsing of names for custom csr registers
this commit fixes a regression introduced in
ba8c1eef5a.

The regression was caused by removal of these lines:

```
-                       /* Register prefix: "csr_" or "custom_" */
-                       strcpy(name, reg_type);
-                       name[strlen(reg_type)] = '_';
```

causing all CSR names with custom names to be parsed as empty strings.
2024-11-27 22:08:20 +03:00
Evgeniy Naydanov eb1ecd7d10
Merge pull request #1170 from fk-sc/fk-sc/priv-mod
target/riscv: decrease modify_privilege function nesting level
2024-11-26 17:26:49 +03:00
Farid Khaydari c8ae081979 target/riscv: fix memory access result type checker function return in case of assertion
Fix memory access result type checker return in case of assertion

Signed-off-by: Farid Khaydari <f.khaydari@syntacore.com>
2024-11-26 12:56:36 +03:00