Re: [PATCH for-next v5 08/10] RDMA/rxe: Implement invalidate MW operations

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

 



On Thu, Apr 29, 2021 at 11:32 AM Pearson, Robert B
<rpearsonhpe@xxxxxxxxx> wrote:
>
>
> On 4/28/2021 10:20 PM, Zhu Yanjun wrote:
> > On Thu, Apr 29, 2021 at 11:07 AM Pearson, Robert B
> > <rpearsonhpe@xxxxxxxxx> wrote:
> >>
> >> On 4/28/2021 7:54 PM, Zhu Yanjun wrote:
> >>> Adding a prefix makes debug easy. This can help filter the functions.
> >>> And a prefix can help us to verify the location of the function.
> >>>
> >>> Zhu Yanjun
> >> For comparison here are all the subroutine names from a well known
> >> driver file. As you can see, 100% of the non static subroutines *do*
> >> have mlx5 in their name but the majority of the static ones *do not*,
> >> and these are by definition not shared anywhere else but this file. This
> >> is representative of the typical style in linux-rdma.
> > With perf or ftrace debug tools, a lot of functions will pop out.
> > A prefix can help the developer to locate the functions source code easily.
> > And a prefix can help the developer filter the functions conveniently.
> >
> > This is why I recommend a prefix.
> >
> > Zhu Yanjun
>
> Yes, I can tell. We're still debating this. Obviously the developers of
> mr.c don't entirely agree and I don't either. There are places where it
> makes sense but the code is ugly IMHO. I think you should let developers

A prefix can make code easy to debug, then easy to maintain. This is
not ugly code.^o^
On the contrary, it is beautiful code. ^o^

> write in the style they are most effective with, especially in the
> context of a local static subroutine which have a very narrow scope.

Even though the local static functions still possibly appear in kernel
debug tools,
it is necessary to add a prefix to make it easy to locate and filter.
This can make maintenance
easy.

Zhu Yanjun

>
> Bob
>
> >
> >> Bob
> >>
> >> static    TYPE add_keys()
> >> static    TYPE alloc_cacheable_mr()
> >> static    TYPE alloc_cache_mr()
> >> static    TYPE assign_mkey_variant()
> >> static    TYPE __cache_work_func()
> >> static    TYPE cache_work_func()
> >> static    TYPE can_use_umr_rereg_access()
> >> static    TYPE can_use_umr_rereg_pas()
> >> static    TYPE clean_keys()
> >> static    TYPE create_cache_mr()
> >> static    TYPE create_mkey_callback()
> >> static    TYPE create_real_mr()
> >> static    TYPE create_user_odp_mr()
> >> static    TYPE delayed_cache_work_func()
> >> static    TYPE delay_time_func()
> >> static    TYPE destroy_mkey()
> >> static    TYPE get_cache_mr()
> >> static    TYPE get_octo_len()
> >> static    TYPE limit_read()
> >> static    TYPE limit_write()
> >> static    TYPE mlx5_alloc_integrity_descs()
> >> static    TYPE mlx5_alloc_mem_reg_descs()
> >> static    TYPE _mlx5_alloc_mkey_descs()
> >> static    TYPE mlx5_alloc_priv_descs()
> >> static    TYPE mlx5_alloc_sg_gaps_descs()
> >> static    TYPE mlx5_free_priv_descs()
> >> static    TYPE __mlx5_ib_alloc_mr()
> >> static    TYPE mlx5_ib_alloc_pi_mr()
> >> static    TYPE *mlx5_ib_alloc_xlt()
> >> static    TYPE mlx5_ib_create_mkey()
> >> static    TYPE mlx5_ib_create_mkey_cb()
> >> static    TYPE *mlx5_ib_create_xlt_wr()
> >> static    TYPE mlx5_ib_dmabuf_invalidate_cb()
> >> static    TYPE mlx5_ib_free_xlt()
> >> static    TYPE mlx5_ib_get_dm_mr()
> >> static    TYPE mlx5_ib_init_umr_context()
> >> static    TYPE mlx5_ib_map_klm_mr_sg_pi()
> >> static    TYPE mlx5_ib_map_mtt_mr_sg_pi()
> >> static    TYPE mlx5_ib_map_pa_mr_sg_pi()
> >> static    TYPE mlx5_ib_post_send_wait()
> >> static    TYPE mlx5_ib_sg_to_klms()
> >> static    TYPE mlx5_ib_umr_done()
> >> static    TYPE mlx5_ib_unmap_free_xlt()
> >> static    TYPE mlx5_mr_cache_debugfs_cleanup()
> >> static    TYPE mlx5_mr_cache_debugfs_init()
> >> static    TYPE mlx5_mr_cache_free()
> >> static    TYPE mlx5_set_page()
> >> static    TYPE mlx5_set_page_pi()
> >> static    TYPE mlx5_set_umr_free_mkey()
> >> static    TYPE mlx5_umem_dmabuf_default_pgsz()
> >> static    TYPE mr_cache_ent_from_order()
> >> static    TYPE mr_cache_max_order()
> >> static    TYPE queue_adjust_cache_locked()
> >> static    TYPE reg_create()
> >> static    TYPE remove_cache_mr_locked()
> >> static    TYPE resize_available_mrs()
> >> static    TYPE revoke_mr()
> >> static    TYPE set_mkc_access_pd_addr_fields()
> >> static    TYPE set_mr_fields()
> >> static    TYPE size_read()
> >> static    TYPE size_write()
> >> static    TYPE someone_adding()
> >> static    TYPE umr_can_use_indirect_mkey()
> >> static    TYPE umr_rereg_pas()
> >> static    TYPE umr_rereg_pd_access()
> >> static    TYPE xlt_wr_final_send_flags()
> >>       TYPE mlx5_ib_advise_mr()
> >>       TYPE mlx5_ib_alloc_mr()
> >>       TYPE mlx5_ib_alloc_mr_integrity()
> >>       TYPE mlx5_ib_alloc_mw()
> >>       TYPE mlx5_ib_check_mr_status()
> >>       TYPE mlx5_ib_dealloc_mw()
> >>       TYPE mlx5_ib_dereg_mr()
> >>       TYPE mlx5_ib_get_dma_mr()
> >>       TYPE mlx5_ib_map_mr_sg()
> >>       TYPE mlx5_ib_map_mr_sg_pi()
> >>       TYPE mlx5_ib_reg_dm_mr()
> >>       TYPE mlx5_ib_reg_user_mr()
> >>       TYPE mlx5_ib_reg_user_mr_dmabuf()
> >>       TYPE mlx5_ib_rereg_user_mr()
> >>       TYPE mlx5_ib_update_mr_pas()
> >>       TYPE mlx5_ib_update_xlt()
> >>       TYPE mlx5_mr_cache_cleanup()
> >>       TYPE mlx5_mr_cache_init()
> >>



[Index of Archives]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Photo]     [Yosemite News]     [Yosemite Photos]     [Linux Kernel]     [Linux SCSI]     [XFree86]

  Powered by Linux