Merge pull request #1199 from ChunfengMu/fix_bugs

1:解决主机端未打开串口时,设备端应用程序dma模式下操作vcom发送数据时,dataqueue条目泄漏的问题。
This commit is contained in:
ZYH 2018-01-31 18:58:21 +08:00 committed by GitHub
commit c9fe93dce2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -260,7 +260,7 @@ static rt_err_t _ep_in_handler(ufunction_t func, rt_size_t size)
RT_DEBUG_LOG(RT_DEBUG_USB, ("_ep_in_handler %d\n", size)); RT_DEBUG_LOG(RT_DEBUG_USB, ("_ep_in_handler %d\n", size));
data = (struct vcom*)func->user_data; data = (struct vcom*)func->user_data;
if ((size != 0) && (size % CDC_MAX_PACKET_SIZE == 0)) if ((size != 0) && ((size % EP_MAXPACKET(data->ep_in)) == 0))
{ {
/* don't have data right now. Send a zero-length-packet to /* don't have data right now. Send a zero-length-packet to
* terminate the transaction. * terminate the transaction.
@ -707,6 +707,8 @@ static rt_size_t _vcom_tx(struct rt_serial_device *serial, rt_uint8_t *buf, rt_s
level = rt_hw_interrupt_disable(); level = rt_hw_interrupt_disable();
size += rt_ringbuffer_put_force(&data->tx_ringbuffer, (const rt_uint8_t *)&buf[size], ptr - size); size += rt_ringbuffer_put_force(&data->tx_ringbuffer, (const rt_uint8_t *)&buf[size], ptr - size);
rt_hw_interrupt_enable(level); rt_hw_interrupt_enable(level);
/* no data was be ignored */
if(size == ptr) if(size == ptr)
{ {
level = rt_hw_interrupt_disable(); level = rt_hw_interrupt_disable();
@ -722,6 +724,8 @@ static rt_size_t _vcom_tx(struct rt_serial_device *serial, rt_uint8_t *buf, rt_s
empty = 1; empty = 1;
break; break;
} }
/* ring buffer is full */
if(size == ptr) if(size == ptr)
{ {
empty = 1; empty = 1;
@ -735,6 +739,7 @@ static rt_size_t _vcom_tx(struct rt_serial_device *serial, rt_uint8_t *buf, rt_s
} }
} }
} }
if(size < baksize && !empty) if(size < baksize && !empty)
{ {
level = rt_hw_interrupt_disable(); level = rt_hw_interrupt_disable();
@ -742,12 +747,17 @@ static rt_size_t _vcom_tx(struct rt_serial_device *serial, rt_uint8_t *buf, rt_s
rt_hw_interrupt_enable(level); rt_hw_interrupt_enable(level);
} }
if(size) if(size)
{ {
rt_event_send(&data->tx_event, CDC_TX_HAS_DATE); rt_event_send(&data->tx_event, CDC_TX_HAS_DATE);
} }
} }
else
{
/* recover dataqueue resources */
rt_hw_serial_isr(&data->serial,RT_SERIAL_EVENT_TX_DMADONE);
}
return size; return size;
} }
static int _vcom_putc(struct rt_serial_device *serial, char c) static int _vcom_putc(struct rt_serial_device *serial, char c)