| /* arch/arm/mach-msm/smd_private.h |
| * |
| * Copyright (C) 2007 Google, Inc. |
| * Copyright (c) 2007 QUALCOMM Incorporated |
| * |
| * This software is licensed under the terms of the GNU General Public |
| * License version 2, as published by the Free Software Foundation, and |
| * may be copied, distributed, and modified under those terms. |
| * |
| * This program is distributed in the hope that it will be useful, |
| * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| * GNU General Public License for more details. |
| * |
| */ |
| #ifndef _ARCH_ARM_MACH_MSM_MSM_SMD_PRIVATE_H_ |
| #define _ARCH_ARM_MACH_MSM_MSM_SMD_PRIVATE_H_ |
| |
| struct smem_heap_info |
| { |
| unsigned initialized; |
| unsigned free_offset; |
| unsigned heap_remaining; |
| unsigned reserved; |
| }; |
| |
| struct smem_heap_entry |
| { |
| unsigned allocated; |
| unsigned offset; |
| unsigned size; |
| unsigned reserved; |
| }; |
| |
| struct smem_proc_comm |
| { |
| unsigned command; |
| unsigned status; |
| unsigned data1; |
| unsigned data2; |
| }; |
| |
| #define PC_APPS 0 |
| #define PC_MODEM 1 |
| |
| #define VERSION_QDSP6 4 |
| #define VERSION_APPS_SBL 6 |
| #define VERSION_MODEM_SBL 7 |
| #define VERSION_APPS 8 |
| #define VERSION_MODEM 9 |
| |
| struct smem_shared |
| { |
| struct smem_proc_comm proc_comm[4]; |
| unsigned version[32]; |
| struct smem_heap_info heap_info; |
| struct smem_heap_entry heap_toc[128]; |
| }; |
| |
| struct smsm_shared |
| { |
| unsigned host; |
| unsigned state; |
| }; |
| |
| struct smsm_interrupt_info |
| { |
| uint32_t aArm_en_mask; |
| uint32_t aArm_interrupts_pending; |
| uint32_t aArm_wakeup_reason; |
| }; |
| |
| #define SZ_DIAG_ERR_MSG 0xC8 |
| #define ID_DIAG_ERR_MSG SMEM_DIAG_ERR_MESSAGE |
| #define ID_SMD_CHANNELS SMEM_SMD_BASE_ID |
| #define ID_SHARED_STATE SMEM_SMSM_SHARED_STATE |
| #define ID_CH_ALLOC_TBL SMEM_CHANNEL_ALLOC_TBL |
| |
| #define SMSM_INIT 0x000001 |
| #define SMSM_SMDINIT 0x000008 |
| #define SMSM_RPCINIT 0x000020 |
| #define SMSM_RESET 0x000040 |
| #define SMSM_RSA 0x0080 |
| #define SMSM_RUN 0x000100 |
| #define SMSM_PWRC 0x0200 |
| #define SMSM_TIMEWAIT 0x0400 |
| #define SMSM_TIMEINIT 0x0800 |
| #define SMSM_PWRC_EARLY_EXIT 0x1000 |
| #define SMSM_WFPI 0x2000 |
| #define SMSM_SLEEP 0x4000 |
| #define SMSM_SLEEPEXIT 0x8000 |
| #define SMSM_OEMSBL_RELEASE 0x10000 |
| #define SMSM_PWRC_SUSPEND 0x200000 |
| |
| #define SMSM_WKUP_REASON_RPC 0x00000001 |
| #define SMSM_WKUP_REASON_INT 0x00000002 |
| #define SMSM_WKUP_REASON_GPIO 0x00000004 |
| #define SMSM_WKUP_REASON_TIMER 0x00000008 |
| #define SMSM_WKUP_REASON_ALARM 0x00000010 |
| #define SMSM_WKUP_REASON_RESET 0x00000020 |
| |
| void *smem_alloc(unsigned id, unsigned size); |
| int smsm_change_state(uint32_t clear_mask, uint32_t set_mask); |
| uint32_t smsm_get_state(void); |
| int smsm_set_sleep_duration(uint32_t delay); |
| int smsm_set_interrupt_info(struct smsm_interrupt_info *info); |
| void smsm_print_sleep_info(void); |
| |
| #define SMEM_NUM_SMD_CHANNELS 64 |
| |
| typedef enum |
| { |
| /* fixed items */ |
| SMEM_PROC_COMM = 0, |
| SMEM_HEAP_INFO, |
| SMEM_ALLOCATION_TABLE, |
| SMEM_VERSION_INFO, |
| SMEM_HW_RESET_DETECT, |
| SMEM_AARM_WARM_BOOT, |
| SMEM_DIAG_ERR_MESSAGE, |
| SMEM_SPINLOCK_ARRAY, |
| SMEM_MEMORY_BARRIER_LOCATION, |
| |
| /* dynamic items */ |
| SMEM_AARM_PARTITION_TABLE, |
| SMEM_AARM_BAD_BLOCK_TABLE, |
| SMEM_RESERVE_BAD_BLOCKS, |
| SMEM_WM_UUID, |
| SMEM_CHANNEL_ALLOC_TBL, |
| SMEM_SMD_BASE_ID, |
| SMEM_SMEM_LOG_IDX = SMEM_SMD_BASE_ID + SMEM_NUM_SMD_CHANNELS, |
| SMEM_SMEM_LOG_EVENTS, |
| SMEM_SMEM_STATIC_LOG_IDX, |
| SMEM_SMEM_STATIC_LOG_EVENTS, |
| SMEM_SMEM_SLOW_CLOCK_SYNC, |
| SMEM_SMEM_SLOW_CLOCK_VALUE, |
| SMEM_BIO_LED_BUF, |
| SMEM_SMSM_SHARED_STATE, |
| SMEM_SMSM_INT_INFO, |
| SMEM_SMSM_SLEEP_DELAY, |
| SMEM_SMSM_LIMIT_SLEEP, |
| SMEM_SLEEP_POWER_COLLAPSE_DISABLED, |
| SMEM_KEYPAD_KEYS_PRESSED, |
| SMEM_KEYPAD_STATE_UPDATED, |
| SMEM_KEYPAD_STATE_IDX, |
| SMEM_GPIO_INT, |
| SMEM_MDDI_LCD_IDX, |
| SMEM_MDDI_HOST_DRIVER_STATE, |
| SMEM_MDDI_LCD_DISP_STATE, |
| SMEM_LCD_CUR_PANEL, |
| SMEM_MARM_BOOT_SEGMENT_INFO, |
| SMEM_AARM_BOOT_SEGMENT_INFO, |
| SMEM_SLEEP_STATIC, |
| SMEM_SCORPION_FREQUENCY, |
| SMEM_SMD_PROFILES, |
| SMEM_TSSC_BUSY, |
| SMEM_HS_SUSPEND_FILTER_INFO, |
| SMEM_BATT_INFO, |
| SMEM_APPS_BOOT_MODE, |
| SMEM_VERSION_FIRST, |
| SMEM_VERSION_LAST = SMEM_VERSION_FIRST + 24, |
| SMEM_OSS_RRCASN1_BUF1, |
| SMEM_OSS_RRCASN1_BUF2, |
| SMEM_ID_VENDOR0, |
| SMEM_ID_VENDOR1, |
| SMEM_ID_VENDOR2, |
| SMEM_HW_SW_BUILD_ID, |
| SMEM_NUM_ITEMS, |
| } smem_mem_type; |
| |
| #endif |