Trackdown the exceptions in MQX

取消
显示结果 
显示  仅  | 搜索替代 
您的意思是: 

Trackdown the exceptions in MQX

Trackdown the exceptions in MQX

When working on Cortex-M4 platform, an exception which has not been expected (an interrupt without ISR, an access to an illegal address, etc).

The code below shows how to implement it.

static void expt_frm_dump(pointer ext_frm_ptr)

{

  static char *expt_name[] = {

    "None",

    "Reset",

    "NMI",

    "HardFault",

    "MemManage",

    "BusFault",

    "UsageFault",

    "Rsvd",

    "Rsvd",

    "Rsvd",

    "SVCall",

    "Debug Monitor",

    "Rsvd",

    "PendSV",

    "SysTick"

  };

  uint_32 excpt_num = __get_PSR() & 0x1FF;

  printf("Opps, bad thing happened.\n");

  if(excpt_num < 16){

    printf("The exception [%s] invoked in TASK 0x%x\n",

         expt_name[excpt_num] , _task_get_id());

    printf("Dump the exception frame as :\n");

    printf("R0:\t0x%08x\n", *((uint_32 *)ext_frm_ptr));

    printf("R1:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 1));

    printf("R2:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 2));

    printf("R3:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 3));

    printf("R12:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 4));

    printf("LR:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 5));

    printf("PC:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 6));

    printf("PSR:\t0x%08x\n", *((uint_32 *)ext_frm_ptr + 7));

  }else{

    printf("The external interrupt %d occured while no handler to serve it.\n");

  }

}

void  task_exception_handler(_mqx_uint para, pointer stack_ptr)

{

    pointer expt_frm_ptr = (pointer)__get_PSP();

    expt_frm_dump(expt_frm_ptr);

}

void test_task(unsigned long para)

{

  unsigned int *p_bad = (unsigned int *)0;

  printf("Install the _int_exception_isr to replace the _int_default_isr\n");

  _int_install_exception_isr();

  /* Set the exception handler of the task */

  _task_set_exception_handler(_task_get_id(), task_exception_handler);

  *p_bad = 0;     // an access to address 0

   _task_block();

}

%3CLINGO-SUB%20id%3D%22lingo-sub-1122087%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%E8%BF%BD%E8%B8%AA%20MQX%20%E4%B8%AD%E7%9A%84%E5%BC%82%E5%B8%B8%3C%2FLINGO-SUB%3E%3CLINGO-BODY%20id%3D%22lingo-body-1122087%22%20slang%3D%22en-US%22%20mode%3D%22CREATE%22%3E%26lt%3Bmeta%20http-equiv%3D%22Content-Type%22%20content%3D%22text%2Fhtml%3B%20charset%3Dutf-8%22%20%2F%26gt%3B%0A%3CP%3E%E5%9C%A8%20Cortex-M4%20%E5%B9%B3%E5%8F%B0%E4%B8%8A%E5%B7%A5%E4%BD%9C%E6%97%B6%EF%BC%8C%E5%87%BA%E7%8E%B0%E6%9C%AA%E9%A2%84%E6%96%99%E5%88%B0%E7%9A%84%E5%BC%82%E5%B8%B8%EF%BC%88%E6%B2%A1%E6%9C%89%20ISR%20%E7%9A%84%E4%B8%AD%E6%96%AD%E3%80%81%E8%AE%BF%E9%97%AE%E9%9D%9E%E6%B3%95%E5%9C%B0%E5%9D%80%E7%AD%89%EF%BC%89%E3%80%82%3C%2FP%3E%3CP%3E%E4%B8%8B%E9%9D%A2%E7%9A%84%E4%BB%A3%E7%A0%81%E5%B1%95%E7%A4%BA%E4%BA%86%E5%A6%82%E4%BD%95%E5%AE%9E%E7%8E%B0%E5%AE%83%E3%80%82%3C%2FP%3E%3CP%3E%3C%2FP%3E%3CPRE%20__default_attr%3D%22c%2B%2B%22%20__jive_macro_name%3D%22code%22%20class%3D%22jive_text_macro%20_jivemacro_uid_13685271450596202%20jive_macro_code%22%20jivemacro_uid%3D%22_13685271450596202%22%20modifiedtitle%3D%22true%22%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E9%9D%99%E6%80%81%20void%20expt_frm_dump(%E6%8C%87%E9%92%88%20ext_frm_ptr)%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E9%9D%99%E6%80%81%E5%AD%97%E7%AC%A6%20*expt_name%5B%5D%20%3D%20%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9C%E6%B2%A1%E6%9C%89%E4%BB%BB%E4%BD%95%E2%80%9D%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9C%E9%87%8D%E7%BD%AE%E2%80%9D%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9CNMI%E2%80%9D%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9C%E7%A1%AC%E6%95%85%E9%9A%9C%E2%80%9D%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9C%E5%86%85%E5%AD%98%E7%AE%A1%E7%90%86%E2%80%9D%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9C%E6%80%BB%E7%BA%BF%E6%95%85%E9%9A%9C%E2%80%9D%EF%BC%8C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22UsageFault%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22Rsvd%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22Rsvd%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22Rsvd%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%22SVCall%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22Debug%20Monitor%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20%22Rsvd%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%22PendSV%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E2%80%9CSysTick%E2%80%9D%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%20%7D%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Euint_32%20excpt_num%20%3D%20__get_PSR()%20%26amp%3B%200x1FF%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22%E5%93%8E%E5%91%80%EF%BC%8C%E7%B3%9F%E7%B3%95%E7%9A%84%E4%BA%8B%E6%83%85%E5%8F%91%E7%94%9F%E4%BA%86%E3%80%82%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E5%A6%82%E6%9E%9C%EF%BC%88excpt_num%20%26lt%3B%2016%EF%BC%89%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22%E5%9C%A8%E4%BB%BB%E5%8A%A1%200x%25x%20%E4%B8%AD%E8%B0%83%E7%94%A8%E4%BA%86%E5%BC%82%E5%B8%B8%20%5B%25s%5D%5Cn%22%2C%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E4%BB%BB%E5%8A%A1%E5%90%8D%E7%A7%B0%5B%E4%BB%BB%E5%8A%A1%E7%BC%96%E5%8F%B7%5D%EF%BC%8C_task_get_id())%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22%E5%B0%86%E5%BC%82%E5%B8%B8%E6%A1%86%E6%9E%B6%E8%BD%AC%E5%82%A8%E4%B8%BA%3A%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22R0%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22R1%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%201))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22R2%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%202))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22R3%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%203))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22R12%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%204))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22LR%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%205))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22PC%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%206))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22PSR%3A%5Ct0x%2508x%5Cn%22%2C%20*((uint_32%20*)ext_frm_ptr%20%2B%207))%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%20%7Delse%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22%E5%8F%91%E7%94%9F%E5%A4%96%E9%83%A8%E4%B8%AD%E6%96%AD%20%25d%EF%BC%8C%E4%BD%86%E6%B2%A1%E6%9C%89%E5%A4%84%E7%90%86%E7%A8%8B%E5%BA%8F%E6%9D%A5%E5%A4%84%E7%90%86%E5%AE%83%E3%80%82%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%20%7D%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7D%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Evoid%26nbsp%3B%20task_exception_handler(_mqx_uint%20para%2C%20pointer%20stack_ptr)%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E6%8C%87%E9%92%88%20expt_frm_ptr%20%3D%20(%E6%8C%87%E9%92%88)__get_PSP()%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%26nbsp%3B%26nbsp%3B%20expt_frm_dump(expt_frm_ptr)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7D%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Evoid%20test_task%EF%BC%88%E6%97%A0%E7%AC%A6%E5%8F%B7%E9%95%BF%E5%8F%82%E6%95%B0%EF%BC%89%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%E6%97%A0%E7%AC%A6%E5%8F%B7%E6%95%B4%E6%95%B0*p_bad%20%3D%20(%E6%97%A0%E7%AC%A6%E5%8F%B7%E6%95%B4%E6%95%B0*)0%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3Eprintf(%22%E5%AE%89%E8%A3%85_int_exception_isr%E6%9D%A5%E6%9B%BF%E6%8D%A2_int_default_isr%5Cn%22)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E_int_install_exception_isr()%EF%BC%9B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%2F*%20%E8%AE%BE%E7%BD%AE%E4%BB%BB%E5%8A%A1%E7%9A%84%E5%BC%82%E5%B8%B8%E5%A4%84%E7%90%86%E7%A8%8B%E5%BA%8F%20*%2F%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%26nbsp%3B%20_task_set_exception_handler(_task_get_id()%2C%20task_exception_handler)%3B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E*p_bad%20%3D%200%3B%20%2F%2F%E8%AE%BF%E9%97%AE%E5%9C%B0%E5%9D%80%200%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E_task_block()%EF%BC%9B%3C%2FSPAN%3E%3C%2FP%3E%0A%3CP%20style%3D%22padding-left%3A%2030px%3B%22%3E%3CSPAN%20style%3D%22font-size%3A%208pt%3B%22%3E%7D%3C%2FSPAN%3E%3C%2FP%3E%0A%0A%0A%3C%2FPRE%3E%3C%2FLINGO-BODY%3E
无评分
版本历史
最后更新:
‎09-10-2020 02:53 AM
更新人: