typedef void (*ofono_sim_imsi_cb_t)(const struct ofono_error *error,
const char *imsi, void *data);
+typedef void (*ofono_sim_mccmnc_cb_t)(const struct ofono_error *error,
+ const char *mcc, const char *mnc,
+ void *data);
+
typedef void (*ofono_sim_state_event_cb_t)(enum ofono_sim_state new_state,
void *data);
ofono_sim_iccid_cb_t cb, void *data);
void (*read_imsi)(struct ofono_sim *sim,
ofono_sim_imsi_cb_t cb, void *data);
+ void (*read_mccmnc)(struct ofono_sim *sim,
+ ofono_sim_mccmnc_cb_t cb, void *data);
void (*query_passwd_state)(struct ofono_sim *sim,
ofono_sim_passwd_cb_t cb, void *data);
void (*send_passwd)(struct ofono_sim *sim, const char *passwd,
memcpy(sim->cphs_service_table, data + 1, 2);
}
+static void sim_mccmnc_cb(const struct ofono_error *error,
+ const char *mcc, const char *mnc, void *userdata)
+{
+ struct ofono_sim *sim = userdata;
+
+ if (error->type != OFONO_ERROR_TYPE_NO_ERROR)
+ return;
+
+ if (!mcc || !mnc)
+ return;
+
+ sim->mnc_length = strlen(mnc);
+}
+
static void sim_ad_read_cb(int ok, int length, int record,
const unsigned char *data,
int record_length, void *userdata)
struct ofono_sim *sim = userdata;
int new_mnc_length;
- if (!ok)
+ if (!ok) {
+ if (sim->driver->read_mccmnc)
+ sim->driver->read_mccmnc(sim, sim_mccmnc_cb, sim);
return;
+ }
if (length < 4)
return;