2003-07-17 15:24:51 +07:00
|
|
|
/*
|
2005-03-13 04:36:32 +07:00
|
|
|
* udev_rules.c
|
2003-07-17 15:24:51 +07:00
|
|
|
*
|
|
|
|
* Userspace devfs
|
|
|
|
*
|
|
|
|
* Copyright (C) 2003 Greg Kroah-Hartman <greg@kroah.com>
|
2005-02-14 12:03:06 +07:00
|
|
|
* Copyright (C) 2003-2005 Kay Sievers <kay.sievers@vrfy.org>
|
2003-07-17 15:24:51 +07:00
|
|
|
*
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
|
|
* under the terms of the GNU General Public License as published by the
|
|
|
|
* Free Software Foundation version 2 of the License.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <ctype.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <errno.h>
|
2003-10-15 13:32:17 +07:00
|
|
|
#include <sys/wait.h>
|
2003-07-17 15:24:51 +07:00
|
|
|
|
2004-02-24 10:07:25 +07:00
|
|
|
#include "libsysfs/sysfs/libsysfs.h"
|
2003-07-17 15:24:51 +07:00
|
|
|
#include "list.h"
|
2005-03-07 10:29:43 +07:00
|
|
|
#include "udev_libc_wrapper.h"
|
2003-07-17 15:24:51 +07:00
|
|
|
#include "udev.h"
|
2004-11-25 08:44:38 +07:00
|
|
|
#include "udev_utils.h"
|
2003-07-17 15:24:51 +07:00
|
|
|
#include "udev_version.h"
|
[PATCH] add udev logging to info log
On Thu, Jan 15, 2004 at 05:14:16AM +0100, Kay Sievers wrote:
> On Wed, Jan 14, 2004 at 01:10:43PM -0800, Greg KH wrote:
> > On Wed, Jan 14, 2004 at 02:34:26PM -0600, Clay Haapala wrote:
> > > On Wed, 14 Jan 2004, Chris Friesen spake thusly:
> > > >
> > > > Maybe for ones with a matching rule, you could print something like:
> > > >
> > > >
> > > Is the act of printing/syslogging a rule in an of itself?
> >
> > No, as currently the only way stuff ends up in the syslog is if
> > DEBUG=true is used on the build line.
> >
> > But it's sounding like we might want to change that... :)
>
> How about this in the syslog after connect/disconnect?
>
> Jan 15 05:07:45 pim udev[28007]: configured rule in '/etc/udev/udev.rules' at line 17 applied, 'video*' becomes 'video/webcam%n'
> Jan 15 05:07:45 pim udev[28007]: creating device node '/udev/video/webcam0'
> Jan 15 05:07:47 pim udev[28015]: removing device node '/udev/video/webcam0'
Here is a slightly better version. I've created a logging.h file and
moved the debug macros from udev.h in there.
If you type:
'make' - you will get a binary that prints one or two lines to syslog
if a device node is created or deleted
'make LOG=false' - you get a binary that prints asolutely nothing
'make DEBUG=true' - the same as today, it will print all debug lines
2004-01-16 12:53:20 +07:00
|
|
|
#include "logging.h"
|
2005-03-13 04:36:32 +07:00
|
|
|
#include "udev_rules.h"
|
2004-11-12 12:32:19 +07:00
|
|
|
#include "udev_db.h"
|
2003-07-17 15:24:51 +07:00
|
|
|
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
|
2003-12-03 21:22:53 +07:00
|
|
|
/* compare string with pattern (supports * ? [0-9] [!A-Z]) */
|
|
|
|
static int strcmp_pattern(const char *p, const char *s)
|
2003-11-24 12:14:33 +07:00
|
|
|
{
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if (s[0] == '\0') {
|
|
|
|
while (p[0] == '*')
|
2003-12-03 21:22:53 +07:00
|
|
|
p++;
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
return (p[0] != '\0');
|
2003-12-03 21:22:53 +07:00
|
|
|
}
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
switch (p[0]) {
|
2003-12-03 21:22:53 +07:00
|
|
|
case '[':
|
|
|
|
{
|
|
|
|
int not = 0;
|
|
|
|
p++;
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if (p[0] == '!') {
|
2003-12-03 21:22:53 +07:00
|
|
|
not = 1;
|
|
|
|
p++;
|
|
|
|
}
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
while ((p[0] != '\0') && (p[0] != ']')) {
|
2003-12-03 21:22:53 +07:00
|
|
|
int match = 0;
|
|
|
|
if (p[1] == '-') {
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if ((s[0] >= p[0]) && (s[0] <= p[2]))
|
2003-12-03 21:22:53 +07:00
|
|
|
match = 1;
|
|
|
|
p += 3;
|
|
|
|
} else {
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
match = (p[0] == s[0]);
|
2003-12-03 21:22:53 +07:00
|
|
|
p++;
|
|
|
|
}
|
|
|
|
if (match ^ not) {
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
while ((p[0] != '\0') && (p[0] != ']'))
|
2003-12-03 21:22:53 +07:00
|
|
|
p++;
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if (p[0] == ']')
|
|
|
|
return strcmp_pattern(p+1, s+1);
|
2003-12-03 21:22:53 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case '*':
|
|
|
|
if (strcmp_pattern(p, s+1))
|
|
|
|
return strcmp_pattern(p+1, s);
|
|
|
|
return 0;
|
|
|
|
case '\0':
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if (s[0] == '\0') {
|
2003-12-03 21:22:53 +07:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
[PATCH] fix possible buffer overflow
On Tue, Jan 27, 2004 at 11:02:25AM -0800, Greg KH wrote:
> On Mon, Jan 26, 2004 at 07:28:03PM -0500, Adrian Drzewiecki wrote:
> > Looking over the code, I noticed something odd in
> > namedev.c:strcmp_pattern() --
> >
> > while (*p && (*p != ']'))
> > p ++;
> > return strcmp_pattern(p+1, s+1);
> >
> > If the pattern string is invalid, and is not terminated by a ']', then 'p'
> > will point at \0 and p+1 will be beyond the string.
>
> Yes, I think you are correct.
>
> Hm, Kay, any idea of the proper way to fix this? I've attached a patch
> below, but I don't think it is correct.
>
> while (*p && (*p != ']'))
> p++;
> - return strcmp_pattern(p+1, s+1);
> + if (*p)
> + return strcmp_pattern(p+1, s+1);
> + else
> + return 1;
> }
> }
Sure, it's perfectly correct. I'm wondering how Adrian found this.
We can use the return 1 at the end of the whole function, and asking
for the closing ']' is more descriptive, but it does the same.
- return strcmp_pattern(p+1, s+1);
+ if (*p == ']')
+ return strcmp_pattern(p+1, s+1);
Patch is attached, that also replaces all the *s with s[0].
2004-01-29 10:00:51 +07:00
|
|
|
if ((p[0] == s[0]) || (p[0] == '?'))
|
2003-12-03 21:22:53 +07:00
|
|
|
return strcmp_pattern(p+1, s+1);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return 1;
|
2003-11-24 12:14:33 +07:00
|
|
|
}
|
|
|
|
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
/* extract possible {attr} and move str behind it */
|
|
|
|
static char *get_format_attribute(char **str)
|
|
|
|
{
|
|
|
|
char *pos;
|
|
|
|
char *attr = NULL;
|
|
|
|
|
|
|
|
if (*str[0] == '{') {
|
|
|
|
pos = strchr(*str, '}');
|
|
|
|
if (pos == NULL) {
|
2005-03-27 06:11:03 +07:00
|
|
|
err("missing closing brace for format");
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
pos[0] = '\0';
|
|
|
|
attr = *str+1;
|
|
|
|
*str = pos+1;
|
|
|
|
dbg("attribute='%s', str='%s'", attr, *str);
|
|
|
|
}
|
|
|
|
return attr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* extract possible format length and move str behind it*/
|
|
|
|
static int get_format_len(char **str)
|
|
|
|
{
|
|
|
|
int num;
|
|
|
|
char *tail;
|
|
|
|
|
|
|
|
if (isdigit(*str[0])) {
|
|
|
|
num = (int) strtoul(*str, &tail, 10);
|
2004-03-02 14:17:59 +07:00
|
|
|
if (num > 0) {
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
*str = tail;
|
|
|
|
dbg("format length=%i", num);
|
|
|
|
return num;
|
|
|
|
} else {
|
2005-03-27 06:11:03 +07:00
|
|
|
err("format parsing error '%s'", *str);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
/** Finds the lowest positive N such that <name>N isn't present in
|
|
|
|
* $(udevroot) either as a file or a symlink.
|
|
|
|
*
|
|
|
|
* @param name Name to check for
|
|
|
|
* @return 0 if <name> didn't exist and N otherwise.
|
|
|
|
*/
|
2004-11-06 20:28:01 +07:00
|
|
|
static int find_free_number(struct udevice *udev, const char *name)
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
{
|
2005-03-07 10:29:43 +07:00
|
|
|
char devpath[PATH_SIZE];
|
|
|
|
char filename[PATH_SIZE];
|
2004-11-06 20:28:01 +07:00
|
|
|
int num = 0;
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcpy(filename, name, sizeof(filename));
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
while (1) {
|
2004-11-06 20:28:01 +07:00
|
|
|
dbg("look for existing node '%s'", filename);
|
2005-03-07 10:29:43 +07:00
|
|
|
if (udev_db_search_name(devpath, sizeof(devpath), filename) != 0) {
|
2004-11-06 20:28:01 +07:00
|
|
|
dbg("free num=%d", num);
|
|
|
|
return num;
|
|
|
|
}
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
|
2004-11-06 20:28:01 +07:00
|
|
|
num++;
|
|
|
|
if (num > 1000) {
|
|
|
|
info("find_free_number gone crazy (num=%d), aborted", num);
|
|
|
|
return -1;
|
|
|
|
}
|
2005-03-07 10:29:43 +07:00
|
|
|
snprintf(filename, sizeof(filename), "%s%d", name, num);
|
|
|
|
filename[sizeof(filename)-1] = '\0';
|
2004-11-06 20:28:01 +07:00
|
|
|
}
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
}
|
|
|
|
|
2005-03-27 06:15:07 +07:00
|
|
|
static int find_sysfs_attribute(struct sysfs_class_device *class_dev, struct sysfs_device *sysfs_device,
|
|
|
|
const char *name, char *value, size_t len)
|
|
|
|
{
|
|
|
|
struct sysfs_attribute *tmpattr;
|
|
|
|
|
|
|
|
dbg("look for device attribute '%s'", name);
|
|
|
|
if (class_dev) {
|
2005-06-20 05:29:38 +07:00
|
|
|
dbg("look for class attribute '%s/%s'", class_dev->path, name);
|
2005-03-27 06:15:07 +07:00
|
|
|
tmpattr = sysfs_get_classdev_attr(class_dev, name);
|
|
|
|
if (tmpattr)
|
|
|
|
goto attr_found;
|
|
|
|
}
|
|
|
|
if (sysfs_device) {
|
2005-06-20 05:29:38 +07:00
|
|
|
dbg("look for devices attribute '%s/%s'", sysfs_device->path, name);
|
2005-03-27 06:15:07 +07:00
|
|
|
tmpattr = sysfs_get_device_attr(sysfs_device, name);
|
|
|
|
if (tmpattr)
|
|
|
|
goto attr_found;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
attr_found:
|
|
|
|
strlcpy(value, tmpattr->value, len);
|
|
|
|
remove_trailing_char(value, '\n');
|
|
|
|
|
|
|
|
dbg("found attribute '%s'", tmpattr->path);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
[PATCH] udev - safer string handling - part two
As promised, here is the next round. We provide in addition to the
already used macros:
strfieldcpy(to, from)
strfieldcat(to, from)
the corresponding friends, if the size of the target is not known and
must be provided by the caller:
strnfieldcpy(to, from, maxsize)
strnfieldcat(to, from, maxsize)
and switch nearly all possibly unsafe users of strcat(), strncat(),
strcpy() and strncpy() to these safer macros.
The last known remaining issue seems the use of sprintf() and
snprintf(). I will take on it later today or tomorrow.
2004-02-27 10:40:22 +07:00
|
|
|
static void apply_format(struct udevice *udev, char *string, size_t maxsize,
|
2005-03-05 02:52:19 +07:00
|
|
|
struct sysfs_class_device *class_dev, struct sysfs_device *sysfs_device)
|
2003-11-24 13:25:13 +07:00
|
|
|
{
|
2005-03-07 10:29:43 +07:00
|
|
|
char temp[PATH_SIZE];
|
|
|
|
char temp2[PATH_SIZE];
|
2005-06-20 05:29:38 +07:00
|
|
|
char *head, *tail, *cpos, *attr, *rest;
|
2004-02-28 21:53:25 +07:00
|
|
|
int len;
|
2004-02-17 16:29:03 +07:00
|
|
|
int i;
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
unsigned int next_free_number;
|
2005-02-10 15:03:55 +07:00
|
|
|
struct sysfs_class_device *class_dev_parent;
|
2005-06-20 05:29:38 +07:00
|
|
|
enum subst_type {
|
|
|
|
SUBST_UNKNOWN,
|
|
|
|
SUBST_DEVPATH,
|
|
|
|
SUBST_ID,
|
|
|
|
SUBST_KERNEL_NUMBER,
|
|
|
|
SUBST_KERNEL_NAME,
|
|
|
|
SUBST_MAJOR,
|
|
|
|
SUBST_MINOR,
|
|
|
|
SUBST_RESULT,
|
|
|
|
SUBST_SYSFS,
|
|
|
|
SUBST_ENUM,
|
|
|
|
SUBST_PARENT,
|
|
|
|
SUBST_TEMP_NODE,
|
|
|
|
SUBST_ROOT,
|
|
|
|
SUBST_MODALIAS,
|
|
|
|
};
|
|
|
|
static const struct subst_map {
|
|
|
|
char *name;
|
|
|
|
char fmt;
|
|
|
|
enum subst_type type;
|
|
|
|
} map[] = {
|
|
|
|
{ .name = "devpath", .fmt = 'p', .type = SUBST_DEVPATH },
|
|
|
|
{ .name = "id", .fmt = 'b', .type = SUBST_ID },
|
|
|
|
{ .name = "number", .fmt = 'n', .type = SUBST_KERNEL_NUMBER },
|
|
|
|
{ .name = "kernel", .fmt = 'k', .type = SUBST_KERNEL_NAME },
|
|
|
|
{ .name = "major", .fmt = 'M', .type = SUBST_MAJOR },
|
|
|
|
{ .name = "minor", .fmt = 'm', .type = SUBST_MINOR },
|
|
|
|
{ .name = "result", .fmt = 'c', .type = SUBST_RESULT },
|
|
|
|
{ .name = "sysfs", .fmt = 's', .type = SUBST_SYSFS },
|
|
|
|
{ .name = "enum", .fmt = 'e', .type = SUBST_ENUM },
|
|
|
|
{ .name = "parent", .fmt = 'P', .type = SUBST_PARENT },
|
|
|
|
{ .name = "tempnode", .fmt = 'N', .type = SUBST_TEMP_NODE },
|
|
|
|
{ .name = "root", .fmt = 'r', .type = SUBST_ROOT },
|
|
|
|
{ .name = "modalias", .fmt = 'A', .type = SUBST_MODALIAS },
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
enum subst_type type;
|
|
|
|
const struct subst_map *subst;
|
|
|
|
|
|
|
|
head = string;
|
2003-11-24 13:25:13 +07:00
|
|
|
while (1) {
|
2005-06-20 05:29:38 +07:00
|
|
|
len = -1;
|
|
|
|
while (head[0] != '\0') {
|
|
|
|
if (head[0] == '$') {
|
|
|
|
/* substitute named variable */
|
|
|
|
if (head[1] == '\0')
|
|
|
|
break;
|
|
|
|
if (head[1] == '$') {
|
|
|
|
strlcpy(temp, head+2, sizeof(temp));
|
|
|
|
strlcpy(head+1, temp, maxsize);
|
|
|
|
head++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
head[0] = '\0';
|
|
|
|
for (subst = map; subst->name; subst++) {
|
|
|
|
if (strncasecmp(&head[1], subst->name, strlen(subst->name)) == 0) {
|
|
|
|
type = subst->type;
|
|
|
|
tail = head + strlen(subst->name)+1;
|
|
|
|
dbg("will substitute format name '%s'", subst->name);
|
|
|
|
goto found;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (head[0] == '%') {
|
|
|
|
/* substitute format char */
|
|
|
|
if (head[1] == '\0')
|
|
|
|
break;
|
|
|
|
if (head[1] == '%') {
|
|
|
|
strlcpy(temp, head+2, sizeof(temp));
|
|
|
|
strlcpy(head+1, temp, maxsize);
|
|
|
|
head++;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
head[0] = '\0';
|
|
|
|
tail = head+1;
|
|
|
|
len = get_format_len(&tail);
|
|
|
|
for (subst = map; subst->name; subst++) {
|
|
|
|
if (tail[0] == subst->fmt) {
|
|
|
|
type = subst->type;
|
|
|
|
tail++;
|
|
|
|
dbg("will substitute format char '%c'", subst->fmt);
|
|
|
|
goto found;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
head++;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
found:
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
attr = get_format_attribute(&tail);
|
2005-06-20 05:29:38 +07:00
|
|
|
strlcpy(temp, tail, sizeof(temp));
|
|
|
|
dbg("format=%i, string='%s', tail='%s', class_dev=%p, sysfs_dev=%p",
|
|
|
|
type ,string, tail, class_dev, sysfs_device);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
|
2005-06-20 05:29:38 +07:00
|
|
|
switch (type) {
|
|
|
|
case SUBST_DEVPATH:
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->devpath, maxsize);
|
2005-06-20 05:29:38 +07:00
|
|
|
dbg("substitute devpath '%s'", udev->devpath);
|
2005-02-09 10:37:32 +07:00
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_ID:
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->bus_id, maxsize);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
dbg("substitute bus_id '%s'", udev->bus_id);
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_KERNEL_NAME:
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->kernel_name, maxsize);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
dbg("substitute kernel name '%s'", udev->kernel_name);
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_KERNEL_NUMBER:
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->kernel_number, maxsize);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
dbg("substitute kernel number '%s'", udev->kernel_number);
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_MAJOR:
|
2005-03-05 12:50:09 +07:00
|
|
|
sprintf(temp2, "%d", major(udev->devt));
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, temp2, maxsize);
|
2005-03-05 12:50:09 +07:00
|
|
|
dbg("substitute major number '%s'", temp2);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_MINOR:
|
|
|
|
sprintf(temp2, "%d", minor(udev->devt));
|
|
|
|
strlcat(string, temp2, maxsize);
|
|
|
|
dbg("substitute minor number '%s'", temp2);
|
|
|
|
break;
|
|
|
|
case SUBST_RESULT:
|
2005-03-05 02:52:19 +07:00
|
|
|
if (udev->program_result[0] == '\0')
|
2003-11-24 13:25:13 +07:00
|
|
|
break;
|
2004-02-17 16:29:03 +07:00
|
|
|
/* get part part of the result string */
|
2004-02-28 21:53:25 +07:00
|
|
|
i = 0;
|
2004-02-17 16:29:03 +07:00
|
|
|
if (attr != NULL)
|
2004-03-11 16:37:18 +07:00
|
|
|
i = strtoul(attr, &rest, 10);
|
2004-02-17 16:29:03 +07:00
|
|
|
if (i > 0) {
|
2005-03-05 12:50:09 +07:00
|
|
|
dbg("request part #%d of result string", i);
|
|
|
|
cpos = udev->program_result;
|
|
|
|
while (--i) {
|
|
|
|
while (cpos[0] != '\0' && !isspace(cpos[0]))
|
|
|
|
cpos++;
|
|
|
|
while (isspace(cpos[0]))
|
|
|
|
cpos++;
|
[PATCH] get part of callout return string
Try this patch if you like, to get special parts of the callout output.
This beast works now:
CALLOUT, BUS="scsi", PROGRAM="/bin/echo -n node link1 link2", ID="node *", NAME="%1c", SYMLINK="%2c %3c"
The callout returned string is separated by spaces and is
addressed by the "len" value of the 'c' format char.
Since we support symlinks, this my be useful for other uses of callout too.
introduce 'len number' for format chars
the first use is 'c'-the callout return to select a part of the output string like:
CALLOUT, BUS="scsi", PROGRAM="/bin/echo -n node link1 link2", ID="node *", NAME="%1c", SYMLINK="%2c %3c"
(note: first part is requested by len=1, len=0 will return the whole string)
add a test to udev-test.pl
2003-12-16 13:54:38 +07:00
|
|
|
}
|
2004-03-04 09:16:35 +07:00
|
|
|
if (i > 0) {
|
2005-03-27 06:11:03 +07:00
|
|
|
err("requested part of result string not found");
|
2004-03-04 09:16:35 +07:00
|
|
|
break;
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
}
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcpy(temp2, cpos, sizeof(temp2));
|
2005-03-05 12:50:09 +07:00
|
|
|
/* %{2+}c copies the whole string from the second part on */
|
|
|
|
if (rest[0] != '+') {
|
|
|
|
cpos = strchr(temp2, ' ');
|
|
|
|
if (cpos)
|
|
|
|
cpos[0] = '\0';
|
|
|
|
}
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, temp2, maxsize);
|
2004-03-04 15:54:13 +07:00
|
|
|
dbg("substitute part of result string '%s'", temp2);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
} else {
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->program_result, maxsize);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
dbg("substitute result string '%s'", udev->program_result);
|
2003-11-24 13:25:13 +07:00
|
|
|
}
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_SYSFS:
|
2005-02-21 20:01:23 +07:00
|
|
|
if (attr == NULL) {
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
dbg("missing attribute");
|
2005-02-21 20:01:23 +07:00
|
|
|
break;
|
|
|
|
}
|
2005-03-27 06:15:07 +07:00
|
|
|
if (find_sysfs_attribute(class_dev, sysfs_device, attr, temp2, sizeof(temp2)) != 0) {
|
2005-03-28 16:22:17 +07:00
|
|
|
struct sysfs_device *parent_device;
|
|
|
|
|
|
|
|
dbg("sysfs attribute '%s' not found, walk up the physical devices", attr);
|
|
|
|
parent_device = sysfs_get_device_parent(sysfs_device);
|
|
|
|
while (parent_device) {
|
|
|
|
dbg("looking at '%s'", parent_device->path);
|
|
|
|
if (find_sysfs_attribute(NULL, parent_device, attr, temp2, sizeof(temp2)) == 0)
|
|
|
|
break;
|
|
|
|
parent_device = sysfs_get_device_parent(parent_device);
|
|
|
|
}
|
|
|
|
if (!parent_device)
|
|
|
|
break;
|
2005-02-21 20:01:23 +07:00
|
|
|
}
|
2005-03-27 06:15:07 +07:00
|
|
|
/* strip trailing whitespace of sysfs value */
|
|
|
|
i = strlen(temp2);
|
|
|
|
while (i > 0 && isspace(temp2[i-1]))
|
|
|
|
temp2[--i] = '\0';
|
|
|
|
replace_untrusted_chars(temp2);
|
|
|
|
strlcat(string, temp2, maxsize);
|
|
|
|
dbg("substitute sysfs value '%s'", temp2);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_ENUM:
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
next_free_number = find_free_number(udev, string);
|
|
|
|
if (next_free_number > 0) {
|
2004-11-06 20:28:01 +07:00
|
|
|
sprintf(temp2, "%d", next_free_number);
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, temp2, maxsize);
|
[PATCH] compatibility symlinks for udev
On Mon, 2004-09-06 at 17:45 +0200, Kay Sievers wrote:
> On Mon, 2004-09-06 at 16:46 +0200, David Zeuthen wrote:
>
> Nice, I like it. It's a easy way to group device nodes of the same type,
> but coming from different kernel subsystems.
>
That's a good way of putting it, yeah.
> > Here's a patch against udev-030 that can help create compatibility
> > symlinks like /dev/cdrom, /dev/cdrom1 etc. The patch introduces a new
> > substitution type %C (for Compatibility) that can be used as follows
>
> I suggest using %e for enumeration here, cause "compatibility" can
> easily be misunderstood.
>
Good point, I've changed that.
> And we need a few lines added to the man page at udev.8.in :)
>
Done. I've also added an example.
Also, Kay pointed out offlist that the rules can be written to not
require a shell script; this actually works
KERNEL="sr*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="scd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="pcd*", NAME="%k", SYMLINK="cdrom%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="cdrom", NAME="\%k", SYMLINK="cdrom%e"
KERNEL="fd[0-9]", NAME="%k", SYMLINK="floppy%e"
KERNEL="hd[a-z]", PROGRAM="/bin/cat /proc/ide/%k/media", RESULT="floppy", NAME=\"%k", SYMLINK="floppy%e"
New patch is attached.
David
2004-09-11 11:04:13 +07:00
|
|
|
}
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_PARENT:
|
2005-02-21 19:48:10 +07:00
|
|
|
if (!class_dev)
|
|
|
|
break;
|
2005-02-10 15:03:55 +07:00
|
|
|
class_dev_parent = sysfs_get_classdev_parent(class_dev);
|
|
|
|
if (class_dev_parent != NULL) {
|
|
|
|
struct udevice udev_parent;
|
|
|
|
|
|
|
|
dbg("found parent '%s', get the node name", class_dev_parent->path);
|
2005-03-29 16:25:52 +07:00
|
|
|
udev_init_device(&udev_parent, NULL, NULL, NULL);
|
2005-02-10 15:03:55 +07:00
|
|
|
/* lookup the name in the udev_db with the DEVPATH of the parent */
|
2005-03-05 11:35:31 +07:00
|
|
|
if (udev_db_get_device(&udev_parent, &class_dev_parent->path[strlen(sysfs_path)]) == 0) {
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev_parent.name, maxsize);
|
2005-02-10 15:03:55 +07:00
|
|
|
dbg("substitute parent node name'%s'", udev_parent.name);
|
|
|
|
} else
|
|
|
|
dbg("parent not found in database");
|
2005-03-05 11:35:31 +07:00
|
|
|
udev_cleanup_device(&udev_parent);
|
2005-02-10 15:03:55 +07:00
|
|
|
}
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_TEMP_NODE:
|
2005-02-09 10:37:32 +07:00
|
|
|
if (udev->tmp_node[0] == '\0') {
|
|
|
|
dbg("create temporary device node for callout");
|
2005-03-07 10:29:43 +07:00
|
|
|
snprintf(udev->tmp_node, sizeof(udev->tmp_node), "%s/.tmp-%u-%u",
|
|
|
|
udev_root, major(udev->devt), minor(udev->devt));
|
|
|
|
udev->tmp_node[sizeof(udev->tmp_node)-1] = '\0';
|
2005-02-21 19:44:39 +07:00
|
|
|
udev_make_node(udev, udev->tmp_node, udev->devt, 0600, 0, 0);
|
2005-02-09 10:37:32 +07:00
|
|
|
}
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev->tmp_node, maxsize);
|
2005-02-09 10:37:32 +07:00
|
|
|
dbg("substitute temporary device node name '%s'", udev->tmp_node);
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_ROOT:
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcat(string, udev_root, maxsize);
|
2005-02-10 15:03:55 +07:00
|
|
|
dbg("substitute udev_root '%s'", udev_root);
|
|
|
|
break;
|
2005-06-20 05:29:38 +07:00
|
|
|
case SUBST_MODALIAS:
|
|
|
|
if (find_sysfs_attribute(NULL, sysfs_device, "modalias", temp2, sizeof(temp2)) != 0)
|
|
|
|
break;
|
|
|
|
strlcat(string, temp2, maxsize);
|
|
|
|
dbg("substitute MODALIAS '%s'", temp2);
|
|
|
|
break;
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
default:
|
2005-06-20 05:29:38 +07:00
|
|
|
err("unknown substitution type=%i", type);
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
break;
|
|
|
|
}
|
2005-06-20 05:29:38 +07:00
|
|
|
/* possibly truncate to format-char specified length */
|
|
|
|
if (len != -1) {
|
|
|
|
head[len] = '\0';
|
|
|
|
dbg("truncate to %i chars, subtitution string becomes '%s'", len, head);
|
|
|
|
}
|
2004-02-28 21:53:25 +07:00
|
|
|
|
2005-06-20 05:29:38 +07:00
|
|
|
strlcat(string, temp, maxsize);
|
2003-11-24 13:25:13 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-03-29 16:25:52 +07:00
|
|
|
static int execute_program_pipe(const char *command, const char *subsystem, char *value, int len)
|
2003-10-15 13:32:17 +07:00
|
|
|
{
|
|
|
|
int retval;
|
2004-03-11 16:36:12 +07:00
|
|
|
int count;
|
2003-10-15 13:32:17 +07:00
|
|
|
int status;
|
2005-03-29 16:25:52 +07:00
|
|
|
int pipefds[2];
|
2003-10-15 13:32:17 +07:00
|
|
|
pid_t pid;
|
2003-12-16 13:38:18 +07:00
|
|
|
char *pos;
|
2005-03-07 10:29:43 +07:00
|
|
|
char arg[PATH_SIZE];
|
|
|
|
char *argv[(sizeof(arg) / 2) + 1];
|
2005-03-29 16:25:52 +07:00
|
|
|
int devnull;
|
2003-11-21 21:48:01 +07:00
|
|
|
int i;
|
2003-10-15 13:32:17 +07:00
|
|
|
|
2005-03-29 16:25:52 +07:00
|
|
|
strlcpy(arg, command, sizeof(arg));
|
2004-03-11 16:36:12 +07:00
|
|
|
i = 0;
|
2005-03-29 16:25:52 +07:00
|
|
|
if (strchr(arg, ' ')) {
|
2004-03-11 16:36:12 +07:00
|
|
|
pos = arg;
|
|
|
|
while (pos != NULL) {
|
|
|
|
if (pos[0] == '\'') {
|
|
|
|
/* don't separate if in apostrophes */
|
|
|
|
pos++;
|
|
|
|
argv[i] = strsep(&pos, "\'");
|
2004-09-14 20:50:38 +07:00
|
|
|
while (pos && pos[0] == ' ')
|
2004-03-11 16:36:12 +07:00
|
|
|
pos++;
|
2004-09-14 20:50:38 +07:00
|
|
|
} else {
|
2004-03-11 16:36:12 +07:00
|
|
|
argv[i] = strsep(&pos, " ");
|
|
|
|
}
|
|
|
|
dbg("arg[%i] '%s'", i, argv[i]);
|
|
|
|
i++;
|
|
|
|
}
|
2004-10-07 13:20:39 +07:00
|
|
|
argv[i] = NULL;
|
|
|
|
dbg("execute '%s' with parsed arguments", arg);
|
|
|
|
} else {
|
|
|
|
argv[0] = arg;
|
2005-03-29 16:25:52 +07:00
|
|
|
argv[1] = (char *) subsystem;
|
2004-10-07 13:20:39 +07:00
|
|
|
argv[2] = NULL;
|
|
|
|
dbg("execute '%s' with subsystem '%s' argument", arg, argv[1]);
|
2004-03-11 16:36:12 +07:00
|
|
|
}
|
2004-10-07 13:20:39 +07:00
|
|
|
|
2005-03-29 16:25:52 +07:00
|
|
|
retval = pipe(pipefds);
|
2003-10-15 13:32:17 +07:00
|
|
|
if (retval != 0) {
|
2005-03-27 06:11:03 +07:00
|
|
|
err("pipe failed");
|
2003-10-15 13:32:17 +07:00
|
|
|
return -1;
|
|
|
|
}
|
2004-03-11 16:36:12 +07:00
|
|
|
|
2003-10-15 13:32:17 +07:00
|
|
|
pid = fork();
|
2004-01-27 15:40:12 +07:00
|
|
|
switch(pid) {
|
|
|
|
case 0:
|
2005-03-27 06:15:07 +07:00
|
|
|
/* child dup2 write side of pipe to STDOUT */
|
2005-03-29 16:25:52 +07:00
|
|
|
devnull = open("/dev/null", O_RDWR);
|
|
|
|
if (devnull >= 0) {
|
|
|
|
dup2(devnull, STDIN_FILENO);
|
|
|
|
dup2(devnull, STDERR_FILENO);
|
|
|
|
close(devnull);
|
|
|
|
}
|
|
|
|
dup2(pipefds[1], STDOUT_FILENO);
|
2004-10-07 13:20:39 +07:00
|
|
|
retval = execv(arg, argv);
|
2005-03-29 09:23:56 +07:00
|
|
|
err("exec of program failed");
|
|
|
|
_exit(1);
|
2004-01-27 15:40:12 +07:00
|
|
|
case -1:
|
2005-03-29 16:25:52 +07:00
|
|
|
err("fork of '%s' failed", arg);
|
2005-03-29 08:56:42 +07:00
|
|
|
retval = -1;
|
|
|
|
break;
|
2004-01-27 15:40:12 +07:00
|
|
|
default:
|
2005-03-29 16:25:52 +07:00
|
|
|
/* parent reads from pipefds[0] */
|
|
|
|
close(pipefds[1]);
|
2003-10-15 13:32:17 +07:00
|
|
|
retval = 0;
|
2004-03-11 16:36:12 +07:00
|
|
|
i = 0;
|
2003-10-15 13:32:17 +07:00
|
|
|
while (1) {
|
2005-03-29 16:25:52 +07:00
|
|
|
count = read(pipefds[0], value + i, len - i-1);
|
2005-03-27 06:15:07 +07:00
|
|
|
if (count < 0) {
|
|
|
|
err("read failed with '%s'", strerror(errno));
|
|
|
|
retval = -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (count == 0)
|
2003-10-15 13:32:17 +07:00
|
|
|
break;
|
2004-03-11 16:36:12 +07:00
|
|
|
|
|
|
|
i += count;
|
|
|
|
if (i >= len-1) {
|
2005-03-27 06:11:03 +07:00
|
|
|
err("result len %d too short", len);
|
2003-10-15 13:32:17 +07:00
|
|
|
retval = -1;
|
2004-03-11 16:36:12 +07:00
|
|
|
break;
|
2003-10-15 13:32:17 +07:00
|
|
|
}
|
|
|
|
}
|
2004-03-11 16:36:12 +07:00
|
|
|
value[i] = '\0';
|
|
|
|
|
2005-03-29 16:25:52 +07:00
|
|
|
close(pipefds[0]);
|
2004-11-05 19:16:56 +07:00
|
|
|
waitpid(pid, &status, 0);
|
2004-03-11 16:36:12 +07:00
|
|
|
|
2003-10-15 13:32:17 +07:00
|
|
|
if (!WIFEXITED(status) || (WEXITSTATUS(status) != 0)) {
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
dbg("exec program status 0x%x", status);
|
2003-10-15 13:32:17 +07:00
|
|
|
retval = -1;
|
|
|
|
}
|
|
|
|
}
|
2003-12-23 13:31:35 +07:00
|
|
|
|
2005-03-27 06:15:07 +07:00
|
|
|
if (!retval) {
|
|
|
|
remove_trailing_char(value, '\n');
|
|
|
|
dbg("result is '%s'", value);
|
|
|
|
replace_untrusted_chars(value);
|
|
|
|
} else
|
|
|
|
value[0] = '\0';
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
|
2005-03-27 06:15:07 +07:00
|
|
|
return retval;
|
[PATCH] Adding '%s' format specifier to NAME and SYMLINK
On Thu, Feb 12, 2004 at 05:34:57PM -0800, Greg KH wrote:
> On Tue, Feb 10, 2004 at 09:14:20AM +0100, Hannes Reinecke wrote:
> > Hi all,
> >
> > this patch makes the format for NAME and SYMLINK a bit more flexible:
> > I've added a new format specifier '%s{<SYSFS_var>}', which allows for
> > the value of any sysfs entry found for this device to be inserted.
> > Example (for our S/390 fcp adapter):
> >
> > BUS="ccw", SYSFS_devtype="1732/03", NAME="%k" \
> > SYMLINK="zfcp-%s{hba_id}-%s{wwpn}:%s{fcp_lun}"
> >
> > I know this could also be done with an external program, but having this
> > incorporated into udev makes life easier, especially if run from
> > initramfs. Plus it makes the rules easier to follow, as the result is
> > directly visible and need not to be looked up in some external program.
> >
> > Comments etc. welcome.
>
> Oops, sorry I missed this for the 017 release. I'll look at it tomorrow
> and get back to you. At first glance it looks like a good thing.
>
> Oh, you forgot to update the documentation, that's important to do if
> you want this change to make it in :)
I took a part of the code and made a version that uses already implemented
attribute finding logic.
The parsing of the format length '%3x' and the '%x{attribute}' is a fuction now,
maybe there are more possible users in the future.
I've also added the test to udev-test.pl.
2004-02-17 12:36:34 +07:00
|
|
|
}
|
|
|
|
|
2005-03-13 04:36:32 +07:00
|
|
|
static int match_rule(struct udevice *udev, struct udev_rule *rule,
|
2004-11-29 19:44:01 +07:00
|
|
|
struct sysfs_class_device *class_dev, struct sysfs_device *sysfs_device)
|
2003-12-20 16:05:13 +07:00
|
|
|
{
|
2005-03-28 07:12:39 +07:00
|
|
|
struct sysfs_device *parent_device = sysfs_device;
|
|
|
|
|
2005-04-02 22:45:35 +07:00
|
|
|
if (rule->action_operation != KEY_OP_UNSET) {
|
|
|
|
dbg("check for " KEY_ACTION " rule->action='%s' udev->action='%s'",
|
|
|
|
rule->action, udev->action);
|
|
|
|
if (strcmp_pattern(rule->action, udev->action) != 0) {
|
|
|
|
dbg(KEY_ACTION " is not matching");
|
|
|
|
if (rule->action_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_ACTION " matches");
|
|
|
|
if (rule->action_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
dbg(KEY_ACTION " key is true");
|
|
|
|
}
|
|
|
|
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->kernel_operation != KEY_OP_UNSET) {
|
2005-03-29 16:25:52 +07:00
|
|
|
dbg("check for " KEY_KERNEL " rule->kernel='%s' udev_kernel_name='%s'",
|
|
|
|
rule->kernel, udev->kernel_name);
|
|
|
|
if (strcmp_pattern(rule->kernel, udev->kernel_name) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_KERNEL " is not matching");
|
|
|
|
if (rule->kernel_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_KERNEL " matches");
|
|
|
|
if (rule->kernel_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_KERNEL " key is true");
|
2005-02-12 00:33:40 +07:00
|
|
|
}
|
2003-11-13 20:52:08 +07:00
|
|
|
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->subsystem_operation != KEY_OP_UNSET) {
|
2005-03-29 16:25:52 +07:00
|
|
|
dbg("check for " KEY_SUBSYSTEM " rule->subsystem='%s' udev->subsystem='%s'",
|
|
|
|
rule->subsystem, udev->subsystem);
|
2005-03-13 04:36:32 +07:00
|
|
|
if (strcmp_pattern(rule->subsystem, udev->subsystem) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_SUBSYSTEM " is not matching");
|
|
|
|
if (rule->subsystem_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_SUBSYSTEM " matches");
|
|
|
|
if (rule->subsystem_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
2004-11-12 12:52:55 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_SUBSYSTEM " key is true");
|
2005-02-12 00:33:40 +07:00
|
|
|
}
|
2004-11-12 12:52:55 +07:00
|
|
|
|
2005-06-20 05:29:38 +07:00
|
|
|
if (rule->devpath_operation != KEY_OP_UNSET) {
|
|
|
|
dbg("check for " KEY_DEVPATH " rule->devpath='%s' udev->devpath='%s'",
|
|
|
|
rule->devpath, udev->devpath);
|
|
|
|
if (strcmp_pattern(rule->devpath, udev->devpath) != 0) {
|
|
|
|
dbg(KEY_DEVPATH " is not matching");
|
|
|
|
if (rule->devpath_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_DEVPATH " matches");
|
|
|
|
if (rule->devpath_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
dbg(KEY_DEVPATH " key is true");
|
|
|
|
}
|
|
|
|
|
|
|
|
if (rule->modalias_operation != KEY_OP_UNSET) {
|
|
|
|
char value[NAME_SIZE];
|
|
|
|
|
|
|
|
if (find_sysfs_attribute(NULL, sysfs_device, "modalias", value, sizeof(value)) != 0) {
|
|
|
|
dbg(KEY_MODALIAS " value not found");
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
dbg("check for " KEY_MODALIAS " rule->modalias='%s' modalias='%s'",
|
|
|
|
rule->modalias, value);
|
|
|
|
if (strcmp_pattern(rule->modalias, value) != 0) {
|
|
|
|
dbg(KEY_MODALIAS " is not matching");
|
|
|
|
if (rule->modalias_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_MODALIAS " matches");
|
|
|
|
if (rule->modalias_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
dbg(KEY_MODALIAS " key is true");
|
|
|
|
}
|
|
|
|
|
2005-03-13 17:40:32 +07:00
|
|
|
if (rule->env_pair_count) {
|
|
|
|
int i;
|
|
|
|
|
|
|
|
dbg("check for " KEY_ENV " pairs");
|
|
|
|
for (i = 0; i < rule->env_pair_count; i++) {
|
|
|
|
struct key_pair *pair;
|
|
|
|
const char *value;
|
|
|
|
|
|
|
|
pair = &rule->env_pair[i];
|
|
|
|
value = getenv(pair->name);
|
|
|
|
if (!value) {
|
|
|
|
dbg(KEY_ENV "{'%s'} is not found", pair->name);
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
if (strcmp_pattern(pair->value, value) != 0) {
|
|
|
|
dbg(KEY_ENV "{'%s'} is not matching", pair->name);
|
|
|
|
if (pair->operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_ENV "{'%s'} matches", pair->name);
|
|
|
|
if (pair->operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
dbg(KEY_ENV " key is true");
|
|
|
|
}
|
|
|
|
|
2005-02-14 07:46:05 +07:00
|
|
|
/* walk up the chain of physical devices and find a match */
|
2005-02-12 00:33:40 +07:00
|
|
|
while (1) {
|
2004-11-13 11:21:12 +07:00
|
|
|
/* check for matching driver */
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->driver_operation != KEY_OP_UNSET) {
|
2005-03-28 07:12:39 +07:00
|
|
|
if (parent_device == NULL) {
|
2005-03-09 08:12:22 +07:00
|
|
|
dbg("device has no sysfs_device");
|
2005-03-14 10:18:20 +07:00
|
|
|
goto exit;
|
2005-03-09 08:12:22 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check for " KEY_DRIVER " rule->driver='%s' sysfs_device->driver_name='%s'",
|
2005-03-28 07:12:39 +07:00
|
|
|
rule->driver, parent_device->driver_name);
|
|
|
|
if (strcmp_pattern(rule->driver, parent_device->driver_name) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_DRIVER " is not matching");
|
|
|
|
if (rule->driver_operation != KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_DRIVER " matches");
|
|
|
|
if (rule->driver_operation == KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
2004-11-13 11:21:12 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_DRIVER " key is true");
|
2004-11-13 11:21:12 +07:00
|
|
|
}
|
|
|
|
|
2005-02-11 11:21:03 +07:00
|
|
|
/* check for matching bus value */
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->bus_operation != KEY_OP_UNSET) {
|
2005-03-28 07:12:39 +07:00
|
|
|
if (parent_device == NULL) {
|
2005-03-09 08:12:22 +07:00
|
|
|
dbg("device has no sysfs_device");
|
2005-03-14 10:18:20 +07:00
|
|
|
goto exit;
|
2005-02-11 11:21:03 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check for " KEY_BUS " rule->bus='%s' sysfs_device->bus='%s'",
|
2005-03-28 07:12:39 +07:00
|
|
|
rule->bus, parent_device->bus);
|
|
|
|
if (strcmp_pattern(rule->bus, parent_device->bus) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_BUS " is not matching");
|
|
|
|
if (rule->bus_operation != KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_BUS " matches");
|
|
|
|
if (rule->bus_operation == KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
2005-02-11 11:21:03 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_BUS " key is true");
|
2005-02-11 11:21:03 +07:00
|
|
|
}
|
|
|
|
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
/* check for matching bus id */
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->id_operation != KEY_OP_UNSET) {
|
2005-03-28 07:12:39 +07:00
|
|
|
if (parent_device == NULL) {
|
2005-03-09 08:12:22 +07:00
|
|
|
dbg("device has no sysfs_device");
|
2005-03-14 10:18:20 +07:00
|
|
|
goto exit;
|
2005-03-09 08:12:22 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check " KEY_ID);
|
2005-03-28 07:12:39 +07:00
|
|
|
if (strcmp_pattern(rule->id, parent_device->bus_id) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_ID " is not matching");
|
|
|
|
if (rule->id_operation != KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_ID " matches");
|
|
|
|
if (rule->id_operation == KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_ID " key is true");
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
2003-11-13 20:52:08 +07:00
|
|
|
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
/* check for matching sysfs pairs */
|
2005-03-13 17:40:32 +07:00
|
|
|
if (rule->sysfs_pair_count) {
|
|
|
|
int i;
|
|
|
|
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check " KEY_SYSFS " pairs");
|
2005-03-13 17:40:32 +07:00
|
|
|
for (i = 0; i < rule->sysfs_pair_count; i++) {
|
|
|
|
struct key_pair *pair;
|
2005-03-28 17:20:05 +07:00
|
|
|
char value[VALUE_SIZE];
|
2005-03-28 17:37:54 +07:00
|
|
|
size_t len;
|
2005-03-13 17:40:32 +07:00
|
|
|
|
|
|
|
pair = &rule->sysfs_pair[i];
|
2005-03-28 17:20:05 +07:00
|
|
|
if (find_sysfs_attribute(class_dev, parent_device, pair->name, value, sizeof(value)) != 0)
|
|
|
|
goto try_parent;
|
|
|
|
|
|
|
|
/* strip trailing whitespace of value, if not asked to match for it */
|
2005-03-28 17:37:54 +07:00
|
|
|
len = strlen(pair->value);
|
|
|
|
if (len && !isspace(pair->value[len-1])) {
|
|
|
|
len = strlen(value);
|
2005-03-28 17:20:05 +07:00
|
|
|
while (len > 0 && isspace(value[len-1]))
|
|
|
|
value[--len] = '\0';
|
|
|
|
dbg("removed %i trailing whitespace chars from '%s'", strlen(value)-len, value);
|
|
|
|
}
|
|
|
|
|
|
|
|
dbg("compare attribute '%s' value '%s' with '%s'", pair->name, value, pair->value);
|
|
|
|
if (strcmp_pattern(pair->value, value) != 0) {
|
2005-03-13 17:40:32 +07:00
|
|
|
dbg(KEY_SYSFS "{'%s'} is not matching", pair->name);
|
|
|
|
if (pair->operation != KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_SYSFS "{'%s'} matches", pair->name);
|
|
|
|
if (pair->operation == KEY_OP_NOMATCH)
|
|
|
|
goto try_parent;
|
|
|
|
}
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_SYSFS " keys are true");
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
|
|
|
|
2005-02-14 07:46:05 +07:00
|
|
|
/* found matching physical device */
|
|
|
|
break;
|
2004-02-12 13:28:51 +07:00
|
|
|
try_parent:
|
|
|
|
dbg("try parent sysfs device");
|
2005-03-28 07:12:39 +07:00
|
|
|
parent_device = sysfs_get_device_parent(parent_device);
|
|
|
|
if (parent_device == NULL)
|
2005-02-11 11:21:03 +07:00
|
|
|
goto exit;
|
2005-03-28 07:12:39 +07:00
|
|
|
dbg("look at sysfs_device->path='%s'", parent_device->path);
|
|
|
|
dbg("look at sysfs_device->bus_id='%s'", parent_device->bus_id);
|
2004-01-23 15:21:13 +07:00
|
|
|
}
|
2005-02-11 11:21:03 +07:00
|
|
|
|
2005-02-14 07:46:05 +07:00
|
|
|
/* execute external program */
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->program_operation != KEY_OP_UNSET) {
|
2005-03-07 10:29:43 +07:00
|
|
|
char program[PATH_SIZE];
|
2005-02-14 07:46:05 +07:00
|
|
|
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check " KEY_PROGRAM);
|
2005-03-13 04:36:32 +07:00
|
|
|
strlcpy(program, rule->program, sizeof(program));
|
2005-02-14 07:46:05 +07:00
|
|
|
apply_format(udev, program, sizeof(program), class_dev, sysfs_device);
|
2005-03-29 16:25:52 +07:00
|
|
|
if (execute_program_pipe(program, udev->subsystem,
|
|
|
|
udev->program_result, sizeof(udev->program_result)) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_PROGRAM " returned nonzero");
|
|
|
|
if (rule->program_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_PROGRAM " returned successful");
|
|
|
|
if (rule->program_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
2005-02-14 07:46:05 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_PROGRAM " key is true");
|
2005-02-14 07:46:05 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* check for matching result of external program */
|
2005-03-28 17:20:05 +07:00
|
|
|
if (rule->result_operation != KEY_OP_UNSET) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg("check for " KEY_RESULT " rule->result='%s', udev->program_result='%s'",
|
2005-03-13 04:36:32 +07:00
|
|
|
rule->result, udev->program_result);
|
|
|
|
if (strcmp_pattern(rule->result, udev->program_result) != 0) {
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_RESULT " is not matching");
|
|
|
|
if (rule->result_operation != KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
|
|
|
} else {
|
|
|
|
dbg(KEY_RESULT " matches");
|
|
|
|
if (rule->result_operation == KEY_OP_NOMATCH)
|
|
|
|
goto exit;
|
2005-02-14 07:46:05 +07:00
|
|
|
}
|
2005-03-13 11:46:31 +07:00
|
|
|
dbg(KEY_RESULT " key is true");
|
2005-02-14 07:46:05 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
/* rule matches */
|
|
|
|
return 0;
|
|
|
|
|
2005-02-11 11:21:03 +07:00
|
|
|
exit:
|
|
|
|
return -1;
|
2004-01-23 15:21:13 +07:00
|
|
|
}
|
|
|
|
|
2005-03-13 04:36:32 +07:00
|
|
|
int udev_rules_get_name(struct udevice *udev, struct sysfs_class_device *class_dev)
|
2004-01-23 15:21:13 +07:00
|
|
|
{
|
2004-10-15 10:36:07 +07:00
|
|
|
struct sysfs_class_device *class_dev_parent;
|
2004-01-23 15:21:13 +07:00
|
|
|
struct sysfs_device *sysfs_device = NULL;
|
2005-03-13 04:36:32 +07:00
|
|
|
struct udev_rule *rule;
|
2004-01-23 15:21:13 +07:00
|
|
|
|
2004-10-15 10:36:07 +07:00
|
|
|
dbg("class_dev->name='%s'", class_dev->name);
|
|
|
|
|
|
|
|
/* Figure out where the "device"-symlink is at. For char devices this will
|
|
|
|
* always be in the class_dev->path. On block devices, only the main block
|
|
|
|
* device will have the device symlink in it's path. All partition devices
|
|
|
|
* need to look at the symlink in its parent directory.
|
|
|
|
*/
|
|
|
|
class_dev_parent = sysfs_get_classdev_parent(class_dev);
|
|
|
|
if (class_dev_parent != NULL) {
|
|
|
|
dbg("given class device has a parent, use this instead");
|
|
|
|
sysfs_device = sysfs_get_classdev_device(class_dev_parent);
|
|
|
|
} else {
|
|
|
|
sysfs_device = sysfs_get_classdev_device(class_dev);
|
|
|
|
}
|
2004-01-23 15:21:13 +07:00
|
|
|
|
|
|
|
if (sysfs_device) {
|
2004-10-19 09:11:51 +07:00
|
|
|
dbg("found devices device: path='%s', bus_id='%s', bus='%s'",
|
2004-10-15 10:36:07 +07:00
|
|
|
sysfs_device->path, sysfs_device->bus_id, sysfs_device->bus);
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcpy(udev->bus_id, sysfs_device->bus_id, sizeof(udev->bus_id));
|
2004-01-23 15:21:13 +07:00
|
|
|
}
|
|
|
|
|
2005-02-21 20:48:12 +07:00
|
|
|
dbg("udev->kernel_name='%s'", udev->kernel_name);
|
2004-01-23 15:21:13 +07:00
|
|
|
|
|
|
|
/* look for a matching rule to apply */
|
2005-06-24 23:05:32 +07:00
|
|
|
udev_rules_iter_init();
|
|
|
|
while (1) {
|
|
|
|
rule = udev_rules_iter_next();
|
|
|
|
if (rule == NULL)
|
|
|
|
break;
|
|
|
|
|
2005-06-20 05:29:38 +07:00
|
|
|
if (udev->name_set && rule->name_operation != KEY_OP_UNSET) {
|
|
|
|
dbg("node name already set, rule ignored");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2004-01-23 15:21:13 +07:00
|
|
|
dbg("process rule");
|
2005-03-13 04:36:32 +07:00
|
|
|
if (match_rule(udev, rule, class_dev, sysfs_device) == 0) {
|
2005-02-14 12:03:06 +07:00
|
|
|
/* apply options */
|
2005-03-13 04:36:32 +07:00
|
|
|
if (rule->ignore_device) {
|
2005-02-14 12:03:06 +07:00
|
|
|
info("configured rule in '%s[%i]' applied, '%s' is ignored",
|
2005-03-13 04:36:32 +07:00
|
|
|
rule->config_file, rule->config_line, udev->kernel_name);
|
2005-04-02 22:45:35 +07:00
|
|
|
udev->ignore_device = 1;
|
|
|
|
return 0;
|
2005-02-14 12:03:06 +07:00
|
|
|
}
|
2005-03-13 04:36:32 +07:00
|
|
|
if (rule->ignore_remove) {
|
2005-03-05 02:52:19 +07:00
|
|
|
udev->ignore_remove = 1;
|
2005-03-13 04:36:32 +07:00
|
|
|
dbg("remove event should be ignored");
|
2005-02-14 12:03:06 +07:00
|
|
|
}
|
|
|
|
/* apply all_partitions option only at a main block device */
|
2005-03-13 04:36:32 +07:00
|
|
|
if (rule->partitions && udev->type == DEV_BLOCK && udev->kernel_number[0] == '\0') {
|
|
|
|
udev->partitions = rule->partitions;
|
2005-02-14 12:03:06 +07:00
|
|
|
dbg("creation of partition nodes requested");
|
|
|
|
}
|
|
|
|
|
2005-02-06 06:13:18 +07:00
|
|
|
/* apply permissions */
|
2005-06-05 09:57:03 +07:00
|
|
|
if (!udev->mode_final && rule->mode != 0000) {
|
|
|
|
if (rule->mode_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
udev->mode_final = 1;
|
2005-03-13 04:36:32 +07:00
|
|
|
udev->mode = rule->mode;
|
2005-02-06 06:13:18 +07:00
|
|
|
dbg("applied mode=%#o to '%s'", udev->mode, udev->kernel_name);
|
|
|
|
}
|
2005-06-05 09:57:03 +07:00
|
|
|
if (!udev->owner_final && rule->owner[0] != '\0') {
|
|
|
|
if (rule->owner_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
udev->owner_final = 1;
|
2005-03-13 04:36:32 +07:00
|
|
|
strlcpy(udev->owner, rule->owner, sizeof(udev->owner));
|
2005-02-06 06:13:18 +07:00
|
|
|
apply_format(udev, udev->owner, sizeof(udev->owner), class_dev, sysfs_device);
|
|
|
|
dbg("applied owner='%s' to '%s'", udev->owner, udev->kernel_name);
|
|
|
|
}
|
2005-06-05 09:57:03 +07:00
|
|
|
if (!udev->group_final && rule->group[0] != '\0') {
|
|
|
|
if (rule->group_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
udev->group_final = 1;
|
2005-03-13 04:36:32 +07:00
|
|
|
strlcpy(udev->group, rule->group, sizeof(udev->group));
|
2005-02-06 06:13:18 +07:00
|
|
|
apply_format(udev, udev->group, sizeof(udev->group), class_dev, sysfs_device);
|
|
|
|
dbg("applied group='%s' to '%s'", udev->group, udev->kernel_name);
|
|
|
|
}
|
|
|
|
|
2005-02-21 20:48:12 +07:00
|
|
|
/* collect symlinks */
|
2005-06-05 20:55:29 +07:00
|
|
|
if (!udev->symlink_final && rule->symlink_operation != KEY_OP_UNSET) {
|
2005-03-07 10:29:43 +07:00
|
|
|
char temp[PATH_SIZE];
|
2005-03-05 11:35:31 +07:00
|
|
|
char *pos, *next;
|
2004-03-25 08:34:00 +07:00
|
|
|
|
2005-06-05 09:57:03 +07:00
|
|
|
if (rule->symlink_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
udev->symlink_final = 1;
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->symlink_operation == KEY_OP_ASSIGN || rule->symlink_operation == KEY_OP_ASSIGN_FINAL) {
|
2005-06-05 10:13:33 +07:00
|
|
|
struct name_entry *name_loop;
|
|
|
|
struct name_entry *temp_loop;
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
info("reset symlink list");
|
2005-06-05 10:13:33 +07:00
|
|
|
list_for_each_entry_safe(name_loop, temp_loop, &udev->symlink_list, node) {
|
|
|
|
list_del(&name_loop->node);
|
|
|
|
free(name_loop);
|
|
|
|
}
|
|
|
|
}
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->symlink[0] != '\0') {
|
|
|
|
info("configured rule in '%s[%i]' applied, added symlink '%s'",
|
|
|
|
rule->config_file, rule->config_line, rule->symlink);
|
|
|
|
strlcpy(temp, rule->symlink, sizeof(temp));
|
|
|
|
apply_format(udev, temp, sizeof(temp), class_dev, sysfs_device);
|
|
|
|
|
|
|
|
/* add multiple symlinks separated by spaces */
|
|
|
|
pos = temp;
|
|
|
|
next = strchr(temp, ' ');
|
|
|
|
while (next) {
|
|
|
|
next[0] = '\0';
|
|
|
|
info("add symlink '%s'", pos);
|
|
|
|
name_list_add(&udev->symlink_list, pos, 0);
|
|
|
|
pos = &next[1];
|
|
|
|
next = strchr(pos, ' ');
|
|
|
|
}
|
2005-03-27 06:11:03 +07:00
|
|
|
info("add symlink '%s'", pos);
|
2005-03-05 11:35:31 +07:00
|
|
|
name_list_add(&udev->symlink_list, pos, 0);
|
|
|
|
}
|
2004-03-02 13:23:39 +07:00
|
|
|
}
|
|
|
|
|
2005-04-02 22:45:35 +07:00
|
|
|
/* set name, later rules with name set will be ignored */
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->name_operation != KEY_OP_UNSET) {
|
|
|
|
udev->name_set = 1;
|
|
|
|
if (rule->name[0] == '\0') {
|
|
|
|
info("configured rule in '%s[%i]' applied, node handling for '%s' supressed",
|
|
|
|
rule->config_file, rule->config_line, udev->kernel_name);
|
|
|
|
} else {
|
|
|
|
strlcpy(udev->name, rule->name, sizeof(udev->name));
|
|
|
|
apply_format(udev, udev->name, sizeof(udev->name), class_dev, sysfs_device);
|
|
|
|
strlcpy(udev->config_file, rule->config_file, sizeof(udev->config_file));
|
|
|
|
udev->config_line = rule->config_line;
|
|
|
|
|
|
|
|
info("configured rule in '%s:%i' applied, '%s' becomes '%s'",
|
|
|
|
rule->config_file, rule->config_line, udev->kernel_name, rule->name);
|
|
|
|
if (udev->type != DEV_NET)
|
|
|
|
dbg("name, '%s' is going to have owner='%s', group='%s', mode=%#o partitions=%i",
|
|
|
|
udev->name, udev->owner, udev->group, udev->mode, udev->partitions);
|
|
|
|
}
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
2004-11-29 19:44:01 +07:00
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (!udev->run_final && rule->run_operation != KEY_OP_UNSET) {
|
2005-04-02 22:45:35 +07:00
|
|
|
char program[PATH_SIZE];
|
|
|
|
|
2005-06-05 09:57:03 +07:00
|
|
|
if (rule->run_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
udev->run_final = 1;
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run_operation == KEY_OP_ASSIGN || rule->run_operation == KEY_OP_ASSIGN_FINAL) {
|
2005-06-05 10:13:33 +07:00
|
|
|
struct name_entry *name_loop;
|
|
|
|
struct name_entry *temp_loop;
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
info("reset run list");
|
2005-06-05 10:13:33 +07:00
|
|
|
list_for_each_entry_safe(name_loop, temp_loop, &udev->run_list, node) {
|
|
|
|
list_del(&name_loop->node);
|
|
|
|
free(name_loop);
|
|
|
|
}
|
|
|
|
}
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run[0] != '\0') {
|
|
|
|
strlcpy(program, rule->run, sizeof(program));
|
|
|
|
apply_format(udev, program, sizeof(program), class_dev, sysfs_device);
|
|
|
|
dbg("add run '%s'", program);
|
|
|
|
name_list_add(&udev->run_list, program, 0);
|
|
|
|
}
|
2004-03-02 13:23:39 +07:00
|
|
|
}
|
2005-03-13 04:55:08 +07:00
|
|
|
|
|
|
|
if (rule->last_rule) {
|
|
|
|
dbg("last rule to be applied");
|
|
|
|
break;
|
|
|
|
}
|
2004-01-23 15:21:13 +07:00
|
|
|
}
|
[PATCH] udev - drop all methods :)
> Hi,
> as promised yesterday, here is a patch that drops the explicit methods
> given in the udev config and implement only one type of rule.
>
> A rule now consists only of a number of keys to match. All known keys
> are valid in any combination. The former configs should work with a few
> changes:
>
> o the "<METHOD>, " at the beginning of the line should be removed
>
> o the result of the externel program is matched with RESULT= instead if ID=
> the PROGRAM= key is only valid if the program exits with zero
> (just exit with nozero in a script if the rule should not match)
>
> o rules are processed in order they appear in the file, no priority
>
> o if NAME="" is given, udev is instructed to ignore this device,
> no node will be created
>
>
> EXAMPLE:
>
> # combined BUS, SYSFS and KERNEL
> BUS="usb", KERNEL="video*", SYSFS_model="Creative Labs WebCam*", NAME="test/webcam%n"
>
> # exec script only for the first ide drive (hda), all other will be skipped
> BUS="ide", KERNEL="hda*", PROGRAM="/home/kay/src/udev.kay/extras/ide-devfs.sh %k %b %n", RESULT="hd*", NAME="%1c", SYMLINK="%2c %3c"
>
>
> The udev-test.pl and test.block works fine here.
> Please adapt your config and give it a try.
>
Here is a slightly better version of the patch.
After a conversation with Patrick, we are now able to execute the PROGRAM
and also match in all following rules with the RESULT value from this exec.
EXAMPLE:
We have 7 rules with RESULT and 2 with PROGRAM.
Only the 5th rule matches with the callout result from the exec in the 4th rule.
RULES:
PROGRAM="/bin/echo abc", RESULT="no_match", NAME="web-no-2"
KERNEL="video*", RESULT="123", NAME="web-no-3"
KERNEL="video*", RESULT="123", NAME="web-no-4"
PROGRAM="/bin/echo 123", RESULT="no_match", NAME="web-no-5"
KERNEL="video*", RESULT="123", NAME="web-yes"
RESULT:
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo abc'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is 'abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='abc'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check PROGRAM
Jan 11 23:36:52 pim udev[26050]: execute_program: executing '/bin/echo 123'
Jan 11 23:36:52 pim udev[26050]: execute_program: result is '123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: PROGRAM returned successful
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='no_match', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT is not matching
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: process rule
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for KERNEL dev->kernel='video*' class_dev->name='video0'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: KERNEL matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: check for RESULT dev->result='123', udev->program_result='123'
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: RESULT matches
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: found matching rule, 'video*' becomes ''
Jan 11 23:36:52 pim udev[26050]: namedev_name_device: name, 'web-yes' is going to have owner='', group='', mode = 0600
2004-01-13 12:39:05 +07:00
|
|
|
}
|
2003-10-20 11:56:21 +07:00
|
|
|
|
2005-03-05 02:52:19 +07:00
|
|
|
if (udev->name[0] == '\0') {
|
2005-03-07 10:29:43 +07:00
|
|
|
strlcpy(udev->name, udev->kernel_name, sizeof(udev->name));
|
2005-03-27 06:11:03 +07:00
|
|
|
info("no rule found, use kernel name '%s'", udev->name);
|
2005-03-05 02:52:19 +07:00
|
|
|
}
|
2003-11-13 08:38:14 +07:00
|
|
|
|
2005-02-09 10:37:32 +07:00
|
|
|
if (udev->tmp_node[0] != '\0') {
|
|
|
|
dbg("removing temporary device node");
|
|
|
|
unlink_secure(udev->tmp_node);
|
|
|
|
udev->tmp_node[0] = '\0';
|
|
|
|
}
|
|
|
|
|
2003-11-12 23:26:08 +07:00
|
|
|
return 0;
|
2003-07-19 12:48:28 +07:00
|
|
|
}
|
2005-04-02 22:45:35 +07:00
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
int udev_rules_get_run(struct udevice *udev, struct sysfs_device *sysfs_device)
|
2005-04-02 22:45:35 +07:00
|
|
|
{
|
|
|
|
struct udev_rule *rule;
|
|
|
|
|
|
|
|
/* look for a matching rule to apply */
|
2005-06-24 23:05:32 +07:00
|
|
|
udev_rules_iter_init();
|
|
|
|
while (1) {
|
|
|
|
rule = udev_rules_iter_next();
|
|
|
|
if (rule == NULL)
|
|
|
|
break;
|
2005-04-02 22:45:35 +07:00
|
|
|
|
2005-06-24 23:05:32 +07:00
|
|
|
dbg("process rule");
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run_operation == KEY_OP_UNSET)
|
2005-04-02 22:45:35 +07:00
|
|
|
continue;
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->name_operation != KEY_OP_UNSET || rule->symlink_operation != KEY_OP_UNSET ||
|
2005-04-02 22:45:35 +07:00
|
|
|
rule->mode != 0000 || rule->owner[0] != '\0' || rule->group[0] != '\0') {
|
|
|
|
dbg("skip rule that names a device");
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (match_rule(udev, rule, NULL, sysfs_device) == 0) {
|
|
|
|
if (rule->ignore_device) {
|
|
|
|
info("configured rule in '%s[%i]' applied, '%s' is ignored",
|
|
|
|
rule->config_file, rule->config_line, udev->kernel_name);
|
|
|
|
udev->ignore_device = 1;
|
|
|
|
return 0;
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (!udev->run_final && rule->run_operation != KEY_OP_UNSET) {
|
|
|
|
char program[PATH_SIZE];
|
2005-04-02 22:45:35 +07:00
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run_operation == KEY_OP_ASSIGN || rule->run_operation == KEY_OP_ASSIGN_FINAL) {
|
|
|
|
struct name_entry *name_loop;
|
|
|
|
struct name_entry *temp_loop;
|
2005-04-02 22:45:35 +07:00
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
info("reset run list");
|
|
|
|
list_for_each_entry_safe(name_loop, temp_loop, &udev->run_list, node) {
|
|
|
|
list_del(&name_loop->node);
|
|
|
|
free(name_loop);
|
|
|
|
}
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run[0] != '\0') {
|
|
|
|
strlcpy(program, rule->run, sizeof(program));
|
2005-06-20 05:29:38 +07:00
|
|
|
apply_format(udev, program, sizeof(program), NULL, sysfs_device);
|
2005-06-05 20:55:29 +07:00
|
|
|
dbg("add run '%s'", program);
|
|
|
|
name_list_add(&udev->run_list, program, 0);
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->run_operation == KEY_OP_ASSIGN_FINAL)
|
|
|
|
break;
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
|
|
|
|
2005-06-05 20:55:29 +07:00
|
|
|
if (rule->last_rule) {
|
|
|
|
dbg("last rule to be applied");
|
|
|
|
break;
|
|
|
|
}
|
2005-04-02 22:45:35 +07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|