On 5/1/2020 5:19 PM, Stephen Hemminger wrote:
> On Fri, 1 May 2020 17:01:40 +0100
> Ferruh Yigit <ferruh.yi...@intel.com> wrote:
> 
>> On 4/27/2020 10:39 PM, Stephen Hemminger wrote:
>>> The TAP driver does not initialize all the elements of the rte_flow
>>> structure. This can lead to crash in rte_flow_destroy.
>>>
>>> (gdb) where
>>>     flow=0x100e99280, error=0x0)
>>>     at drivers/net/tap/tap_flow.c:1514
>>>
>>> (gdb) p remote_flow
>>> $1 = (struct rte_flow *) 0x6b6b6b6b6b6b6b6b
>>>
>>> Which is here:
>>> static int
>>> tap_flow_destroy_pmd(struct pmd_internals *pmd,
>>>                  struct rte_flow *flow,
>>>                  struct rte_flow_error *error)
>>> {
>>>     struct rte_flow *remote_flow = flow->remote_flow;
>>> ...
>>>     if (remote_flow) {
>>>             remote_flow->msg.nh.nlmsg_flags = NLM_F_REQUEST | NLM_F_ACK;
>>>
>>> Simplest fix is to use rte_zmalloc() so remote_flow and other fields
>>> are always set at zero.  
>>
>> Both 'rte_malloc' & 'rte_zmalloc' should be zeroing the allocated memory, 
>> unless
>> MALLOC_DEBUG config option set [1], if this is not the case the issue can be
>> still valid after this change.
> 
> Malloc debug poisons memory to find bugs like this.
> 

Fair enough, if that is the intention use 'rte_zmalloc' to clarify it.

Reviewed-by: Ferruh Yigit <ferruh.yi...@intel.com>

Reply via email to