/*
 * public_event_mbox.h
 *
 * Copyright(c) 1998 - 2009 Texas Instruments. All rights reserved.      
 * All rights reserved.                                                  
 *                                                                       
 * Redistribution and use in source and binary forms, with or without    
 * modification, are permitted provided that the following conditions    
 * are met:                                                              
 *                                                                       
 *  * Redistributions of source code must retain the above copyright     
 *    notice, this list of conditions and the following disclaimer.      
 *  * Redistributions in binary form must reproduce the above copyright  
 *    notice, this list of conditions and the following disclaimer in    
 *    the documentation and/or other materials provided with the         
 *    distribution.                                                      
 *  * Neither the name Texas Instruments nor the names of its            
 *    contributors may be used to endorse or promote products derived    
 *    from this software without specific prior written permission.      
 *                                                                       
 * 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 THE COPYRIGHT  
 * OWNER OR CONTRIBUTORS 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.
 */

/**********************************************************************************************************************

  FILENAME:       public_event_mbox.h
 
  DESCRIPTION:    Public header for the Event Mailbox FW<->Driver interface



***********************************************************************************************************************/
#ifndef PUBLIC_EVENT_MBOX_H
#define PUBLIC_EVENT_MBOX_H

/******************************************************************************

	EVENT MBOX
	 
    The event mechanism is based on a pair of event buffers (buffers "A" and "B") in fixed locations
    in the device's memory. The host processes one buffer (buffer "A") while the other buffer 
    (buffer "B") continues to collect events. When the host is finished, it begins processing the 
    other buffer ("B") while the first buffer ("A") collects, and so on.
    If the host is not processing events, an interrupt is issued to the host signaling that a 
    buffer is ready. The interrupt that the host receives indicates the appropriate event structure
    buffer. Once the host finishes processing events from one buffer, 
    it signals with an acknowledge interrupt (bit 0 in the INT_TRIG register) that the event buffer
    is free. This interrupt triggers the device to send the next event structure if there are any 
    collected events in it.

    Note: Only one instance (the last) of each type of event is collected.
       
******************************************************************************/


#include "public_types.h"
#include "public_commands.h"
#include "public_infoele.h"



/*************************************************************************

  Events Enumeration 

**************************************************************************/
typedef enum 
{
    RSSI_SNR_TRIGGER_0_EVENT_ID              = BIT_0, 
    RSSI_SNR_TRIGGER_1_EVENT_ID              = BIT_1, 
    RSSI_SNR_TRIGGER_2_EVENT_ID              = BIT_2, 
    RSSI_SNR_TRIGGER_3_EVENT_ID              = BIT_3, 
    RSSI_SNR_TRIGGER_4_EVENT_ID              = BIT_4, 
    RSSI_SNR_TRIGGER_5_EVENT_ID              = BIT_5, 
    RSSI_SNR_TRIGGER_6_EVENT_ID              = BIT_6, 
    RSSI_SNR_TRIGGER_7_EVENT_ID              = BIT_7, 

    MEASUREMENT_START_EVENT_ID               = BIT_8,
    MEASUREMENT_COMPLETE_EVENT_ID            = BIT_9,
    SCAN_COMPLETE_EVENT_ID                   = BIT_10,
    SCHEDULED_SCAN_COMPLETE_EVENT_ID         = BIT_11,
    AP_DISCOVERY_COMPLETE_EVENT_ID           = BIT_12,
    PS_REPORT_EVENT_ID                       = BIT_13,
    PSPOLL_DELIVERY_FAILURE_EVENT_ID 	     = BIT_14,
    DISCONNECT_EVENT_COMPLETE_ID             = BIT_15,
    JOIN_EVENT_COMPLETE_ID                   = BIT_16,
    CHANNEL_SWITCH_COMPLETE_EVENT_ID         = BIT_17,
    BSS_LOSE_EVENT_ID                        = BIT_18,
    REGAINED_BSS_EVENT_ID                    = BIT_19,
    ROAMING_TRIGGER_MAX_TX_RETRY_EVENT_ID    = BIT_20,
    RESERVED_21                              = BIT_21,
    SOFT_GEMINI_SENSE_EVENT_ID               = BIT_22,
    SOFT_GEMINI_PREDICTION_EVENT_ID          = BIT_23,
    SOFT_GEMINI_AVALANCHE_EVENT_ID           = BIT_24,
    PLT_RX_CALIBRATION_COMPLETE_EVENT_ID     = BIT_25,
    DBG_EVENT_ID                             = BIT_26,
    HEALTH_CHECK_REPLY_EVENT_ID              = BIT_27,

    PERIODIC_SCAN_COMPLETE_EVENT_ID          = BIT_28,
    PERIODIC_SCAN_REPORT_EVENT_ID            = BIT_29,

    BA_SESSION_TEAR_DOWN_EVENT_ID	         = BIT_30,

    EVENT_MBOX_ALL_EVENT_ID                  = MAX_POSITIVE32
} EventMBoxId_e;

