diff options
author | Arve Hjønnevåg <arve@android.com> | 2009-05-20 19:52:36 -0400 |
---|---|---|
committer | Daniel Walker <dwalker@codeaurora.org> | 2010-05-12 12:15:03 -0400 |
commit | 283794100d2b1c1645b2949273aa4be29929812d (patch) | |
tree | 30c371ec32ff2d8767ec3b3fb72c7a0b32c0e513 /arch/arm/mach-msm/smd.c | |
parent | 5b0f5a3f6084397194a8b556cdca572ad8e14f05 (diff) |
[ARM] msm: Add item argument to smsm_change_state and smsm_get_state
The new protocol require writing to two state fields, and reading
several fields.
Signed-off-by: Arve Hjønnevåg <arve@android.com>
Signed-off-by: Daniel Walker <dwalker@codeaurora.org>
Diffstat (limited to 'arch/arm/mach-msm/smd.c')
-rw-r--r-- | arch/arm/mach-msm/smd.c | 58 |
1 files changed, 28 insertions, 30 deletions
diff --git a/arch/arm/mach-msm/smd.c b/arch/arm/mach-msm/smd.c index f731ddeaa25c..e33fd029fa37 100644 --- a/arch/arm/mach-msm/smd.c +++ b/arch/arm/mach-msm/smd.c | |||
@@ -49,16 +49,13 @@ static int msm_smd_debug_mask; | |||
49 | struct shared_info | 49 | struct shared_info |
50 | { | 50 | { |
51 | int ready; | 51 | int ready; |
52 | unsigned state_apps; | 52 | unsigned state; |
53 | unsigned state_modem; | ||
54 | }; | 53 | }; |
55 | 54 | ||
56 | static unsigned dummy_state_apps; | 55 | static unsigned dummy_state[SMSM_STATE_COUNT]; |
57 | static unsigned dummy_state_modem; | ||
58 | 56 | ||
59 | static struct shared_info smd_info = { | 57 | static struct shared_info smd_info = { |
60 | .state_apps = (unsigned) &dummy_state_apps, | 58 | .state = (unsigned) &dummy_state, |
61 | .state_modem = (unsigned) &dummy_state_modem, | ||
62 | }; | 59 | }; |
63 | 60 | ||
64 | module_param_named(debug_mask, msm_smd_debug_mask, | 61 | module_param_named(debug_mask, msm_smd_debug_mask, |
@@ -115,9 +112,14 @@ static void handle_modem_crash(void) | |||
115 | 112 | ||
116 | extern int (*msm_check_for_modem_crash)(void); | 113 | extern int (*msm_check_for_modem_crash)(void); |
117 | 114 | ||
115 | uint32_t raw_smsm_get_state(enum smsm_state_item item) | ||
116 | { | ||
117 | return readl(smd_info.state + item * 4); | ||
118 | } | ||
119 | |||
118 | static int check_for_modem_crash(void) | 120 | static int check_for_modem_crash(void) |
119 | { | 121 | { |
120 | if (readl(smd_info.state_modem) & SMSM_RESET) { | 122 | if (raw_smsm_get_state(SMSM_STATE_MODEM) & SMSM_RESET) { |
121 | handle_modem_crash(); | 123 | handle_modem_crash(); |
122 | return -1; | 124 | return -1; |
123 | } | 125 | } |
@@ -978,8 +980,8 @@ static irqreturn_t smsm_irq_handler(int irq, void *data) | |||
978 | 980 | ||
979 | spin_lock_irqsave(&smem_lock, flags); | 981 | spin_lock_irqsave(&smem_lock, flags); |
980 | 982 | ||
981 | apps = readl(smd_info.state_apps); | 983 | apps = raw_smsm_get_state(SMSM_STATE_APPS); |
982 | modm = readl(smd_info.state_modem); | 984 | modm = raw_smsm_get_state(SMSM_STATE_MODEM); |
983 | 985 | ||
984 | if (msm_smd_debug_mask & MSM_SMSM_DEBUG) | 986 | if (msm_smd_debug_mask & MSM_SMSM_DEBUG) |
985 | pr_info("<SM %08x %08x>\n", apps, modm); | 987 | pr_info("<SM %08x %08x>\n", apps, modm); |
@@ -992,24 +994,26 @@ static irqreturn_t smsm_irq_handler(int irq, void *data) | |||
992 | return IRQ_HANDLED; | 994 | return IRQ_HANDLED; |
993 | } | 995 | } |
994 | 996 | ||
995 | int smsm_change_state(uint32_t clear_mask, uint32_t set_mask) | 997 | int smsm_change_state(enum smsm_state_item item, |
998 | uint32_t clear_mask, uint32_t set_mask) | ||
996 | { | 999 | { |
997 | unsigned long flags; | 1000 | unsigned long flags; |
998 | unsigned state; | 1001 | unsigned state; |
1002 | unsigned addr = smd_info.state + item * 4; | ||
999 | 1003 | ||
1000 | if (!smd_info.ready) | 1004 | if (!smd_info.ready) |
1001 | return -EIO; | 1005 | return -EIO; |
1002 | 1006 | ||
1003 | spin_lock_irqsave(&smem_lock, flags); | 1007 | spin_lock_irqsave(&smem_lock, flags); |
1004 | 1008 | ||
1005 | if (readl(smd_info.state_modem) & SMSM_RESET) | 1009 | if (raw_smsm_get_state(SMSM_STATE_MODEM) & SMSM_RESET) |
1006 | handle_modem_crash(); | 1010 | handle_modem_crash(); |
1007 | 1011 | ||
1008 | state = (readl(smd_info.state_apps) & ~clear_mask) | set_mask; | 1012 | state = (readl(addr) & ~clear_mask) | set_mask; |
1009 | writel(state, smd_info.state_apps); | 1013 | writel(state, addr); |
1010 | 1014 | ||
1011 | if (msm_smd_debug_mask & MSM_SMSM_DEBUG) | 1015 | if (msm_smd_debug_mask & MSM_SMSM_DEBUG) |
1012 | pr_info("smsm_change_state %x\n", state); | 1016 | pr_info("smsm_change_state %d %x\n", item, state); |
1013 | notify_other_smsm(); | 1017 | notify_other_smsm(); |
1014 | 1018 | ||
1015 | spin_unlock_irqrestore(&smem_lock, flags); | 1019 | spin_unlock_irqrestore(&smem_lock, flags); |
@@ -1017,16 +1021,16 @@ int smsm_change_state(uint32_t clear_mask, uint32_t set_mask) | |||
1017 | return 0; | 1021 | return 0; |
1018 | } | 1022 | } |
1019 | 1023 | ||
1020 | uint32_t smsm_get_state(void) | 1024 | uint32_t smsm_get_state(enum smsm_state_item item) |
1021 | { | 1025 | { |
1022 | unsigned long flags; | 1026 | unsigned long flags; |
1023 | uint32_t rv; | 1027 | uint32_t rv; |
1024 | 1028 | ||
1025 | spin_lock_irqsave(&smem_lock, flags); | 1029 | spin_lock_irqsave(&smem_lock, flags); |
1026 | 1030 | ||
1027 | rv = readl(smd_info.state_modem); | 1031 | rv = readl(smd_info.state + item * 4); |
1028 | 1032 | ||
1029 | if (rv & SMSM_RESET) | 1033 | if (item == SMSM_STATE_MODEM && (rv & SMSM_RESET)) |
1030 | handle_modem_crash(); | 1034 | handle_modem_crash(); |
1031 | 1035 | ||
1032 | spin_unlock_irqrestore(&smem_lock, flags); | 1036 | spin_unlock_irqrestore(&smem_lock, flags); |
@@ -1145,14 +1149,8 @@ int smd_core_init(void) | |||
1145 | unsigned size; | 1149 | unsigned size; |
1146 | void *state; | 1150 | void *state; |
1147 | state = smem_item(SMEM_SMSM_SHARED_STATE, &size); | 1151 | state = smem_item(SMEM_SMSM_SHARED_STATE, &size); |
1148 | if (size == SMSM_V1_SIZE) { | 1152 | if (size == SMSM_V1_SIZE || size == SMSM_V2_SIZE) { |
1149 | smd_info.state_apps = state + SMSM_V1_STATE_APPS; | 1153 | smd_info.state = (unsigned)state; |
1150 | smd_info.state_modem = state + SMSM_V1_STATE_MODEM; | ||
1151 | break; | ||
1152 | } | ||
1153 | if (size == SMSM_V2_SIZE) { | ||
1154 | smd_info.state_apps = state + SMSM_V2_STATE_APPS; | ||
1155 | smd_info.state_modem = state + SMSM_V2_STATE_MODEM; | ||
1156 | break; | 1154 | break; |
1157 | } | 1155 | } |
1158 | } | 1156 | } |
@@ -1181,8 +1179,8 @@ int smd_core_init(void) | |||
1181 | do_smd_probe(); | 1179 | do_smd_probe(); |
1182 | 1180 | ||
1183 | /* indicate that we're up and running */ | 1181 | /* indicate that we're up and running */ |
1184 | writel(SMSM_INIT | SMSM_SMDINIT | SMSM_RPCINIT, smd_info.state_apps); | 1182 | smsm_change_state(SMSM_STATE_APPS, |
1185 | notify_other_smsm(); | 1183 | ~0, SMSM_INIT | SMSM_SMDINIT | SMSM_RPCINIT); |
1186 | 1184 | ||
1187 | pr_info("smd_core_init() done\n"); | 1185 | pr_info("smd_core_init() done\n"); |
1188 | 1186 | ||
@@ -1227,13 +1225,13 @@ static int debug_read_stat(char *buf, int max) | |||
1227 | 1225 | ||
1228 | msg = smem_find(ID_DIAG_ERR_MSG, SZ_DIAG_ERR_MSG); | 1226 | msg = smem_find(ID_DIAG_ERR_MSG, SZ_DIAG_ERR_MSG); |
1229 | 1227 | ||
1230 | if (readl(smd_info.state_modem) & SMSM_RESET) | 1228 | if (raw_smsm_get_state(SMSM_STATE_MODEM) & SMSM_RESET) |
1231 | i += scnprintf(buf + i, max - i, | 1229 | i += scnprintf(buf + i, max - i, |
1232 | "smsm: ARM9 HAS CRASHED\n"); | 1230 | "smsm: ARM9 HAS CRASHED\n"); |
1233 | 1231 | ||
1234 | i += scnprintf(buf + i, max - i, "smsm: a9: %08x a11: %08x\n", | 1232 | i += scnprintf(buf + i, max - i, "smsm: a9: %08x a11: %08x\n", |
1235 | readl(smd_info.state_modem), | 1233 | raw_smsm_get_state(SMSM_STATE_MODEM), |
1236 | readl(smd_info.state_apps)); | 1234 | raw_smsm_get_state(SMSM_STATE_APPS)); |
1237 | 1235 | ||
1238 | if (msg) { | 1236 | if (msg) { |
1239 | msg[SZ_DIAG_ERR_MSG - 1] = 0; | 1237 | msg[SZ_DIAG_ERR_MSG - 1] = 0; |