FreeCalypso > hg > fc-magnetite
view src/cs/drivers/drv_app/spi/spi_process.c @ 695:530f71d65c20
uartfax.c: pull from Tourmaline (GTM900 RI output)
In addition to the primary intent of bringing in GTM900 RI output support,
pulling uartfax.c wholesale from Tourmaline also changes the initial_time
argument in the two NU_Create_Timer() calls from 0 to 1. This change
is required for the new version of Nucleus used in Tourmaline and Selenite
(and apparently also used by TI in LoCosto), and it is harmless (no effect)
for the original TCS211 version of Nucleus used in Magnetite.
The new philosophical model being adopted is that Tourmaline is our new
development head firmware, whereas Magnetite will now be maintained
similarly to how Linux maintainers treat stable kernels: changes will be
backported from Tourmaline if they are deemed appropriate for stable
modem firmware.
author | Mychaela Falconia <falcon@freecalypso.org> |
---|---|
date | Sat, 24 Oct 2020 17:33:10 +0000 |
parents | 945cf7f506b2 |
children |
line wrap: on
line source
/*****************************************************************************/ /* */ /* Name spi_process.c */ /* */ /* Function this file contains the spi_process function, used to */ /* handle messages received in the SPI mailbox, and used to */ /* access the ABB. It is called by the spi task core. */ /* */ /* Version 0.1 */ /* */ /* Date Modification */ /* ------------------------------------ */ /* 20/08/2000 Create */ /* */ /* Author */ /* */ /* (C) Copyright 2000 by Texas Instruments Incorporated, All Rights Reserved */ /*****************************************************************************/ #include "rvf/rvf_api.h" #include "spi/spi_api.h" #include "rvm/rvm_use_id_list.h" #include "spi/spi_process.h" #include "rv/rv_defined_swe.h" // for RVM_PWR_SWE //#ifndef _WINDOWS //#include "iq.h" //#endif /******************************************************************************* ** Function spi_process ** *******************************************************************************/ UINT8 spi_process(T_RV_HDR * msg_ptr) { UINT16 data ; // static UINT8 int_nb = 0; if(msg_ptr != NULL) { switch (msg_ptr->msg_id) { case ABB_EXT_IRQ_EVT: { /* Call to the low-level driver function : interrupt status register reading */ data = ABB_Read_Register_on_page(PAGE0, ITSTATREG); //#ifndef _WINDOWS // SW workaround to avoid an ABB interrupt occuring to early after the application start. // The first ABB interrupt is skipped. // if((int_nb == 0) && (data == ADCEND_IT_STS)) // { // int_nb++; /* Unmask keypad interrupt */ // IQ_Unmask(IQ_EXT); // } // else // { /* Callback function */ // if(msg_ptr->callback_func != NULL) // { // msg_ptr->callback_func(&data); // } // } //#else /* Callback function */ if(msg_ptr->callback_func != NULL) { msg_ptr->callback_func(&data); } //#endif rvf_free_buf ((void *) msg_ptr); break; } case SPI_ABB_READ_EVT: { rvf_send_trace("SPI_task: SPI_READ_ABB_EVT received", 35, NULL_PARAM, RV_TRACE_LEVEL_DEBUG_LOW, SPI_USE_ID); /* Call to the low-level driver function */ data = ABB_Read_Register_on_page(((T_SPI_READ *)msg_ptr)->page, ((T_SPI_READ *)msg_ptr)->address); /* Callback function */ if(((T_SPI_READ *)msg_ptr)->os_hdr.callback_func != NULL) { ((T_SPI_READ *)msg_ptr)->os_hdr.callback_func(&data); } rvf_free_buf ((void *) msg_ptr); return 0; } case SPI_ABB_WRITE_EVT: { rvf_send_trace("SPI_task: SPI_WRITE_ABB_EVT received", 36, NULL_PARAM, RV_TRACE_LEVEL_DEBUG_LOW, SPI_USE_ID); /* Call to the low-level driver function */ ABB_Write_Register_on_page(((T_SPI_WRITE *)msg_ptr)->page, ((T_SPI_WRITE *)msg_ptr)->address, ((T_SPI_WRITE *)msg_ptr)->data); rvf_free_buf ((void *) msg_ptr); return 0; } case SPI_ABB_CONF_ADC_EVT: { rvf_send_trace("SPI_task: SPI_ABB_CONF_ADC_EVT received", 39, NULL_PARAM, RV_TRACE_LEVEL_DEBUG_LOW, SPI_USE_ID); /* Call to the low-level driver function */ ABB_Conf_ADC(((T_SPI_ABB_CONF_ADC *)msg_ptr)->channels, ((T_SPI_ABB_CONF_ADC *)msg_ptr)->itval); rvf_free_buf ((void *) msg_ptr); return 0; } case SPI_ABB_READ_ADC_EVT: { rvf_send_trace("SPI_task: SPI_ABB_READ_ADC_EVT received", 39, NULL_PARAM, RV_TRACE_LEVEL_DEBUG_LOW, SPI_USE_ID); /* Call to the low-level driver function */ ABB_Read_ADC(((T_SPI_ABB_READ_ADC *)msg_ptr)->Buff); /* Callback function */ if(((T_SPI_ABB_READ_ADC *)msg_ptr)->callback_func != NULL) { ((T_SPI_ABB_READ_ADC *)msg_ptr)->callback_func(); } rvf_free_buf ((void *) msg_ptr); return 0; } default: { /* Unknown message has been received */ #ifdef RVM_PWR_SWE rvf_send_trace("SPI_task : Received an unknown or a PWR message",47, NULL_PARAM , RV_TRACE_LEVEL_DEBUG_HIGH, SPI_USE_ID); #else rvf_send_trace("SPI_task : Received an unknown message",38, NULL_PARAM , RV_TRACE_LEVEL_DEBUG_HIGH, SPI_USE_ID); rvf_free_buf ((void *) msg_ptr); #endif return 1; } } // end of switch } // end of if (msg_ptr != NULL) return 0; }