/*************************************************************************

  Specific Event Parameters 

**************************************************************************/
typedef enum
{
    SCHEDULED_SCAN_COMPLETED_OK = 0,
    SCHEDULED_SCAN_TSF_ERROR    = 1
} ScheduledScanReportStatus_enum;


typedef enum
{
    CHANNEL_SWITCH_COMPLETE_OK,
    CHANNEL_SWITCH_TSF_ERROR
} ChannelSwitchReportStatus_enum;


typedef enum
{
    ENTER_POWER_SAVE_FAIL    =  0,
    ENTER_POWER_SAVE_SUCCESS =  1,
    EXIT_POWER_SAVE_FAIL     =  2,
    EXIT_POWER_SAVE_SUCCESS  =  3,
    POWER_SAVE_STATUS_NUMBER
} EventsPowerSave_enum;

typedef enum
{
    TEST1_DBG_EVENT_ID = 0,
    TEST2_DBG_EVENT_ID = 0x11,
    LAST_DBG_EVENT_ID= 0xff
}dbgEventId_enum;

#ifdef HOST_COMPILE
typedef uint8 ScheduledScanReportStatus_e;
typedef uint8 ChannelSwitchReportStatus_e;
typedef uint8 EventsPowerSave_e;
typedef uint8 dbgEventId_e;
#else
typedef ScheduledScanReportStatus_enum ScheduledScanReportStatus_e;
typedef ChannelSwitchReportStatus_enum ChannelSwitchReportStatus_e;
typedef EventsPowerSave_enum EventsPowerSave_e;
typedef dbgEventId_enum dbgEventId_e;
#endif


#define MAX_EVENT_REPORT_PARAMS 5
typedef struct
{ 
    dbgEventId_e dbgEventId;  /*uint8*/
    uint8       numberOfRelevantParams;
    uint16      reservedPad16;
    uint32      eventReportP1;
    uint32      eventReportP2;
    uint32      eventReportP3;
}dbgEventRep_t;

typedef struct 
{
	uint8		numberOfScanResults;   /* How many results were parsed */
	uint8       scanTag;               /* Tag of scan */
    uint8       padding[2];            /* for alignment to 32 bits boundry*/
    uint32      scheduledScanStatus;   /* [0-7] scan completed status, [8-23] Attended Channels map, [24-31] reserved. */
} scanCompleteResults_t;

/*************************************************************************

  The Event Mailbox structure in memory 

**************************************************************************/
typedef struct EventMailBox_t
{
    /* Events Bit Mask */
    uint32 eventsVector;
    uint32 eventsMask;
    uint32 reserved1;
    uint32 reserved2;

    /* Events Data */


    dbgEventRep_t      dbgEventRep;         /* refer to dbgEventRep_t*/
                                            /* [DBG_EVENT_ID]*/
    
    scanCompleteResults_t scanCompleteResults; /* Scan complete results (counter and scan tag) */
    
    uint16 scheduledScanAttendedChannels;   /* Channels scanned by the Scheduled Scan. */
                                            /* [SCHEDULED_SCAN_COMPLETE_EVENT_ID]*/

    uint8  softGeminiSenseInfo;             /* Contains the type of the BT Coexistence sense event.*/
                                            /* [SOFT_GEMINI_SENSE_EVENT_ID]*/    

    uint8  softGeminiProtectiveInfo;        /* Contains information from the BT activity prediction */
                                            /* machine [SOFT_GEMINI_PREDICTION_EVENT_ID]*/

    int8   RSSISNRTriggerMetric[NUM_OF_RSSI_SNR_TRIGGERS];   /* RSSI and SNR Multiple Triggers Array */
                                            /* machine [RSSI_SNR_TRIGGER_0-8_EVENT_ID]*/

    uint8  channelSwitchStatus;             /* Status of channel switch. Refer to*/
                                            /* ChannelSwitchReportStatus_enum.*/
                                            /* [CHANNEL_SWITCH_COMPLETE_EVENT_ID]*/

    uint8  scheduledScanStatus;             /* Status of scheduled scan. Refer to */
                                            /* ScheduledScanReportStatus_enum.*/
                                            /* [SCHEDULED_SCAN_COMPLETE_EVENT_ID]*/
    
    uint8  psStatus;                        /* refer to EventsPowerSave_enum.*/
                                            /* [PS_REPORT_EVENT_ID].*/

    

    uint8  padding[29];                     /* for alignment to 32 bits boundry*/

    
} EventMailBox_t;

#endif /* PUBLIC_EVENT_MBOX_H*/