+void wifi_set_early_suspend(gboolean value)
+{
+ static gboolean old_state = FALSE;
+ struct ifreq ifr;
+ char buf[MAX_DRV_CMD_SIZE];
+ netconfig_wifi_priv_cmd priv_cmd;
+ int ret = 0;
+ int ioctl_sock = 0;
+ int pm_state = 0;
+ wifi_service_state_e wifi_state;
+ char error_buf[MAX_SIZE_ERROR_BUFFER] = {0, };
+
+ if (old_state == value) {
+ DBG("Old and new states are same");
+ return;
+ }
+
+ if (netconfig_vconf_get_int(VCONFKEY_PM_STATE, &pm_state) < 0)
+ ERR("Fail to get VCONFKEY_PM_STATE");
+
+ wifi_state = wifi_state_get_service_state();
+
+ if (value == TRUE &&
+ (pm_state < VCONFKEY_PM_STATE_LCDOFF ||
+ wifi_state == NETCONFIG_WIFI_ASSOCIATION ||
+ wifi_state == NETCONFIG_WIFI_CONFIGURATION)){
+ DBG("");
+ return;
+ }
+
+ memset(buf, 0, sizeof(buf));
+ snprintf(buf, sizeof(buf), "SETSUSPENDMODE %d", value);
+
+ memset(&ifr, 0, sizeof(struct ifreq));
+ g_strlcpy((char *)ifr.ifr_name, WIFI_IFNAME, IFNAMSIZ);
+
+ DBG("Early suspend command: [%s]", buf);
+
+ memset(&priv_cmd, 0, sizeof(priv_cmd));
+ priv_cmd.buf = buf;
+ priv_cmd.used_len = sizeof(buf);
+ priv_cmd.total_len = sizeof(buf);
+ ifr.ifr_data = (char *)&priv_cmd;
+
+ ioctl_sock = socket(PF_INET, SOCK_DGRAM, 0);
+ if (ioctl_sock < 0) {
+ DBG("socket(PF_INET,SOCK_DGRAM) failed: %s",
+ strerror_r(errno, error_buf, MAX_SIZE_ERROR_BUFFER));
+ return;
+ }
+
+ ret = ioctl(ioctl_sock, WLAN_IOCTL_SUSPEND, &ifr);
+ if (ret < 0) {
+ ERR("Fail to issue private commands: %d. %s", ret,
+ strerror_r(errno, error_buf, MAX_SIZE_ERROR_BUFFER));
+ } else {
+ old_state = value;
+ }
+
+ close(ioctl_sock);
+}
+