Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 1a5d54a321 |
+1
-1
@@ -66,7 +66,7 @@ BES2600_DRV_VERSION := bes2600_0.3.5_2024.0116
|
|||||||
ifeq ($(CONFIG_BES2600_CALIB_FROM_LINUX),y)
|
ifeq ($(CONFIG_BES2600_CALIB_FROM_LINUX),y)
|
||||||
FACTORY_CRC_CHECK ?= n
|
FACTORY_CRC_CHECK ?= n
|
||||||
STANDARD_FACTORY_EFUSE_FLAG ?= y
|
STANDARD_FACTORY_EFUSE_FLAG ?= y
|
||||||
FACTORY_PATH ?= /lib/firmware/bes2600_factory.txt
|
FACTORY_PATH ?= bes2600/bes2600_factory.txt
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# basic function
|
# basic function
|
||||||
|
|||||||
+14
-19
@@ -12,6 +12,7 @@
|
|||||||
#include <linux/module.h>
|
#include <linux/module.h>
|
||||||
#include <linux/sched.h>
|
#include <linux/sched.h>
|
||||||
#include <linux/fs.h>
|
#include <linux/fs.h>
|
||||||
|
#include <linux/firmware.h>
|
||||||
#include <linux/slab.h>
|
#include <linux/slab.h>
|
||||||
#include <linux/mutex.h>
|
#include <linux/mutex.h>
|
||||||
#include <linux/crc32.h>
|
#include <linux/crc32.h>
|
||||||
@@ -137,38 +138,32 @@ static int bes2600_factory_crc_check(struct factory_t *factory_data)
|
|||||||
*/
|
*/
|
||||||
static int factory_section_read_file(char *path, void *buffer)
|
static int factory_section_read_file(char *path, void *buffer)
|
||||||
{
|
{
|
||||||
int ret = 0;
|
const struct firmware *fw;
|
||||||
struct file *fp;
|
int ret;
|
||||||
|
|
||||||
if (!path || !buffer) {
|
if (!path || !buffer) {
|
||||||
bes_err("%s NULL pointer err\n", __func__);
|
bes_err("%s NULL pointer err\n", __func__);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
bes_devel("reading %s \n", path);
|
bes_devel("requesting firmware-class %s\n", path);
|
||||||
|
|
||||||
fp = filp_open(path, O_RDONLY, 0); //S_IRUSR
|
ret = request_firmware(&fw, path, NULL);
|
||||||
if (IS_ERR(fp)) {
|
if (ret) {
|
||||||
bes_devel("BES2600 : can't open %s\n",path);
|
bes_devel("BES2600: request_firmware(%s) failed: %d\n", path, ret);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (fp->f_inode->i_size <= 0 || fp->f_inode->i_size > FACTORY_MAX_SIZE) {
|
if (fw->size == 0 || fw->size > FACTORY_MAX_SIZE) {
|
||||||
bes_err( "bes2600_factory.txt size check failed, read_size: %lld max_size: %d\n",
|
bes_err("bes2600_factory.txt size check failed, read_size: %zu max_size: %d\n",
|
||||||
fp->f_inode->i_size, FACTORY_MAX_SIZE);
|
fw->size, FACTORY_MAX_SIZE);
|
||||||
filp_close(fp, NULL);
|
release_firmware(fw);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = kernel_read(fp, buffer, fp->f_inode->i_size, &fp->f_pos);
|
memcpy(buffer, fw->data, fw->size);
|
||||||
|
ret = (int)fw->size;
|
||||||
filp_close(fp, NULL);
|
release_firmware(fw);
|
||||||
|
|
||||||
if (ret != fp->f_inode->i_size) {
|
|
||||||
bes_err("bes2600_factory.txt read fail\n");
|
|
||||||
ret = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
+1
-38
@@ -94,7 +94,6 @@ struct sbus_priv {
|
|||||||
struct work_struct tx_work;
|
struct work_struct tx_work;
|
||||||
struct scatterlist tx_sg[BES_SDIO_TX_MULTIPLE_NUM + 1];
|
struct scatterlist tx_sg[BES_SDIO_TX_MULTIPLE_NUM + 1];
|
||||||
struct scatterlist tx_sg_nosignal[BES_SDIO_TX_MULTIPLE_NUM_NOSIGNAL + 1];
|
struct scatterlist tx_sg_nosignal[BES_SDIO_TX_MULTIPLE_NUM_NOSIGNAL + 1];
|
||||||
u8 *tx_bounce;
|
|
||||||
u32 tx_data_cnt;
|
u32 tx_data_cnt;
|
||||||
u32 tx_xfer_cnt;
|
u32 tx_xfer_cnt;
|
||||||
u32 tx_proc_cnt;
|
u32 tx_proc_cnt;
|
||||||
@@ -1136,26 +1135,7 @@ static void sdio_tx_work(struct work_struct *work)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
sg_set_buf(&sg[scatters], tx_buffer->buf, align);
|
||||||
* The transfer length is rounded up to the SDIO block
|
|
||||||
* size, but tx_buffer->buf is only tx_buffer->len bytes
|
|
||||||
* long (it usually aliases into an skb linear head).
|
|
||||||
* Copy into a driver-owned bounce buffer and zero-pad
|
|
||||||
* to the aligned size; otherwise DMA reads past the
|
|
||||||
* skb and leaks adjacent kernel memory on the wire --
|
|
||||||
* observed as KFENCE OOB reads from
|
|
||||||
* bes_sdio_memcpy_to_io_helper via dma_map_sg.
|
|
||||||
*/
|
|
||||||
if (WARN_ON_ONCE(total_len + align > MAX_SDIO_TRANSFER_LEN))
|
|
||||||
goto flush_previous;
|
|
||||||
memcpy(self->tx_bounce + total_len,
|
|
||||||
tx_buffer->buf, tx_buffer->len);
|
|
||||||
if (align > tx_buffer->len)
|
|
||||||
memset(self->tx_bounce + total_len +
|
|
||||||
tx_buffer->len, 0,
|
|
||||||
align - tx_buffer->len);
|
|
||||||
sg_set_buf(&sg[scatters],
|
|
||||||
self->tx_bounce + total_len, align);
|
|
||||||
total_len += align;
|
total_len += align;
|
||||||
++scatters;
|
++scatters;
|
||||||
/*del_node:*/
|
/*del_node:*/
|
||||||
@@ -1873,17 +1853,6 @@ static int bes2600_sdio_probe(struct sdio_func *func,
|
|||||||
if (!self->single_gathered_buffer)
|
if (!self->single_gathered_buffer)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
#endif
|
#endif
|
||||||
#ifdef BES_SDIO_TX_MULTIPLE_ENABLE
|
|
||||||
self->tx_bounce = (u8 *)__get_dma_pages(GFP_KERNEL,
|
|
||||||
get_order(MAX_SDIO_TRANSFER_LEN));
|
|
||||||
if (!self->tx_bounce) {
|
|
||||||
#ifndef SDIO_HOST_ADMA_SUPPORT
|
|
||||||
free_pages((unsigned long)self->single_gathered_buffer,
|
|
||||||
get_order(MAX_SDIO_TRANSFER_LEN));
|
|
||||||
#endif
|
|
||||||
return -ENOMEM;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#ifdef BES_SDIO_RXTX_TOGGLE
|
#ifdef BES_SDIO_RXTX_TOGGLE
|
||||||
self->fw_started = false;
|
self->fw_started = false;
|
||||||
#endif
|
#endif
|
||||||
@@ -2012,12 +1981,6 @@ static void bes2600_sdio_remove(struct sdio_func *func)
|
|||||||
if (self->single_gathered_buffer) {
|
if (self->single_gathered_buffer) {
|
||||||
free_pages((unsigned long)self->single_gathered_buffer, get_order(MAX_SDIO_TRANSFER_LEN));
|
free_pages((unsigned long)self->single_gathered_buffer, get_order(MAX_SDIO_TRANSFER_LEN));
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
#ifdef BES_SDIO_TX_MULTIPLE_ENABLE
|
|
||||||
if (self->tx_bounce) {
|
|
||||||
free_pages((unsigned long)self->tx_bounce,
|
|
||||||
get_order(MAX_SDIO_TRANSFER_LEN));
|
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
kfree(self);
|
kfree(self);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user