Hi Sergey, On 24-09-24 00:47, Sergey Senozhatsky wrote: > ** Re-sending properly, somehow I managed to badly mess up > the headers the first time, sorry *** > > > On (24/09/24 00:34), Sergey Senozhatsky wrote: > > On (24/09/23 11:02), Andrey Skvortsov wrote: > > > for (prio = ZRAM_SECONDARY_COMP; prio < ZRAM_MAX_COMPS; prio++) { > > > - kfree(zram->comp_algs[prio]); > > > + /* Do not free statically defined compression algorithms */ > > > > We probably don't really need this comment. > > > > > + if (zram->comp_algs[prio] != default_compressor) > > > + kfree(zram->comp_algs[prio]); > > > zram->comp_algs[prio] = NULL; > > > } > > > > OK, so... I wonder how do you get a `default_compressor` on a > > non-ZRAM_PRIMARY_COMP prio. May I ask what's your reproducer? > > > > I didn't expect `default_compressor` on ZRAM_SECONDARY_COMP > > and below. As far as I can tell, we only do this: > > > > comp_algorithm_set(zram, ZRAM_PRIMARY_COMP, default_compressor); > > > > in zram_reset_device() and zram_add(). So, how does it end up in > > ZRAM_SECONDARY_COMP... > > Ugh, I know what's happening. You don't have CONFIG_ZRAM_MULTI_COMP > so that ZRAM_PRIMARY_COMP and ZRAM_SECONDARY_COMP are the same thing. > Yeah, that all makes sense now, I haven't thought about it. yes, I don't have CONFIG_ZRAM_MULTI_COMP set. I'll include your comment into commit description for v2. > Can you please send v2 (with the feedback resolved). -- Best regards, Andrey Skvortsov