doc: renamed project
This commit is contained in:
committed by
Sylvan Arnold
parent
244e516bd8
commit
32618389d1
@@ -0,0 +1,273 @@
|
||||
/** Copyright (C) SEGGER Microcontroller GmbH */ /* << EST */
|
||||
/*********************************************************************
|
||||
* SEGGER Microcontroller GmbH *
|
||||
* The Embedded Experts *
|
||||
**********************************************************************
|
||||
* *
|
||||
* (c) 1995 - 2024 SEGGER Microcontroller GmbH *
|
||||
* *
|
||||
* www.segger.com Support: support@segger.com *
|
||||
* *
|
||||
**********************************************************************
|
||||
* *
|
||||
* SEGGER SystemView * Real-time application analysis *
|
||||
* *
|
||||
**********************************************************************
|
||||
* *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* SEGGER strongly recommends to not make any changes *
|
||||
* to or modify the source code of this software in order to stay *
|
||||
* compatible with the SystemView and RTT protocol, and J-Link. *
|
||||
* *
|
||||
* Redistribution and use in source and binary forms, with or *
|
||||
* without modification, are permitted provided that the following *
|
||||
* condition is met: *
|
||||
* *
|
||||
* o Redistributions of source code must retain the above copyright *
|
||||
* notice, this condition and the following disclaimer. *
|
||||
* *
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND *
|
||||
* CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, *
|
||||
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF *
|
||||
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE *
|
||||
* DISCLAIMED. IN NO EVENT SHALL SEGGER Microcontroller BE LIABLE FOR *
|
||||
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR *
|
||||
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT *
|
||||
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; *
|
||||
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF *
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT *
|
||||
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE *
|
||||
* USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH *
|
||||
* DAMAGE. *
|
||||
* *
|
||||
**********************************************************************
|
||||
* *
|
||||
* SystemView version: 3.56 *
|
||||
* *
|
||||
**********************************************************************
|
||||
-------------------------- END-OF-HEADER -----------------------------
|
||||
|
||||
File : SEGGER_SYSVIEW_Config_FreeRTOS.c
|
||||
Purpose : Sample setup configuration of SystemView with FreeRTOS.
|
||||
Revision: $Rev: 7745 $
|
||||
*/
|
||||
#include "FreeRTOS.h"
|
||||
#include "SEGGER_SYSVIEW.h"
|
||||
|
||||
extern const SEGGER_SYSVIEW_OS_API SYSVIEW_X_OS_TraceAPI;
|
||||
|
||||
/*********************************************************************
|
||||
*
|
||||
* Defines, configurable
|
||||
*
|
||||
**********************************************************************
|
||||
*/
|
||||
#if 0 /* << EST: original code by SEGGER: */
|
||||
// The application name to be displayed in SystemViewer
|
||||
#define SYSVIEW_APP_NAME "FreeRTOS Demo Application"
|
||||
|
||||
// The target device name
|
||||
#define SYSVIEW_DEVICE_NAME "Cortex-M4"
|
||||
|
||||
// Frequency of the timestamp. Must match SEGGER_SYSVIEW_GET_TIMESTAMP in SEGGER_SYSVIEW_Conf.h
|
||||
#define SYSVIEW_TIMESTAMP_FREQ (configCPU_CLOCK_HZ)
|
||||
|
||||
// System Frequency. SystemcoreClock is used in most CMSIS compatible projects.
|
||||
#define SYSVIEW_CPU_FREQ configCPU_CLOCK_HZ
|
||||
|
||||
// The lowest RAM address used for IDs (pointers)
|
||||
#define SYSVIEW_RAM_BASE (0x10000000)
|
||||
#endif
|
||||
/* << EST: begin */
|
||||
#include "SEGGER_SYSVIEW_Conf.h" /* needed for SEGGER_SYSVIEW_TIMESTAMP_SHIFT */
|
||||
#include "McuSystemViewconfig.h"
|
||||
#include "McuLib.h"
|
||||
//#define SYSVIEW_USING_PEX (McuLib_CONFIG_PEX_SDK_USED) /* 1: project is a Kinetis SDK Processor Expert project; 0: No Kinetis Processor Expert project */
|
||||
//#define SYSVIEW_USING_FREERTOS (McuLib_CONFIG_SDK_USE_FREERTOS) /* 1: using FreeRTOS; 0: Bare metal */
|
||||
|
||||
#if SYSVIEW_USING_PEX
|
||||
#include "Cpu.h"
|
||||
#endif
|
||||
#if SYSVIEW_USING_FREERTOS
|
||||
#include "FreeRTOS.h"
|
||||
#endif
|
||||
|
||||
// The application name to be displayed in SystemViewer
|
||||
//#ifndef SYSVIEW_APP_NAME
|
||||
// #define SYSVIEW_APP_NAME "Demo Application" /* application name, configured in properties */
|
||||
//#endif
|
||||
|
||||
// The operating system, if any
|
||||
#if SYSVIEW_USING_FREERTOS
|
||||
extern const SEGGER_SYSVIEW_OS_API SYSVIEW_X_OS_TraceAPI;
|
||||
//#define SYSVIEW_OS_NAME "FreeRTOS"
|
||||
#define SYSVIEW_OS_API &SYSVIEW_X_OS_TraceAPI
|
||||
#else
|
||||
//#define SYSVIEW_OS_NAME "Bare-metal"
|
||||
#define SYSVIEW_OS_API NULL
|
||||
#endif
|
||||
/* << EST: end */
|
||||
|
||||
// The target device name
|
||||
//#ifndef SYSVIEW_DEVICE_NAME
|
||||
// #define SYSVIEW_DEVICE_NAME "Cortex" /* device name, configured in properties */
|
||||
//#endif
|
||||
|
||||
// System Frequency. SystemcoreClock is used in most CMSIS compatible projects.
|
||||
#if SYSVIEW_USING_FREERTOS
|
||||
#define SYSVIEW_CPU_FREQ configCPU_CLOCK_HZ
|
||||
#elif SYSVIEW_USING_PEX
|
||||
#define SYSVIEW_CPU_FREQ configCPU_CLOCK_HZ
|
||||
#else
|
||||
/* The SDK variable SystemCoreClock contains the current clock speed */
|
||||
extern uint32_t SystemCoreClock;
|
||||
#define SYSVIEW_CPU_FREQ (SystemCoreClock) /* CPU clock frequency */
|
||||
#endif /* SYSVIEW_USING_KINETIS_SDK */
|
||||
|
||||
// Frequency of the timestamp. Must match SEGGER_SYSVIEW_Conf.h
|
||||
#define SYSVIEW_TIMESTAMP_FREQ (configSYSTICK_CLOCK_HZ>>SEGGER_SYSVIEW_TIMESTAMP_SHIFT) /* use FreeRTOS Systick frequency value, as this might depend on prescalers */
|
||||
|
||||
// The lowest RAM address used for IDs (pointers)
|
||||
#define SYSVIEW_RAM_BASE (McuSystemView_CONFIG_SYSVIEW_RAM_BASE) /* RAM base, configured in properties */
|
||||
|
||||
#if 1 /* << EST */
|
||||
#define portNVIC_SYSTICK_LOAD_REG (*((volatile unsigned long *)0xe000e014)) /* SYST_RVR, SysTick reload value register */
|
||||
#define portNVIC_SYSTICK_CURRENT_VALUE_REG (*((volatile unsigned long *)0xe000e018)) /* SYST_CVR, SysTick current value register */
|
||||
|
||||
#define TICK_NOF_BITS 24
|
||||
#define COUNTS_UP 0 /* SysTick is counting down to zero */
|
||||
#define SET_TICK_DURATION(val) portNVIC_SYSTICK_LOAD_REG = val
|
||||
#define GET_TICK_DURATION() portNVIC_SYSTICK_LOAD_REG
|
||||
#define GET_TICK_CURRENT_VAL(addr) *(addr)=portNVIC_SYSTICK_CURRENT_VALUE_REG
|
||||
|
||||
|
||||
uint32_t SEGGER_uxGetTickCounterValue(void) {
|
||||
uint32_t val;
|
||||
|
||||
GET_TICK_CURRENT_VAL(&val);
|
||||
return val;
|
||||
}
|
||||
#endif
|
||||
|
||||
#if SEGGER_SYSVIEW_CORE == SEGGER_SYSVIEW_CORE_CM0 /* << EST */
|
||||
//
|
||||
// SEGGER_SYSVIEW_TickCnt has to be defined in the module which
|
||||
// handles the SysTick and must be incremented in the SysTick
|
||||
// handler before any SYSVIEW event is generated.
|
||||
//
|
||||
// Example in embOS RTOSInit.c:
|
||||
//
|
||||
// unsigned int SEGGER_SYSVIEW_TickCnt; // <<-- Define SEGGER_SYSVIEW_TickCnt.
|
||||
// void SysTick_Handler(void) {
|
||||
// #if OS_PROFILE
|
||||
// SYSVIEW_TickCnt++; // <<-- Increment SEGGER_SYSVIEW_TickCnt before calling OS_EnterNestableInterrupt.
|
||||
// #endif
|
||||
// OS_EnterNestableInterrupt();
|
||||
// OS_TICK_Handle();
|
||||
// OS_LeaveNestableInterrupt();
|
||||
// }
|
||||
//
|
||||
extern unsigned int SEGGER_SYSVIEW_TickCnt;
|
||||
|
||||
#ifndef SCB_ICSR
|
||||
#define SCB_ICSR (*(volatile U32*) (0xE000ED04uL)) // Interrupt Control State Register
|
||||
#endif
|
||||
|
||||
#ifndef SCB_ICSR_PENDSTSET_MASK
|
||||
#define SCB_ICSR_PENDSTSET_MASK (1UL << 26) // SysTick pending bit
|
||||
#endif
|
||||
|
||||
#ifndef SYST_RVR
|
||||
#define SYST_RVR (*(volatile U32*) (0xE000E014uL)) // SysTick Reload Value Register
|
||||
#endif
|
||||
|
||||
#ifndef SYST_CVR
|
||||
#define SYST_CVR (*(volatile U32*) (0xE000E018uL)) // SysTick Current Value Register
|
||||
#endif
|
||||
|
||||
/*********************************************************************
|
||||
*
|
||||
* SEGGER_SYSVIEW_X_GetTimestamp()
|
||||
*
|
||||
* Function description
|
||||
* Returns the current timestamp in ticks using the system tick
|
||||
* count and the SysTick counter.
|
||||
* All parameters of the SysTick have to be known and are set via
|
||||
* configuration defines on top of the file.
|
||||
*
|
||||
* Return value
|
||||
* The current timestamp.
|
||||
*
|
||||
* Additional information
|
||||
* SEGGER_SYSVIEW_X_GetTimestamp is always called when interrupts are
|
||||
* disabled. Therefore locking here is not required.
|
||||
*/
|
||||
U32 SEGGER_SYSVIEW_X_GetTimestamp(void) {
|
||||
#if configUSE_SEGGER_SYSTEM_VIEWER_HOOKS
|
||||
U32 TickCount;
|
||||
U32 Cycles;
|
||||
U32 CyclesPerTick;
|
||||
//
|
||||
// Get the cycles of the current system tick.
|
||||
// SysTick is down-counting, subtract the current value from the number of cycles per tick.
|
||||
//
|
||||
CyclesPerTick = SYST_RVR + 1;
|
||||
Cycles = (CyclesPerTick - SYST_CVR);
|
||||
//
|
||||
// Get the system tick count.
|
||||
//
|
||||
TickCount = SEGGER_SYSVIEW_TickCnt;
|
||||
//
|
||||
// If a SysTick interrupt is pending increment the TickCount
|
||||
//
|
||||
if ((SCB_ICSR & SCB_ICSR_PENDSTSET_MASK) != 0) {
|
||||
TickCount++;
|
||||
}
|
||||
Cycles += TickCount * CyclesPerTick;
|
||||
|
||||
return Cycles;
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
#endif /* << EST */
|
||||
|
||||
/*********************************************************************
|
||||
*
|
||||
* _cbSendSystemDesc()
|
||||
*
|
||||
* Function description
|
||||
* Sends SystemView description strings.
|
||||
*/
|
||||
#if SYSVIEW_USING_FREERTOS /* << EST */
|
||||
/* default callback */
|
||||
void _cbSendSystemDesc(void) {
|
||||
SEGGER_SYSVIEW_SendSysDesc("N="SYSVIEW_APP_NAME",O="SYSVIEW_OS_NAME",D="SYSVIEW_DEVICE_NAME);
|
||||
SEGGER_SYSVIEW_SendSysDesc("I#15=SysTick");
|
||||
}
|
||||
#endif
|
||||
|
||||
/*********************************************************************
|
||||
*
|
||||
* Global functions
|
||||
*
|
||||
**********************************************************************
|
||||
*/
|
||||
void SEGGER_SYSVIEW_Conf(void) {
|
||||
#if SYSVIEW_USING_FREERTOS /* << EST */
|
||||
#if configUSE_TRACE_HOOKS /* << EST: using Percepio Trace */ && configUSE_SEGGER_SYSTEM_VIEWER_HOOKS /* using SEGGER SystemViewer */
|
||||
#warning "Percepio Trace is enabled, this might conflict with Segger System View."
|
||||
#endif
|
||||
#if !defined(McuSystemView_CONFIG_SYSVIEW_CONFIG_CALLBACK) /* use default */
|
||||
SEGGER_SYSVIEW_Init(SYSVIEW_TIMESTAMP_FREQ, SYSVIEW_CPU_FREQ, &SYSVIEW_X_OS_TraceAPI, _cbSendSystemDesc);
|
||||
#else /* use application specific callback */
|
||||
void McuSystemView_CONFIG_SYSVIEW_CONFIG_CALLBACK(void); /* prototype */
|
||||
SEGGER_SYSVIEW_Init(SYSVIEW_TIMESTAMP_FREQ, SYSVIEW_CPU_FREQ, &SYSVIEW_X_OS_TraceAPI, McuSystemView_CONFIG_SYSVIEW_CONFIG_CALLBACK);
|
||||
#endif
|
||||
SEGGER_SYSVIEW_SetRAMBase(SYSVIEW_RAM_BASE);
|
||||
#endif
|
||||
}
|
||||
|
||||
/*************************** End of file ****************************/
|
||||
|
||||
Reference in New Issue
Block a user