FIX | 修改PRPS数据上送失败问题

main
yuliang 6 days ago
parent 993d711d10
commit bb4e536830

@ -53,7 +53,6 @@
/* Exported types ------------------------------------------------------------*/ /* Exported types ------------------------------------------------------------*/
typedef int32_t (*dau_recv_cb)(uint8_t, char*, uint16_t); typedef int32_t (*dau_recv_cb)(uint8_t, char*, uint16_t);
typedef int32_t (*dau_send_cb)(uint8_t, uint8_t, void*); typedef int32_t (*dau_send_cb)(uint8_t, uint8_t, void*);
typedef void (*dau_data_free_cb)(uint8_t);
typedef void (*dau_show_cfg_cb)(uint8_t); typedef void (*dau_show_cfg_cb)(uint8_t);
typedef void (*dau_show_port_cb)(uint8_t, uint8_t); typedef void (*dau_show_port_cb)(uint8_t, uint8_t);
@ -200,7 +199,6 @@ typedef struct
dau_state_t state; // dau 状态 dau_state_t state; // dau 状态
dau_recv_cb recv_cb; // dau 收包处理函数 dau_recv_cb recv_cb; // dau 收包处理函数
dau_send_cb send_cb; // dau 收包处理函数 dau_send_cb send_cb; // dau 收包处理函数
dau_data_free_cb free_cb; // 内存释放函数
dau_show_cfg_cb show_cfg_cb; // 显示全局配置函数 dau_show_cfg_cb show_cfg_cb; // 显示全局配置函数
dau_show_port_cb show_port_cb; // 显示端口配置函数 dau_show_port_cb show_port_cb; // 显示端口配置函数
int32_t fifo_send; // 发包 fifo int32_t fifo_send; // 发包 fifo

@ -325,8 +325,7 @@ typedef struct
/* Extern functions ----------------------------------------------------------*/ /* Extern functions ----------------------------------------------------------*/
extern int32_t hf_recv_process(uint8_t slot, char *pkt, uint16_t len); extern int32_t hf_recv_process(uint8_t slot, char *pkt, uint16_t len);
extern int32_t hf_send_process(uint8_t slot, uint8_t type, void *data); extern int32_t hf_send_process(uint8_t slot, uint8_t type, void *data);
extern void* hf_data_malloc(void); extern void* hf_data_malloc(uint8_t slot);
extern void hf_data_free(uint8_t slot);
extern void hf_show_cfg(uint8_t slot); extern void hf_show_cfg(uint8_t slot);
extern void hf_show_port(uint8_t slot, uint8_t port); extern void hf_show_port(uint8_t slot, uint8_t port);
#endif #endif

@ -237,15 +237,9 @@ int _dau_insert(dau_t *dau)
{ {
if (3 == dau->info.type_m && 1 == dau->info.type_s) if (3 == dau->info.type_m && 1 == dau->info.type_s)
{ {
/* 申请和释放放在一起, 避免地址失效 */ hf_data_malloc(dau->slot);
if (dau->private_data && dau->free_cb)
{
dau->free_cb(dau->slot);
}
dau->private_data = hf_data_malloc();
dau->recv_cb = hf_recv_process; dau->recv_cb = hf_recv_process;
dau->send_cb = hf_send_process; dau->send_cb = hf_send_process;
dau->free_cb = hf_data_free;
dau->show_cfg_cb = hf_show_cfg; dau->show_cfg_cb = hf_show_cfg;
dau->show_port_cb = hf_show_port; dau->show_port_cb = hf_show_port;
} }

@ -564,7 +564,7 @@ void _hf_recv_prps(uint8_t slot, char *pkt, uint16_t len)
{ {
dau_t *dau = &daus[slot]; dau_t *dau = &daus[slot];
hf_data_t *hf_data = (hf_data_t*)dau->private_data; hf_data_t *hf_data = (hf_data_t*)dau->private_data;
hf_prps_t prps = hf_data->prps; hf_prps_t *prps = &hf_data->prps;
hf_prps_t *prps_send = NULL; hf_prps_t *prps_send = NULL;
hf_prps_head_t *head_prps = (hf_prps_head_t*)(pkt + sizeof(dau_pkt_head_t)); hf_prps_head_t *head_prps = (hf_prps_head_t*)(pkt + sizeof(dau_pkt_head_t));
char *data = (char*)(pkt + sizeof(dau_pkt_head_t) + sizeof(hf_prps_head_t)); char *data = (char*)(pkt + sizeof(dau_pkt_head_t) + sizeof(hf_prps_head_t));
@ -573,10 +573,10 @@ void _hf_recv_prps(uint8_t slot, char *pkt, uint16_t len)
/* 第一个报文 */ /* 第一个报文 */
if (0 == head_prps->pkt_index) if (0 == head_prps->pkt_index)
{ {
memcpy(&prps.head, head_prps, sizeof(hf_prps_head_t)); memcpy(&prps->head, head_prps, sizeof(hf_prps_head_t));
} }
point = (char*)prps.prps; point = (char*)prps->prps;
point += head_prps->pkt_index * HF_DATA_LEN; point += head_prps->pkt_index * HF_DATA_LEN;
memcpy(point, data, head_prps->len); memcpy(point, data, head_prps->len);
@ -590,7 +590,7 @@ void _hf_recv_prps(uint8_t slot, char *pkt, uint16_t len)
return; return;
} }
memcpy(prps_send, &prps, sizeof(hf_prps_t)); memcpy(prps_send, prps, sizeof(hf_prps_t));
/* 发送给后台, 内存由后台释放 */ /* 发送给后台, 内存由后台释放 */
if (dau_msg_send(DAU_SEND_PRPS, slot, prps_send) != E_NONE) if (dau_msg_send(DAU_SEND_PRPS, slot, prps_send) != E_NONE)
@ -795,31 +795,32 @@ int32_t hf_send_process(uint8_t slot, uint8_t type, void *data)
} }
/* 高频私有数据 */ /* 高频私有数据 */
void* hf_data_malloc(void) void* hf_data_malloc(uint8_t slot)
{ {
hf_data_t *p = XMALLOC_Q(MTYPE_HF, sizeof(hf_data_t)); dau_t *dau = &daus[slot];
if (!p) hf_data_t *p = (hf_data_t*)dau->private_data;
/* 申请新内存 */
dau->private_data = XMALLOC_Q(MTYPE_HF, sizeof(hf_data_t));
if (!dau->private_data)
{ {
DBG(DBG_M_PD_HF_ERR, "XMALLOC ERROR!\r\n"); DBG(DBG_M_PD_HF_ERR, "XMALLOC ERROR!\r\n");
return NULL; return NULL;
} }
/* 释放旧内存 */
if (p)
{
XFREE(MTYPE_HF, p);
}
p = (hf_data_t*)dau->private_data;
memset(&p->cfg, 0, sizeof(hf_cfg_t)); memset(&p->cfg, 0, sizeof(hf_cfg_t));
memset(&p->port, 0, sizeof(hf_cfg_port_t) * PD_DAU_PORT_SUM); memset(&p->port, 0, sizeof(hf_cfg_port_t) * PD_DAU_PORT_SUM);
return p; return p;
} }
/* 高频私有数据释放 */
void hf_data_free(uint8_t slot)
{
hf_data_t *hf_data = (hf_data_t*)daus[slot].private_data;
XFREE(MTYPE_HF, hf_data);
return;
}
/* 显示全局配置 */ /* 显示全局配置 */
void hf_show_cfg(uint8_t slot) void hf_show_cfg(uint8_t slot)
{ {

Loading…
Cancel
Save