Re: [PATCH] usb: gadget: f_midi: Use snd_card_free_when_closed with refcount

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,


On 8/18/2017 11:30 AM, Manu Gautam wrote:
> Hi,
>
>
> On 8/15/2017 2:44 AM, Jerry Zhang wrote:

>> @@ -1197,14 +1200,21 @@ static void f_midi_free(struct usb_function *f)
>>  
>>  	midi = func_to_midi(f);
>>  	opts = container_of(f->fi, struct f_midi_opts, func_inst);
> opts could be freed as well if f_midi_free_inst already happened. Say another user
> deleted midi instance  before pcm_file was released.

This would be a regression (use-after-free) with the patch.
Do you plan to fix this as I see Felipe has already queued this for 4.14.

One simple solution could be to fail midi free_instance if pcm device
is in-use/open.


>> -	kfree(midi->id);
>>  	mutex_lock(&opts->lock);
>> -	kfifo_free(&midi->in_req_fifo);
>> -	kfree(midi);
>> -	--opts->refcnt;
>> +	if (!--midi->free_ref) {
>> +		kfree(midi->id);
>> +		kfifo_free(&midi->in_req_fifo);
>> +		kfree(midi);
>> +		--opts->refcnt;
>> +	}
>>  	mutex_unlock(&opts->lock);
>>  }
>>  
>> +static void f_midi_rmidi_free(struct snd_rawmidi *rmidi)
>> +{
>> +	f_midi_free(rmidi->private_data);
>> +}
>> +

-- 
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux