frontswap: is frontswap_init called from swapoff safe?

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

 



I was looking at the swapfile.c parts of the recently-merged frontswap, and noticed that frontswap_init can be called from swapoff when try_to_unuse fails.

This looks odd to me. Whether it is safe or not depends on what frontswap_ops.init does, but the comment for __frontswap_init ("Called when a swap device is swapon'd") and the function name itself seem to imply it should be called only for swapon, not when relinking the swap_info after a failed swapoff.

In particular, if frontswap_ops.init assumes the swap map is empty, it would break, since as far as I know when try_to_unuse fails there are still pages in the swap.

(By the way, the comment above enable_swap_info at sys_swapoff needs to be updated to also explain why reading p->frontswap_map outside the lock is safe at that point, like it does for p->prio and p->swap_map.)

--
Cesar Eduardo Barros
cesarb@xxxxxxxxxx
cesar.barros@xxxxxxxxx

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxx.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Fight unfair telecom internet charges in Canada: sign http://stopthemeter.ca/
Don't email: <a href=mailto:"dont@xxxxxxxxx";> email@xxxxxxxxx </a>


[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]