mirror of
https://github.com/Fishwaldo/linux-bl808.git
synced 2025-06-17 20:25:19 +00:00
Nothing major: the stricter permissions checking for sysfs broke
a staging driver; fix included. Greg KH said he'd take the patch but hadn't as the merge window opened, so it's included here to avoid breaking build. Cheers, Rusty. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.14 (GNU/Linux) iQIcBAABAgAGBQJTQMH9AAoJENkgDmzRrbjxo4UP/jwlenP44v+RFpo/dn8Z8E2n SREQscU5ZZKvuyFD6kUdvOz8YC/nTrJvXoVkMUF05GVbuvb8/8UPtT9ECVemd0rW xNy4aFfv9rbrqRLBLpLK9LAgTuhwlbTgGxgL78zRn3hWmf1hBZWCY+cEvKM8l/+9 oEQdORL0sUpZh7iryAeGqbOrXT4gqJEvSLOFwiYTSo6ryzWIilmdXSUAh6s8MIEX PR1+oH9J8B6J29lcXKMf8/sDI1EBUeSLdBmMCuN5Y7xpYxsQLroVx94kPbdBY+XK ZRoYuUGSUJfGRZY46cFKApIGeF07z1DGoyXghbSWEQrI+23TMUmrKUg47LSukE4Y yCUf8HAtqIA3gVc9GKDdSp/2UpkAhTTv5ogKgnIzs1InWtOIBdDRSVUQXDosFEXw 6ZZe1pQs2zfXyXxO4j0Wq36K4RgI0aqOVw+dcC+w5BidjVylgnYRV0PSDd72tid7 bIfnjDbUBo+o4LanPNGYK474KyO7AslgTE50w6zwbJzgdwCQ36hCpKqScBZzm60a 42LrgTVoIHHWAL1tDzWL/LzWflZGdJAezzNje0/f2Q3bGMiNHWoljAvUphkTZ7qt E8+jWqmM+riH3e8Y5wKpO1BKt7NGHISEy//bUlnqTwisjIzVILZ6VjfugQ1AI+0x llTXPBotFvfvXqxunBg7 =yzUO -----END PGP SIGNATURE----- Merge tag 'modules-next-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux Pull module updates from Rusty Russell: "Nothing major: the stricter permissions checking for sysfs broke a staging driver; fix included. Greg KH said he'd take the patch but hadn't as the merge window opened, so it's included here to avoid breaking build" * tag 'modules-next-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/rusty/linux: staging: fix up speakup kobject mode Use 'E' instead of 'X' for unsigned module taint flag. VERIFY_OCTAL_PERMISSIONS: stricter checking for sysfs perms. kallsyms: fix percpu vars on x86-64 with relocation. kallsyms: generalize address range checking module: LLVMLinux: Remove unused function warning from __param_check macro Fix: module signature vs tracepoints: add new TAINT_UNSIGNED_MODULE module: remove MODULE_GENERIC_TABLE module: allow multiple calls to MODULE_DEVICE_TABLE() per module module: use pr_cont
This commit is contained in:
commit
6f4c98e1c2
37 changed files with 331 additions and 278 deletions
|
@ -49,3 +49,4 @@ Description: Module taint flags:
|
||||||
O - out-of-tree module
|
O - out-of-tree module
|
||||||
F - force-loaded module
|
F - force-loaded module
|
||||||
C - staging driver module
|
C - staging driver module
|
||||||
|
E - unsigned module
|
||||||
|
|
|
@ -53,7 +53,8 @@ This has a number of options available:
|
||||||
|
|
||||||
If this is off (ie. "permissive"), then modules for which the key is not
|
If this is off (ie. "permissive"), then modules for which the key is not
|
||||||
available and modules that are unsigned are permitted, but the kernel will
|
available and modules that are unsigned are permitted, but the kernel will
|
||||||
be marked as being tainted.
|
be marked as being tainted, and the concerned modules will be marked as
|
||||||
|
tainted, shown with the character 'E'.
|
||||||
|
|
||||||
If this is on (ie. "restrictive"), only modules that have a valid
|
If this is on (ie. "restrictive"), only modules that have a valid
|
||||||
signature that can be verified by a public key in the kernel's possession
|
signature that can be verified by a public key in the kernel's possession
|
||||||
|
|
|
@ -265,6 +265,9 @@ characters, each representing a particular tainted value.
|
||||||
|
|
||||||
13: 'O' if an externally-built ("out-of-tree") module has been loaded.
|
13: 'O' if an externally-built ("out-of-tree") module has been loaded.
|
||||||
|
|
||||||
|
14: 'E' if an unsigned module has been loaded in a kernel supporting
|
||||||
|
module signature.
|
||||||
|
|
||||||
The primary reason for the 'Tainted: ' string is to tell kernel
|
The primary reason for the 'Tainted: ' string is to tell kernel
|
||||||
debuggers if this is a clean kernel or if anything unusual has
|
debuggers if this is a clean kernel or if anything unusual has
|
||||||
occurred. Tainting is permanent: even if an offending module is
|
occurred. Tainting is permanent: even if an offending module is
|
||||||
|
|
|
@ -785,6 +785,8 @@ can be ORed together:
|
||||||
1024 - A module from drivers/staging was loaded.
|
1024 - A module from drivers/staging was loaded.
|
||||||
2048 - The system is working around a severe firmware bug.
|
2048 - The system is working around a severe firmware bug.
|
||||||
4096 - An out-of-tree module has been loaded.
|
4096 - An out-of-tree module has been loaded.
|
||||||
|
8192 - An unsigned module has been loaded in a kernel supporting module
|
||||||
|
signature.
|
||||||
|
|
||||||
==============================================================
|
==============================================================
|
||||||
|
|
||||||
|
|
|
@ -116,11 +116,11 @@ static void pci_slot_release(struct kobject *kobj)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct pci_slot_attribute pci_slot_attr_address =
|
static struct pci_slot_attribute pci_slot_attr_address =
|
||||||
__ATTR(address, (S_IFREG | S_IRUGO), address_read_file, NULL);
|
__ATTR(address, S_IRUGO, address_read_file, NULL);
|
||||||
static struct pci_slot_attribute pci_slot_attr_max_speed =
|
static struct pci_slot_attribute pci_slot_attr_max_speed =
|
||||||
__ATTR(max_bus_speed, (S_IFREG | S_IRUGO), max_speed_read_file, NULL);
|
__ATTR(max_bus_speed, S_IRUGO, max_speed_read_file, NULL);
|
||||||
static struct pci_slot_attribute pci_slot_attr_cur_speed =
|
static struct pci_slot_attribute pci_slot_attr_cur_speed =
|
||||||
__ATTR(cur_bus_speed, (S_IFREG | S_IRUGO), cur_speed_read_file, NULL);
|
__ATTR(cur_bus_speed, S_IRUGO, cur_speed_read_file, NULL);
|
||||||
|
|
||||||
static struct attribute *pci_slot_default_attrs[] = {
|
static struct attribute *pci_slot_default_attrs[] = {
|
||||||
&pci_slot_attr_address.attr,
|
&pci_slot_attr_address.attr,
|
||||||
|
|
|
@ -851,75 +851,75 @@ static ssize_t message_store(struct kobject *kobj, struct kobj_attribute *attr,
|
||||||
* Declare the attributes.
|
* Declare the attributes.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute keymap_attribute =
|
static struct kobj_attribute keymap_attribute =
|
||||||
__ATTR(keymap, ROOT_W, keymap_show, keymap_store);
|
__ATTR(keymap, S_IWUSR|S_IRUGO, keymap_show, keymap_store);
|
||||||
static struct kobj_attribute silent_attribute =
|
static struct kobj_attribute silent_attribute =
|
||||||
__ATTR(silent, USER_W, NULL, silent_store);
|
__ATTR(silent, S_IWUGO, NULL, silent_store);
|
||||||
static struct kobj_attribute synth_attribute =
|
static struct kobj_attribute synth_attribute =
|
||||||
__ATTR(synth, USER_RW, synth_show, synth_store);
|
__ATTR(synth, S_IWUGO|S_IRUGO, synth_show, synth_store);
|
||||||
static struct kobj_attribute synth_direct_attribute =
|
static struct kobj_attribute synth_direct_attribute =
|
||||||
__ATTR(synth_direct, USER_W, NULL, synth_direct_store);
|
__ATTR(synth_direct, S_IWUGO, NULL, synth_direct_store);
|
||||||
static struct kobj_attribute version_attribute =
|
static struct kobj_attribute version_attribute =
|
||||||
__ATTR_RO(version);
|
__ATTR_RO(version);
|
||||||
|
|
||||||
static struct kobj_attribute delimiters_attribute =
|
static struct kobj_attribute delimiters_attribute =
|
||||||
__ATTR(delimiters, USER_RW, punc_show, punc_store);
|
__ATTR(delimiters, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
static struct kobj_attribute ex_num_attribute =
|
static struct kobj_attribute ex_num_attribute =
|
||||||
__ATTR(ex_num, USER_RW, punc_show, punc_store);
|
__ATTR(ex_num, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
static struct kobj_attribute punc_all_attribute =
|
static struct kobj_attribute punc_all_attribute =
|
||||||
__ATTR(punc_all, USER_RW, punc_show, punc_store);
|
__ATTR(punc_all, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
static struct kobj_attribute punc_most_attribute =
|
static struct kobj_attribute punc_most_attribute =
|
||||||
__ATTR(punc_most, USER_RW, punc_show, punc_store);
|
__ATTR(punc_most, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
static struct kobj_attribute punc_some_attribute =
|
static struct kobj_attribute punc_some_attribute =
|
||||||
__ATTR(punc_some, USER_RW, punc_show, punc_store);
|
__ATTR(punc_some, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
static struct kobj_attribute repeats_attribute =
|
static struct kobj_attribute repeats_attribute =
|
||||||
__ATTR(repeats, USER_RW, punc_show, punc_store);
|
__ATTR(repeats, S_IWUGO|S_IRUGO, punc_show, punc_store);
|
||||||
|
|
||||||
static struct kobj_attribute attrib_bleep_attribute =
|
static struct kobj_attribute attrib_bleep_attribute =
|
||||||
__ATTR(attrib_bleep, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(attrib_bleep, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute bell_pos_attribute =
|
static struct kobj_attribute bell_pos_attribute =
|
||||||
__ATTR(bell_pos, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(bell_pos, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute bleep_time_attribute =
|
static struct kobj_attribute bleep_time_attribute =
|
||||||
__ATTR(bleep_time, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(bleep_time, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute bleeps_attribute =
|
static struct kobj_attribute bleeps_attribute =
|
||||||
__ATTR(bleeps, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(bleeps, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute cursor_time_attribute =
|
static struct kobj_attribute cursor_time_attribute =
|
||||||
__ATTR(cursor_time, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(cursor_time, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute key_echo_attribute =
|
static struct kobj_attribute key_echo_attribute =
|
||||||
__ATTR(key_echo, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(key_echo, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute no_interrupt_attribute =
|
static struct kobj_attribute no_interrupt_attribute =
|
||||||
__ATTR(no_interrupt, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(no_interrupt, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punc_level_attribute =
|
static struct kobj_attribute punc_level_attribute =
|
||||||
__ATTR(punc_level, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punc_level, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute reading_punc_attribute =
|
static struct kobj_attribute reading_punc_attribute =
|
||||||
__ATTR(reading_punc, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(reading_punc, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute say_control_attribute =
|
static struct kobj_attribute say_control_attribute =
|
||||||
__ATTR(say_control, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(say_control, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute say_word_ctl_attribute =
|
static struct kobj_attribute say_word_ctl_attribute =
|
||||||
__ATTR(say_word_ctl, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(say_word_ctl, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute spell_delay_attribute =
|
static struct kobj_attribute spell_delay_attribute =
|
||||||
__ATTR(spell_delay, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(spell_delay, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* These attributes are i18n related.
|
* These attributes are i18n related.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute announcements_attribute =
|
static struct kobj_attribute announcements_attribute =
|
||||||
__ATTR(announcements, USER_RW, message_show, message_store);
|
__ATTR(announcements, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute characters_attribute =
|
static struct kobj_attribute characters_attribute =
|
||||||
__ATTR(characters, USER_RW, chars_chartab_show, chars_chartab_store);
|
__ATTR(characters, S_IWUGO|S_IRUGO, chars_chartab_show, chars_chartab_store);
|
||||||
static struct kobj_attribute chartab_attribute =
|
static struct kobj_attribute chartab_attribute =
|
||||||
__ATTR(chartab, USER_RW, chars_chartab_show, chars_chartab_store);
|
__ATTR(chartab, S_IWUGO|S_IRUGO, chars_chartab_show, chars_chartab_store);
|
||||||
static struct kobj_attribute ctl_keys_attribute =
|
static struct kobj_attribute ctl_keys_attribute =
|
||||||
__ATTR(ctl_keys, USER_RW, message_show, message_store);
|
__ATTR(ctl_keys, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute colors_attribute =
|
static struct kobj_attribute colors_attribute =
|
||||||
__ATTR(colors, USER_RW, message_show, message_store);
|
__ATTR(colors, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute formatted_attribute =
|
static struct kobj_attribute formatted_attribute =
|
||||||
__ATTR(formatted, USER_RW, message_show, message_store);
|
__ATTR(formatted, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute function_names_attribute =
|
static struct kobj_attribute function_names_attribute =
|
||||||
__ATTR(function_names, USER_RW, message_show, message_store);
|
__ATTR(function_names, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute key_names_attribute =
|
static struct kobj_attribute key_names_attribute =
|
||||||
__ATTR(key_names, USER_RW, message_show, message_store);
|
__ATTR(key_names, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
static struct kobj_attribute states_attribute =
|
static struct kobj_attribute states_attribute =
|
||||||
__ATTR(states, USER_RW, message_show, message_store);
|
__ATTR(states, S_IWUGO|S_IRUGO, message_show, message_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create groups of attributes so that we can create and destroy them all
|
* Create groups of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -12,8 +12,6 @@
|
||||||
/* proc permissions */
|
/* proc permissions */
|
||||||
#define USER_R (S_IFREG|S_IRUGO)
|
#define USER_R (S_IFREG|S_IRUGO)
|
||||||
#define USER_W (S_IFREG|S_IWUGO)
|
#define USER_W (S_IFREG|S_IWUGO)
|
||||||
#define USER_RW (S_IFREG|S_IRUGO|S_IWUGO)
|
|
||||||
#define ROOT_W (S_IFREG|S_IRUGO|S_IWUSR)
|
|
||||||
|
|
||||||
#define TOGGLE_0 .u.n = {NULL, 0, 0, 1, 0, 0, NULL }
|
#define TOGGLE_0 .u.n = {NULL, 0, 0, 1, 0, 0, NULL }
|
||||||
#define TOGGLE_1 .u.n = {NULL, 1, 0, 1, 0, 0, NULL }
|
#define TOGGLE_1 .u.n = {NULL, 1, 0, 1, 0, 0, NULL }
|
||||||
|
|
|
@ -62,28 +62,28 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/acntpc.
|
* These attributes will appear in /sys/accessibility/speakup/acntpc.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -47,28 +47,28 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/acntsa.
|
* These attributes will appear in /sys/accessibility/speakup/acntsa.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IRUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IRUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IRUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IRUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -53,30 +53,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/apollo.
|
* These attributes will appear in /sys/accessibility/speakup/apollo.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute lang_attribute =
|
static struct kobj_attribute lang_attribute =
|
||||||
__ATTR(lang, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(lang, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -49,30 +49,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/audptr.
|
* These attributes will appear in /sys/accessibility/speakup/audptr.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -44,28 +44,28 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/bns.
|
* These attributes will appear in /sys/accessibility/speakup/bns.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -70,30 +70,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/decext.
|
* These attributes will appear in /sys/accessibility/speakup/decext.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -164,30 +164,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/decpc.
|
* These attributes will appear in /sys/accessibility/speakup/decpc.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -70,30 +70,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/dectlk.
|
* These attributes will appear in /sys/accessibility/speakup/dectlk.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -67,34 +67,34 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/dtlk.
|
* These attributes will appear in /sys/accessibility/speakup/dtlk.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute freq_attribute =
|
static struct kobj_attribute freq_attribute =
|
||||||
__ATTR(freq, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(freq, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -46,28 +46,28 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/dummy.
|
* These attributes will appear in /sys/accessibility/speakup/dummy.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -59,24 +59,24 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/keypc.
|
* These attributes will appear in /sys/accessibility/speakup/keypc.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -50,34 +50,34 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/ltlk.
|
* These attributes will appear in /sys/accessibility/speakup/ltlk.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute freq_attribute =
|
static struct kobj_attribute freq_attribute =
|
||||||
__ATTR(freq, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(freq, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -61,41 +61,41 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/soft.
|
* These attributes will appear in /sys/accessibility/speakup/soft.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute freq_attribute =
|
static struct kobj_attribute freq_attribute =
|
||||||
__ATTR(freq, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(freq, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute voice_attribute =
|
static struct kobj_attribute voice_attribute =
|
||||||
__ATTR(voice, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(voice, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We should uncomment the following definition, when we agree on a
|
* We should uncomment the following definition, when we agree on a
|
||||||
* method of passing a language designation to the software synthesizer.
|
* method of passing a language designation to the software synthesizer.
|
||||||
* static struct kobj_attribute lang_attribute =
|
* static struct kobj_attribute lang_attribute =
|
||||||
* __ATTR(lang, USER_RW, spk_var_show, spk_var_store);
|
* __ATTR(lang, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
*/
|
*/
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -48,30 +48,30 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/spkout.
|
* These attributes will appear in /sys/accessibility/speakup/spkout.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute punct_attribute =
|
static struct kobj_attribute punct_attribute =
|
||||||
__ATTR(punct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(punct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -44,28 +44,28 @@ static struct var_t vars[] = {
|
||||||
* These attributes will appear in /sys/accessibility/speakup/txprt.
|
* These attributes will appear in /sys/accessibility/speakup/txprt.
|
||||||
*/
|
*/
|
||||||
static struct kobj_attribute caps_start_attribute =
|
static struct kobj_attribute caps_start_attribute =
|
||||||
__ATTR(caps_start, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_start, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute caps_stop_attribute =
|
static struct kobj_attribute caps_stop_attribute =
|
||||||
__ATTR(caps_stop, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(caps_stop, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute pitch_attribute =
|
static struct kobj_attribute pitch_attribute =
|
||||||
__ATTR(pitch, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(pitch, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute rate_attribute =
|
static struct kobj_attribute rate_attribute =
|
||||||
__ATTR(rate, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(rate, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute tone_attribute =
|
static struct kobj_attribute tone_attribute =
|
||||||
__ATTR(tone, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(tone, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute vol_attribute =
|
static struct kobj_attribute vol_attribute =
|
||||||
__ATTR(vol, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(vol, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
static struct kobj_attribute delay_time_attribute =
|
static struct kobj_attribute delay_time_attribute =
|
||||||
__ATTR(delay_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(delay_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute direct_attribute =
|
static struct kobj_attribute direct_attribute =
|
||||||
__ATTR(direct, USER_RW, spk_var_show, spk_var_store);
|
__ATTR(direct, S_IWUGO|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute full_time_attribute =
|
static struct kobj_attribute full_time_attribute =
|
||||||
__ATTR(full_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(full_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute jiffy_delta_attribute =
|
static struct kobj_attribute jiffy_delta_attribute =
|
||||||
__ATTR(jiffy_delta, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(jiffy_delta, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
static struct kobj_attribute trigger_time_attribute =
|
static struct kobj_attribute trigger_time_attribute =
|
||||||
__ATTR(trigger_time, ROOT_W, spk_var_show, spk_var_store);
|
__ATTR(trigger_time, S_IWUSR|S_IRUGO, spk_var_show, spk_var_store);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Create a group of attributes so that we can create and destroy them all
|
* Create a group of attributes so that we can create and destroy them all
|
||||||
|
|
|
@ -569,7 +569,7 @@ static ssize_t cuse_class_waiting_show(struct device *dev,
|
||||||
|
|
||||||
return sprintf(buf, "%d\n", atomic_read(&cc->fc.num_waiting));
|
return sprintf(buf, "%d\n", atomic_read(&cc->fc.num_waiting));
|
||||||
}
|
}
|
||||||
static DEVICE_ATTR(waiting, S_IFREG | 0400, cuse_class_waiting_show, NULL);
|
static DEVICE_ATTR(waiting, 0400, cuse_class_waiting_show, NULL);
|
||||||
|
|
||||||
static ssize_t cuse_class_abort_store(struct device *dev,
|
static ssize_t cuse_class_abort_store(struct device *dev,
|
||||||
struct device_attribute *attr,
|
struct device_attribute *attr,
|
||||||
|
@ -580,7 +580,7 @@ static ssize_t cuse_class_abort_store(struct device *dev,
|
||||||
fuse_abort_conn(&cc->fc);
|
fuse_abort_conn(&cc->fc);
|
||||||
return count;
|
return count;
|
||||||
}
|
}
|
||||||
static DEVICE_ATTR(abort, S_IFREG | 0200, NULL, cuse_class_abort_store);
|
static DEVICE_ATTR(abort, 0200, NULL, cuse_class_abort_store);
|
||||||
|
|
||||||
static struct attribute *cuse_class_dev_attrs[] = {
|
static struct attribute *cuse_class_dev_attrs[] = {
|
||||||
&dev_attr_waiting.attr,
|
&dev_attr_waiting.attr,
|
||||||
|
|
|
@ -41,7 +41,7 @@ static ssize_t version_show(struct kobject *kobj, struct kobj_attribute *attr,
|
||||||
return snprintf(buf, PAGE_SIZE, "%u\n", O2NM_API_VERSION);
|
return snprintf(buf, PAGE_SIZE, "%u\n", O2NM_API_VERSION);
|
||||||
}
|
}
|
||||||
static struct kobj_attribute attr_version =
|
static struct kobj_attribute attr_version =
|
||||||
__ATTR(interface_revision, S_IFREG | S_IRUGO, version_show, NULL);
|
__ATTR(interface_revision, S_IRUGO, version_show, NULL);
|
||||||
|
|
||||||
static struct attribute *o2cb_attrs[] = {
|
static struct attribute *o2cb_attrs[] = {
|
||||||
&attr_version.attr,
|
&attr_version.attr,
|
||||||
|
|
|
@ -496,7 +496,7 @@ static ssize_t ocfs2_max_locking_protocol_show(struct kobject *kobj,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct kobj_attribute ocfs2_attr_max_locking_protocol =
|
static struct kobj_attribute ocfs2_attr_max_locking_protocol =
|
||||||
__ATTR(max_locking_protocol, S_IFREG | S_IRUGO,
|
__ATTR(max_locking_protocol, S_IRUGO,
|
||||||
ocfs2_max_locking_protocol_show, NULL);
|
ocfs2_max_locking_protocol_show, NULL);
|
||||||
|
|
||||||
static ssize_t ocfs2_loaded_cluster_plugins_show(struct kobject *kobj,
|
static ssize_t ocfs2_loaded_cluster_plugins_show(struct kobject *kobj,
|
||||||
|
@ -528,7 +528,7 @@ static ssize_t ocfs2_loaded_cluster_plugins_show(struct kobject *kobj,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct kobj_attribute ocfs2_attr_loaded_cluster_plugins =
|
static struct kobj_attribute ocfs2_attr_loaded_cluster_plugins =
|
||||||
__ATTR(loaded_cluster_plugins, S_IFREG | S_IRUGO,
|
__ATTR(loaded_cluster_plugins, S_IRUGO,
|
||||||
ocfs2_loaded_cluster_plugins_show, NULL);
|
ocfs2_loaded_cluster_plugins_show, NULL);
|
||||||
|
|
||||||
static ssize_t ocfs2_active_cluster_plugin_show(struct kobject *kobj,
|
static ssize_t ocfs2_active_cluster_plugin_show(struct kobject *kobj,
|
||||||
|
@ -550,7 +550,7 @@ static ssize_t ocfs2_active_cluster_plugin_show(struct kobject *kobj,
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct kobj_attribute ocfs2_attr_active_cluster_plugin =
|
static struct kobj_attribute ocfs2_attr_active_cluster_plugin =
|
||||||
__ATTR(active_cluster_plugin, S_IFREG | S_IRUGO,
|
__ATTR(active_cluster_plugin, S_IRUGO,
|
||||||
ocfs2_active_cluster_plugin_show, NULL);
|
ocfs2_active_cluster_plugin_show, NULL);
|
||||||
|
|
||||||
static ssize_t ocfs2_cluster_stack_show(struct kobject *kobj,
|
static ssize_t ocfs2_cluster_stack_show(struct kobject *kobj,
|
||||||
|
@ -599,7 +599,7 @@ static ssize_t ocfs2_cluster_stack_store(struct kobject *kobj,
|
||||||
|
|
||||||
|
|
||||||
static struct kobj_attribute ocfs2_attr_cluster_stack =
|
static struct kobj_attribute ocfs2_attr_cluster_stack =
|
||||||
__ATTR(cluster_stack, S_IFREG | S_IRUGO | S_IWUSR,
|
__ATTR(cluster_stack, S_IRUGO | S_IWUSR,
|
||||||
ocfs2_cluster_stack_show,
|
ocfs2_cluster_stack_show,
|
||||||
ocfs2_cluster_stack_store);
|
ocfs2_cluster_stack_store);
|
||||||
|
|
||||||
|
|
|
@ -56,10 +56,6 @@
|
||||||
#define ISAPNP_DEVICE_ID(_va, _vb, _vc, _function) \
|
#define ISAPNP_DEVICE_ID(_va, _vb, _vc, _function) \
|
||||||
{ .vendor = ISAPNP_VENDOR(_va, _vb, _vc), .function = ISAPNP_FUNCTION(_function) }
|
{ .vendor = ISAPNP_VENDOR(_va, _vb, _vc), .function = ISAPNP_FUNCTION(_function) }
|
||||||
|
|
||||||
/* export used IDs outside module */
|
|
||||||
#define ISAPNP_CARD_TABLE(name) \
|
|
||||||
MODULE_GENERIC_TABLE(isapnp_card, name)
|
|
||||||
|
|
||||||
struct isapnp_card_id {
|
struct isapnp_card_id {
|
||||||
unsigned long driver_data; /* data private to the driver */
|
unsigned long driver_data; /* data private to the driver */
|
||||||
unsigned short card_vendor, card_device;
|
unsigned short card_vendor, card_device;
|
||||||
|
|
|
@ -469,6 +469,7 @@ extern enum system_states {
|
||||||
#define TAINT_CRAP 10
|
#define TAINT_CRAP 10
|
||||||
#define TAINT_FIRMWARE_WORKAROUND 11
|
#define TAINT_FIRMWARE_WORKAROUND 11
|
||||||
#define TAINT_OOT_MODULE 12
|
#define TAINT_OOT_MODULE 12
|
||||||
|
#define TAINT_UNSIGNED_MODULE 13
|
||||||
|
|
||||||
extern const char hex_asc[];
|
extern const char hex_asc[];
|
||||||
#define hex_asc_lo(x) hex_asc[((x) & 0x0f)]
|
#define hex_asc_lo(x) hex_asc[((x) & 0x0f)]
|
||||||
|
@ -841,4 +842,12 @@ static inline void ftrace_dump(enum ftrace_dump_mode oops_dump_mode) { }
|
||||||
# define REBUILD_DUE_TO_FTRACE_MCOUNT_RECORD
|
# define REBUILD_DUE_TO_FTRACE_MCOUNT_RECORD
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* Permissions on a sysfs file: you didn't miss the 0 prefix did you? */
|
||||||
|
#define VERIFY_OCTAL_PERMISSIONS(perms) \
|
||||||
|
(BUILD_BUG_ON_ZERO((perms) < 0) + \
|
||||||
|
BUILD_BUG_ON_ZERO((perms) > 0777) + \
|
||||||
|
/* User perms >= group perms >= other perms */ \
|
||||||
|
BUILD_BUG_ON_ZERO(((perms) >> 6) < (((perms) >> 3) & 7)) + \
|
||||||
|
BUILD_BUG_ON_ZERO((((perms) >> 3) & 7) < ((perms) & 7)) + \
|
||||||
|
(perms))
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -82,15 +82,6 @@ void sort_extable(struct exception_table_entry *start,
|
||||||
void sort_main_extable(void);
|
void sort_main_extable(void);
|
||||||
void trim_init_extable(struct module *m);
|
void trim_init_extable(struct module *m);
|
||||||
|
|
||||||
#ifdef MODULE
|
|
||||||
#define MODULE_GENERIC_TABLE(gtype, name) \
|
|
||||||
extern const struct gtype##_id __mod_##gtype##_table \
|
|
||||||
__attribute__ ((unused, alias(__stringify(name))))
|
|
||||||
|
|
||||||
#else /* !MODULE */
|
|
||||||
#define MODULE_GENERIC_TABLE(gtype, name)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Generic info of form tag = "info" */
|
/* Generic info of form tag = "info" */
|
||||||
#define MODULE_INFO(tag, info) __MODULE_INFO(tag, tag, info)
|
#define MODULE_INFO(tag, info) __MODULE_INFO(tag, tag, info)
|
||||||
|
|
||||||
|
@ -141,8 +132,14 @@ extern const struct gtype##_id __mod_##gtype##_table \
|
||||||
/* What your module does. */
|
/* What your module does. */
|
||||||
#define MODULE_DESCRIPTION(_description) MODULE_INFO(description, _description)
|
#define MODULE_DESCRIPTION(_description) MODULE_INFO(description, _description)
|
||||||
|
|
||||||
#define MODULE_DEVICE_TABLE(type, name) \
|
#ifdef MODULE
|
||||||
MODULE_GENERIC_TABLE(type##_device, name)
|
/* Creates an alias so file2alias.c can find device table. */
|
||||||
|
#define MODULE_DEVICE_TABLE(type, name) \
|
||||||
|
extern const struct type##_device_id __mod_##type##__##name##_device_table \
|
||||||
|
__attribute__ ((unused, alias(__stringify(name))))
|
||||||
|
#else /* !MODULE */
|
||||||
|
#define MODULE_DEVICE_TABLE(type, name)
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Version of form [<epoch>:]<version>[-<extra-version>].
|
/* Version of form [<epoch>:]<version>[-<extra-version>].
|
||||||
* Or for CVS/RCS ID version, everything but the number is stripped.
|
* Or for CVS/RCS ID version, everything but the number is stripped.
|
||||||
|
|
|
@ -186,14 +186,12 @@ struct kparam_array
|
||||||
parameters. */
|
parameters. */
|
||||||
#define __module_param_call(prefix, name, ops, arg, perm, level) \
|
#define __module_param_call(prefix, name, ops, arg, perm, level) \
|
||||||
/* Default value instead of permissions? */ \
|
/* Default value instead of permissions? */ \
|
||||||
static int __param_perm_check_##name __attribute__((unused)) = \
|
static const char __param_str_##name[] = prefix #name; \
|
||||||
BUILD_BUG_ON_ZERO((perm) < 0 || (perm) > 0777 || ((perm) & 2)) \
|
|
||||||
+ BUILD_BUG_ON_ZERO(sizeof(""prefix) > MAX_PARAM_PREFIX_LEN); \
|
|
||||||
static const char __param_str_##name[] = prefix #name; \
|
|
||||||
static struct kernel_param __moduleparam_const __param_##name \
|
static struct kernel_param __moduleparam_const __param_##name \
|
||||||
__used \
|
__used \
|
||||||
__attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) \
|
__attribute__ ((unused,__section__ ("__param"),aligned(sizeof(void *)))) \
|
||||||
= { __param_str_##name, ops, perm, level, { arg } }
|
= { __param_str_##name, ops, VERIFY_OCTAL_PERMISSIONS(perm), \
|
||||||
|
level, { arg } }
|
||||||
|
|
||||||
/* Obsolete - use module_param_cb() */
|
/* Obsolete - use module_param_cb() */
|
||||||
#define module_param_call(name, set, get, arg, perm) \
|
#define module_param_call(name, set, get, arg, perm) \
|
||||||
|
@ -346,7 +344,7 @@ static inline void destroy_params(const struct kernel_param *params,
|
||||||
/* The macros to do compile-time type checking stolen from Jakub
|
/* The macros to do compile-time type checking stolen from Jakub
|
||||||
Jelinek, who IIRC came up with this idea for the 2.4 module init code. */
|
Jelinek, who IIRC came up with this idea for the 2.4 module init code. */
|
||||||
#define __param_check(name, p, type) \
|
#define __param_check(name, p, type) \
|
||||||
static inline type *__check_##name(void) { return(p); }
|
static inline type __always_unused *__check_##name(void) { return(p); }
|
||||||
|
|
||||||
extern struct kernel_param_ops param_ops_byte;
|
extern struct kernel_param_ops param_ops_byte;
|
||||||
extern int param_set_byte(const char *val, const struct kernel_param *kp);
|
extern int param_set_byte(const char *val, const struct kernel_param *kp);
|
||||||
|
|
|
@ -71,7 +71,8 @@ struct attribute_group {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define __ATTR(_name, _mode, _show, _store) { \
|
#define __ATTR(_name, _mode, _show, _store) { \
|
||||||
.attr = {.name = __stringify(_name), .mode = _mode }, \
|
.attr = {.name = __stringify(_name), \
|
||||||
|
.mode = VERIFY_OCTAL_PERMISSIONS(_mode) }, \
|
||||||
.show = _show, \
|
.show = _show, \
|
||||||
.store = _store, \
|
.store = _store, \
|
||||||
}
|
}
|
||||||
|
|
|
@ -22,8 +22,10 @@ struct module;
|
||||||
|
|
||||||
#define show_module_flags(flags) __print_flags(flags, "", \
|
#define show_module_flags(flags) __print_flags(flags, "", \
|
||||||
{ (1UL << TAINT_PROPRIETARY_MODULE), "P" }, \
|
{ (1UL << TAINT_PROPRIETARY_MODULE), "P" }, \
|
||||||
|
{ (1UL << TAINT_OOT_MODULE), "O" }, \
|
||||||
{ (1UL << TAINT_FORCED_MODULE), "F" }, \
|
{ (1UL << TAINT_FORCED_MODULE), "F" }, \
|
||||||
{ (1UL << TAINT_CRAP), "C" })
|
{ (1UL << TAINT_CRAP), "C" }, \
|
||||||
|
{ (1UL << TAINT_UNSIGNED_MODULE), "X" })
|
||||||
|
|
||||||
TRACE_EVENT(module_load,
|
TRACE_EVENT(module_load,
|
||||||
|
|
||||||
|
|
|
@ -1013,6 +1013,8 @@ static size_t module_flags_taint(struct module *mod, char *buf)
|
||||||
buf[l++] = 'F';
|
buf[l++] = 'F';
|
||||||
if (mod->taints & (1 << TAINT_CRAP))
|
if (mod->taints & (1 << TAINT_CRAP))
|
||||||
buf[l++] = 'C';
|
buf[l++] = 'C';
|
||||||
|
if (mod->taints & (1 << TAINT_UNSIGNED_MODULE))
|
||||||
|
buf[l++] = 'E';
|
||||||
/*
|
/*
|
||||||
* TAINT_FORCED_RMMOD: could be added.
|
* TAINT_FORCED_RMMOD: could be added.
|
||||||
* TAINT_CPU_OUT_OF_SPEC, TAINT_MACHINE_CHECK, TAINT_BAD_PAGE don't
|
* TAINT_CPU_OUT_OF_SPEC, TAINT_MACHINE_CHECK, TAINT_BAD_PAGE don't
|
||||||
|
@ -3218,7 +3220,7 @@ static int load_module(struct load_info *info, const char __user *uargs,
|
||||||
pr_notice_once("%s: module verification failed: signature "
|
pr_notice_once("%s: module verification failed: signature "
|
||||||
"and/or required key missing - tainting "
|
"and/or required key missing - tainting "
|
||||||
"kernel\n", mod->name);
|
"kernel\n", mod->name);
|
||||||
add_taint_module(mod, TAINT_FORCED_MODULE, LOCKDEP_STILL_OK);
|
add_taint_module(mod, TAINT_UNSIGNED_MODULE, LOCKDEP_STILL_OK);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -3813,12 +3815,12 @@ void print_modules(void)
|
||||||
list_for_each_entry_rcu(mod, &modules, list) {
|
list_for_each_entry_rcu(mod, &modules, list) {
|
||||||
if (mod->state == MODULE_STATE_UNFORMED)
|
if (mod->state == MODULE_STATE_UNFORMED)
|
||||||
continue;
|
continue;
|
||||||
printk(" %s%s", mod->name, module_flags(mod, buf));
|
pr_cont(" %s%s", mod->name, module_flags(mod, buf));
|
||||||
}
|
}
|
||||||
preempt_enable();
|
preempt_enable();
|
||||||
if (last_unloaded_module[0])
|
if (last_unloaded_module[0])
|
||||||
printk(" [last unloaded: %s]", last_unloaded_module);
|
pr_cont(" [last unloaded: %s]", last_unloaded_module);
|
||||||
printk("\n");
|
pr_cont("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef CONFIG_MODVERSIONS
|
#ifdef CONFIG_MODVERSIONS
|
||||||
|
|
|
@ -210,6 +210,7 @@ static const struct tnt tnts[] = {
|
||||||
{ TAINT_CRAP, 'C', ' ' },
|
{ TAINT_CRAP, 'C', ' ' },
|
||||||
{ TAINT_FIRMWARE_WORKAROUND, 'I', ' ' },
|
{ TAINT_FIRMWARE_WORKAROUND, 'I', ' ' },
|
||||||
{ TAINT_OOT_MODULE, 'O', ' ' },
|
{ TAINT_OOT_MODULE, 'O', ' ' },
|
||||||
|
{ TAINT_UNSIGNED_MODULE, 'E', ' ' },
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -228,6 +229,7 @@ static const struct tnt tnts[] = {
|
||||||
* 'C' - modules from drivers/staging are loaded.
|
* 'C' - modules from drivers/staging are loaded.
|
||||||
* 'I' - Working around severe firmware bug.
|
* 'I' - Working around severe firmware bug.
|
||||||
* 'O' - Out-of-tree module has been loaded.
|
* 'O' - Out-of-tree module has been loaded.
|
||||||
|
* 'E' - Unsigned module has been loaded.
|
||||||
*
|
*
|
||||||
* The string is overwritten by the next call to print_tainted().
|
* The string is overwritten by the next call to print_tainted().
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -460,7 +460,8 @@ EXPORT_SYMBOL_GPL(tracepoint_probe_unregister);
|
||||||
#ifdef CONFIG_MODULES
|
#ifdef CONFIG_MODULES
|
||||||
bool trace_module_has_bad_taint(struct module *mod)
|
bool trace_module_has_bad_taint(struct module *mod)
|
||||||
{
|
{
|
||||||
return mod->taints & ~((1 << TAINT_OOT_MODULE) | (1 << TAINT_CRAP));
|
return mod->taints & ~((1 << TAINT_OOT_MODULE) | (1 << TAINT_CRAP) |
|
||||||
|
(1 << TAINT_UNSIGNED_MODULE));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int tracepoint_module_coming(struct module *mod)
|
static int tracepoint_module_coming(struct module *mod)
|
||||||
|
@ -474,7 +475,7 @@ static int tracepoint_module_coming(struct module *mod)
|
||||||
/*
|
/*
|
||||||
* We skip modules that taint the kernel, especially those with different
|
* We skip modules that taint the kernel, especially those with different
|
||||||
* module headers (for forced load), to make sure we don't cause a crash.
|
* module headers (for forced load), to make sure we don't cause a crash.
|
||||||
* Staging and out-of-tree GPL modules are fine.
|
* Staging, out-of-tree, and unsigned GPL modules are fine.
|
||||||
*/
|
*/
|
||||||
if (trace_module_has_bad_taint(mod))
|
if (trace_module_has_bad_taint(mod))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -36,13 +36,13 @@ struct sym_entry {
|
||||||
unsigned char *sym;
|
unsigned char *sym;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct text_range {
|
struct addr_range {
|
||||||
const char *stext, *etext;
|
const char *start_sym, *end_sym;
|
||||||
unsigned long long start, end;
|
unsigned long long start, end;
|
||||||
};
|
};
|
||||||
|
|
||||||
static unsigned long long _text;
|
static unsigned long long _text;
|
||||||
static struct text_range text_ranges[] = {
|
static struct addr_range text_ranges[] = {
|
||||||
{ "_stext", "_etext" },
|
{ "_stext", "_etext" },
|
||||||
{ "_sinittext", "_einittext" },
|
{ "_sinittext", "_einittext" },
|
||||||
{ "_stext_l1", "_etext_l1" }, /* Blackfin on-chip L1 inst SRAM */
|
{ "_stext_l1", "_etext_l1" }, /* Blackfin on-chip L1 inst SRAM */
|
||||||
|
@ -51,9 +51,14 @@ static struct text_range text_ranges[] = {
|
||||||
#define text_range_text (&text_ranges[0])
|
#define text_range_text (&text_ranges[0])
|
||||||
#define text_range_inittext (&text_ranges[1])
|
#define text_range_inittext (&text_ranges[1])
|
||||||
|
|
||||||
|
static struct addr_range percpu_range = {
|
||||||
|
"__per_cpu_start", "__per_cpu_end", -1ULL, 0
|
||||||
|
};
|
||||||
|
|
||||||
static struct sym_entry *table;
|
static struct sym_entry *table;
|
||||||
static unsigned int table_size, table_cnt;
|
static unsigned int table_size, table_cnt;
|
||||||
static int all_symbols = 0;
|
static int all_symbols = 0;
|
||||||
|
static int absolute_percpu = 0;
|
||||||
static char symbol_prefix_char = '\0';
|
static char symbol_prefix_char = '\0';
|
||||||
static unsigned long long kernel_start_addr = 0;
|
static unsigned long long kernel_start_addr = 0;
|
||||||
|
|
||||||
|
@ -83,19 +88,20 @@ static inline int is_arm_mapping_symbol(const char *str)
|
||||||
&& (str[2] == '\0' || str[2] == '.');
|
&& (str[2] == '\0' || str[2] == '.');
|
||||||
}
|
}
|
||||||
|
|
||||||
static int read_symbol_tr(const char *sym, unsigned long long addr)
|
static int check_symbol_range(const char *sym, unsigned long long addr,
|
||||||
|
struct addr_range *ranges, int entries)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
struct text_range *tr;
|
struct addr_range *ar;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) {
|
for (i = 0; i < entries; ++i) {
|
||||||
tr = &text_ranges[i];
|
ar = &ranges[i];
|
||||||
|
|
||||||
if (strcmp(sym, tr->stext) == 0) {
|
if (strcmp(sym, ar->start_sym) == 0) {
|
||||||
tr->start = addr;
|
ar->start = addr;
|
||||||
return 0;
|
return 0;
|
||||||
} else if (strcmp(sym, tr->etext) == 0) {
|
} else if (strcmp(sym, ar->end_sym) == 0) {
|
||||||
tr->end = addr;
|
ar->end = addr;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -130,7 +136,8 @@ static int read_symbol(FILE *in, struct sym_entry *s)
|
||||||
/* Ignore most absolute/undefined (?) symbols. */
|
/* Ignore most absolute/undefined (?) symbols. */
|
||||||
if (strcmp(sym, "_text") == 0)
|
if (strcmp(sym, "_text") == 0)
|
||||||
_text = s->addr;
|
_text = s->addr;
|
||||||
else if (read_symbol_tr(sym, s->addr) == 0)
|
else if (check_symbol_range(sym, s->addr, text_ranges,
|
||||||
|
ARRAY_SIZE(text_ranges)) == 0)
|
||||||
/* nothing to do */;
|
/* nothing to do */;
|
||||||
else if (toupper(stype) == 'A')
|
else if (toupper(stype) == 'A')
|
||||||
{
|
{
|
||||||
|
@ -164,18 +171,22 @@ static int read_symbol(FILE *in, struct sym_entry *s)
|
||||||
strcpy((char *)s->sym + 1, str);
|
strcpy((char *)s->sym + 1, str);
|
||||||
s->sym[0] = stype;
|
s->sym[0] = stype;
|
||||||
|
|
||||||
|
/* Record if we've found __per_cpu_start/end. */
|
||||||
|
check_symbol_range(sym, s->addr, &percpu_range, 1);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int symbol_valid_tr(struct sym_entry *s)
|
static int symbol_in_range(struct sym_entry *s, struct addr_range *ranges,
|
||||||
|
int entries)
|
||||||
{
|
{
|
||||||
size_t i;
|
size_t i;
|
||||||
struct text_range *tr;
|
struct addr_range *ar;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(text_ranges); ++i) {
|
for (i = 0; i < entries; ++i) {
|
||||||
tr = &text_ranges[i];
|
ar = &ranges[i];
|
||||||
|
|
||||||
if (s->addr >= tr->start && s->addr <= tr->end)
|
if (s->addr >= ar->start && s->addr <= ar->end)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -214,7 +225,8 @@ static int symbol_valid(struct sym_entry *s)
|
||||||
/* if --all-symbols is not specified, then symbols outside the text
|
/* if --all-symbols is not specified, then symbols outside the text
|
||||||
* and inittext sections are discarded */
|
* and inittext sections are discarded */
|
||||||
if (!all_symbols) {
|
if (!all_symbols) {
|
||||||
if (symbol_valid_tr(s) == 0)
|
if (symbol_in_range(s, text_ranges,
|
||||||
|
ARRAY_SIZE(text_ranges)) == 0)
|
||||||
return 0;
|
return 0;
|
||||||
/* Corner case. Discard any symbols with the same value as
|
/* Corner case. Discard any symbols with the same value as
|
||||||
* _etext _einittext; they can move between pass 1 and 2 when
|
* _etext _einittext; they can move between pass 1 and 2 when
|
||||||
|
@ -223,9 +235,11 @@ static int symbol_valid(struct sym_entry *s)
|
||||||
* rules.
|
* rules.
|
||||||
*/
|
*/
|
||||||
if ((s->addr == text_range_text->end &&
|
if ((s->addr == text_range_text->end &&
|
||||||
strcmp((char *)s->sym + offset, text_range_text->etext)) ||
|
strcmp((char *)s->sym + offset,
|
||||||
|
text_range_text->end_sym)) ||
|
||||||
(s->addr == text_range_inittext->end &&
|
(s->addr == text_range_inittext->end &&
|
||||||
strcmp((char *)s->sym + offset, text_range_inittext->etext)))
|
strcmp((char *)s->sym + offset,
|
||||||
|
text_range_inittext->end_sym)))
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -298,6 +312,11 @@ static int expand_symbol(unsigned char *data, int len, char *result)
|
||||||
return total;
|
return total;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int symbol_absolute(struct sym_entry *s)
|
||||||
|
{
|
||||||
|
return toupper(s->sym[0]) == 'A';
|
||||||
|
}
|
||||||
|
|
||||||
static void write_src(void)
|
static void write_src(void)
|
||||||
{
|
{
|
||||||
unsigned int i, k, off;
|
unsigned int i, k, off;
|
||||||
|
@ -325,7 +344,7 @@ static void write_src(void)
|
||||||
*/
|
*/
|
||||||
output_label("kallsyms_addresses");
|
output_label("kallsyms_addresses");
|
||||||
for (i = 0; i < table_cnt; i++) {
|
for (i = 0; i < table_cnt; i++) {
|
||||||
if (toupper(table[i].sym[0]) != 'A') {
|
if (!symbol_absolute(&table[i])) {
|
||||||
if (_text <= table[i].addr)
|
if (_text <= table[i].addr)
|
||||||
printf("\tPTR\t_text + %#llx\n",
|
printf("\tPTR\t_text + %#llx\n",
|
||||||
table[i].addr - _text);
|
table[i].addr - _text);
|
||||||
|
@ -646,6 +665,15 @@ static void sort_symbols(void)
|
||||||
qsort(table, table_cnt, sizeof(struct sym_entry), compare_symbols);
|
qsort(table, table_cnt, sizeof(struct sym_entry), compare_symbols);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void make_percpus_absolute(void)
|
||||||
|
{
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
for (i = 0; i < table_cnt; i++)
|
||||||
|
if (symbol_in_range(&table[i], &percpu_range, 1))
|
||||||
|
table[i].sym[0] = 'A';
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
if (argc >= 2) {
|
if (argc >= 2) {
|
||||||
|
@ -653,6 +681,8 @@ int main(int argc, char **argv)
|
||||||
for (i = 1; i < argc; i++) {
|
for (i = 1; i < argc; i++) {
|
||||||
if(strcmp(argv[i], "--all-symbols") == 0)
|
if(strcmp(argv[i], "--all-symbols") == 0)
|
||||||
all_symbols = 1;
|
all_symbols = 1;
|
||||||
|
else if (strcmp(argv[i], "--absolute-percpu") == 0)
|
||||||
|
absolute_percpu = 1;
|
||||||
else if (strncmp(argv[i], "--symbol-prefix=", 16) == 0) {
|
else if (strncmp(argv[i], "--symbol-prefix=", 16) == 0) {
|
||||||
char *p = &argv[i][16];
|
char *p = &argv[i][16];
|
||||||
/* skip quote */
|
/* skip quote */
|
||||||
|
@ -669,6 +699,8 @@ int main(int argc, char **argv)
|
||||||
usage();
|
usage();
|
||||||
|
|
||||||
read_map(stdin);
|
read_map(stdin);
|
||||||
|
if (absolute_percpu)
|
||||||
|
make_percpus_absolute();
|
||||||
sort_symbols();
|
sort_symbols();
|
||||||
optimize_token_table();
|
optimize_token_table();
|
||||||
write_src();
|
write_src();
|
||||||
|
|
|
@ -86,6 +86,10 @@ kallsyms()
|
||||||
kallsymopt="${kallsymopt} --page-offset=$CONFIG_PAGE_OFFSET"
|
kallsymopt="${kallsymopt} --page-offset=$CONFIG_PAGE_OFFSET"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if [ -n "${CONFIG_X86_64}" ]; then
|
||||||
|
kallsymopt="${kallsymopt} --absolute-percpu"
|
||||||
|
fi
|
||||||
|
|
||||||
local aflags="${KBUILD_AFLAGS} ${KBUILD_AFLAGS_KERNEL} \
|
local aflags="${KBUILD_AFLAGS} ${KBUILD_AFLAGS_KERNEL} \
|
||||||
${NOSTDINC_FLAGS} ${LINUXINCLUDE} ${KBUILD_CPPFLAGS}"
|
${NOSTDINC_FLAGS} ${LINUXINCLUDE} ${KBUILD_CPPFLAGS}"
|
||||||
|
|
||||||
|
|
|
@ -42,7 +42,7 @@ typedef unsigned char __u8;
|
||||||
|
|
||||||
/* This array collects all instances that use the generic do_table */
|
/* This array collects all instances that use the generic do_table */
|
||||||
struct devtable {
|
struct devtable {
|
||||||
const char *device_id; /* name of table, __mod_<name>_device_table. */
|
const char *device_id; /* name of table, __mod_<name>__*_device_table. */
|
||||||
unsigned long id_size;
|
unsigned long id_size;
|
||||||
void *function;
|
void *function;
|
||||||
};
|
};
|
||||||
|
@ -146,7 +146,8 @@ static void device_id_check(const char *modname, const char *device_id,
|
||||||
|
|
||||||
if (size % id_size || size < id_size) {
|
if (size % id_size || size < id_size) {
|
||||||
fatal("%s: sizeof(struct %s_device_id)=%lu is not a modulo "
|
fatal("%s: sizeof(struct %s_device_id)=%lu is not a modulo "
|
||||||
"of the size of section __mod_%s_device_table=%lu.\n"
|
"of the size of "
|
||||||
|
"section __mod_%s__<identifier>_device_table=%lu.\n"
|
||||||
"Fix definition of struct %s_device_id "
|
"Fix definition of struct %s_device_id "
|
||||||
"in mod_devicetable.h\n",
|
"in mod_devicetable.h\n",
|
||||||
modname, device_id, id_size, device_id, size, device_id);
|
modname, device_id, id_size, device_id, size, device_id);
|
||||||
|
@ -1216,7 +1217,7 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,
|
||||||
{
|
{
|
||||||
void *symval;
|
void *symval;
|
||||||
char *zeros = NULL;
|
char *zeros = NULL;
|
||||||
const char *name;
|
const char *name, *identifier;
|
||||||
unsigned int namelen;
|
unsigned int namelen;
|
||||||
|
|
||||||
/* We're looking for a section relative symbol */
|
/* We're looking for a section relative symbol */
|
||||||
|
@ -1227,7 +1228,7 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,
|
||||||
if (ELF_ST_TYPE(sym->st_info) != STT_OBJECT)
|
if (ELF_ST_TYPE(sym->st_info) != STT_OBJECT)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* All our symbols are of form <prefix>__mod_XXX_device_table. */
|
/* All our symbols are of form <prefix>__mod_<name>__<identifier>_device_table. */
|
||||||
name = strstr(symname, "__mod_");
|
name = strstr(symname, "__mod_");
|
||||||
if (!name)
|
if (!name)
|
||||||
return;
|
return;
|
||||||
|
@ -1237,7 +1238,10 @@ void handle_moddevtable(struct module *mod, struct elf_info *info,
|
||||||
return;
|
return;
|
||||||
if (strcmp(name + namelen - strlen("_device_table"), "_device_table"))
|
if (strcmp(name + namelen - strlen("_device_table"), "_device_table"))
|
||||||
return;
|
return;
|
||||||
namelen -= strlen("_device_table");
|
identifier = strstr(name, "__");
|
||||||
|
if (!identifier)
|
||||||
|
return;
|
||||||
|
namelen = identifier - name;
|
||||||
|
|
||||||
/* Handle all-NULL symbols allocated into .bss */
|
/* Handle all-NULL symbols allocated into .bss */
|
||||||
if (info->sechdrs[get_secindex(info, sym)].sh_type & SHT_NOBITS) {
|
if (info->sechdrs[get_secindex(info, sym)].sh_type & SHT_NOBITS) {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue