2013-01-08 05:05:02 -08:00
|
|
|
/*
|
2018-10-15 01:35:07 +08:00
|
|
|
* Copyright (c) 2006-2018, RT-Thread Development Team
|
2013-01-08 05:05:02 -08:00
|
|
|
*
|
2018-10-15 01:35:07 +08:00
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
2013-01-08 05:05:02 -08:00
|
|
|
*
|
|
|
|
* Change Logs:
|
|
|
|
* Date Author Notes
|
|
|
|
* 2008-07-29 Bernard first version from QiuYi implementation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <rtthread.h>
|
|
|
|
|
|
|
|
#ifdef __GNUC__
|
|
|
|
/*
|
|
|
|
-->High Address,Stack Top
|
|
|
|
PC<-----|
|
|
|
|
LR |
|
|
|
|
IP |
|
|
|
|
FP |
|
|
|
|
...... |
|
|
|
|
PC<-| |
|
|
|
|
LR | |
|
|
|
|
IP | |
|
|
|
|
FP---|-- |
|
|
|
|
...... |
|
|
|
|
PC |
|
|
|
|
LR |
|
|
|
|
IP |
|
|
|
|
FP---
|
|
|
|
-->Low Address,Stack Bottom
|
|
|
|
*/
|
|
|
|
void rt_hw_backtrace(rt_uint32_t *fp, rt_uint32_t thread_entry)
|
|
|
|
{
|
|
|
|
rt_uint32_t i, pc, func_entry;
|
|
|
|
|
|
|
|
pc = *fp;
|
|
|
|
rt_kprintf("[0x%x]\n", pc-0xC);
|
|
|
|
|
|
|
|
for(i=0; i<10; i++)
|
|
|
|
{
|
|
|
|
fp = (rt_uint32_t *)*(fp - 3);
|
|
|
|
pc = *fp ;
|
|
|
|
|
|
|
|
func_entry = pc - 0xC;
|
|
|
|
|
|
|
|
if(func_entry <= 0x30000000) break;
|
|
|
|
|
2018-09-10 19:58:28 +08:00
|
|
|
if(func_entry == thread_entry)
|
2013-01-08 05:05:02 -08:00
|
|
|
{
|
|
|
|
rt_kprintf("EntryPoint:0x%x\n", func_entry);
|
|
|
|
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
rt_kprintf("[0x%x]\n", func_entry);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
void rt_hw_backtrace(rt_uint32_t *fp, rt_uint32_t thread_entry)
|
|
|
|
{
|
|
|
|
/* old compiler implementation */
|
|
|
|
}
|
|
|
|
#endif
|