Skip to content
2 changes: 2 additions & 0 deletions .rat-excludes
Original file line number Diff line number Diff line change
Expand Up @@ -183,6 +183,7 @@ hw/mcu/stm/stm32g0xx/src/clock_stm32g0xx.c
hw/mcu/stm/stm32g0xx/src/system_stm32g0xx.c
hw/mcu/stm/stm32g4xx/src/clock_stm32g4xx.c
hw/mcu/stm/stm32g4xx/src/system_stm32g4xx.c
hw/mcu/stm/stm32h5xx/src/system_stm32h5xx.c
hw/mcu/stm/stm32h7xx/src/clock_stm32h7xx.c
hw/mcu/stm/stm32h7xx/src/system_stm32h7xx.c
hw/mcu/stm/stm32l0xx/src/clock_stm32l0xx.c
Expand Down Expand Up @@ -215,6 +216,7 @@ hw/bsp/nucleo-f746zg/include/bsp/stm32f7xx_hal_conf.h
hw/bsp/nucleo-f767zi/include/bsp/stm32f7xx_hal_conf.h
hw/bsp/nucleo-g0b1re/include/bsp/stm32g0xx_hal_conf.h
hw/bsp/nucleo-g491re/include/bsp/stm32g4xx_hal_conf.h
hw/bsp/nucleo-h563zi/include/bsp/stm32h5xx_hal_conf.h
hw/bsp/nucleo-h723zg/include/bsp/stm32h7xx_hal_conf.h
hw/bsp/nucleo-h753zi/include/bsp/stm32h7xx_hal_conf.h
hw/bsp/nucleo-l073rz/include/bsp/stm32l0xx_hal_conf.h
Expand Down
2 changes: 2 additions & 0 deletions .style_ignored_dirs
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,7 @@ hw/bsp/nucleo-f746zg/include/bsp/stm32f7xx_hal_conf.h
hw/bsp/nucleo-f767zi/include/bsp/stm32f7xx_hal_conf.h
hw/bsp/nucleo-g0b1re/include/bsp/stm32g0xx_hal_conf.h
hw/bsp/nucleo-g491re/include/bsp/stm32g4xx_hal_conf.h
hw/bsp/nucleo-h563zi/include/bsp/stm32h5xx_hal_conf.h
hw/bsp/nucleo-l073rz/include/bsp/stm32l0xx_hal_conf.h
hw/bsp/nucleo-l476rg/include/bsp/stm32l4xx_hal_conf.h
hw/bsp/olimex-p103/include/bsp/stm32f1xx_hal_conf.h
Expand All @@ -52,6 +53,7 @@ hw/mcu/stm/stm32f3xx/src/system_stm32f3xx.c
hw/mcu/stm/stm32f7xx/src/system_stm32f7xx.c
hw/mcu/stm/stm32g0xx/src/system_stm32g0xx.c
hw/mcu/stm/stm32g4xx/src/system_stm32g4xx.c
hw/mcu/stm/stm32h5xx/src/system_stm32h5xx.c
hw/mcu/stm/stm32u5xx/src/system_stm32u5xx.c

hw/mcu/stm/stm32_common/src/stm32_driver_mod_i2c_v1.c
Expand Down
65 changes: 65 additions & 0 deletions hw/bsp/nucleo-h563zi/bsp.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,65 @@
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#

bsp.name: "NUCLEO-H563ZI"
bsp.url: https://www.st.com/en/evaluation-tools/nucleo-h563zi.html
bsp.maker: "STMicroelectronics"
bsp.arch: cortex_m33
bsp.compiler: compiler/arm-none-eabi-m33
bsp.linkerscript: autogenerated
bsp.downloadscript: "hw/scripts/download.sh"
bsp.debugscript: "hw/bsp/nucleo-h563zi/debug.sh"

bsp.flash_map:
areas:
# System areas.
FLASH_AREA_BOOTLOADER:
device: 0
offset: 0x08000000
size: 48kB
FLASH_AREA_IMAGE_0:
device: 0
offset: 0x08010000
size: 512kB
FLASH_AREA_IMAGE_1:
device: 0
offset: 0x08090000
size: 512kB
FLASH_AREA_IMAGE_SCRATCH:
device: 0
offset: 0x08110000
size: 64kB

# User areas.
FLASH_AREA_REBOOT_LOG:
user_id: 0
device: 0
offset: 0x0800C000
size: 16kB
FLASH_AREA_NFFS:
user_id: 1
device: 0
offset: 0x08120000
size: 64kB

