Skip to content

Commit

Permalink
Merge pull request #136 from kshitij-sisodia-arm/feature/update-pack-…
Browse files Browse the repository at this point in the history
…versions-20240619

MLECO-4703: Updates for pack versions
  • Loading branch information
phorsman-arm authored Jun 19, 2024
2 parents 739fdf1 + c989486 commit eb6e267
Show file tree
Hide file tree
Showing 27 changed files with 385 additions and 323 deletions.
33 changes: 17 additions & 16 deletions cmsis-pack-examples/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -34,13 +34,13 @@ Currently, the following examples are supported:

Target platforms supported:

| Name | Type | IP | Examples |
|---------------------|---------------------|-----------------------------------------------|----------|
| Arm® Corstone™-300 | Virtual or physical | Arm® Cortex®-M55 CPU with Arm® Ethos™-U55 or Arm® Ethos™-U65 NPU | All |
| Arm® Corstone™-310 | Virtual or physical | Arm® Cortex®-M85 CPU with Arm® Ethos™-U55 or Arm® Ethos™-U65 NPU | All |
| Alif Ensemble E7 | Physical board | Arm® Cortex®-M55 CPU with Arm® Ethos™-U55 NPU | All |
| STM32F746G-Discovery| Physical board | Arm® Cortex®-M7 CPU | KWS |
| NXP FRDM-K64F | Physical board | Arm® Cortex®-M4 CPU | KWS |
| Name | Type | IP | Examples |
|-----------------------|---------------------|-----------------------------------------------|----------|
| Arm® Corstone™-300 | Virtual or physical | Arm® Cortex®-M55 CPU with Arm® Ethos™-U55 or Arm® Ethos™-U65 NPU | All |
| Arm® Corstone™-310 | Virtual or physical | Arm® Cortex®-M85 CPU with Arm® Ethos™-U55 or Arm® Ethos™-U65 NPU | All |
| Alif Ensemble E7 AI/ML Kit | Physical board | Arm® Cortex®-M55 CPU with Arm® Ethos™-U55 NPU | All |
| STM32® F746G-Discovery| Physical board | Arm® Cortex®-M7 CPU | KWS |
| NXP® FRDM-K64F | Physical board | Arm® Cortex®-M4 CPU | KWS |


