On Mon, Feb 01, 2021 at 06:08:03PM +0200, Andy Shevchenko wrote: > On Mon, Feb 01, 2021 at 02:52:51PM +0100, Christian König wrote: > > Adding the same element to a linked list multiple times > > seems to be a rather common programming mistake. To debug > > those I've more than once written some code to check a > > linked list for duplicates. > > > > Since re-inventing the wheel over and over again is a bad > > idea this patch tries to add some common code which allows > > to check linked lists for duplicates while adding new > > elements. > > > > When list debugging is enabled we currently already check > > the previous and next element if they are identical to the > > new one. This patch now adds a configuration option to > > check N elements before and after the desired position. > > > > By default we still only test one item since testing more > > means quite a large CPU overhead. This can be overwritten > > on a per C file bases by defining DEBUG_LIST_DOUBLE_ADD > > before including list.h. > > I'm not sure it is a good idea. Currently the implementation is *generic*. > You are customizing it w/o letting caller know. > > Create a derivative implementation and name it exlist (exclusive list) and use > whenever it makes sense.
And make depth is a runtime parameter available for user. > And I think if you are still pushing to modify generic one the default must be > 0 in order not altering current behaviour. > > > A new kunit test is also added to the existing list tests > > which intentionally triggers the debug functionality. -- With Best Regards, Andy Shevchenko