summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPrzemyslaw Marczak <p.marczak@samsung.com>2015-11-02 15:16:27 +0100
committerSeung-Woo Kim <sw0312.kim@samsung.com>2016-12-14 13:48:21 +0900
commit6303c74be19f942cfac0d2554b612546a630730e (patch)
tree04945abcd875e3eaa2792a2cda3b2f02a00aa936
parentd16dc1c1bb7803045e3d5b4d397d0b38a44d6d2d (diff)
LOCAL / net: bcm4358: call vfs functions instead of direct file ops
After enable writing the card's MAC address to filesystem by: commit: LOCAL / net: bcm4358: Enable the some configurations in the driver's code for bcmdhd4358, filesystem access is required to read/write some settings, especially the card's MAC address. Instead of calling proper fs functions, a direct calls were used to particular file operations methods. Since read/write operations are deprecated, the present code without null pointer checking, refers to null function pointers. This causes kernel panic when runs wpa_supplicant application. This commit moves the direct calls to proper function calls, which fixes the panic issue. Signed-off-by: Przemyslaw Marczak <p.marczak@samsung.com> Cc: Jaehoon Chung <jh80.chung@samsung.com>
-rw-r--r--drivers/net/wireless/bcmdhd4358/dhd_custom_sec.c203
1 files changed, 68 insertions, 135 deletions
diff --git a/drivers/net/wireless/bcmdhd4358/dhd_custom_sec.c b/drivers/net/wireless/bcmdhd4358/dhd_custom_sec.c
index b3ea2f8b5c1e..35e8eda8c5ef 100644
--- a/drivers/net/wireless/bcmdhd4358/dhd_custom_sec.c
+++ b/drivers/net/wireless/bcmdhd4358/dhd_custom_sec.c
@@ -380,7 +380,6 @@ int dhd_read_macaddr(struct dhd_info *dhd, struct ether_addr *mac)
{
struct file *fp = NULL;
char macbuffer[18] = {0};
- mm_segment_t oldfs = {0};
char randommac[3] = {0};
char buf[18] = {0};
char *filepath_efs = MACINFO_EFS;
@@ -395,27 +394,22 @@ start_readmac:
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_efs));
return -1;
}
- oldfs = get_fs();
- set_fs(get_ds());
/* Generating the Random Bytes for 3 last octects of the MAC address */
get_random_bytes(randommac, 3);
-
sprintf(macbuffer, "%02X:%02X:%02X:%02X:%02X:%02X\n",
0x00, 0x12, 0x34, randommac[0], randommac[1], randommac[2]);
DHD_ERROR(("[WIFI_SEC] The Random Generated MAC ID: %s\n", macbuffer));
- if (fp->f_mode & FMODE_WRITE) {
- ret = fp->f_op->write(fp, (const char *)macbuffer,
- sizeof(macbuffer), &fp->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] MAC address [%s] Failed to write into File:"
- " %s\n", macbuffer, filepath_efs));
- else
- DHD_ERROR(("[WIFI_SEC] MAC address [%s] written into File: %s\n",
- macbuffer, filepath_efs));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp, (const char *)macbuffer,
+ sizeof(macbuffer), fp->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] MAC address [%s] Failed to write"
+ " into File: %s\n", macbuffer, filepath_efs));
+ else
+ DHD_ERROR(("[WIFI_SEC] MAC address [%s] written into File: %s\n",
+ macbuffer, filepath_efs));
+
/* Reading the MAC Address from .mac.info file
( the existed file or just created file)
*/
@@ -476,7 +470,6 @@ int dhd_write_rdwr_macaddr(struct ether_addr *mac)
char *filepath_efs = MACINFO_EFS;
struct file *fp_mac = NULL;
char buf[18] = {0};
- mm_segment_t oldfs = {0};
int ret = -1;
if ((g_imac_flag != MACADDR_COB) && (g_imac_flag != MACADDR_MOD))
@@ -491,21 +484,16 @@ int dhd_write_rdwr_macaddr(struct ether_addr *mac)
if (IS_ERR(fp_mac)) {
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_data));
return -1;
- } else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp_mac->f_mode & FMODE_WRITE) {
- ret = fp_mac->f_op->write(fp_mac, (const char *)buf,
- sizeof(buf), &fp_mac->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed"
- " to write into File: %s\n", buf, filepath_data));
- else
- DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
- " into File: %s\n", buf, filepath_data));
- }
- set_fs(oldfs);
+ } else {
+ kernel_write(fp_mac, (const char *)buf, sizeof(buf),
+ fp_mac->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed"
+ " to write into File: %s\n", buf, filepath_data));
+ else
+ DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
+ " into File: %s\n", buf, filepath_data));
+
filp_close(fp_mac, NULL);
}
/* /data/.mac.info will be created */
@@ -513,21 +501,15 @@ int dhd_write_rdwr_macaddr(struct ether_addr *mac)
if (IS_ERR(fp_mac)) {
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_efs));
return -1;
- } else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp_mac->f_mode & FMODE_WRITE) {
- ret = fp_mac->f_op->write(fp_mac, (const char *)buf,
- sizeof(buf), &fp_mac->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed"
- " to write into File: %s\n", buf, filepath_efs));
- else
- DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
- " into File: %s\n", buf, filepath_efs));
- }
- set_fs(oldfs);
+ } else {
+ ret = kernel_write(fp_mac, (const char *)buf, sizeof(buf),
+ fp_mac->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed"
+ " to write into File: %s\n", buf, filepath_efs));
+ else
+ DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
+ " into File: %s\n", buf, filepath_efs));
filp_close(fp_mac, NULL);
}
@@ -592,6 +574,7 @@ int dhd_check_rdwr_macaddr(struct dhd_info *dhd, dhd_pub_t *dhdp,
int is_zeromac;
ret = kernel_read(fp_mac, 0, buf, 18);
+
filp_close(fp_mac, NULL);
buf[17] = '\0';
@@ -747,7 +730,6 @@ int dhd_write_rdwr_korics_macaddr(struct dhd_info *dhd, struct ether_addr *mac)
{
struct file *fp = NULL;
char macbuffer[18] = {0};
- mm_segment_t oldfs = {0};
char randommac[3] = {0};
char buf[18] = {0};
char *filepath_efs = MACINFO_EFS;
@@ -765,9 +747,6 @@ int dhd_write_rdwr_korics_macaddr(struct dhd_info *dhd, struct ether_addr *mac)
return -1;
}
- oldfs = get_fs();
- set_fs(get_ds());
-
/* Generating the Random Bytes for
* 3 last octects of the MAC address
*/
@@ -779,20 +758,16 @@ int dhd_write_rdwr_korics_macaddr(struct dhd_info *dhd, struct ether_addr *mac)
DHD_ERROR(("[WIFI_SEC] The Random Generated MAC ID : %s\n",
macbuffer));
- if (fp->f_mode & FMODE_WRITE) {
- ret = fp->f_op->write(fp,
- (const char *)macbuffer,
- sizeof(macbuffer), &fp->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Mac address [%s]"
- " Failed to write into File:"
- " %s\n", macbuffer, filepath_efs));
- else
- DHD_ERROR(("[WIFI_SEC] Mac address [%s]"
- " written into File: %s\n",
- macbuffer, filepath_efs));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp, (const char *)macbuffer,
+ sizeof(macbuffer), fp->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s]"
+ " Failed to write into File:"
+ " %s\n", macbuffer, filepath_efs));
+ else
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s]"
+ " written into File: %s\n",
+ macbuffer, filepath_efs));
} else {
/* Reading the MAC Address from .mac.info file
* (the existed file or just created file)
@@ -846,7 +821,6 @@ int dhd_write_rdwr_korics_macaddr(struct dhd_info *dhd, struct ether_addr *mac)
static int dhd_write_cid_file(const char *filepath_cid, const char *buf, int buf_len)
{
struct file *fp = NULL;
- mm_segment_t oldfs = {0};
int ret = 0;
/* File is always created. */
@@ -855,19 +829,13 @@ static int dhd_write_cid_file(const char *filepath_cid, const char *buf, int buf
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_cid));
return -1;
} else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp->f_mode & FMODE_WRITE) {
- ret = fp->f_op->write(fp, buf, buf_len, &fp->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Failed to write CIS[%s]"
- " into '%s'\n", buf, filepath_cid));
- else
- DHD_ERROR(("[WIFI_SEC] CID [%s] written into"
- " '%s'\n", buf, filepath_cid));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp, buf, buf_len, fp->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Failed to write CIS[%s]"
+ " into '%s'\n", buf, filepath_cid));
+ else
+ DHD_ERROR(("[WIFI_SEC] CID [%s] written into"
+ " '%s'\n", buf, filepath_cid));
}
filp_close(fp, NULL);
@@ -1085,7 +1053,6 @@ write_cid:
static int dhd_write_mac_file(const char *filepath, const char *buf, int buf_len)
{
struct file *fp = NULL;
- mm_segment_t oldfs = {0};
int ret = 0;
fp = filp_open(filepath, O_RDWR | O_CREAT, 0666);
@@ -1094,17 +1061,11 @@ static int dhd_write_mac_file(const char *filepath, const char *buf, int buf_len
DHD_ERROR(("[WIFI_SEC] File open error\n"));
return -1;
} else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp->f_mode & FMODE_WRITE) {
- ret = fp->f_op->write(fp, buf, buf_len, &fp->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Failed to write CIS. \n"));
- else
- DHD_ERROR(("[WIFI_SEC] MAC written. \n"));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp, buf, buf_len, fp->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Failed to write CIS. \n"));
+ else
+ DHD_ERROR(("[WIFI_SEC] MAC written. \n"));
}
filp_close(fp, NULL);
@@ -1196,7 +1157,6 @@ int dhd_write_macaddr(struct ether_addr *mac)
struct file *fp_mac = NULL;
char buf[WRMAC_BUF_SIZE] = {0};
- mm_segment_t oldfs = {0};
int ret = -1;
int retry_count = 0;
@@ -1213,20 +1173,14 @@ startwrite:
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_data));
return -1;
} else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp_mac->f_mode & FMODE_WRITE) {
- ret = fp_mac->f_op->write(fp_mac, (const char *)buf,
- sizeof(buf), &fp_mac->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed to"
- " write into File: %s\n", buf, filepath_data));
- else
- DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
- " into File: %s\n", buf, filepath_data));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp_mac, (const char *)buf,
+ sizeof(buf), fp_mac->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed to"
+ " write into File: %s\n", buf, filepath_data));
+ else
+ DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
+ " into File: %s\n", buf, filepath_data));
filp_close(fp_mac, NULL);
}
/* check .mac.info file is 0 byte */
@@ -1253,20 +1207,14 @@ startwrite:
DHD_ERROR(("[WIFI_SEC] %s: File open error\n", filepath_efs));
return -1;
} else {
- oldfs = get_fs();
- set_fs(get_ds());
-
- if (fp_mac->f_mode & FMODE_WRITE) {
- ret = fp_mac->f_op->write(fp_mac, (const char *)buf,
- sizeof(buf), &fp_mac->f_pos);
- if (ret < 0)
- DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed to"
- " write into File: %s\n", buf, filepath_efs));
- else
- DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
- " into File: %s\n", buf, filepath_efs));
- }
- set_fs(oldfs);
+ ret = kernel_write(fp_mac, (const char *)buf,
+ sizeof(buf), fp_mac->f_pos);
+ if (ret < 0)
+ DHD_ERROR(("[WIFI_SEC] Mac address [%s] Failed to"
+ " write into File: %s\n", buf, filepath_efs));
+ else
+ DHD_INFO(("[WIFI_SEC] Mac address [%s] written"
+ " into File: %s\n", buf, filepath_efs));
filp_close(fp_mac, NULL);
}
@@ -1539,21 +1487,6 @@ int sec_get_param(dhd_pub_t *dhd, int mode)
char version_info[512];
char version_old_info[512];
-int write_filesystem(struct file *file, unsigned long long offset,
- unsigned char* data, unsigned int size)
-{
- mm_segment_t oldfs;
- int ret;
-
- oldfs = get_fs();
- set_fs(get_ds());
-
- ret = vfs_write(file, data, size, &offset);
-
- set_fs(oldfs);
- return ret;
-}
-
uint32 sec_save_wlinfo(char *firm_ver, char *dhd_ver, char *nvram_p)
{
struct file *fp = NULL;
@@ -1660,7 +1593,7 @@ uint32 sec_save_wlinfo(char *firm_ver, char *dhd_ver, char *nvram_p)
DHD_ERROR(("[WIFI_SEC] %s: .wifiver.info File open failed.\n",
__FUNCTION__));
} else {
- ret = write_filesystem(fp, fp->f_pos, version_info, sizeof(version_info));
+ ret = kernel_write(fp, version_info, sizeof(version_info), fp->f_pos);
DHD_INFO(("[WIFI_SEC] sec_save_wlinfo done. ret : %d\n", ret));
DHD_ERROR(("[WIFI_SEC] save .wifiver.info file.\n"));
filp_close(fp, NULL);