Use this import button to open the solution in Keil Studio Cloud: [![Open in Keil Studio](https://img.shields.io/badge/Keil%20Studio-Import-blue?logo=&logoWidth=47)](https://studio.keil.arm.com/?import=/~https://github.com/Arm-Examples/mlek-cmsis-pack-examples.git)
Expand Down Expand Up @@ -224,17 +224,18 @@ Note that most applications will redirect their standard output and error stream
Keil Sudio Cloud has an option to open a serial connection that can be used to monitor these
streams.

For the Alif Semiconductor's Ensemble DevKit boards, the output over UART is not wired though any
USB. A 1.8V FTDI USART cable is recommended to view the serial output. By default, the high
performance core uses UART device 4, and the high efficiency core uses UART device 2. Check the
board schematic to see which pins these modules use. For the Rev1 version of the board the pins
are:
For the Alif Semiconductor™ Ensemble™ AI/ML kit boards, the output over UART is wired though port
J2 (maked PRG_USB). This port exposes two UARTs - one for SE (Secure Enclave) and the other is
confirable to pass through either UART2 or UART4 using jumpers on J15. For the applications built,
the high performance core uses UART4, and the high efficiency core uses UART2.

J15 setup is shown below:

```
UART2 RX_B on J413 pin 13 (P3_16) ↔ FTDI TX
UART2 TX_B on J413 pin 14 (P3_17) ↔ FTDI RX
UART4 RX_B on J412 pin 11 (P3_1) ↔ FTDI TX
UART4 TX_B on J412 pin 12 (P3_2) ↔ FTDI RX
J15-1-3 & 2-4: SE UART
J15-3-5 & 4-6: UART2
J15-5-7 & 6-8: UART2
J15-7-9 & 8-10: UART4
```
For all other targets, serial is available over USB from primary debug/connection port.

Expand Down
4 changes: 2 additions & 2 deletions cmsis-pack-examples/cdefault.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# SPDX-FileCopyrightText: Copyright 2023 Arm Limited and/or its
# SPDX-FileCopyrightText: Copyright 2023-2024 Arm Limited and/or its
# affiliates <open-source-office@arm.com>
# SPDX-License-Identifier: Apache-2.0
#
Expand All @@ -14,7 +14,7 @@
# See the License for the specific language governing permissions and
# limitations under the License.

# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.0.0/tools/projmgr/schemas/cdefault.schema.json
# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.4.0/tools/projmgr/schemas/cdefault.schema.json

default:
# Note that we need AC6@6.18 or higher to compile for Corstone-310 target.
Expand Down
4 changes: 2 additions & 2 deletions cmsis-pack-examples/common/common.clayer.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# SPDX-FileCopyrightText: Copyright 2022-2023 Arm Limited and/or its
# SPDX-FileCopyrightText: Copyright 2022-2024 Arm Limited and/or its
# affiliates <open-source-office@arm.com>
# SPDX-License-Identifier: Apache-2.0
#
Expand All @@ -14,7 +14,7 @@
# See the License for the specific language governing permissions and
# limitations under the License.

# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.0.0/tools/projmgr/schemas/clayer.schema.json
# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.4.0/tools/projmgr/schemas/clayer.schema.json

layer:

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
# SPDX-FileCopyrightText: Copyright 2023 Arm Limited and/or its
# SPDX-FileCopyrightText: Copyright 2023-2024 Arm Limited and/or its
# affiliates <open-source-office@arm.com>
# SPDX-License-Identifier: Apache-2.0
#
Expand All @@ -14,7 +14,7 @@
# See the License for the specific language governing permissions and
# limitations under the License.

# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.0.0/tools/projmgr/schemas/clayer.schema.json
# yaml-language-server: $schema=https://raw.githubusercontent.com/Open-CMSIS-Pack/devtools/schemas/projmgr/2.4.0/tools/projmgr/schemas/clayer.schema.json

layer:
description: Alif Ensemble E7 ML islands' CPU device layer (High-Performance and High-Efficiency Arm Cortex-M55 CPUs).
Expand All @@ -26,7 +26,8 @@ layer:
files:
- file: ./src/GpioSignal.cpp
- file: ./include/GpioSignal.hpp
- file: ./src/gpio.c
- file: ./src/gpio_wrapper.c
- file: ./src/gpio_wrapper.h

- group: AudioHelpers
for-context: +Alif-E7-M55-HE
Expand Down Expand Up @@ -64,11 +65,10 @@ layer:
- component: AlifSemiconductor::Device:SOC Peripherals:USART
- component: AlifSemiconductor::Device:SOC Peripherals:GPIO
- component: AlifSemiconductor::Device:SOC Peripherals:PINCONF
- component: AlifSemiconductor::Device:SOC Peripherals:MHU
- component: AlifSemiconductor::Device:Startup
- component: ARM::CMSIS Driver:USART
- component: ARM::CMSIS Driver:USART:Custom
- component: AlifSemiconductor::Device:SE Services:SE RunTime services&Source
- component: AlifSemiconductor::Device:SE Services:MHU Driver

- component: AlifSemiconductor::Device:SOC Peripherals:DMA
for-context: +Alif-E7-M55-HE
Expand All @@ -79,7 +79,7 @@ layer:
- component: AlifSemiconductor::Device:SOC Peripherals:I3C
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SOC Peripherals:CDC200
- component: AlifSemiconductor::Device:SOC Peripherals:CDC
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SOC Peripherals:MIPI CSI2
Expand All @@ -88,11 +88,22 @@ layer:
- component: AlifSemiconductor::Device:SOC Peripherals:MIPI DSI
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SOC Peripherals:CAMERA Controller
- component: AlifSemiconductor::Device:SOC Peripherals:I2C
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SOC Peripherals:CPI
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::BSP:External peripherals:ILI9806E LCD panel
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::BSP:External peripherals:CAMERA Sensor ARX3A0
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SE runtime Services:core
for-context: +Alif-E7-M55-HP

- component: AlifSemiconductor::Device:SE runtime Services:Initialization Helper
for-context: +Alif-E7-M55-HP


24 changes: 14 additions & 10 deletions cmsis-pack-examples/device/alif-ensemble/include/CameraCapture.hpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* SPDX-FileCopyrightText: Copyright 2023 Arm Limited and/or its
* SPDX-FileCopyrightText: Copyright 2023-2024 Arm Limited and/or its
* affiliates <open-source-office@arm.com>
* SPDX-License-Identifier: Apache-2.0
*
Expand All @@ -18,18 +18,22 @@
#ifndef CAMERA_CAPTURE_HPP
#define CAMERA_CAPTURE_HPP

#if defined (__cplusplus)
extern "C" {
#include "Camera_Common.h"
}
#endif
#include <cstdint>
#include "Driver_CPI.h"
#include "RTE_Device.h"

#if !defined(RTE_ARX3A0_CAMERA_SENSOR_FRAME_WIDTH) || !defined(RTE_ARX3A0_CAMERA_SENSOR_FRAME_HEIGHT)
#error "Camera frame dimensions undefined!"
#endif

#define CAMERA_FRAME_WIDTH 560
#define CAMERA_FRAME_HEIGHT 560
#define CAMERA_RESOLUTION CAMERA_RESOLUTION_560x560
#define CAMERA_FRAME_WIDTH RTE_ARX3A0_CAMERA_SENSOR_FRAME_WIDTH
#define CAMERA_FRAME_HEIGHT RTE_ARX3A0_CAMERA_SENSOR_FRAME_HEIGHT
#define CAMERA_IMAGE_RAW_SIZE (CAMERA_FRAME_WIDTH * CAMERA_FRAME_HEIGHT)

#if CAMERA_IMAGE_RAW_SIZE <= 0
#error "Invalid image size"
#endif

namespace arm {
namespace app {

Expand All @@ -48,7 +52,7 @@ enum class ColourFilter {
* @param raw_image Pointer to the raw image that can be populated.
* @return int: 0 if successful, error code otherwise
*/
int CameraCaptureInit(ARM_CAMERA_RESOLUTION resolution);
int CameraCaptureInit();

/**
* @brief Starts the camera capture (does not wait for it to finish)
Expand Down
17 changes: 10 additions & 7 deletions cmsis-pack-examples/device/alif-ensemble/include/GpioSignal.hpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* SPDX-FileCopyrightText: Copyright 2022-2023 Arm Limited and/or its
* SPDX-FileCopyrightText: Copyright 2022-2024 Arm Limited and/or its
* affiliates <open-source-office@arm.com>
* SPDX-License-Identifier: Apache-2.0
*
Expand All @@ -24,7 +24,7 @@
extern "C" {
#endif // #if defined(__cplusplus)

#include "gpio.h"
#include "gpio_wrapper.h"

#if defined(__cplusplus)
}
Expand All @@ -37,14 +37,17 @@ namespace app {
enum class SignalDirection { DirectionOutput = 0, DirectionInput = 1, DirectionInvalid = 2 };

/* Valid GPIO port numbers */
enum class SignalPort { Port1 = 1, Port2 = 2, Port3 = 3 };
enum class SignalPort { Port6 = 6, Port7 = 7, Port12 = 12 };

/* Valid and used GPIO pin number definitions */
enum class SignalPin {
Port1_UserButton1 = 12, /* Wired to SW2 on the board. */
Port3_UserButton2 = 4, /* Wired to SW3 on the board. */
Port1_StatusLED1 = 14, /* LED1 - green. */
Port1_StatusLED2 = 15 /* LED2 - orange. */
Port12_LED0_R = 3, /* LED0 - red. */
Port07_LED0_G = 4, /* LED0 - green. */
Port12_LED0_B = 0, /* LED0 - blue. */

Port06_LED1_R = 2, /* LED0 - red. */
Port06_LED1_G = 4, /* LED0 - green. */
Port06_LED1_B = 6 /* LED0 - blue. */
};

/**
Expand Down
10 changes: 9 additions & 1 deletion cmsis-pack-examples/device/alif-ensemble/include/LcdDisplay.hpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* SPDX-FileCopyrightText: Copyright 2022-2023 Arm Limited and/or its
* SPDX-FileCopyrightText: Copyright 2022-2024 Arm Limited and/or its
* affiliates <open-source-office@arm.com>
* SPDX-License-Identifier: Apache-2.0
*
Expand All @@ -26,6 +26,14 @@
#define DIMAGE_Y RTE_PANEL_VACTIVE_LINE
#define RGB_BYTES 3

#if RTE_CDC200_PIXEL_FORMAT==(1)
#define LCD_BYTES_PER_PIXEL (3)
#elif RTE_CDC200_PIXEL_FORMAT==(2)
#define LCD_BYTES_PER_PIXEL (2)
#else // LCD_BYTES_PER_PIXEL
#error "Unsupported RTE_CDC200_PIXEL_FORMAT."
#endif // LCD_BYTES_PER_PIXEL

namespace arm {
namespace app {

Expand Down
28 changes: 11 additions & 17 deletions cmsis-pack-examples/device/alif-ensemble/src/BoardAudioUtils.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
/*
* SPDX-FileCopyrightText: Copyright 2023 Arm Limited and/or its
* SPDX-FileCopyrightText: Copyright 2023-2024 Arm Limited and/or its
* affiliates <open-source-office@arm.com>
* SPDX-License-Identifier: Apache-2.0
*
Expand All @@ -26,13 +26,13 @@ extern "C" {

#include "RTE_Components.h"
#include "RTE_Device.h"
#include <Driver_PINMUX_AND_PINPAD.h>
#include "pinconf.h"
#include <Driver_SAI.h>
#include CMSIS_device_header

#include <stdio.h>

#define I2S_ADC 2 /* Audio I2S Controller 2 */
#define I2S_ADC 3 /* Audio I2S Controller 3 */
extern ARM_DRIVER_SAI ARM_Driver_SAI_(I2S_ADC);
ARM_DRIVER_SAI* s_i2s_drv;

Expand All @@ -45,9 +45,9 @@ static volatile audio_capture_state s_cap_state;

static void set_capture_completed(bool val)
{
NVIC_DisableIRQ((IRQn_Type)I2S2_IRQ);
NVIC_DisableIRQ((IRQn_Type)I2S3_IRQ_IRQn);
s_cap_state.capCompleted = val;
NVIC_EnableIRQ((IRQn_Type)I2S2_IRQ);
NVIC_EnableIRQ((IRQn_Type)I2S3_IRQ_IRQn);
}

static void set_capture_started(bool val)
Expand Down Expand Up @@ -77,20 +77,14 @@ static int32_t ConfigureI2SPinMuxPinPad()
{
int32_t status = 0;

// Configure P2_1.I2S2_SDI_A
status |= PINMUX_Config(PORT_NUMBER_2, PIN_NUMBER_1, PINMUX_ALTERNATE_FUNCTION_3);
status |=
PINPAD_Config(PORT_NUMBER_2,
PIN_NUMBER_1,
PAD_FUNCTION_DRIVER_DISABLE_STATE_WITH_PULL_DOWN | PAD_FUNCTION_READ_ENABLE);
/** Configure I2S3_B_WS */
status |= pinconf_set(PORT_8, PIN_7, PINMUX_ALTERNATE_FUNCTION_2, 0);

/* Configure P2_3.I2S2_SCLK_A */
status |= PINMUX_Config(PORT_NUMBER_2, PIN_NUMBER_3, PINMUX_ALTERNATE_FUNCTION_3);
status |= PINPAD_Config(PORT_NUMBER_2, PIN_NUMBER_3, PAD_FUNCTION_READ_ENABLE);
/** Configure I2S3_B_SCLK */
status |= pinconf_set(PORT_8, PIN_6, PINMUX_ALTERNATE_FUNCTION_2, 0);

/* Configure P2_3.I2S2_WS_A */
status |= PINMUX_Config(PORT_NUMBER_2, PIN_NUMBER_4, PINMUX_ALTERNATE_FUNCTION_2);
status |= PINPAD_Config(PORT_NUMBER_2, PIN_NUMBER_4, PAD_FUNCTION_READ_ENABLE);
/** Configure I2S3_B_SDI */
status |= pinconf_set(PORT_9, PIN_0, PINMUX_ALTERNATE_FUNCTION_2, PADCTRL_READ_ENABLE);

return status;
}
Expand Down
Loading

0 comments on commit eb6e267

Please sign in to comment.