FLASH_AREA_SPI:
user_id: 2
device: 1
offset: 0x0
size: 128kB
34 changes: 34 additions & 0 deletions hw/bsp/nucleo-h563zi/debug.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
#!/bin/sh
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#

# Called with following variables set:
# - CORE_PATH is absolute path to @apache-mynewt-core
# - BSP_PATH is absolute path to hw/bsp/bsp_name
# - BIN_BASENAME is the path to prefix to target binary,
# .elf appended to name is the ELF file
# - FEATURES holds the target features string
# - EXTRA_JTAG_CMD holds extra parameters to pass to jtag software
# - RESET set if target should be reset when attaching
# - NO_GDB set if we should not start gdb to debug
#
. $CORE_PATH/hw/scripts/stm32_programmer.sh

FILE_NAME=$BIN_BASENAME.elf

stm32_debug
96 changes: 96 additions & 0 deletions hw/bsp/nucleo-h563zi/include/bsp/bsp.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
#ifndef H_BSP_H
#define H_BSP_H

#include <inttypes.h>
#include <mcu/mcu.h>

#ifdef __cplusplus
extern "C" {
#endif

/* Define special stackos sections */
#define sec_data_core __attribute__((section(".data.core")))
#define sec_bss_core __attribute__((section(".bss.core")))
#define sec_bss_nz_core __attribute__((section(".bss.core.nz")))

/* More convenient section placement macros. */
#define bssnz_t sec_bss_nz_core

extern uint8_t _ram_start;
extern uint8_t _dtcmram_start;
extern uint8_t _itcmram_start;
extern uint8_t _ram2_start;

#define RAM1_SIZE (256 * 1024)
#define RAM2_SIZE (64 * 1024)
#define RAM3_SIZE (320 * 1024)
#define RAM_SIZE (RAM1_SIZE + RAM2_SIZE + RAM3_SIZE)

/* LED pins */
#define LED_1 MCU_GPIO_PORTB(0)
#define LED_2 MCU_GPIO_PORTE(1)
#define LED_3 MCU_GPIO_PORTB(14)
#define LED_green LED_1
#define LED_blue LED_2
#define LED_red LED_3
#define LED_BLINK_PIN LED_1

/* BUTTON pins */
#define BTN_USER_1 MCU_GPIO_PORTC(13)
#define BUTTON_1 BTN_USER_1

/* Arduino pins */
#define ARDUINO_PIN_D0 MCU_GPIO_PORTB(7)
#define ARDUINO_PIN_D1 MCU_GPIO_PORTB(6)
#define ARDUINO_PIN_D2 MCU_GPIO_PORTG(14)
#define ARDUINO_PIN_D3 MCU_GPIO_PORTE(13)
#define ARDUINO_PIN_D4 MCU_GPIO_PORTE(14)
#define ARDUINO_PIN_D5 MCU_GPIO_PORTE(11)
#define ARDUINO_PIN_D6 MCU_GPIO_PORTE(9)
#define ARDUINO_PIN_D7 MCU_GPIO_PORTG(12)
#define ARDUINO_PIN_D8 MCU_GPIO_PORTF(3)
#define ARDUINO_PIN_D9 MCU_GPIO_PORTD(15)
#define ARDUINO_PIN_D10 MCU_GPIO_PORTD(14)
#define ARDUINO_PIN_D11 MCU_GPIO_PORTB(5)
#define ARDUINO_PIN_D12 MCU_GPIO_PORTG(9)
#define ARDUINO_PIN_D13 MCU_GPIO_PORTA(5)
#define ARDUINO_PIN_A0 MCU_GPIO_PORTA(6)
#define ARDUINO_PIN_A1 MCU_GPIO_PORTC(0)
#define ARDUINO_PIN_A2 MCU_GPIO_PORTC(3)
#define ARDUINO_PIN_A3 MCU_GPIO_PORTB(1)
#define ARDUINO_PIN_A4 MCU_GPIO_PORTC(2)
#define ARDUINO_PIN_A5 MCU_GPIO_PORTF(11)

#define ARDUINO_PIN_RX ARDUINO_PIN_D0
#define ARDUINO_PIN_TX ARDUINO_PIN_D1

#define ARDUINO_PIN_SCL MCU_GPIO_PORTB(8)
#define ARDUINO_PIN_SDA MCU_GPIO_PORTB(9)

#define ARDUINO_PIN_SCK ARDUINO_PIN_D13
#define ARDUINO_PIN_MOSI ARDUINO_PIN_D11
#define ARDUINO_PIN_MISO ARDUINO_PIN_D12

#ifdef __cplusplus
}
#endif

#endif /* H_BSP_H */
Loading
Loading