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 (sim->driver->read_mccmnc)
- sim->driver->read_mccmnc(sim, sim_mccmnc_cb, sim);
+ if (!ok)
return;
- }
if (length < 4)
return;