[LTP] [PATCH] kernel/uevent: Adjust the number of uevents dynamically in uevent02

Dylan Jhong dylan@andestech.com
Thu Sep 15 12:32:35 CEST 2022


Hi Cyril,

Oh, i got it!!! Sorry for the misunderstanding.
I thought this was talking about adding the .needs_kconfigs property.
I will add setup() function in v2 patch.

And about the adjustment of uevent declaration, any comments that I can
do in v2 patch?

Best,
Dylan

On Thu, Sep 15, 2022 at 06:09:07PM +0800, Cyril Hrubis wrote:
> Hi!
> > > >  #include "uevent.h"
> > > >  
> > > >  #define TUN_PATH "/dev/net/tun"
> > > >  
> > > > +#define MAX_UEVENT 7
> > > > +
> > > > +struct uevent_desc add = {
> > > > +	.msg = "add@/devices/virtual/net/ltp-tun0",
> > > > +	.value_cnt = 4,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=add",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0",
> > > > +		"SUBSYSTEM=net",
> > > > +		"INTERFACE=ltp-tun0",
> > > > +	}
> > > > +};
> > > > +struct uevent_desc add_rx = {
> > > > +	.msg = "add@/devices/virtual/net/ltp-tun0/queues/rx-0",
> > > > +	.value_cnt = 3,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=add",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0/queues/rx-0",
> > > > +		"SUBSYSTEM=queues",
> > > > +	}
> > > > +};
> > > > +struct uevent_desc add_tx = {
> > > > +	.msg = "add@/devices/virtual/net/ltp-tun0/queues/tx-0",
> > > > +	.value_cnt = 3,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=add",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0/queues/tx-0",
> > > > +		"SUBSYSTEM=queues",
> > > > +	}
> > > > +};
> > > > +struct uevent_desc rem_rx = {
> > > > +	.msg = "remove@/devices/virtual/net/ltp-tun0/queues/rx-0",
> > > > +	.value_cnt = 3,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=remove",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0/queues/rx-0",
> > > > +		"SUBSYSTEM=queues",
> > > > +	}
> > > > +};
> > > > +struct uevent_desc rem_tx = {
> > > > +	.msg = "remove@/devices/virtual/net/ltp-tun0/queues/tx-0",
> > > > +	.value_cnt = 3,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=remove",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0/queues/tx-0",
> > > > +		"SUBSYSTEM=queues",
> > > > +	}
> > > > +};
> > > > +struct uevent_desc rem = {
> > > > +	.msg = "remove@/devices/virtual/net/ltp-tun0",
> > > > +	.value_cnt = 4,
> > > > +	.values = (const char*[]) {
> > > > +		"ACTION=remove",
> > > > +		"DEVPATH=/devices/virtual/net/ltp-tun0",
> > > > +		"SUBSYSTEM=net",
> > > > +		"INTERFACE=ltp-tun0",
> > > > +	}
> > > > +};
> > > 
> > > Why do we have to move these outside of the function? I do not see a
> > > single reason to do so.
> > > 
> > 
> > I think separating the declaration of uevents and dynamic adding uevents 
> > will make the program easier to read.
> > This part is open to discussion, I'm just giving my thoughts.
> > if everyone think it's a bad idea, I'll change it back in v2 patch.
> > 
> > declaration
> > ----------------------------
> > struct uevent_desc rem_tx = {}
> > struct uevent_desc add_rx = {}
> > struct uevent_desc add_tx = {}
> > .....
> > 
> > dynamically adding uevent:
> > --------------------------
> > uevents[i++] = &add;
> > if (has_RPS)
> >         uevents[i++] = &add_rx;
> > uevents[i++] = &add_tx;
> > if (has_RPS)
> >         uevents[i++] = &rem_rx;
> > uevents[i++] = &rem_tx;
> > uevents[i++] = &rem;
> > uevents[i++] = NULL;
> > 
> > > > +	const struct uevent_desc *uevents[MAX_UEVENT];
> > > > +	int pid, fd, i = 0;
> > > > +	int has_RPS = tst_kconfig_get("CONFIG_RPS");
> > > 
> > > Getting the flag should be done once in the test setup, otherwise kernel
> > > config will be parsed in each iteration of the test.
> > > 
> > 
> > If we parse the kernel configuration during test setup, we will block all 
> > images without CONFIG_RPS from executing this testcase. This is not my 
> > intention, in this patch I designed to continue executing uevent02 even 
> > without CONFIG_RPS. Just adjusting uevents can pass this test. So I think 
> > parsing the kernel config in test_all() should be the correct way.
> 
> I do not think that we understand each other here. What I proposed is to
> call the function that parses kernel config in the test setup and
> initialize the has_RPS flag there so that it's not called on each
> interation of the run() function (e.g. when test is passed -i 100 on
> command line).
> 
> -- 
> Cyril Hrubis
> chrubis@suse.cz


More information about the ltp mailing list