Hi Felipe,

On 11/5/2018 4:16 AM, Felipe Balbi wrote:
> Hi,
>
> Thinh Nguyen <thinh.ngu...@synopsys.com> writes:
>> +static void dwc3_dump_gadget_internal_states(struct seq_file *s)
>> +{
>> +    struct dwc3             *dwc = s->private;
>> +    int                     num_selects = 16;
>> +    int                     i;
>> +    u32                     reg;
>> +    u64                     ep_info;
>> +
>> +    for (i = 0; i < num_selects; i++) {
>> +            reg = dwc3_gadget_lsp_register(dwc, i);
>> +            seq_printf(s, "GDBGLSP[%d] = 0x%08x\n", i, reg);
>> +    }
>> +
>> +    for (i = 0; i < dwc->num_eps; i++) {
>> +            ep_info = dwc3_ep_info_register(dwc, i);
>> +            seq_printf(s, "GDBGEPINFO[%d] = 0x%016llx\n", i, ep_info);
>> +    }
>> +}
> we have per-endpoint directories already. Why don't you dump endpoint
> debug info there?

Yes, I can dump it there.


> Also, while at that, could you write a patch that
> properly decodes the queue sizes? It looks to me as the queue sizes are
> in same units as GTXFIFOSIZ registers

Sure. It can be done.

>> +static int dwc3_internal_states_show(struct seq_file *s, void *unused)
>> +{
>> +    struct dwc3             *dwc = s->private;
>> +    unsigned int            current_mode;
>> +    unsigned long           flags;
>> +    u32                     reg;
>> +
>> +    spin_lock_irqsave(&dwc->lock, flags);
>> +    reg = dwc3_readl(dwc->regs, DWC3_GSTS);
>> +    current_mode = DWC3_GSTS_CURMOD(reg);
>> +
>> +    reg = dwc3_readl(dwc->regs, DWC3_GDBGBMU);
>> +    spin_unlock_irqrestore(&dwc->lock, flags);
>> +
>> +    seq_printf(s, "GDBGBMU = 0x%08x\n", reg);
> shouldn't the print be done with locks held?

I think the lock for the prints should be held at a higher level.
Otherwise, I don't think it will make a difference using dwc->lock.

>> +static ssize_t dwc3_internal_states_write(struct file *file,
>> +            const char __user *ubuf, size_t count, loff_t *ppos)
> why is this necessary? Seems like it would be nicer to create a
> directory structure if the current operating mode is host so that we
> don't need to write anything.

Can you clarify more about the directory structure? Actually, I was
wondering what's the best way to do this also. The reason I want to
write to it is because the LSP selection for host is quite large (2^14).
It doesn't make sense to dump everything if the controller is in host
mode. So I force the user to write a specific LSP selection to dump at a
time.

Thanks for the review!
Thinh

Reply via email to