Guillaume Thouvenin <[EMAIL PROTECTED]> wrote:
>
> Hello,
> 
>   This patch replaces the relay_fork module and it implements a fork
> connector in the kernel/fork.c:do_fork() routine. The connector sends
> information about parent PID and child PID over a netlink interface. It
> allows to several user space applications to be informed when a fork
> occurs in the kernel. The main drawback is that even if nobody listens,
> message is send. I don't know how to avoid that.

We really should find a way to fix that.  Especially if we want all the
distributors to enable the connector in their builds (we do).

What happened to the idea of sending an on/off message down the netlink
socket?

> +#ifdef CONFIG_FORK_CONNECTOR
> +#define FORK_CN_INFO_SIZE    64 
> +static inline void fork_connector(pid_t parent, pid_t child)
> +{
> +     struct cb_id fork_id = {CN_IDX_FORK, CN_VAL_FORK};

This can be static const, which will save some stack and cycles.

> +     static __u32 seq; /* used to test if we lost message */
> +     
> +     if (cn_already_initialized) {
> +             struct cn_msg *msg;
> +             size_t size;
> +
> +             size = sizeof(*msg) + FORK_CN_INFO_SIZE;
> +             msg = kmalloc(size, GFP_KERNEL);
> +             if (msg) {
> +                     memset(msg, '\0', size);

Do we really need to memset the whole thing?

> +                     memcpy(&msg->id, &fork_id, sizeof(msg->id));
> +                     msg->seq = seq++;

`seq' needs a lock to protect it.  Or use atomic_add_return(), maybe.

> +                     msg->ack = 0; /* not used */
> +                     /* 
> +                      * size of data is the number of characters 
> +                      * printed plus one for the trailing '\0'
> +                      */
> +                     msg->len = snprintf(msg->data, FORK_CN_INFO_SIZE-1, 
> +                                         "%i %i", parent, child) + 1;

scnprintf() would be more appropriate here, even though it should be a "can't
happen".

> +                     cn_netlink_send(msg, CN_IDX_FORK);
> +
> +                     kfree(msg);

`msg' is only 84 bytes and do_fork() has a shallow call graph.  Make `msg'
a local?  

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to