14
									
								
								.idea/cmake.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										14
									
								
								.idea/cmake.xml
									
									
									
										generated
									
									
									
								
							| @@ -3,11 +3,9 @@ | ||||
|   <component name="CMakeSharedSettings"> | ||||
|     <configurations> | ||||
|       <configuration PROFILE_NAME="mcxn947" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=mcx -DBOARD=mcxn947brk" /> | ||||
|       <configuration PROFILE_NAME="rt1060 evk" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=imxrt -DBOARD=mimxrt1060_evk" /> | ||||
|       <configuration PROFILE_NAME="pca10056" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=nrf -DBOARD=pca10056" /> | ||||
|       <configuration PROFILE_NAME="pca10095" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=nrf -DBOARD=pca10095" /> | ||||
|       <configuration PROFILE_NAME="pca10056" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=nrf -DBOARD=pca10056" BUILD_OPTIONS="-v" /> | ||||
|       <configuration PROFILE_NAME="lpc55s69" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=lpc55 -DBOARD=lpcxpresso55s69" /> | ||||
|       <configuration PROFILE_NAME="esp32s3" ENABLED="false" GENERATION_OPTIONS="-DFAMILY=espressif -DBOARD=espressif_s3_devkitm -DIDF_TARGET=esp32s3"> | ||||
|       <configuration PROFILE_NAME="esp32s2" ENABLED="false" GENERATION_OPTIONS="-DFAMILY=espressif -DBOARD=espressif_saola_1 -DIDF_TARGET=esp32s2"> | ||||
|         <ADDITIONAL_GENERATION_ENVIRONMENT> | ||||
|           <envs> | ||||
|             <env name="ESPBAUD" value="1500000" /> | ||||
| @@ -17,7 +15,7 @@ | ||||
|           </envs> | ||||
|         </ADDITIONAL_GENERATION_ENVIRONMENT> | ||||
|       </configuration> | ||||
|       <configuration PROFILE_NAME="esp32s2" ENABLED="false" GENERATION_OPTIONS="-DFAMILY=espressif -DBOARD=espressif_saola_1 -DIDF_TARGET=esp32s2"> | ||||
|       <configuration PROFILE_NAME="esp32s3" ENABLED="false" GENERATION_OPTIONS="-DFAMILY=espressif -DBOARD=espressif_s3_devkitm -DIDF_TARGET=esp32s3"> | ||||
|         <ADDITIONAL_GENERATION_ENVIRONMENT> | ||||
|           <envs> | ||||
|             <env name="ESPBAUD" value="1500000" /> | ||||
| @@ -29,12 +27,16 @@ | ||||
|       </configuration> | ||||
|       <configuration PROFILE_NAME="rp2040" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=rp2040 -DBOARD=raspberry_pi_pico" /> | ||||
|       <configuration PROFILE_NAME="rt1010 evk" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=imxrt -DBOARD=mimxrt1010_evk" /> | ||||
|       <configuration PROFILE_NAME="rt1060 evk" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=imxrt -DBOARD=mimxrt1060_evk" /> | ||||
|       <configuration PROFILE_NAME="rt1064 evk" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=imxrt -DBOARD=mimxrt1064_evk" /> | ||||
|       <configuration PROFILE_NAME="mcb1800" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=lpc18 -DBOARD=mcb1800" /> | ||||
|       <configuration PROFILE_NAME="lpcxpresso18s37" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=lpc18 -DBOARD=lpcxpresso18s37" /> | ||||
|       <configuration PROFILE_NAME="lpc55s69" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=lpc55 -DBOARD=lpcxpresso55s69" /> | ||||
|       <configuration PROFILE_NAME="stm32g0b1nucleo" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g0 -DBOARD=stm32g0b1nucleo" /> | ||||
|       <configuration PROFILE_NAME="stm32g0b1nucleo iar" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g0 -DBOARD=stm32g0b1nucleo -DTOOLCHAIN=iar" /> | ||||
|       <configuration PROFILE_NAME="stm32g474nucleo" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g4 -DBOARD=stm32g474nucleo" /> | ||||
|       <configuration PROFILE_NAME="b_g474e_dpow1" ENABLED="true" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g4 -DBOARD=b_g474e_dpow1" /> | ||||
|       <configuration PROFILE_NAME="b_g474e_dpow1" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g4 -DBOARD=b_g474e_dpow1 -DLOG=3 -DLOGGER=RTT" /> | ||||
|       <configuration PROFILE_NAME="b_g474e_dpow1 iar" ENABLED="false" CONFIG_NAME="Debug" GENERATION_OPTIONS="-DFAMILY=stm32g4 -DBOARD=b_g474e_dpow1 -DTOOLCHAIN=iar" /> | ||||
|     </configurations> | ||||
|   </component> | ||||
| </project> | ||||
							
								
								
									
										10
									
								
								.idea/runConfigurations/mcx947_jlink.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								.idea/runConfigurations/mcx947_jlink.xml
									
									
									
										generated
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,10 @@ | ||||
| <component name="ProjectRunConfigurationManager"> | ||||
|   <configuration default="false" name="mcx947 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "MCXN947_M33_0" -if swd -speed 50000 -port 25321 -nogui -singlerun -jlinkscriptfile $ProjectFileDir$/hw/bsp/mcx/mcx.jlinkscript" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="mcxn947" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|     <custom-gdb-server version="1" gdb-connect="tcp::25321" executable="/usr/bin/JLinkGDBServer" warmup-ms="0" download-type="UPDATED_ONLY" reset-cmd="monitor reset" reset-type="AFTER_DOWNLOAD"> | ||||
|       <debugger kind="GDB" isBundled="true" /> | ||||
|     </custom-gdb-server> | ||||
|     <method v="2"> | ||||
|       <option name="CLION.COMPOUND.BUILD" enabled="true" /> | ||||
|     </method> | ||||
|   </configuration> | ||||
| </component> | ||||
							
								
								
									
										2
									
								
								.idea/runConfigurations/rp2040.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.idea/runConfigurations/rp2040.xml
									
									
									
										generated
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| <component name="ProjectRunConfigurationManager"> | ||||
|   <configuration default="false" name="rp2040" type="com.jetbrains.cidr.embedded.openocd.conf.type" factoryName="com.jetbrains.cidr.embedded.openocd.conf.factory" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="tinyusb_device_examples" TARGET_NAME="cdc_msc" CONFIG_NAME="b_g474e_dpow1" version="1" RUN_TARGET_PROJECT_NAME="tinyusb_device_examples" RUN_TARGET_NAME="cdc_msc"> | ||||
|   <configuration default="false" name="rp2040" type="com.jetbrains.cidr.embedded.openocd.conf.type" factoryName="com.jetbrains.cidr.embedded.openocd.conf.factory" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="tinyusb_device_examples" TARGET_NAME="cdc_msc" version="1" RUN_TARGET_PROJECT_NAME="tinyusb_device_examples" RUN_TARGET_NAME="cdc_msc"> | ||||
|     <openocd version="1" gdb-port="3333" telnet-port="4444" board-config="$PROJECT_DIR$/hw/bsp/rp2040/rp2040-openocd.cfg" reset-type="INIT" download-type="UPDATED_ONLY"> | ||||
|       <debugger kind="GDB" isBundled="true" /> | ||||
|     </openocd> | ||||
|   | ||||
							
								
								
									
										2
									
								
								.idea/runConfigurations/rt1010_jlink.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.idea/runConfigurations/rt1010_jlink.xml
									
									
									
										generated
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| <component name="ProjectRunConfigurationManager"> | ||||
|   <configuration default="false" name="rt1010 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "MIMXRT1011xxx5A" -if swd -speed 8000 -port 25321 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="mcxn947" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|   <configuration default="false" name="rt1010 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "MIMXRT1011xxx5A" -if swd -speed 50000 -port 25321 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="b_g474e_dpow1" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|     <custom-gdb-server version="1" gdb-connect="tcp::25321" executable="/usr/bin/JLinkGDBServer" warmup-ms="0" download-type="UPDATED_ONLY" reset-cmd="monitor reset" reset-type="AFTER_DOWNLOAD"> | ||||
|       <debugger kind="GDB" isBundled="true" /> | ||||
|     </custom-gdb-server> | ||||
|   | ||||
							
								
								
									
										2
									
								
								.idea/runConfigurations/rt1060_jlink.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.idea/runConfigurations/rt1060_jlink.xml
									
									
									
										generated
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| <component name="ProjectRunConfigurationManager"> | ||||
|   <configuration default="false" name="rt1060 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "MIMXRT1062xxx5A" -if swd -speed 8000 -port 25321 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="host_hid_to_device_cdc" TARGET_NAME="host_hid_to_device_cdc" CONFIG_NAME="rt1060 evk" version="1" RUN_TARGET_PROJECT_NAME="host_hid_to_device_cdc" RUN_TARGET_NAME="host_hid_to_device_cdc"> | ||||
|   <configuration default="false" name="rt1060 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "MIMXRT1062xxx5A" -if swd -speed 50000 -port 25321 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="b_g474e_dpow1" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|     <custom-gdb-server version="1" gdb-connect="tcp::25321" executable="/usr/bin/JLinkGDBServer" warmup-ms="0" download-type="UPDATED_ONLY" reset-cmd="monitor reset" reset-type="AFTER_DOWNLOAD"> | ||||
|       <debugger kind="GDB" isBundled="true" /> | ||||
|     </custom-gdb-server> | ||||
|   | ||||
							
								
								
									
										2
									
								
								.idea/runConfigurations/stm32g474_jlink.xml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2
									
								
								.idea/runConfigurations/stm32g474_jlink.xml
									
									
									
										generated
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| <component name="ProjectRunConfigurationManager"> | ||||
|   <configuration default="false" name="stm32g474 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "stm32g474re" -if swd -speed 100000 -port 25321 -swoport 25322 -TelnetPort 25323 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="b_g474e_dpow1" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|   <configuration default="false" name="stm32g474 jlink" type="com.jetbrains.cidr.embedded.customgdbserver.type" factoryName="com.jetbrains.cidr.embedded.customgdbserver.factory" PROGRAM_PARAMS="-device "stm32g474re" -if swd -speed 50000 -port 25321 -nogui -singlerun" REDIRECT_INPUT="false" ELEVATE="false" USE_EXTERNAL_CONSOLE="false" PASS_PARENT_ENVS_2="true" PROJECT_NAME="cdc_msc" TARGET_NAME="cdc_msc" CONFIG_NAME="b_g474e_dpow1" version="1" RUN_TARGET_PROJECT_NAME="cdc_msc" RUN_TARGET_NAME="cdc_msc"> | ||||
|     <custom-gdb-server version="1" gdb-connect="tcp::25321" executable="/usr/bin/JLinkGDBServer" warmup-ms="0" download-type="UPDATED_ONLY" reset-cmd="monitor reset" reset-type="AFTER_DOWNLOAD"> | ||||
|       <debugger kind="GDB" isBundled="true" /> | ||||
|     </custom-gdb-server> | ||||
|   | ||||
| @@ -10,6 +10,7 @@ function(update_board TARGET) | ||||
|     CPU_MCXN947VDF_cm33_core0 | ||||
|     # port 1 is highspeed | ||||
|     BOARD_TUD_RHPORT=1 | ||||
|     BOARD_TUD_MAX_SPEED=OPT_MODE_HIGH_SPEED | ||||
|     ) | ||||
|   target_sources(${TARGET} PUBLIC | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/clock_config.c | ||||
|   | ||||
| @@ -4,8 +4,8 @@ PORT ?= 1 | ||||
|  | ||||
| CFLAGS += -DCPU_MCXN947VDF_cm33_core0 | ||||
|  | ||||
| JLINK_DEVICE = LPC55S69 | ||||
| PYOCD_TARGET = LPC55S69 | ||||
| JLINK_DEVICE = MCXN947_M33_0 | ||||
| PYOCD_TARGET = MCXN947 | ||||
|  | ||||
| # flash using pyocd | ||||
| flash: flash-pyocd | ||||
| flash: flash-jlink | ||||
|   | ||||
| @@ -14,7 +14,7 @@ include(${CMAKE_CURRENT_LIST_DIR}/boards/${BOARD}/board.cmake) | ||||
| set(CMAKE_SYSTEM_PROCESSOR cortex-m33 CACHE INTERNAL "System Processor") | ||||
| set(CMAKE_TOOLCHAIN_FILE ${TOP}/tools/cmake/toolchain/arm_${TOOLCHAIN}.cmake) | ||||
|  | ||||
| set(FAMILY_MCUS LPC55XX CACHE INTERNAL "") | ||||
| set(FAMILY_MCUS MCXN9 CACHE INTERNAL "") | ||||
|  | ||||
| # enable LTO if supported | ||||
| include(CheckIPOSupported) | ||||
|   | ||||
							
								
								
									
										5
									
								
								hw/bsp/mcx/mcx.jlinkscript
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								hw/bsp/mcx/mcx.jlinkscript
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,5 @@ | ||||
| int SetupTarget(void) { | ||||
|   JLINK_ExecCommand("SetRTTSearchRanges 0x20000000 0x40000"); | ||||
|  | ||||
|   return 0; | ||||
| } | ||||
| @@ -306,7 +306,7 @@ static unsigned char _ActiveTerminal; | ||||
|   #define INIT()                                                                             \ | ||||
|     do {                                                                                     \ | ||||
|       volatile SEGGER_RTT_CB* pRTTCBInit;                                                    \ | ||||
|       pRTTCBInit = (volatile SEGGER_RTT_CB*)((char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF); \ | ||||
|       pRTTCBInit = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF); \ | ||||
|       if (pRTTCBInit->acID[0] != 'S') {                                                      \ | ||||
|         _DoInit();                                                                           \ | ||||
|       }                                                                                      \ | ||||
| @@ -319,7 +319,7 @@ static void _DoInit(void) { | ||||
|   // | ||||
|   // Initialize control block | ||||
|   // | ||||
|   p                     = (volatile SEGGER_RTT_CB*)((char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access control block uncached so that nothing in the cache ever becomes dirty and all changes are visible in HW directly | ||||
|   p                     = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access control block uncached so that nothing in the cache ever becomes dirty and all changes are visible in HW directly | ||||
|   memset((SEGGER_RTT_CB*)p, 0, sizeof(_SEGGER_RTT));         // Make sure that the RTT CB is always zero initialized. | ||||
|   p->MaxNumUpBuffers    = SEGGER_RTT_MAX_NUM_UP_BUFFERS; | ||||
|   p->MaxNumDownBuffers  = SEGGER_RTT_MAX_NUM_DOWN_BUFFERS; | ||||
| @@ -581,7 +581,7 @@ unsigned SEGGER_RTT_ReadUpBufferNoLock(unsigned BufferIndex, void* pData, unsign | ||||
|   volatile char*          pSrc; | ||||
|  | ||||
|   INIT(); | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pBuffer = (unsigned char*)pData; | ||||
|   RdOff = pRing->RdOff; | ||||
|   WrOff = pRing->WrOff; | ||||
| @@ -673,7 +673,7 @@ unsigned SEGGER_RTT_ReadNoLock(unsigned BufferIndex, void* pData, unsigned Buffe | ||||
|   volatile char*          pSrc; | ||||
|   // | ||||
|   INIT(); | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((uintptr_t)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pBuffer = (unsigned char*)pData; | ||||
|   RdOff = pRing->RdOff; | ||||
|   WrOff = pRing->WrOff; | ||||
| @@ -840,7 +840,7 @@ void SEGGER_RTT_WriteWithOverwriteNoLock(unsigned BufferIndex, const void* pBuff | ||||
|   // Get "to-host" ring buffer and copy some elements into local variables. | ||||
|   // | ||||
|   pData = (const char *)pBuffer; | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // Check if we will overwrite data and need to adjust the RdOff. | ||||
|   // | ||||
| @@ -1033,7 +1033,7 @@ unsigned SEGGER_RTT_WriteDownBufferNoLock(unsigned BufferIndex, const void* pBuf | ||||
|   // It is save to cast that to a "to-host" buffer. Up and Down buffer differ in volatility of offsets that might be modified by J-Link. | ||||
|   // | ||||
|   pData = (const char *)pBuffer; | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // How we output depends upon the mode... | ||||
|   // | ||||
| @@ -1107,7 +1107,7 @@ unsigned SEGGER_RTT_WriteNoLock(unsigned BufferIndex, const void* pBuffer, unsig | ||||
|   // Get "to-host" ring buffer. | ||||
|   // | ||||
|   pData = (const char *)pBuffer; | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // How we output depends upon the mode... | ||||
|   // | ||||
| @@ -1271,7 +1271,7 @@ unsigned SEGGER_RTT_PutCharSkipNoLock(unsigned BufferIndex, char c) { | ||||
|   // | ||||
|   // Get "to-host" ring buffer. | ||||
|   // | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // Get write position and handle wrap-around if necessary | ||||
|   // | ||||
| @@ -1326,7 +1326,7 @@ unsigned SEGGER_RTT_PutCharSkip(unsigned BufferIndex, char c) { | ||||
|   // | ||||
|   // Get "to-host" ring buffer. | ||||
|   // | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // Get write position and handle wrap-around if necessary | ||||
|   // | ||||
| @@ -1385,7 +1385,7 @@ unsigned SEGGER_RTT_PutChar(unsigned BufferIndex, char c) { | ||||
|   // | ||||
|   // Get "to-host" ring buffer. | ||||
|   // | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   // | ||||
|   // Get write position and handle wrap-around if necessary | ||||
|   // | ||||
| @@ -1492,7 +1492,7 @@ int SEGGER_RTT_HasKey(void) { | ||||
|   int r; | ||||
|  | ||||
|   INIT(); | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((uintptr_t)&_SEGGER_RTT.aDown[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   RdOff = pRing->RdOff; | ||||
|   if (RdOff != pRing->WrOff) { | ||||
|     r = 1; | ||||
| @@ -1518,7 +1518,7 @@ unsigned SEGGER_RTT_HasData(unsigned BufferIndex) { | ||||
|   SEGGER_RTT_BUFFER_DOWN* pRing; | ||||
|   unsigned                v; | ||||
|  | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_DOWN*)((uintptr_t)&_SEGGER_RTT.aDown[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   v = pRing->WrOff; | ||||
|   return v - pRing->RdOff; | ||||
| } | ||||
| @@ -1539,7 +1539,7 @@ unsigned SEGGER_RTT_HasDataUp(unsigned BufferIndex) { | ||||
|   SEGGER_RTT_BUFFER_UP* pRing; | ||||
|   unsigned                v; | ||||
|  | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   v = pRing->RdOff; | ||||
|   return pRing->WrOff - v; | ||||
| } | ||||
| @@ -1570,7 +1570,7 @@ int SEGGER_RTT_AllocDownBuffer(const char* sName, void* pBuffer, unsigned Buffer | ||||
|  | ||||
|   INIT(); | ||||
|   SEGGER_RTT_LOCK(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   BufferIndex = 0; | ||||
|   do { | ||||
|     if (pRTTCB->aDown[BufferIndex].pBuffer == NULL) { | ||||
| @@ -1619,7 +1619,7 @@ int SEGGER_RTT_AllocUpBuffer(const char* sName, void* pBuffer, unsigned BufferSi | ||||
|  | ||||
|   INIT(); | ||||
|   SEGGER_RTT_LOCK(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   BufferIndex = 0; | ||||
|   do { | ||||
|     if (pRTTCB->aUp[BufferIndex].pBuffer == NULL) { | ||||
| @@ -1674,7 +1674,7 @@ int SEGGER_RTT_ConfigUpBuffer(unsigned BufferIndex, const char* sName, void* pBu | ||||
|   volatile SEGGER_RTT_BUFFER_UP* pUp; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_UP_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pUp = &pRTTCB->aUp[BufferIndex]; | ||||
| @@ -1726,7 +1726,7 @@ int SEGGER_RTT_ConfigDownBuffer(unsigned BufferIndex, const char* sName, void* p | ||||
|   volatile SEGGER_RTT_BUFFER_DOWN* pDown; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_DOWN_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pDown = &pRTTCB->aDown[BufferIndex]; | ||||
| @@ -1769,7 +1769,7 @@ int SEGGER_RTT_SetNameUpBuffer(unsigned BufferIndex, const char* sName) { | ||||
|   volatile SEGGER_RTT_BUFFER_UP* pUp; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_UP_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pUp = &pRTTCB->aUp[BufferIndex]; | ||||
| @@ -1804,7 +1804,7 @@ int SEGGER_RTT_SetNameDownBuffer(unsigned BufferIndex, const char* sName) { | ||||
|   volatile SEGGER_RTT_BUFFER_DOWN* pDown; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_DOWN_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pDown = &pRTTCB->aDown[BufferIndex]; | ||||
| @@ -1840,7 +1840,7 @@ int SEGGER_RTT_SetFlagsUpBuffer(unsigned BufferIndex, unsigned Flags) { | ||||
|   volatile SEGGER_RTT_BUFFER_UP* pUp; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_UP_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pUp = &pRTTCB->aUp[BufferIndex]; | ||||
| @@ -1876,7 +1876,7 @@ int SEGGER_RTT_SetFlagsDownBuffer(unsigned BufferIndex, unsigned Flags) { | ||||
|   volatile SEGGER_RTT_BUFFER_DOWN* pDown; | ||||
|  | ||||
|   INIT(); | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   if (BufferIndex < SEGGER_RTT_MAX_NUM_DOWN_BUFFERS) { | ||||
|     SEGGER_RTT_LOCK(); | ||||
|     pDown = &pRTTCB->aDown[BufferIndex]; | ||||
| @@ -1930,7 +1930,7 @@ int SEGGER_RTT_SetTerminal (unsigned char TerminalId) { | ||||
|   ac[0] = 0xFFu; | ||||
|   if (TerminalId < sizeof(_aTerminalId)) { // We only support a certain number of channels | ||||
|     ac[1] = _aTerminalId[TerminalId]; | ||||
|     pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|     pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|     SEGGER_RTT_LOCK();                     // Lock to make sure that no other task is writing into buffer, while we are and number of free bytes in buffer does not change downwards after checking and before writing | ||||
|     if ((pRing->Flags & SEGGER_RTT_MODE_MASK) == SEGGER_RTT_MODE_BLOCK_IF_FIFO_FULL) { | ||||
|       _ActiveTerminal = TerminalId; | ||||
| @@ -1982,7 +1982,7 @@ int SEGGER_RTT_TerminalOut (unsigned char TerminalId, const char* s) { | ||||
|     // | ||||
|     // Get "to-host" ring buffer. | ||||
|     // | ||||
|     pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|     pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[0] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|     // | ||||
|     // Need to be able to change terminal, write data, change back. | ||||
|     // Compute the fixed and variable sizes. | ||||
| @@ -2059,7 +2059,7 @@ int SEGGER_RTT_TerminalOut (unsigned char TerminalId, const char* s) { | ||||
| unsigned SEGGER_RTT_GetAvailWriteSpace (unsigned BufferIndex) { | ||||
|   SEGGER_RTT_BUFFER_UP* pRing; | ||||
|  | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRing = (SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[BufferIndex] + SEGGER_RTT_UNCACHED_OFF);  // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   return _GetAvailWriteSpace(pRing); | ||||
| } | ||||
|  | ||||
| @@ -2086,7 +2086,7 @@ unsigned SEGGER_RTT_GetBytesInBuffer(unsigned BufferIndex) { | ||||
|   // Avoid warnings regarding volatile access order.  It's not a problem | ||||
|   // in this case, but dampen compiler enthusiasm. | ||||
|   // | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((unsigned char*)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   pRTTCB = (volatile SEGGER_RTT_CB*)((uintptr_t)&_SEGGER_RTT + SEGGER_RTT_UNCACHED_OFF);  // Access RTTCB uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|   RdOff = pRTTCB->aUp[BufferIndex].RdOff; | ||||
|   WrOff = pRTTCB->aUp[BufferIndex].WrOff; | ||||
|   if (RdOff <= WrOff) { | ||||
|   | ||||
| @@ -91,6 +91,10 @@ Revision: $Rev: 25842 $ | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #elif (defined(__ARM_ARCH_8_1M_MAIN__))       // Cortex-M85 | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #else | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 0 | ||||
|     #endif | ||||
| @@ -121,6 +125,10 @@ Revision: $Rev: 25842 $ | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #elif (defined __ARM_ARCH_8_1M_MAIN__)        // Cortex-M85 | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #elif ((defined __ARM_ARCH_7A__) || (defined __ARM_ARCH_7R__))  // Cortex-A/R 32-bit ARMv7-A/R | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
| @@ -147,6 +155,10 @@ Revision: $Rev: 25842 $ | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #elif (defined __ARM_ARCH_8_1M_MAIN__)        // Cortex-M85 | ||||
|       #define _CORE_HAS_RTT_ASM_SUPPORT 1 | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
|     #elif ((defined __ARM_ARCH_7A__) || (defined __ARM_ARCH_7R__))  // Cortex-A/R 32-bit ARMv7-A/R | ||||
|       #define _CORE_NEEDS_DMB           1 | ||||
|       #define RTT__DMB() __asm volatile ("dmb\n" : : :); | ||||
| @@ -262,6 +274,7 @@ Revision: $Rev: 25842 $ | ||||
| #ifndef SEGGER_RTT_ASM  // defined when SEGGER_RTT.h is included from assembly file | ||||
| #include <stdlib.h> | ||||
| #include <stdarg.h> | ||||
| #include <stdint.h> | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| @@ -381,7 +394,7 @@ unsigned     SEGGER_RTT_GetBytesInBuffer        (unsigned BufferIndex); | ||||
| // | ||||
| // Function macro for performance optimization | ||||
| // | ||||
| #define      SEGGER_RTT_HASDATA(n)       (((SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[n] + SEGGER_RTT_UNCACHED_OFF))->WrOff - ((SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[n] + SEGGER_RTT_UNCACHED_OFF))->RdOff) | ||||
| #define      SEGGER_RTT_HASDATA(n)       (((SEGGER_RTT_BUFFER_DOWN*)((uintptr_t)&_SEGGER_RTT.aDown[n] + SEGGER_RTT_UNCACHED_OFF))->WrOff - ((SEGGER_RTT_BUFFER_DOWN*)((char*)&_SEGGER_RTT.aDown[n] + SEGGER_RTT_UNCACHED_OFF))->RdOff) | ||||
|  | ||||
| #if RTT_USE_ASM | ||||
|   #define SEGGER_RTT_WriteSkipNoLock  SEGGER_RTT_ASM_WriteSkipNoLock | ||||
| @@ -398,7 +411,7 @@ unsigned     SEGGER_RTT_ReadUpBufferNoLock      (unsigned BufferIndex, void* pDa | ||||
| unsigned     SEGGER_RTT_WriteDownBuffer         (unsigned BufferIndex, const void* pBuffer, unsigned NumBytes); | ||||
| unsigned     SEGGER_RTT_WriteDownBufferNoLock   (unsigned BufferIndex, const void* pBuffer, unsigned NumBytes); | ||||
|  | ||||
| #define      SEGGER_RTT_HASDATA_UP(n)    (((SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[n] + SEGGER_RTT_UNCACHED_OFF))->WrOff - ((SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[n] + SEGGER_RTT_UNCACHED_OFF))->RdOff)   // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
| #define      SEGGER_RTT_HASDATA_UP(n)    (((SEGGER_RTT_BUFFER_UP*)((uintptr_t)&_SEGGER_RTT.aUp[n] + SEGGER_RTT_UNCACHED_OFF))->WrOff - ((SEGGER_RTT_BUFFER_UP*)((char*)&_SEGGER_RTT.aUp[n] + SEGGER_RTT_UNCACHED_OFF))->RdOff)   // Access uncached to make sure we see changes made by the J-Link side and all of our changes go into HW directly | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
|   | ||||
							
								
								
									
										500
									
								
								lib/SEGGER_RTT/RTT/SEGGER_RTT_printf.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										500
									
								
								lib/SEGGER_RTT/RTT/SEGGER_RTT_printf.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,500 @@ | ||||
| /********************************************************************* | ||||
| *                    SEGGER Microcontroller GmbH                     * | ||||
| *                        The Embedded Experts                        * | ||||
| ********************************************************************** | ||||
| *                                                                    * | ||||
| *            (c) 1995 - 2019 SEGGER Microcontroller GmbH             * | ||||
| *                                                                    * | ||||
| *       www.segger.com     Support: support@segger.com               * | ||||
| *                                                                    * | ||||
| ********************************************************************** | ||||
| *                                                                    * | ||||
| *       SEGGER RTT * Real Time Transfer for embedded targets         * | ||||
| *                                                                    * | ||||
| ********************************************************************** | ||||
| *                                                                    * | ||||
| * 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 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.                                                            * | ||||
| *                                                                    * | ||||
| ********************************************************************** | ||||
| ---------------------------END-OF-HEADER------------------------------ | ||||
| File    : SEGGER_RTT_printf.c | ||||
| Purpose : Replacement for printf to write formatted data via RTT | ||||
| Revision: $Rev: 17697 $ | ||||
| ---------------------------------------------------------------------- | ||||
| */ | ||||
| #include "SEGGER_RTT.h" | ||||
| #include "SEGGER_RTT_Conf.h" | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       Defines, configurable | ||||
| * | ||||
| ********************************************************************** | ||||
| */ | ||||
|  | ||||
| #ifndef SEGGER_RTT_PRINTF_BUFFER_SIZE | ||||
|   #define SEGGER_RTT_PRINTF_BUFFER_SIZE (64) | ||||
| #endif | ||||
|  | ||||
| #include <stdlib.h> | ||||
| #include <stdarg.h> | ||||
|  | ||||
|  | ||||
| #define FORMAT_FLAG_LEFT_JUSTIFY   (1u << 0) | ||||
| #define FORMAT_FLAG_PAD_ZERO       (1u << 1) | ||||
| #define FORMAT_FLAG_PRINT_SIGN     (1u << 2) | ||||
| #define FORMAT_FLAG_ALTERNATE      (1u << 3) | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       Types | ||||
| * | ||||
| ********************************************************************** | ||||
| */ | ||||
|  | ||||
| typedef struct { | ||||
|   char*     pBuffer; | ||||
|   unsigned  BufferSize; | ||||
|   unsigned  Cnt; | ||||
|  | ||||
|   int   ReturnValue; | ||||
|  | ||||
|   unsigned RTTBufferIndex; | ||||
| } SEGGER_RTT_PRINTF_DESC; | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       Function prototypes | ||||
| * | ||||
| ********************************************************************** | ||||
| */ | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       Static code | ||||
| * | ||||
| ********************************************************************** | ||||
| */ | ||||
| /********************************************************************* | ||||
| * | ||||
| *       _StoreChar | ||||
| */ | ||||
| static void _StoreChar(SEGGER_RTT_PRINTF_DESC * p, char c) { | ||||
|   unsigned Cnt; | ||||
|  | ||||
|   Cnt = p->Cnt; | ||||
|   if ((Cnt + 1u) <= p->BufferSize) { | ||||
|     *(p->pBuffer + Cnt) = c; | ||||
|     p->Cnt = Cnt + 1u; | ||||
|     p->ReturnValue++; | ||||
|   } | ||||
|   // | ||||
|   // Write part of string, when the buffer is full | ||||
|   // | ||||
|   if (p->Cnt == p->BufferSize) { | ||||
|     if (SEGGER_RTT_Write(p->RTTBufferIndex, p->pBuffer, p->Cnt) != p->Cnt) { | ||||
|       p->ReturnValue = -1; | ||||
|     } else { | ||||
|       p->Cnt = 0u; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       _PrintUnsigned | ||||
| */ | ||||
| static void _PrintUnsigned(SEGGER_RTT_PRINTF_DESC * pBufferDesc, unsigned v, unsigned Base, unsigned NumDigits, unsigned FieldWidth, unsigned FormatFlags) { | ||||
|   static const char _aV2C[16] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' }; | ||||
|   unsigned Div; | ||||
|   unsigned Digit; | ||||
|   unsigned Number; | ||||
|   unsigned Width; | ||||
|   char c; | ||||
|  | ||||
|   Number = v; | ||||
|   Digit = 1u; | ||||
|   // | ||||
|   // Get actual field width | ||||
|   // | ||||
|   Width = 1u; | ||||
|   while (Number >= Base) { | ||||
|     Number = (Number / Base); | ||||
|     Width++; | ||||
|   } | ||||
|   if (NumDigits > Width) { | ||||
|     Width = NumDigits; | ||||
|   } | ||||
|   // | ||||
|   // Print leading chars if necessary | ||||
|   // | ||||
|   if ((FormatFlags & FORMAT_FLAG_LEFT_JUSTIFY) == 0u) { | ||||
|     if (FieldWidth != 0u) { | ||||
|       if (((FormatFlags & FORMAT_FLAG_PAD_ZERO) == FORMAT_FLAG_PAD_ZERO) && (NumDigits == 0u)) { | ||||
|         c = '0'; | ||||
|       } else { | ||||
|         c = ' '; | ||||
|       } | ||||
|       while ((FieldWidth != 0u) && (Width < FieldWidth)) { | ||||
|         FieldWidth--; | ||||
|         _StoreChar(pBufferDesc, c); | ||||
|         if (pBufferDesc->ReturnValue < 0) { | ||||
|           break; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   if (pBufferDesc->ReturnValue >= 0) { | ||||
|     // | ||||
|     // Compute Digit. | ||||
|     // Loop until Digit has the value of the highest digit required. | ||||
|     // Example: If the output is 345 (Base 10), loop 2 times until Digit is 100. | ||||
|     // | ||||
|     while (1) { | ||||
|       if (NumDigits > 1u) {       // User specified a min number of digits to print? => Make sure we loop at least that often, before checking anything else (> 1 check avoids problems with NumDigits being signed / unsigned) | ||||
|         NumDigits--; | ||||
|       } else { | ||||
|         Div = v / Digit; | ||||
|         if (Div < Base) {        // Is our divider big enough to extract the highest digit from value? => Done | ||||
|           break; | ||||
|         } | ||||
|       } | ||||
|       Digit *= Base; | ||||
|     } | ||||
|     // | ||||
|     // Output digits | ||||
|     // | ||||
|     do { | ||||
|       Div = v / Digit; | ||||
|       v -= Div * Digit; | ||||
|       _StoreChar(pBufferDesc, _aV2C[Div]); | ||||
|       if (pBufferDesc->ReturnValue < 0) { | ||||
|         break; | ||||
|       } | ||||
|       Digit /= Base; | ||||
|     } while (Digit); | ||||
|     // | ||||
|     // Print trailing spaces if necessary | ||||
|     // | ||||
|     if ((FormatFlags & FORMAT_FLAG_LEFT_JUSTIFY) == FORMAT_FLAG_LEFT_JUSTIFY) { | ||||
|       if (FieldWidth != 0u) { | ||||
|         while ((FieldWidth != 0u) && (Width < FieldWidth)) { | ||||
|           FieldWidth--; | ||||
|           _StoreChar(pBufferDesc, ' '); | ||||
|           if (pBufferDesc->ReturnValue < 0) { | ||||
|             break; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       _PrintInt | ||||
| */ | ||||
| static void _PrintInt(SEGGER_RTT_PRINTF_DESC * pBufferDesc, int v, unsigned Base, unsigned NumDigits, unsigned FieldWidth, unsigned FormatFlags) { | ||||
|   unsigned Width; | ||||
|   int Number; | ||||
|  | ||||
|   Number = (v < 0) ? -v : v; | ||||
|  | ||||
|   // | ||||
|   // Get actual field width | ||||
|   // | ||||
|   Width = 1u; | ||||
|   while (Number >= (int)Base) { | ||||
|     Number = (Number / (int)Base); | ||||
|     Width++; | ||||
|   } | ||||
|   if (NumDigits > Width) { | ||||
|     Width = NumDigits; | ||||
|   } | ||||
|   if ((FieldWidth > 0u) && ((v < 0) || ((FormatFlags & FORMAT_FLAG_PRINT_SIGN) == FORMAT_FLAG_PRINT_SIGN))) { | ||||
|     FieldWidth--; | ||||
|   } | ||||
|  | ||||
|   // | ||||
|   // Print leading spaces if necessary | ||||
|   // | ||||
|   if ((((FormatFlags & FORMAT_FLAG_PAD_ZERO) == 0u) || (NumDigits != 0u)) && ((FormatFlags & FORMAT_FLAG_LEFT_JUSTIFY) == 0u)) { | ||||
|     if (FieldWidth != 0u) { | ||||
|       while ((FieldWidth != 0u) && (Width < FieldWidth)) { | ||||
|         FieldWidth--; | ||||
|         _StoreChar(pBufferDesc, ' '); | ||||
|         if (pBufferDesc->ReturnValue < 0) { | ||||
|           break; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|   // | ||||
|   // Print sign if necessary | ||||
|   // | ||||
|   if (pBufferDesc->ReturnValue >= 0) { | ||||
|     if (v < 0) { | ||||
|       v = -v; | ||||
|       _StoreChar(pBufferDesc, '-'); | ||||
|     } else if ((FormatFlags & FORMAT_FLAG_PRINT_SIGN) == FORMAT_FLAG_PRINT_SIGN) { | ||||
|       _StoreChar(pBufferDesc, '+'); | ||||
|     } else { | ||||
|  | ||||
|     } | ||||
|     if (pBufferDesc->ReturnValue >= 0) { | ||||
|       // | ||||
|       // Print leading zeros if necessary | ||||
|       // | ||||
|       if (((FormatFlags & FORMAT_FLAG_PAD_ZERO) == FORMAT_FLAG_PAD_ZERO) && ((FormatFlags & FORMAT_FLAG_LEFT_JUSTIFY) == 0u) && (NumDigits == 0u)) { | ||||
|         if (FieldWidth != 0u) { | ||||
|           while ((FieldWidth != 0u) && (Width < FieldWidth)) { | ||||
|             FieldWidth--; | ||||
|             _StoreChar(pBufferDesc, '0'); | ||||
|             if (pBufferDesc->ReturnValue < 0) { | ||||
|               break; | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|       if (pBufferDesc->ReturnValue >= 0) { | ||||
|         // | ||||
|         // Print number without sign | ||||
|         // | ||||
|         _PrintUnsigned(pBufferDesc, (unsigned)v, Base, NumDigits, FieldWidth, FormatFlags); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       Public code | ||||
| * | ||||
| ********************************************************************** | ||||
| */ | ||||
| /********************************************************************* | ||||
| * | ||||
| *       SEGGER_RTT_vprintf | ||||
| * | ||||
| *  Function description | ||||
| *    Stores a formatted string in SEGGER RTT control block. | ||||
| *    This data is read by the host. | ||||
| * | ||||
| *  Parameters | ||||
| *    BufferIndex  Index of "Up"-buffer to be used. (e.g. 0 for "Terminal") | ||||
| *    sFormat      Pointer to format string | ||||
| *    pParamList   Pointer to the list of arguments for the format string | ||||
| * | ||||
| *  Return values | ||||
| *    >= 0:  Number of bytes which have been stored in the "Up"-buffer. | ||||
| *     < 0:  Error | ||||
| */ | ||||
| int SEGGER_RTT_vprintf(unsigned BufferIndex, const char * sFormat, va_list * pParamList) { | ||||
|   char c; | ||||
|   SEGGER_RTT_PRINTF_DESC BufferDesc; | ||||
|   int v; | ||||
|   unsigned NumDigits; | ||||
|   unsigned FormatFlags; | ||||
|   unsigned FieldWidth; | ||||
|   char acBuffer[SEGGER_RTT_PRINTF_BUFFER_SIZE]; | ||||
|  | ||||
|   BufferDesc.pBuffer        = acBuffer; | ||||
|   BufferDesc.BufferSize     = SEGGER_RTT_PRINTF_BUFFER_SIZE; | ||||
|   BufferDesc.Cnt            = 0u; | ||||
|   BufferDesc.RTTBufferIndex = BufferIndex; | ||||
|   BufferDesc.ReturnValue    = 0; | ||||
|  | ||||
|   do { | ||||
|     c = *sFormat; | ||||
|     sFormat++; | ||||
|     if (c == 0u) { | ||||
|       break; | ||||
|     } | ||||
|     if (c == '%') { | ||||
|       // | ||||
|       // Filter out flags | ||||
|       // | ||||
|       FormatFlags = 0u; | ||||
|       v = 1; | ||||
|       do { | ||||
|         c = *sFormat; | ||||
|         switch (c) { | ||||
|         case '-': FormatFlags |= FORMAT_FLAG_LEFT_JUSTIFY; sFormat++; break; | ||||
|         case '0': FormatFlags |= FORMAT_FLAG_PAD_ZERO;     sFormat++; break; | ||||
|         case '+': FormatFlags |= FORMAT_FLAG_PRINT_SIGN;   sFormat++; break; | ||||
|         case '#': FormatFlags |= FORMAT_FLAG_ALTERNATE;    sFormat++; break; | ||||
|         default:  v = 0; break; | ||||
|         } | ||||
|       } while (v); | ||||
|       // | ||||
|       // filter out field with | ||||
|       // | ||||
|       FieldWidth = 0u; | ||||
|       do { | ||||
|         c = *sFormat; | ||||
|         if ((c < '0') || (c > '9')) { | ||||
|           break; | ||||
|         } | ||||
|         sFormat++; | ||||
|         FieldWidth = (FieldWidth * 10u) + ((unsigned)c - '0'); | ||||
|       } while (1); | ||||
|  | ||||
|       // | ||||
|       // Filter out precision (number of digits to display) | ||||
|       // | ||||
|       NumDigits = 0u; | ||||
|       c = *sFormat; | ||||
|       if (c == '.') { | ||||
|         sFormat++; | ||||
|         do { | ||||
|           c = *sFormat; | ||||
|           if ((c < '0') || (c > '9')) { | ||||
|             break; | ||||
|           } | ||||
|           sFormat++; | ||||
|           NumDigits = NumDigits * 10u + ((unsigned)c - '0'); | ||||
|         } while (1); | ||||
|       } | ||||
|       // | ||||
|       // Filter out length modifier | ||||
|       // | ||||
|       c = *sFormat; | ||||
|       do { | ||||
|         if ((c == 'l') || (c == 'h')) { | ||||
|           sFormat++; | ||||
|           c = *sFormat; | ||||
|         } else { | ||||
|           break; | ||||
|         } | ||||
|       } while (1); | ||||
|       // | ||||
|       // Handle specifiers | ||||
|       // | ||||
|       switch (c) { | ||||
|       case 'c': { | ||||
|         char c0; | ||||
|         v = va_arg(*pParamList, int); | ||||
|         c0 = (char)v; | ||||
|         _StoreChar(&BufferDesc, c0); | ||||
|         break; | ||||
|       } | ||||
|       case 'd': | ||||
|         v = va_arg(*pParamList, int); | ||||
|         _PrintInt(&BufferDesc, v, 10u, NumDigits, FieldWidth, FormatFlags); | ||||
|         break; | ||||
|       case 'u': | ||||
|         v = va_arg(*pParamList, int); | ||||
|         _PrintUnsigned(&BufferDesc, (unsigned)v, 10u, NumDigits, FieldWidth, FormatFlags); | ||||
|         break; | ||||
|       case 'x': | ||||
|       case 'X': | ||||
|         v = va_arg(*pParamList, int); | ||||
|         _PrintUnsigned(&BufferDesc, (unsigned)v, 16u, NumDigits, FieldWidth, FormatFlags); | ||||
|         break; | ||||
|       case 's': | ||||
|         { | ||||
|           const char * s = va_arg(*pParamList, const char *); | ||||
|           do { | ||||
|             c = *s; | ||||
|             s++; | ||||
|             if (c == '\0') { | ||||
|               break; | ||||
|             } | ||||
|            _StoreChar(&BufferDesc, c); | ||||
|           } while (BufferDesc.ReturnValue >= 0); | ||||
|         } | ||||
|         break; | ||||
|       case 'p': | ||||
|         v = va_arg(*pParamList, int); | ||||
|         _PrintUnsigned(&BufferDesc, (unsigned)v, 16u, 8u, 8u, 0u); | ||||
|         break; | ||||
|       case '%': | ||||
|         _StoreChar(&BufferDesc, '%'); | ||||
|         break; | ||||
|       default: | ||||
|         break; | ||||
|       } | ||||
|       sFormat++; | ||||
|     } else { | ||||
|       _StoreChar(&BufferDesc, c); | ||||
|     } | ||||
|   } while (BufferDesc.ReturnValue >= 0); | ||||
|  | ||||
|   if (BufferDesc.ReturnValue > 0) { | ||||
|     // | ||||
|     // Write remaining data, if any | ||||
|     // | ||||
|     if (BufferDesc.Cnt != 0u) { | ||||
|       SEGGER_RTT_Write(BufferIndex, acBuffer, BufferDesc.Cnt); | ||||
|     } | ||||
|     BufferDesc.ReturnValue += (int)BufferDesc.Cnt; | ||||
|   } | ||||
|   return BufferDesc.ReturnValue; | ||||
| } | ||||
|  | ||||
| /********************************************************************* | ||||
| * | ||||
| *       SEGGER_RTT_printf | ||||
| * | ||||
| *  Function description | ||||
| *    Stores a formatted string in SEGGER RTT control block. | ||||
| *    This data is read by the host. | ||||
| * | ||||
| *  Parameters | ||||
| *    BufferIndex  Index of "Up"-buffer to be used. (e.g. 0 for "Terminal") | ||||
| *    sFormat      Pointer to format string, followed by the arguments for conversion | ||||
| * | ||||
| *  Return values | ||||
| *    >= 0:  Number of bytes which have been stored in the "Up"-buffer. | ||||
| *     < 0:  Error | ||||
| * | ||||
| *  Notes | ||||
| *    (1) Conversion specifications have following syntax: | ||||
| *          %[flags][FieldWidth][.Precision]ConversionSpecifier | ||||
| *    (2) Supported flags: | ||||
| *          -: Left justify within the field width | ||||
| *          +: Always print sign extension for signed conversions | ||||
| *          0: Pad with 0 instead of spaces. Ignored when using '-'-flag or precision | ||||
| *        Supported conversion specifiers: | ||||
| *          c: Print the argument as one char | ||||
| *          d: Print the argument as a signed integer | ||||
| *          u: Print the argument as an unsigned integer | ||||
| *          x: Print the argument as an hexadecimal integer | ||||
| *          s: Print the string pointed to by the argument | ||||
| *          p: Print the argument as an 8-digit hexadecimal integer. (Argument shall be a pointer to void.) | ||||
| */ | ||||
| int SEGGER_RTT_printf(unsigned BufferIndex, const char * sFormat, ...) { | ||||
|   int r; | ||||
|   va_list ParamList; | ||||
|  | ||||
|   va_start(ParamList, sFormat); | ||||
|   r = SEGGER_RTT_vprintf(BufferIndex, sFormat, &ParamList); | ||||
|   va_end(ParamList); | ||||
|   return r; | ||||
| } | ||||
| /*************************** End of file ****************************/ | ||||
| @@ -33,7 +33,7 @@ function(add_tinyusb TARGET) | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/class/msc/msc_host.c | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/class/vendor/vendor_host.c | ||||
|     # typec | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/typec/utcd.c | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR}/typec/usbc.c | ||||
|     ) | ||||
|   target_include_directories(${TARGET} PUBLIC | ||||
|     ${CMAKE_CURRENT_FUNCTION_LIST_DIR} | ||||
|   | ||||
| @@ -42,7 +42,7 @@ | ||||
|  | ||||
| //------------- TypeC -------------// | ||||
| #if CFG_TUC_ENABLED | ||||
|   #include "typec/utcd.h" | ||||
|   #include "typec/usbc.h" | ||||
| #endif | ||||
|  | ||||
| //------------- HOST -------------// | ||||
|   | ||||
| @@ -29,24 +29,24 @@ | ||||
| #if CFG_TUC_ENABLED | ||||
| 
 | ||||
| #include "tcd.h" | ||||
| #include "utcd.h" | ||||
| #include "usbc.h" | ||||
| 
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| //
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| 
 | ||||
| // Debug level of USBD
 | ||||
| #define UTCD_DEBUG   2 | ||||
| #define TU_LOG_UTCD(...)   TU_LOG(UTCD_DEBUG, __VA_ARGS__) | ||||
| #define USBC_DEBUG   2 | ||||
| #define TU_LOG_USBC(...)   TU_LOG(USBC_DEBUG, __VA_ARGS__) | ||||
| 
 | ||||
| // Event queue
 | ||||
| // utcd_int_set() is used as mutex in OS NONE config
 | ||||
| void utcd_int_set(bool enabled); | ||||
| OSAL_QUEUE_DEF(utcd_int_set, _utcd_qdef, CFG_TUC_TASK_QUEUE_SZ, tcd_event_t); | ||||
| tu_static osal_queue_t _utcd_q; | ||||
| // usbc_int_set() is used as mutex in OS NONE config
 | ||||
| void usbc_int_set(bool enabled); | ||||
| OSAL_QUEUE_DEF(usbc_int_set, _usbc_qdef, CFG_TUC_TASK_QUEUE_SZ, tcd_event_t); | ||||
| tu_static osal_queue_t _usbc_q; | ||||
| 
 | ||||
| // if stack is initialized
 | ||||
| static bool _utcd_inited = false; | ||||
| static bool _usbc_inited = false; | ||||
| 
 | ||||
| // if port is initialized
 | ||||
| static bool _port_inited[TUP_TYPEC_RHPORTS_NUM]; | ||||
| @@ -55,7 +55,7 @@ static bool _port_inited[TUP_TYPEC_RHPORTS_NUM]; | ||||
| static uint8_t _rx_buf[64] TU_ATTR_ALIGNED(4); | ||||
| static uint8_t _tx_buf[64] TU_ATTR_ALIGNED(4); | ||||
| 
 | ||||
| bool utcd_msg_send(uint8_t rhport, pd_header_t const* header, void const* data); | ||||
| bool usbc_msg_send(uint8_t rhport, pd_header_t const* header, void const* data); | ||||
| bool parse_msg_data(uint8_t rhport, pd_header_t const* header, uint8_t const* dobj, uint8_t const* p_end); | ||||
| bool parse_msg_control(uint8_t rhport, pd_header_t const* header); | ||||
| 
 | ||||
| @@ -63,18 +63,18 @@ bool parse_msg_control(uint8_t rhport, pd_header_t const* header); | ||||
| //
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| bool tuc_inited(uint8_t rhport) { | ||||
|   return _utcd_inited && _port_inited[rhport]; | ||||
|   return _usbc_inited && _port_inited[rhport]; | ||||
| } | ||||
| 
 | ||||
| bool tuc_init(uint8_t rhport, uint32_t port_type) { | ||||
|   // Initialize stack
 | ||||
|   if (!_utcd_inited) { | ||||
|   if (!_usbc_inited) { | ||||
|     tu_memclr(_port_inited, sizeof(_port_inited)); | ||||
| 
 | ||||
|     _utcd_q = osal_queue_create(&_utcd_qdef); | ||||
|     TU_ASSERT(_utcd_q != NULL); | ||||
|     _usbc_q = osal_queue_create(&_usbc_qdef); | ||||
|     TU_ASSERT(_usbc_q != NULL); | ||||
| 
 | ||||
|     _utcd_inited = true; | ||||
|     _usbc_inited = true; | ||||
|   } | ||||
| 
 | ||||
|   // skip if port already initialized
 | ||||
| @@ -82,8 +82,8 @@ bool tuc_init(uint8_t rhport, uint32_t port_type) { | ||||
|     return true; | ||||
|   } | ||||
| 
 | ||||
|   TU_LOG_UTCD("UTCD init on port %u\r\n", rhport); | ||||
|   TU_LOG_INT(UTCD_DEBUG, sizeof(tcd_event_t)); | ||||
|   TU_LOG_USBC("USBC init on port %u\r\n", rhport); | ||||
|   TU_LOG_INT(USBC_DEBUG, sizeof(tcd_event_t)); | ||||
| 
 | ||||
|   TU_ASSERT(tcd_init(rhport, port_type)); | ||||
|   tcd_int_enable(rhport); | ||||
| @@ -96,12 +96,12 @@ void tuc_task_ext(uint32_t timeout_ms, bool in_isr) { | ||||
|   (void) in_isr; // not implemented yet
 | ||||
| 
 | ||||
|   // Skip if stack is not initialized
 | ||||
|   if (!_utcd_inited) return; | ||||
|   if (!_usbc_inited) return; | ||||
| 
 | ||||
|   // Loop until there is no more events in the queue
 | ||||
|   while (1) { | ||||
|     tcd_event_t event; | ||||
|     if (!osal_queue_receive(_utcd_q, &event, timeout_ms)) return; | ||||
|     if (!osal_queue_receive(_usbc_q, &event, timeout_ms)) return; | ||||
| 
 | ||||
|     switch (event.event_id) { | ||||
|       case TCD_EVENT_CC_CHANGED: | ||||
| @@ -155,7 +155,7 @@ bool parse_msg_control(uint8_t rhport, pd_header_t const* header) { | ||||
| //
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| 
 | ||||
| bool utcd_msg_send(uint8_t rhport, pd_header_t const* header, void const* data) { | ||||
| bool usbc_msg_send(uint8_t rhport, pd_header_t const* header, void const* data) { | ||||
|   // copy header
 | ||||
|   memcpy(_tx_buf, header, sizeof(pd_header_t)); | ||||
| 
 | ||||
| @@ -179,7 +179,7 @@ bool tuc_msg_request(uint8_t rhport, void const* rdo) { | ||||
|       .extended = 0, | ||||
|   }; | ||||
| 
 | ||||
|   return utcd_msg_send(rhport, &header, rdo); | ||||
|   return usbc_msg_send(rhport, &header, rdo); | ||||
| } | ||||
| 
 | ||||
| void tcd_event_handler(tcd_event_t const * event, bool in_isr) { | ||||
| @@ -197,13 +197,13 @@ void tcd_event_handler(tcd_event_t const * event, bool in_isr) { | ||||
|     default: break; | ||||
|   } | ||||
| 
 | ||||
|   osal_queue_send(_utcd_q, event, in_isr); | ||||
|   osal_queue_send(_usbc_q, event, in_isr); | ||||
| } | ||||
| 
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| //
 | ||||
| //--------------------------------------------------------------------+
 | ||||
| void utcd_int_set(bool enabled) { | ||||
| void usbc_int_set(bool enabled) { | ||||
|   // Disable all controllers since they shared the same event queue
 | ||||
|   for (uint8_t p = 0; p < TUP_TYPEC_RHPORTS_NUM; p++) { | ||||
|     if ( _port_inited[p] ) { | ||||
		Reference in New Issue
	
	Block a user
	 Ha Thach
					Ha Thach