-
Notifications
You must be signed in to change notification settings - Fork 75
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
678deb9
commit c863759
Showing
120 changed files
with
14,366 additions
and
104 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,5 @@ | ||
/* | ||
* Copyright 2021-2023 NXP | ||
* All rights reserved. | ||
* | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,5 @@ | ||
/* | ||
* Copyright 2021-2023 NXP | ||
* All rights reserved. | ||
* | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,7 +1,5 @@ | ||
/* | ||
* Copyright 2021-2023 NXP | ||
* All rights reserved. | ||
* | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
/* | ||
* Copyright 2021-2023 NXP | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
#ifndef RPMSG_PLATFORM_H_ | ||
#define RPMSG_PLATFORM_H_ | ||
|
||
#include <stdint.h> | ||
|
||
typedef struct rpmsg_platform_shmem_config | ||
{ | ||
uint32_t buffer_payload_size; /* custom buffer payload size setting that overwrites RL_BUFFER_PAYLOAD_SIZE global | ||
config, must be equal to (240, 496, 1008, ...) [2^n - 16] */ | ||
uint16_t buffer_count; /* custom buffer count setting that overwrites RL_BUFFER_COUNT global config, must be power | ||
of two (2, 4, ...) */ | ||
uint32_t vring_size; /* custom vring size */ | ||
uint32_t vring_align; /* custom vring alignment */ | ||
} rpmsg_platform_shmem_config_t; | ||
|
||
/* RPMSG MU channel index */ | ||
#define RPMSG_MU_CHANNEL (1U) | ||
|
||
#if !(defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1)) | ||
/* | ||
* No need to align the VRING as defined in Linux because the FUSION DSP is not intended | ||
* to communicate with Linux. | ||
*/ | ||
#ifndef VRING_ALIGN | ||
#define VRING_ALIGN (0x10U) | ||
#endif | ||
|
||
/* contains pool of descriptors and two circular buffers */ | ||
#ifndef VRING_SIZE | ||
/* set VRING_SIZE based on number of used buffers as calculated in vring_init */ | ||
#define VRING_DESC_SIZE (((RL_BUFFER_COUNT * sizeof(struct vring_desc)) + VRING_ALIGN - 1UL) & ~(VRING_ALIGN - 1UL)) | ||
#define VRING_AVAIL_SIZE \ | ||
(((sizeof(struct vring_avail) + (RL_BUFFER_COUNT * sizeof(uint16_t)) + sizeof(uint16_t)) + VRING_ALIGN - 1UL) & \ | ||
~(VRING_ALIGN - 1UL)) | ||
#define VRING_USED_SIZE \ | ||
(((sizeof(struct vring_used) + (RL_BUFFER_COUNT * sizeof(struct vring_used_elem)) + sizeof(uint16_t)) + \ | ||
VRING_ALIGN - 1UL) & \ | ||
~(VRING_ALIGN - 1UL)) | ||
#define VRING_SIZE (VRING_DESC_SIZE + VRING_AVAIL_SIZE + VRING_USED_SIZE) | ||
#endif | ||
|
||
/* define shared memory space for VRINGS per one channel */ | ||
#define RL_VRING_OVERHEAD (2UL * VRING_SIZE) | ||
#endif | ||
|
||
/* VQ_ID in 8ULP is defined as follows: | ||
* com_id: [4:3] communication ID, used to identify the MU instance. | ||
* vring_id: [2:1] vring ID, used to identify the vring. | ||
* q_id: [0:0] queue ID, used to identify the tvq or rvq. | ||
* com_id + vring_id = link_id | ||
*/ | ||
#define RL_GET_VQ_ID(link_id, queue_id) (((queue_id)&0x1U) | (((link_id) << 1U) & 0xFFFFFFFEU)) | ||
#define RL_GET_LINK_ID(vq_id) (((vq_id)&0xFFFFFFFEU) >> 1U) | ||
#define RL_GET_Q_ID(vq_id) ((vq_id)&0x1U) | ||
#define RL_GEN_MU_MSG(vq_id) (uint32_t)(((vq_id)&0x7U) << 16U) /* com_id is discarded in msg */ | ||
|
||
#define RL_GEN_LINK_ID(com_id, vring_id) (((com_id) << 2U) | (vring_id)) | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID (1U) | ||
#define RL_PLATFORM_IMX8ULP_FUSION_SRTM_VRING_ID (0U) | ||
#define RL_PLATFORM_IMX8ULP_FUSION_USER_VRING_ID (1U) | ||
|
||
/* Use same link id with master/CM33. */ | ||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_SRTM_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID, RL_PLATFORM_IMX8ULP_FUSION_SRTM_VRING_ID) | ||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_USER_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID, RL_PLATFORM_IMX8ULP_FUSION_USER_VRING_ID) | ||
|
||
#define RL_PLATFORM_HIGHEST_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID, RL_PLATFORM_IMX8ULP_FUSION_USER_VRING_ID) | ||
|
||
/* platform interrupt related functions */ | ||
int32_t platform_init_interrupt(uint32_t vector_id, void *isr_data); | ||
int32_t platform_deinit_interrupt(uint32_t vector_id); | ||
int32_t platform_interrupt_enable(uint32_t vector_id); | ||
int32_t platform_interrupt_disable(uint32_t vector_id); | ||
int32_t platform_in_isr(void); | ||
void platform_notify(uint32_t vector_id); | ||
|
||
/* platform low-level time-delay (busy loop) */ | ||
void platform_time_delay(uint32_t num_msec); | ||
|
||
/* platform memory functions */ | ||
void platform_map_mem_region(uint32_t vrt_addr, uint32_t phy_addr, uint32_t size, uint32_t flags); | ||
void platform_cache_all_flush_invalidate(void); | ||
void platform_cache_disable(void); | ||
uintptr_t platform_vatopa(void *addr); | ||
void *platform_patova(uintptr_t addr); | ||
|
||
#if defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1) | ||
#define RL_VRING_SIZE_M33_FUSION_DSP_COM (0x400UL) | ||
|
||
#define RL_VRING_ALIGN_M33_FUSION_DSP_COM (0x10U) | ||
|
||
int32_t platform_get_custom_shmem_config(uint32_t link_id, rpmsg_platform_shmem_config_t *cfg); | ||
#endif /* defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1) */ | ||
|
||
/* platform init/deinit */ | ||
int32_t platform_init(void); | ||
int32_t platform_deinit(void); | ||
|
||
#endif /* RPMSG_PLATFORM_H_ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,115 @@ | ||
/* | ||
* Copyright 2021-2023 NXP | ||
* | ||
* SPDX-License-Identifier: BSD-3-Clause | ||
*/ | ||
#ifndef RPMSG_PLATFORM_H_ | ||
#define RPMSG_PLATFORM_H_ | ||
|
||
#include <stdint.h> | ||
|
||
typedef struct rpmsg_platform_shmem_config | ||
{ | ||
uint32_t buffer_payload_size; /* custom buffer payload size setting that overwrites RL_BUFFER_PAYLOAD_SIZE global | ||
config, must be equal to (240, 496, 1008, ...) [2^n - 16] */ | ||
uint16_t buffer_count; /* custom buffer count setting that overwrites RL_BUFFER_COUNT global config, must be power | ||
of two (2, 4, ...) */ | ||
uint32_t vring_size; /* custom vring size */ | ||
uint32_t vring_align; /* custom vring alignment */ | ||
} rpmsg_platform_shmem_config_t; | ||
|
||
/* RPMSG MU channel index */ | ||
#define RPMSG_MU_CHANNEL (1) | ||
|
||
#if !(defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1)) | ||
/* | ||
* Linux requires the ALIGN to 0x1000(4KB) instead of 0x80 | ||
*/ | ||
#ifndef VRING_ALIGN | ||
#define VRING_ALIGN (0x1000U) | ||
#endif | ||
|
||
/* contains pool of descriptors and two circular buffers */ | ||
#ifndef VRING_SIZE | ||
#define VRING_SIZE (0x8000UL) | ||
#endif | ||
|
||
/* define shared memory space for VRINGS per one channel */ | ||
#define RL_VRING_OVERHEAD (2UL * VRING_SIZE) | ||
#endif | ||
|
||
/* VQ_ID in 8ULP is defined as follows: | ||
* com_id: [4:3] communication ID, used to identify the MU instance. | ||
* vring_id: [2:1] vring ID, used to identify the vring. | ||
* q_id: [0:0] queue ID, used to identify the tvq or rvq. | ||
* com_id + vring_id = link_id | ||
*/ | ||
|
||
#define RL_GET_VQ_ID(link_id, queue_id) (((queue_id)&0x1U) | (((link_id) << 1U) & 0xFFFFFFFEU)) | ||
#define RL_GET_LINK_ID(vq_id) ((vq_id) >> 1U) | ||
#define RL_GET_COM_ID(vq_id) ((vq_id) >> 3U) | ||
#define RL_GET_Q_ID(vq_id) ((vq_id)&0x1U) | ||
|
||
#define RL_GEN_LINK_ID(com_id, vring_id) (((com_id) << 2U) | (vring_id)) | ||
#define RL_GEN_MU_MSG(vq_id) (uint32_t)(((vq_id)&0x7U) << 16U) /* com_id is discarded in msg */ | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_A35_COM_ID (0U) | ||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID (1U) | ||
#define RL_PLATFORM_IMX8ULP_M33_HIFI4_COM_ID (2U) | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_SRTM_VRING_ID (0U) | ||
#define RL_PLATFORM_IMX8ULP_M33_USER_VRING_ID (1U) | ||
|
||
#define RL_PLATFORM_HIGHEST_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_HIFI4_COM_ID, RL_PLATFORM_IMX8ULP_M33_USER_VRING_ID) | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_A35_SRTM_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_A35_COM_ID, RL_PLATFORM_IMX8ULP_M33_SRTM_VRING_ID) | ||
#define RL_PLATFORM_IMX8ULP_M33_A35_USER_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_A35_COM_ID, RL_PLATFORM_IMX8ULP_M33_USER_VRING_ID) | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_SRTM_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID, RL_PLATFORM_IMX8ULP_M33_SRTM_VRING_ID) | ||
#define RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_USER_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_FUSION_DSP_COM_ID, RL_PLATFORM_IMX8ULP_M33_USER_VRING_ID) | ||
|
||
#define RL_PLATFORM_IMX8ULP_M33_HIFI4_SRTM_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_HIFI4_COM_ID, RL_PLATFORM_IMX8ULP_M33_SRTM_VRING_ID) | ||
#define RL_PLATFORM_IMX8ULP_M33_HIFI4_USER_LINK_ID \ | ||
RL_GEN_LINK_ID(RL_PLATFORM_IMX8ULP_M33_HIFI4_COM_ID, RL_PLATFORM_IMX8ULP_M33_USER_VRING_ID) | ||
|
||
/* platform interrupt related functions */ | ||
int32_t platform_init_interrupt(uint32_t vector_id, void *isr_data); | ||
int32_t platform_deinit_interrupt(uint32_t vector_id); | ||
int32_t platform_interrupt_enable(uint32_t vector_id); | ||
int32_t platform_interrupt_disable(uint32_t vector_id); | ||
int32_t platform_in_isr(void); | ||
void platform_notify(uint32_t vector_id); | ||
|
||
/* platform low-level time-delay (busy loop) */ | ||
void platform_time_delay(uint32_t num_msec); | ||
|
||
/* platform memory functions */ | ||
void platform_map_mem_region(uint32_t vrt_addr, uint32_t phy_addr, uint32_t size, uint32_t flags); | ||
void platform_cache_all_flush_invalidate(void); | ||
void platform_cache_disable(void); | ||
uintptr_t platform_vatopa(void *addr); | ||
void *platform_patova(uintptr_t addr); | ||
|
||
#if defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1) | ||
#define RL_VRING_SIZE_M33_A35_COM (0x8000UL) /* contains pool of descriptors and two circular buffers */ | ||
#define RL_VRING_SIZE_M33_FUSION_DSP_COM (0x400UL) | ||
#define RL_VRING_SIZE_M33_HIFI4_COM (0x400UL) | ||
|
||
#define RL_VRING_ALIGN_M33_A35_COM (0x1000U) /* Linux requires the ALIGN to 0x1000(4KB) instead of 0x80 */ | ||
#define RL_VRING_ALIGN_M33_FUSION_DSP_COM (0x10U) | ||
#define RL_VRING_ALIGN_M33_HIFI4_COM (0x10U) | ||
|
||
int32_t platform_get_custom_shmem_config(uint32_t link_id, rpmsg_platform_shmem_config_t *cfg); | ||
#endif /* defined(RL_ALLOW_CUSTOM_SHMEM_CONFIG) && (RL_ALLOW_CUSTOM_SHMEM_CONFIG == 1) */ | ||
|
||
/* platform init/deinit */ | ||
int32_t platform_init(void); | ||
int32_t platform_deinit(void); | ||
|
||
#endif /* RPMSG_PLATFORM_H_ */ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.