diff options
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/crypto/padlock-sha.c | 14 | ||||
| -rw-r--r-- | drivers/input/input.c | 65 | ||||
| -rw-r--r-- | drivers/input/keyboard/atkbd.c | 96 | ||||
| -rw-r--r-- | drivers/input/misc/hp_sdc_rtc.c | 2 | ||||
| -rw-r--r-- | drivers/input/mouse/logips2pp.c | 2 | ||||
| -rw-r--r-- | drivers/input/mouse/synaptics.c | 10 | ||||
| -rw-r--r-- | drivers/input/serio/i8042-x86ia64io.h | 13 | ||||
| -rw-r--r-- | drivers/md/dm-exception-store.c | 38 | ||||
| -rw-r--r-- | drivers/md/dm-exception-store.h | 8 | ||||
| -rw-r--r-- | drivers/md/dm-log-userspace-base.c | 2 | ||||
| -rw-r--r-- | drivers/md/dm-snap-persistent.c | 16 | ||||
| -rw-r--r-- | drivers/md/dm-snap.c | 25 | ||||
| -rw-r--r-- | drivers/md/dm.c | 11 | ||||
| -rw-r--r-- | drivers/mmc/host/at91_mci.c | 1 |
14 files changed, 194 insertions, 109 deletions
diff --git a/drivers/crypto/padlock-sha.c b/drivers/crypto/padlock-sha.c index 76cb6b345e7b..0af80577dc7b 100644 --- a/drivers/crypto/padlock-sha.c +++ b/drivers/crypto/padlock-sha.c | |||
| @@ -24,6 +24,12 @@ | |||
| 24 | #include <asm/i387.h> | 24 | #include <asm/i387.h> |
| 25 | #include "padlock.h" | 25 | #include "padlock.h" |
| 26 | 26 | ||
| 27 | #ifdef CONFIG_64BIT | ||
| 28 | #define STACK_ALIGN 16 | ||
| 29 | #else | ||
| 30 | #define STACK_ALIGN 4 | ||
| 31 | #endif | ||
| 32 | |||
| 27 | struct padlock_sha_desc { | 33 | struct padlock_sha_desc { |
| 28 | struct shash_desc fallback; | 34 | struct shash_desc fallback; |
| 29 | }; | 35 | }; |
| @@ -64,7 +70,9 @@ static int padlock_sha1_finup(struct shash_desc *desc, const u8 *in, | |||
| 64 | /* We can't store directly to *out as it may be unaligned. */ | 70 | /* We can't store directly to *out as it may be unaligned. */ |
| 65 | /* BTW Don't reduce the buffer size below 128 Bytes! | 71 | /* BTW Don't reduce the buffer size below 128 Bytes! |
| 66 | * PadLock microcode needs it that big. */ | 72 | * PadLock microcode needs it that big. */ |
| 67 | char result[128] __attribute__ ((aligned(PADLOCK_ALIGNMENT))); | 73 | char buf[128 + PADLOCK_ALIGNMENT - STACK_ALIGN] __attribute__ |
| 74 | ((aligned(STACK_ALIGN))); | ||
| 75 | char *result = PTR_ALIGN(&buf[0], PADLOCK_ALIGNMENT); | ||
| 68 | struct padlock_sha_desc *dctx = shash_desc_ctx(desc); | 76 | struct padlock_sha_desc *dctx = shash_desc_ctx(desc); |
| 69 | struct sha1_state state; | 77 | struct sha1_state state; |
| 70 | unsigned int space; | 78 | unsigned int space; |
| @@ -128,7 +136,9 @@ static int padlock_sha256_finup(struct shash_desc *desc, const u8 *in, | |||
| 128 | /* We can't store directly to *out as it may be unaligned. */ | 136 | /* We can't store directly to *out as it may be unaligned. */ |
| 129 | /* BTW Don't reduce the buffer size below 128 Bytes! | 137 | /* BTW Don't reduce the buffer size below 128 Bytes! |
| 130 | * PadLock microcode needs it that big. */ | 138 | * PadLock microcode needs it that big. */ |
| 131 | char result[128] __attribute__ ((aligned(PADLOCK_ALIGNMENT))); | 139 | char buf[128 + PADLOCK_ALIGNMENT - STACK_ALIGN] __attribute__ |
| 140 | ((aligned(STACK_ALIGN))); | ||
| 141 | char *result = PTR_ALIGN(&buf[0], PADLOCK_ALIGNMENT); | ||
| 132 | struct padlock_sha_desc *dctx = shash_desc_ctx(desc); | 142 | struct padlock_sha_desc *dctx = shash_desc_ctx(desc); |
| 133 | struct sha256_state state; | 143 | struct sha256_state state; |
| 134 | unsigned int space; | 144 | unsigned int space; |
diff --git a/drivers/input/input.c b/drivers/input/input.c index c6f88ebb40c7..cc763c96fada 100644 --- a/drivers/input/input.c +++ b/drivers/input/input.c | |||
| @@ -782,10 +782,29 @@ static unsigned int input_proc_devices_poll(struct file *file, poll_table *wait) | |||
| 782 | return 0; | 782 | return 0; |
| 783 | } | 783 | } |
| 784 | 784 | ||
| 785 | union input_seq_state { | ||
| 786 | struct { | ||
| 787 | unsigned short pos; | ||
| 788 | bool mutex_acquired; | ||
| 789 | }; | ||
| 790 | void *p; | ||
| 791 | }; | ||
| 792 | |||
| 785 | static void *input_devices_seq_start(struct seq_file *seq, loff_t *pos) | 793 | static void *input_devices_seq_start(struct seq_file *seq, loff_t *pos) |
| 786 | { | 794 | { |
| 787 | if (mutex_lock_interruptible(&input_mutex)) | 795 | union input_seq_state *state = (union input_seq_state *)&seq->private; |
| 788 | return NULL; | 796 | int error; |
| 797 | |||
| 798 | /* We need to fit into seq->private pointer */ | ||
| 799 | BUILD_BUG_ON(sizeof(union input_seq_state) != sizeof(seq->private)); | ||
| 800 | |||
| 801 | error = mutex_lock_interruptible(&input_mutex); | ||
| 802 | if (error) { | ||
| 803 | state->mutex_acquired = false; | ||
| 804 | return ERR_PTR(error); | ||
| 805 | } | ||
| 806 | |||
| 807 | state->mutex_acquired = true; | ||
| 789 | 808 | ||
| 790 | return seq_list_start(&input_dev_list, *pos); | 809 | return seq_list_start(&input_dev_list, *pos); |
| 791 | } | 810 | } |
| @@ -795,9 +814,12 @@ static void *input_devices_seq_next(struct seq_file *seq, void *v, loff_t *pos) | |||
| 795 | return seq_list_next(v, &input_dev_list, pos); | 814 | return seq_list_next(v, &input_dev_list, pos); |
| 796 | } | 815 | } |
| 797 | 816 | ||
| 798 | static void input_devices_seq_stop(struct seq_file *seq, void *v) | 817 | static void input_seq_stop(struct seq_file *seq, void *v) |
| 799 | { | 818 | { |
| 800 | mutex_unlock(&input_mutex); | 819 | union input_seq_state *state = (union input_seq_state *)&seq->private; |
| 820 | |||
| 821 | if (state->mutex_acquired) | ||
| 822 | mutex_unlock(&input_mutex); | ||
| 801 | } | 823 | } |
| 802 | 824 | ||
| 803 | static void input_seq_print_bitmap(struct seq_file *seq, const char *name, | 825 | static void input_seq_print_bitmap(struct seq_file *seq, const char *name, |
| @@ -861,7 +883,7 @@ static int input_devices_seq_show(struct seq_file *seq, void *v) | |||
| 861 | static const struct seq_operations input_devices_seq_ops = { | 883 | static const struct seq_operations input_devices_seq_ops = { |
| 862 | .start = input_devices_seq_start, | 884 | .start = input_devices_seq_start, |
| 863 | .next = input_devices_seq_next, | 885 | .next = input_devices_seq_next, |
| 864 | .stop = input_devices_seq_stop, | 886 | .stop = input_seq_stop, |
| 865 | .show = input_devices_seq_show, | 887 | .show = input_devices_seq_show, |
| 866 | }; | 888 | }; |
| 867 | 889 | ||
| @@ -881,40 +903,49 @@ static const struct file_operations input_devices_fileops = { | |||
| 881 | 903 | ||
| 882 | static void *input_handlers_seq_start(struct seq_file *seq, loff_t *pos) | 904 | static void *input_handlers_seq_start(struct seq_file *seq, loff_t *pos) |
| 883 | { | 905 | { |
| 884 | if (mutex_lock_interruptible(&input_mutex)) | 906 | union input_seq_state *state = (union input_seq_state *)&seq->private; |
| 885 | return NULL; | 907 | int error; |
| 908 | |||
| 909 | /* We need to fit into seq->private pointer */ | ||
| 910 | BUILD_BUG_ON(sizeof(union input_seq_state) != sizeof(seq->private)); | ||
| 911 | |||
| 912 | error = mutex_lock_interruptible(&input_mutex); | ||
| 913 | if (error) { | ||
| 914 | state->mutex_acquired = false; | ||
| 915 | return ERR_PTR(error); | ||
| 916 | } | ||
| 917 | |||
| 918 | state->mutex_acquired = true; | ||
| 919 | state->pos = *pos; | ||
| 886 | 920 | ||
| 887 | seq->private = (void *)(unsigned long)*pos; | ||
| 888 | return seq_list_start(&input_handler_list, *pos); | 921 | return seq_list_start(&input_handler_list, *pos); |
| 889 | } | 922 | } |
| 890 | 923 | ||
| 891 | static void *input_handlers_seq_next(struct seq_file *seq, void *v, loff_t *pos) | 924 | static void *input_handlers_seq_next(struct seq_file *seq, void *v, loff_t *pos) |
| 892 | { | 925 | { |
| 893 | seq->private = (void *)(unsigned long)(*pos + 1); | 926 | union input_seq_state *state = (union input_seq_state *)&seq->private; |
| 894 | return seq_list_next(v, &input_handler_list, pos); | ||
| 895 | } | ||
| 896 | 927 | ||
| 897 | static void input_handlers_seq_stop(struct seq_file *seq, void *v) | 928 | state->pos = *pos + 1; |
| 898 | { | 929 | return seq_list_next(v, &input_handler_list, pos); |
| 899 | mutex_unlock(&input_mutex); | ||
| 900 | } | 930 | } |
| 901 | 931 | ||
| 902 | static int input_handlers_seq_show(struct seq_file *seq, void *v) | 932 | static int input_handlers_seq_show(struct seq_file *seq, void *v) |
| 903 | { | 933 | { |
| 904 | struct input_handler *handler = container_of(v, struct input_handler, node); | 934 | struct input_handler *handler = container_of(v, struct input_handler, node); |
| 935 | union input_seq_state *state = (union input_seq_state *)&seq->private; | ||
| 905 | 936 | ||
| 906 | seq_printf(seq, "N: Number=%ld Name=%s", | 937 | seq_printf(seq, "N: Number=%u Name=%s", state->pos, handler->name); |
| 907 | (unsigned long)seq->private, handler->name); | ||
| 908 | if (handler->fops) | 938 | if (handler->fops) |
| 909 | seq_printf(seq, " Minor=%d", handler->minor); | 939 | seq_printf(seq, " Minor=%d", handler->minor); |
| 910 | seq_putc(seq, '\n'); | 940 | seq_putc(seq, '\n'); |
| 911 | 941 | ||
| 912 | return 0; | 942 | return 0; |
| 913 | } | 943 | } |
| 944 | |||
| 914 | static const struct seq_operations input_handlers_seq_ops = { | 945 | static const struct seq_operations input_handlers_seq_ops = { |
| 915 | .start = input_handlers_seq_start, | 946 | .start = input_handlers_seq_start, |
| 916 | .next = input_handlers_seq_next, | 947 | .next = input_handlers_seq_next, |
| 917 | .stop = input_handlers_seq_stop, | 948 | .stop = input_seq_stop, |
| 918 | .show = input_handlers_seq_show, | 949 | .show = input_handlers_seq_show, |
| 919 | }; | 950 | }; |
| 920 | 951 | ||
diff --git a/drivers/input/keyboard/atkbd.c b/drivers/input/keyboard/atkbd.c index 4709e15af607..a6512372c7a3 100644 --- a/drivers/input/keyboard/atkbd.c +++ b/drivers/input/keyboard/atkbd.c | |||
| @@ -574,11 +574,22 @@ static void atkbd_event_work(struct work_struct *work) | |||
| 574 | 574 | ||
| 575 | mutex_lock(&atkbd->event_mutex); | 575 | mutex_lock(&atkbd->event_mutex); |
| 576 | 576 | ||
| 577 | if (test_and_clear_bit(ATKBD_LED_EVENT_BIT, &atkbd->event_mask)) | 577 | if (!atkbd->enabled) { |
| 578 | atkbd_set_leds(atkbd); | 578 | /* |
| 579 | * Serio ports are resumed asynchronously so while driver core | ||
| 580 | * thinks that device is already fully operational in reality | ||
| 581 | * it may not be ready yet. In this case we need to keep | ||
| 582 | * rescheduling till reconnect completes. | ||
| 583 | */ | ||
| 584 | schedule_delayed_work(&atkbd->event_work, | ||
| 585 | msecs_to_jiffies(100)); | ||
| 586 | } else { | ||
| 587 | if (test_and_clear_bit(ATKBD_LED_EVENT_BIT, &atkbd->event_mask)) | ||
| 588 | atkbd_set_leds(atkbd); | ||
| 579 | 589 | ||
| 580 | if (test_and_clear_bit(ATKBD_REP_EVENT_BIT, &atkbd->event_mask)) | 590 | if (test_and_clear_bit(ATKBD_REP_EVENT_BIT, &atkbd->event_mask)) |
| 581 | atkbd_set_repeat_rate(atkbd); | 591 | atkbd_set_repeat_rate(atkbd); |
| 592 | } | ||
| 582 | 593 | ||
| 583 | mutex_unlock(&atkbd->event_mutex); | 594 | mutex_unlock(&atkbd->event_mutex); |
| 584 | } | 595 | } |
| @@ -770,6 +781,30 @@ static int atkbd_select_set(struct atkbd *atkbd, int target_set, int allow_extra | |||
| 770 | return 3; | 781 | return 3; |
| 771 | } | 782 | } |
| 772 | 783 | ||
| 784 | static int atkbd_reset_state(struct atkbd *atkbd) | ||
| 785 | { | ||
| 786 | struct ps2dev *ps2dev = &atkbd->ps2dev; | ||
| 787 | unsigned char param[1]; | ||
| 788 | |||
| 789 | /* | ||
| 790 | * Set the LEDs to a predefined state (all off). | ||
| 791 | */ | ||
| 792 | |||
| 793 | param[0] = 0; | ||
| 794 | if (ps2_command(ps2dev, param, ATKBD_CMD_SETLEDS)) | ||
| 795 | return -1; | ||
| 796 | |||
| 797 | /* | ||
| 798 | * Set autorepeat to fastest possible. | ||
| 799 | */ | ||
| 800 | |||
| 801 | param[0] = 0; | ||
| 802 | if (ps2_command(ps2dev, param, ATKBD_CMD_SETREP)) | ||
| 803 | return -1; | ||
| 804 | |||
| 805 | return 0; | ||
| 806 | } | ||
| 807 | |||
| 773 | static int atkbd_activate(struct atkbd *atkbd) | 808 | static int atkbd_activate(struct atkbd *atkbd) |
| 774 | { | 809 | { |
| 775 | struct ps2dev *ps2dev = &atkbd->ps2dev; | 810 | struct ps2dev *ps2dev = &atkbd->ps2dev; |
| @@ -852,29 +887,6 @@ static unsigned int atkbd_hp_forced_release_keys[] = { | |||
| 852 | }; | 887 | }; |
| 853 | 888 | ||
| 854 | /* | 889 | /* |
| 855 | * Inventec system with broken key release on volume keys | ||
| 856 | */ | ||
| 857 | static unsigned int atkbd_inventec_forced_release_keys[] = { | ||
| 858 | 0xae, 0xb0, -1U | ||
| 859 | }; | ||
| 860 | |||
| 861 | /* | ||
| 862 | * Perform fixup for HP Pavilion ZV6100 laptop that doesn't generate release | ||
| 863 | * for its volume buttons | ||
| 864 | */ | ||
| 865 | static unsigned int atkbd_hp_zv6100_forced_release_keys[] = { | ||
| 866 | 0xae, 0xb0, -1U | ||
| 867 | }; | ||
| 868 | |||
| 869 | /* | ||
| 870 | * Perform fixup for HP (Compaq) Presario R4000 R4100 R4200 that don't generate | ||
| 871 | * release for their volume buttons | ||
| 872 | */ | ||
| 873 | static unsigned int atkbd_hp_r4000_forced_release_keys[] = { | ||
| 874 | 0xae, 0xb0, -1U | ||
| 875 | }; | ||
| 876 | |||
| 877 | /* | ||
| 878 | * Samsung NC10,NC20 with Fn+F? key release not working | 890 | * Samsung NC10,NC20 with Fn+F? key release not working |
| 879 | */ | 891 | */ |
| 880 | static unsigned int atkbd_samsung_forced_release_keys[] = { | 892 | static unsigned int atkbd_samsung_forced_release_keys[] = { |
| @@ -882,14 +894,6 @@ static unsigned int atkbd_samsung_forced_release_keys[] = { | |||
| 882 | }; | 894 | }; |
| 883 | 895 | ||
| 884 | /* | 896 | /* |
| 885 | * The volume up and volume down special keys on a Fujitsu Amilo PA 1510 laptop | ||
| 886 | * do not generate release events so we have to do it ourselves. | ||
| 887 | */ | ||
| 888 | static unsigned int atkbd_amilo_pa1510_forced_release_keys[] = { | ||
| 889 | 0xb0, 0xae, -1U | ||
| 890 | }; | ||
| 891 | |||
| 892 | /* | ||
| 893 | * Amilo Pi 3525 key release for Fn+Volume keys not working | 897 | * Amilo Pi 3525 key release for Fn+Volume keys not working |
| 894 | */ | 898 | */ |
| 895 | static unsigned int atkbd_amilo_pi3525_forced_release_keys[] = { | 899 | static unsigned int atkbd_amilo_pi3525_forced_release_keys[] = { |
| @@ -911,6 +915,14 @@ static unsigned int atkdb_soltech_ta12_forced_release_keys[] = { | |||
| 911 | }; | 915 | }; |
| 912 | 916 | ||
| 913 | /* | 917 | /* |
| 918 | * Many notebooks don't send key release event for volume up/down | ||
| 919 | * keys, with key list below common among them | ||
| 920 | */ | ||
| 921 | static unsigned int atkbd_volume_forced_release_keys[] = { | ||
| 922 | 0xae, 0xb0, -1U | ||
| 923 | }; | ||
| 924 | |||
| 925 | /* | ||
| 914 | * atkbd_set_keycode_table() initializes keyboard's keycode table | 926 | * atkbd_set_keycode_table() initializes keyboard's keycode table |
| 915 | * according to the selected scancode set | 927 | * according to the selected scancode set |
| 916 | */ | 928 | */ |
| @@ -1087,6 +1099,7 @@ static int atkbd_connect(struct serio *serio, struct serio_driver *drv) | |||
| 1087 | } | 1099 | } |
| 1088 | 1100 | ||
| 1089 | atkbd->set = atkbd_select_set(atkbd, atkbd_set, atkbd_extra); | 1101 | atkbd->set = atkbd_select_set(atkbd, atkbd_set, atkbd_extra); |
| 1102 | atkbd_reset_state(atkbd); | ||
| 1090 | atkbd_activate(atkbd); | 1103 | atkbd_activate(atkbd); |
| 1091 | 1104 | ||
| 1092 | } else { | 1105 | } else { |
| @@ -1267,6 +1280,7 @@ static ssize_t atkbd_set_extra(struct atkbd *atkbd, const char *buf, size_t coun | |||
| 1267 | 1280 | ||
| 1268 | atkbd->dev = new_dev; | 1281 | atkbd->dev = new_dev; |
| 1269 | atkbd->set = atkbd_select_set(atkbd, atkbd->set, value); | 1282 | atkbd->set = atkbd_select_set(atkbd, atkbd->set, value); |
| 1283 | atkbd_reset_state(atkbd); | ||
| 1270 | atkbd_activate(atkbd); | 1284 | atkbd_activate(atkbd); |
| 1271 | atkbd_set_keycode_table(atkbd); | 1285 | atkbd_set_keycode_table(atkbd); |
| 1272 | atkbd_set_device_attrs(atkbd); | 1286 | atkbd_set_device_attrs(atkbd); |
| @@ -1548,7 +1562,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1548 | DMI_MATCH(DMI_PRODUCT_NAME, "Pavilion ZV6100"), | 1562 | DMI_MATCH(DMI_PRODUCT_NAME, "Pavilion ZV6100"), |
| 1549 | }, | 1563 | }, |
| 1550 | .callback = atkbd_setup_forced_release, | 1564 | .callback = atkbd_setup_forced_release, |
| 1551 | .driver_data = atkbd_hp_zv6100_forced_release_keys, | 1565 | .driver_data = atkbd_volume_forced_release_keys, |
| 1552 | }, | 1566 | }, |
| 1553 | { | 1567 | { |
| 1554 | .ident = "HP Presario R4000", | 1568 | .ident = "HP Presario R4000", |
| @@ -1557,7 +1571,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1557 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4000"), | 1571 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4000"), |
| 1558 | }, | 1572 | }, |
| 1559 | .callback = atkbd_setup_forced_release, | 1573 | .callback = atkbd_setup_forced_release, |
| 1560 | .driver_data = atkbd_hp_r4000_forced_release_keys, | 1574 | .driver_data = atkbd_volume_forced_release_keys, |
| 1561 | }, | 1575 | }, |
| 1562 | { | 1576 | { |
| 1563 | .ident = "HP Presario R4100", | 1577 | .ident = "HP Presario R4100", |
| @@ -1566,7 +1580,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1566 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4100"), | 1580 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4100"), |
| 1567 | }, | 1581 | }, |
| 1568 | .callback = atkbd_setup_forced_release, | 1582 | .callback = atkbd_setup_forced_release, |
| 1569 | .driver_data = atkbd_hp_r4000_forced_release_keys, | 1583 | .driver_data = atkbd_volume_forced_release_keys, |
| 1570 | }, | 1584 | }, |
| 1571 | { | 1585 | { |
| 1572 | .ident = "HP Presario R4200", | 1586 | .ident = "HP Presario R4200", |
| @@ -1575,7 +1589,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1575 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4200"), | 1589 | DMI_MATCH(DMI_PRODUCT_NAME, "Presario R4200"), |
| 1576 | }, | 1590 | }, |
| 1577 | .callback = atkbd_setup_forced_release, | 1591 | .callback = atkbd_setup_forced_release, |
| 1578 | .driver_data = atkbd_hp_r4000_forced_release_keys, | 1592 | .driver_data = atkbd_volume_forced_release_keys, |
| 1579 | }, | 1593 | }, |
| 1580 | { | 1594 | { |
| 1581 | .ident = "Inventec Symphony", | 1595 | .ident = "Inventec Symphony", |
| @@ -1584,7 +1598,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1584 | DMI_MATCH(DMI_PRODUCT_NAME, "SYMPHONY 6.0/7.0"), | 1598 | DMI_MATCH(DMI_PRODUCT_NAME, "SYMPHONY 6.0/7.0"), |
| 1585 | }, | 1599 | }, |
| 1586 | .callback = atkbd_setup_forced_release, | 1600 | .callback = atkbd_setup_forced_release, |
| 1587 | .driver_data = atkbd_inventec_forced_release_keys, | 1601 | .driver_data = atkbd_volume_forced_release_keys, |
| 1588 | }, | 1602 | }, |
| 1589 | { | 1603 | { |
| 1590 | .ident = "Samsung NC10", | 1604 | .ident = "Samsung NC10", |
| @@ -1620,7 +1634,7 @@ static struct dmi_system_id atkbd_dmi_quirk_table[] __initdata = { | |||
| 1620 | DMI_MATCH(DMI_PRODUCT_NAME, "AMILO Pa 1510"), | 1634 | DMI_MATCH(DMI_PRODUCT_NAME, "AMILO Pa 1510"), |
| 1621 | }, | 1635 | }, |
| 1622 | .callback = atkbd_setup_forced_release, | 1636 | .callback = atkbd_setup_forced_release, |
| 1623 | .driver_data = atkbd_amilo_pa1510_forced_release_keys, | 1637 | .driver_data = atkbd_volume_forced_release_keys, |
| 1624 | }, | 1638 | }, |
| 1625 | { | 1639 | { |
| 1626 | .ident = "Fujitsu Amilo Pi 3525", | 1640 | .ident = "Fujitsu Amilo Pi 3525", |
diff --git a/drivers/input/misc/hp_sdc_rtc.c b/drivers/input/misc/hp_sdc_rtc.c index 216a559f55ea..ea821b546969 100644 --- a/drivers/input/misc/hp_sdc_rtc.c +++ b/drivers/input/misc/hp_sdc_rtc.c | |||
| @@ -209,7 +209,7 @@ static inline int hp_sdc_rtc_read_rt(struct timeval *res) { | |||
| 209 | 209 | ||
| 210 | /* Read the i8042 fast handshake timer */ | 210 | /* Read the i8042 fast handshake timer */ |
| 211 | static inline int hp_sdc_rtc_read_fhs(struct timeval *res) { | 211 | static inline int hp_sdc_rtc_read_fhs(struct timeval *res) { |
| 212 | uint64_t raw; | 212 | int64_t raw; |
| 213 | unsigned int tenms; | 213 | unsigned int tenms; |
| 214 | 214 | ||
| 215 | raw = hp_sdc_rtc_read_i8042timer(HP_SDC_CMD_LOAD_FHS, 2); | 215 | raw = hp_sdc_rtc_read_i8042timer(HP_SDC_CMD_LOAD_FHS, 2); |
diff --git a/drivers/input/mouse/logips2pp.c b/drivers/input/mouse/logips2pp.c index de745d751162..ab5dc5f5fd83 100644 --- a/drivers/input/mouse/logips2pp.c +++ b/drivers/input/mouse/logips2pp.c | |||
| @@ -219,7 +219,7 @@ static const struct ps2pp_info *get_model_info(unsigned char model) | |||
| 219 | PS2PP_WHEEL | PS2PP_SIDE_BTN | PS2PP_TASK_BTN | | 219 | PS2PP_WHEEL | PS2PP_SIDE_BTN | PS2PP_TASK_BTN | |
| 220 | PS2PP_EXTRA_BTN | PS2PP_NAV_BTN | PS2PP_HWHEEL }, | 220 | PS2PP_EXTRA_BTN | PS2PP_NAV_BTN | PS2PP_HWHEEL }, |
| 221 | { 72, PS2PP_KIND_TRACKMAN, 0 }, /* T-CH11: TrackMan Marble */ | 221 | { 72, PS2PP_KIND_TRACKMAN, 0 }, /* T-CH11: TrackMan Marble */ |
| 222 | { 73, 0, PS2PP_SIDE_BTN }, | 222 | { 73, PS2PP_KIND_TRACKMAN, PS2PP_SIDE_BTN }, /* TrackMan FX */ |
| 223 | { 75, PS2PP_KIND_WHEEL, PS2PP_WHEEL }, | 223 | { 75, PS2PP_KIND_WHEEL, PS2PP_WHEEL }, |
| 224 | { 76, PS2PP_KIND_WHEEL, PS2PP_WHEEL }, | 224 | { 76, PS2PP_KIND_WHEEL, PS2PP_WHEEL }, |
| 225 | { 79, PS2PP_KIND_TRACKMAN, PS2PP_WHEEL }, /* TrackMan with wheel */ | 225 | { 79, PS2PP_KIND_TRACKMAN, PS2PP_WHEEL }, /* TrackMan with wheel */ |
diff --git a/drivers/input/mouse/synaptics.c b/drivers/input/mouse/synaptics.c index b66ff1ac7dea..f4a61252bcc9 100644 --- a/drivers/input/mouse/synaptics.c +++ b/drivers/input/mouse/synaptics.c | |||
| @@ -652,6 +652,16 @@ static const struct dmi_system_id toshiba_dmi_table[] = { | |||
| 652 | DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"), | 652 | DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"), |
| 653 | DMI_MATCH(DMI_PRODUCT_NAME, "PORTEGE M300"), | 653 | DMI_MATCH(DMI_PRODUCT_NAME, "PORTEGE M300"), |
| 654 | }, | 654 | }, |
| 655 | |||
| 656 | }, | ||
| 657 | { | ||
| 658 | .ident = "Toshiba Portege M300", | ||
| 659 | .matches = { | ||
| 660 | DMI_MATCH(DMI_SYS_VENDOR, "TOSHIBA"), | ||
| 661 | DMI_MATCH(DMI_PRODUCT_NAME, "Portable PC"), | ||
| 662 | DMI_MATCH(DMI_PRODUCT_VERSION, "Version 1.0"), | ||
| 663 | }, | ||
| 664 | |||
| 655 | }, | 665 | }, |
| 656 | { } | 666 | { } |
| 657 | }; | 667 | }; |
diff --git a/drivers/input/serio/i8042-x86ia64io.h b/drivers/input/serio/i8042-x86ia64io.h index a39bc4eb902b..a537925f7651 100644 --- a/drivers/input/serio/i8042-x86ia64io.h +++ b/drivers/input/serio/i8042-x86ia64io.h | |||
| @@ -327,6 +327,17 @@ static struct dmi_system_id __initdata i8042_dmi_nomux_table[] = { | |||
| 327 | }, | 327 | }, |
| 328 | }, | 328 | }, |
| 329 | { | 329 | { |
| 330 | /* | ||
| 331 | * Reset and GET ID commands issued via KBD port are | ||
| 332 | * sometimes being delivered to AUX3. | ||
| 333 | */ | ||
| 334 | .ident = "Sony Vaio FZ-240E", | ||
| 335 | .matches = { | ||
| 336 | DMI_MATCH(DMI_SYS_VENDOR, "Sony Corporation"), | ||
| 337 | DMI_MATCH(DMI_PRODUCT_NAME, "VGN-FZ240E"), | ||
| 338 | }, | ||
| 339 | }, | ||
| 340 | { | ||
| 330 | .ident = "Amoi M636/A737", | 341 | .ident = "Amoi M636/A737", |
| 331 | .matches = { | 342 | .matches = { |
| 332 | DMI_MATCH(DMI_SYS_VENDOR, "Amoi Electronics CO.,LTD."), | 343 | DMI_MATCH(DMI_SYS_VENDOR, "Amoi Electronics CO.,LTD."), |
| @@ -661,7 +672,7 @@ static void i8042_pnp_exit(void) | |||
| 661 | static int __init i8042_pnp_init(void) | 672 | static int __init i8042_pnp_init(void) |
| 662 | { | 673 | { |
| 663 | char kbd_irq_str[4] = { 0 }, aux_irq_str[4] = { 0 }; | 674 | char kbd_irq_str[4] = { 0 }, aux_irq_str[4] = { 0 }; |
| 664 | int pnp_data_busted = false; | 675 | bool pnp_data_busted = false; |
| 665 | int err; | 676 | int err; |
| 666 | 677 | ||
| 667 | #ifdef CONFIG_X86 | 678 | #ifdef CONFIG_X86 |
diff --git a/drivers/md/dm-exception-store.c b/drivers/md/dm-exception-store.c index 556acff3952f..7dbe652efb5a 100644 --- a/drivers/md/dm-exception-store.c +++ b/drivers/md/dm-exception-store.c | |||
| @@ -138,16 +138,6 @@ int dm_exception_store_type_unregister(struct dm_exception_store_type *type) | |||
| 138 | } | 138 | } |
| 139 | EXPORT_SYMBOL(dm_exception_store_type_unregister); | 139 | EXPORT_SYMBOL(dm_exception_store_type_unregister); |
| 140 | 140 | ||
| 141 | /* | ||
| 142 | * Round a number up to the nearest 'size' boundary. size must | ||
| 143 | * be a power of 2. | ||
| 144 | */ | ||
| 145 | static ulong round_up(ulong n, ulong size) | ||
| 146 | { | ||
| 147 | size--; | ||
| 148 | return (n + size) & ~size; | ||
| 149 | } | ||
| 150 | |||
| 151 | static int set_chunk_size(struct dm_exception_store *store, | 141 | static int set_chunk_size(struct dm_exception_store *store, |
| 152 | const char *chunk_size_arg, char **error) | 142 | const char *chunk_size_arg, char **error) |
| 153 | { | 143 | { |
| @@ -155,7 +145,8 @@ static int set_chunk_size(struct dm_exception_store *store, | |||
| 155 | char *value; | 145 | char *value; |
| 156 | 146 | ||
| 157 | chunk_size_ulong = simple_strtoul(chunk_size_arg, &value, 10); | 147 | chunk_size_ulong = simple_strtoul(chunk_size_arg, &value, 10); |
| 158 | if (*chunk_size_arg == '\0' || *value != '\0') { | 148 | if (*chunk_size_arg == '\0' || *value != '\0' || |
| 149 | chunk_size_ulong > UINT_MAX) { | ||
| 159 | *error = "Invalid chunk size"; | 150 | *error = "Invalid chunk size"; |
| 160 | return -EINVAL; | 151 | return -EINVAL; |
| 161 | } | 152 | } |
| @@ -165,40 +156,35 @@ static int set_chunk_size(struct dm_exception_store *store, | |||
| 165 | return 0; | 156 | return 0; |
| 166 | } | 157 | } |
| 167 | 158 | ||
| 168 | /* | 159 | return dm_exception_store_set_chunk_size(store, |
| 169 | * Chunk size must be multiple of page size. Silently | 160 | (unsigned) chunk_size_ulong, |
| 170 | * round up if it's not. | ||
| 171 | */ | ||
| 172 | chunk_size_ulong = round_up(chunk_size_ulong, PAGE_SIZE >> 9); | ||
| 173 | |||
| 174 | return dm_exception_store_set_chunk_size(store, chunk_size_ulong, | ||
| 175 | error); | 161 | error); |
| 176 | } | 162 | } |
| 177 | 163 | ||
| 178 | int dm_exception_store_set_chunk_size(struct dm_exception_store *store, | 164 | int dm_exception_store_set_chunk_size(struct dm_exception_store *store, |
| 179 | unsigned long chunk_size_ulong, | 165 | unsigned chunk_size, |
| 180 | char **error) | 166 | char **error) |
| 181 | { | 167 | { |
| 182 | /* Check chunk_size is a power of 2 */ | 168 | /* Check chunk_size is a power of 2 */ |
| 183 | if (!is_power_of_2(chunk_size_ulong)) { | 169 | if (!is_power_of_2(chunk_size)) { |
| 184 | *error = "Chunk size is not a power of 2"; | 170 | *error = "Chunk size is not a power of 2"; |
| 185 | return -EINVAL; | 171 | return -EINVAL; |
| 186 | } | 172 | } |
| 187 | 173 | ||
| 188 | /* Validate the chunk size against the device block size */ | 174 | /* Validate the chunk size against the device block size */ |
| 189 | if (chunk_size_ulong % (bdev_logical_block_size(store->cow->bdev) >> 9)) { | 175 | if (chunk_size % (bdev_logical_block_size(store->cow->bdev) >> 9)) { |
| 190 | *error = "Chunk size is not a multiple of device blocksize"; | 176 | *error = "Chunk size is not a multiple of device blocksize"; |
| 191 | return -EINVAL; | 177 | return -EINVAL; |
| 192 | } | 178 | } |
| 193 | 179 | ||
| 194 | if (chunk_size_ulong > INT_MAX >> SECTOR_SHIFT) { | 180 | if (chunk_size > INT_MAX >> SECTOR_SHIFT) { |
| 195 | *error = "Chunk size is too high"; | 181 | *error = "Chunk size is too high"; |
| 196 | return -EINVAL; | 182 | return -EINVAL; |
| 197 | } | 183 | } |
| 198 | 184 | ||
| 199 | store->chunk_size = chunk_size_ulong; | 185 | store->chunk_size = chunk_size; |
| 200 | store->chunk_mask = chunk_size_ulong - 1; | 186 | store->chunk_mask = chunk_size - 1; |
| 201 | store->chunk_shift = ffs(chunk_size_ulong) - 1; | 187 | store->chunk_shift = ffs(chunk_size) - 1; |
| 202 | 188 | ||
| 203 | return 0; | 189 | return 0; |
| 204 | } | 190 | } |
| @@ -251,7 +237,7 @@ int dm_exception_store_create(struct dm_target *ti, int argc, char **argv, | |||
| 251 | 237 | ||
| 252 | r = set_chunk_size(tmp_store, argv[2], &ti->error); | 238 | r = set_chunk_size(tmp_store, argv[2], &ti->error); |
| 253 | if (r) | 239 | if (r) |
| 254 | goto bad_cow; | 240 | goto bad_ctr; |
| 255 | 241 | ||
| 256 | r = type->ctr(tmp_store, 0, NULL); | 242 | r = type->ctr(tmp_store, 0, NULL); |
| 257 | if (r) { | 243 | if (r) { |
diff --git a/drivers/md/dm-exception-store.h b/drivers/md/dm-exception-store.h index 812c71872ba0..8a223a48802c 100644 --- a/drivers/md/dm-exception-store.h +++ b/drivers/md/dm-exception-store.h | |||
| @@ -101,9 +101,9 @@ struct dm_exception_store { | |||
| 101 | struct dm_dev *cow; | 101 | struct dm_dev *cow; |
| 102 | 102 | ||
| 103 | /* Size of data blocks saved - must be a power of 2 */ | 103 | /* Size of data blocks saved - must be a power of 2 */ |
| 104 | chunk_t chunk_size; | 104 | unsigned chunk_size; |
| 105 | chunk_t chunk_mask; | 105 | unsigned chunk_mask; |
| 106 | chunk_t chunk_shift; | 106 | unsigned chunk_shift; |
| 107 | 107 | ||
| 108 | void *context; | 108 | void *context; |
| 109 | }; | 109 | }; |
| @@ -169,7 +169,7 @@ int dm_exception_store_type_register(struct dm_exception_store_type *type); | |||
| 169 | int dm_exception_store_type_unregister(struct dm_exception_store_type *type); | 169 | int dm_exception_store_type_unregister(struct dm_exception_store_type *type); |
| 170 | 170 | ||
| 171 | int dm_exception_store_set_chunk_size(struct dm_exception_store *store, | 171 | int dm_exception_store_set_chunk_size(struct dm_exception_store *store, |
| 172 | unsigned long chunk_size_ulong, | 172 | unsigned chunk_size, |
| 173 | char **error); | 173 | char **error); |
| 174 | 174 | ||
| 175 | int dm_exception_store_create(struct dm_target *ti, int argc, char **argv, | 175 | int dm_exception_store_create(struct dm_target *ti, int argc, char **argv, |
diff --git a/drivers/md/dm-log-userspace-base.c b/drivers/md/dm-log-userspace-base.c index 652bd33109e3..7ac2c1450d10 100644 --- a/drivers/md/dm-log-userspace-base.c +++ b/drivers/md/dm-log-userspace-base.c | |||
| @@ -156,7 +156,7 @@ static int userspace_ctr(struct dm_dirty_log *log, struct dm_target *ti, | |||
| 156 | } | 156 | } |
| 157 | 157 | ||
| 158 | /* The ptr value is sufficient for local unique id */ | 158 | /* The ptr value is sufficient for local unique id */ |
| 159 | lc->luid = (uint64_t)lc; | 159 | lc->luid = (unsigned long)lc; |
| 160 | 160 | ||
| 161 | lc->ti = ti; | 161 | lc->ti = ti; |
| 162 | 162 | ||
diff --git a/drivers/md/dm-snap-persistent.c b/drivers/md/dm-snap-persistent.c index d5b2e08750d5..0c746420c008 100644 --- a/drivers/md/dm-snap-persistent.c +++ b/drivers/md/dm-snap-persistent.c | |||
| @@ -284,12 +284,13 @@ static int read_header(struct pstore *ps, int *new_snapshot) | |||
| 284 | { | 284 | { |
| 285 | int r; | 285 | int r; |
| 286 | struct disk_header *dh; | 286 | struct disk_header *dh; |
| 287 | chunk_t chunk_size; | 287 | unsigned chunk_size; |
| 288 | int chunk_size_supplied = 1; | 288 | int chunk_size_supplied = 1; |
| 289 | char *chunk_err; | 289 | char *chunk_err; |
| 290 | 290 | ||
| 291 | /* | 291 | /* |
| 292 | * Use default chunk size (or hardsect_size, if larger) if none supplied | 292 | * Use default chunk size (or logical_block_size, if larger) |
| 293 | * if none supplied | ||
| 293 | */ | 294 | */ |
| 294 | if (!ps->store->chunk_size) { | 295 | if (!ps->store->chunk_size) { |
| 295 | ps->store->chunk_size = max(DM_CHUNK_SIZE_DEFAULT_SECTORS, | 296 | ps->store->chunk_size = max(DM_CHUNK_SIZE_DEFAULT_SECTORS, |
| @@ -334,10 +335,9 @@ static int read_header(struct pstore *ps, int *new_snapshot) | |||
| 334 | return 0; | 335 | return 0; |
| 335 | 336 | ||
| 336 | if (chunk_size_supplied) | 337 | if (chunk_size_supplied) |
| 337 | DMWARN("chunk size %llu in device metadata overrides " | 338 | DMWARN("chunk size %u in device metadata overrides " |
| 338 | "table chunk size of %llu.", | 339 | "table chunk size of %u.", |
| 339 | (unsigned long long)chunk_size, | 340 | chunk_size, ps->store->chunk_size); |
| 340 | (unsigned long long)ps->store->chunk_size); | ||
| 341 | 341 | ||
| 342 | /* We had a bogus chunk_size. Fix stuff up. */ | 342 | /* We had a bogus chunk_size. Fix stuff up. */ |
| 343 | free_area(ps); | 343 | free_area(ps); |
| @@ -345,8 +345,8 @@ static int read_header(struct pstore *ps, int *new_snapshot) | |||
| 345 | r = dm_exception_store_set_chunk_size(ps->store, chunk_size, | 345 | r = dm_exception_store_set_chunk_size(ps->store, chunk_size, |
| 346 | &chunk_err); | 346 | &chunk_err); |
| 347 | if (r) { | 347 | if (r) { |
| 348 | DMERR("invalid on-disk chunk size %llu: %s.", | 348 | DMERR("invalid on-disk chunk size %u: %s.", |
| 349 | (unsigned long long)chunk_size, chunk_err); | 349 | chunk_size, chunk_err); |
| 350 | return r; | 350 | return r; |
| 351 | } | 351 | } |
| 352 | 352 | ||
diff --git a/drivers/md/dm-snap.c b/drivers/md/dm-snap.c index 57f1bf7f3b7a..3a3ba46e6d4b 100644 --- a/drivers/md/dm-snap.c +++ b/drivers/md/dm-snap.c | |||
| @@ -296,6 +296,7 @@ static void __insert_origin(struct origin *o) | |||
| 296 | */ | 296 | */ |
| 297 | static int register_snapshot(struct dm_snapshot *snap) | 297 | static int register_snapshot(struct dm_snapshot *snap) |
| 298 | { | 298 | { |
| 299 | struct dm_snapshot *l; | ||
| 299 | struct origin *o, *new_o; | 300 | struct origin *o, *new_o; |
| 300 | struct block_device *bdev = snap->origin->bdev; | 301 | struct block_device *bdev = snap->origin->bdev; |
| 301 | 302 | ||
| @@ -319,7 +320,11 @@ static int register_snapshot(struct dm_snapshot *snap) | |||
| 319 | __insert_origin(o); | 320 | __insert_origin(o); |
| 320 | } | 321 | } |
| 321 | 322 | ||
| 322 | list_add_tail(&snap->list, &o->snapshots); | 323 | /* Sort the list according to chunk size, largest-first smallest-last */ |
| 324 | list_for_each_entry(l, &o->snapshots, list) | ||
| 325 | if (l->store->chunk_size < snap->store->chunk_size) | ||
| 326 | break; | ||
| 327 | list_add_tail(&snap->list, &l->list); | ||
| 323 | 328 | ||
| 324 | up_write(&_origins_lock); | 329 | up_write(&_origins_lock); |
| 325 | return 0; | 330 | return 0; |
| @@ -668,6 +673,11 @@ static int snapshot_ctr(struct dm_target *ti, unsigned int argc, char **argv) | |||
| 668 | bio_list_init(&s->queued_bios); | 673 | bio_list_init(&s->queued_bios); |
| 669 | INIT_WORK(&s->queued_bios_work, flush_queued_bios); | 674 | INIT_WORK(&s->queued_bios_work, flush_queued_bios); |
| 670 | 675 | ||
| 676 | if (!s->store->chunk_size) { | ||
| 677 | ti->error = "Chunk size not set"; | ||
| 678 | goto bad_load_and_register; | ||
| 679 | } | ||
| 680 | |||
| 671 | /* Add snapshot to the list of snapshots for this origin */ | 681 | /* Add snapshot to the list of snapshots for this origin */ |
| 672 | /* Exceptions aren't triggered till snapshot_resume() is called */ | 682 | /* Exceptions aren't triggered till snapshot_resume() is called */ |
| 673 | if (register_snapshot(s)) { | 683 | if (register_snapshot(s)) { |
| @@ -951,7 +961,7 @@ static void start_copy(struct dm_snap_pending_exception *pe) | |||
| 951 | 961 | ||
| 952 | src.bdev = bdev; | 962 | src.bdev = bdev; |
| 953 | src.sector = chunk_to_sector(s->store, pe->e.old_chunk); | 963 | src.sector = chunk_to_sector(s->store, pe->e.old_chunk); |
| 954 | src.count = min(s->store->chunk_size, dev_size - src.sector); | 964 | src.count = min((sector_t)s->store->chunk_size, dev_size - src.sector); |
| 955 | 965 | ||
| 956 | dest.bdev = s->store->cow->bdev; | 966 | dest.bdev = s->store->cow->bdev; |
| 957 | dest.sector = chunk_to_sector(s->store, pe->e.new_chunk); | 967 | dest.sector = chunk_to_sector(s->store, pe->e.new_chunk); |
| @@ -1142,6 +1152,8 @@ static int snapshot_status(struct dm_target *ti, status_type_t type, | |||
| 1142 | unsigned sz = 0; | 1152 | unsigned sz = 0; |
| 1143 | struct dm_snapshot *snap = ti->private; | 1153 | struct dm_snapshot *snap = ti->private; |
| 1144 | 1154 | ||
| 1155 | down_write(&snap->lock); | ||
| 1156 | |||
| 1145 | switch (type) { | 1157 | switch (type) { |
| 1146 | case STATUSTYPE_INFO: | 1158 | case STATUSTYPE_INFO: |
| 1147 | if (!snap->valid) | 1159 | if (!snap->valid) |
| @@ -1173,6 +1185,8 @@ static int snapshot_status(struct dm_target *ti, status_type_t type, | |||
| 1173 | break; | 1185 | break; |
| 1174 | } | 1186 | } |
| 1175 | 1187 | ||
| 1188 | up_write(&snap->lock); | ||
| 1189 | |||
| 1176 | return 0; | 1190 | return 0; |
| 1177 | } | 1191 | } |
| 1178 | 1192 | ||
| @@ -1388,7 +1402,7 @@ static void origin_resume(struct dm_target *ti) | |||
| 1388 | struct dm_dev *dev = ti->private; | 1402 | struct dm_dev *dev = ti->private; |
| 1389 | struct dm_snapshot *snap; | 1403 | struct dm_snapshot *snap; |
| 1390 | struct origin *o; | 1404 | struct origin *o; |
| 1391 | chunk_t chunk_size = 0; | 1405 | unsigned chunk_size = 0; |
| 1392 | 1406 | ||
| 1393 | down_read(&_origins_lock); | 1407 | down_read(&_origins_lock); |
| 1394 | o = __lookup_origin(dev->bdev); | 1408 | o = __lookup_origin(dev->bdev); |
| @@ -1465,7 +1479,7 @@ static int __init dm_snapshot_init(void) | |||
| 1465 | r = dm_register_target(&snapshot_target); | 1479 | r = dm_register_target(&snapshot_target); |
| 1466 | if (r) { | 1480 | if (r) { |
| 1467 | DMERR("snapshot target register failed %d", r); | 1481 | DMERR("snapshot target register failed %d", r); |
| 1468 | return r; | 1482 | goto bad_register_snapshot_target; |
| 1469 | } | 1483 | } |
| 1470 | 1484 | ||
| 1471 | r = dm_register_target(&origin_target); | 1485 | r = dm_register_target(&origin_target); |
| @@ -1522,6 +1536,9 @@ bad2: | |||
| 1522 | dm_unregister_target(&origin_target); | 1536 | dm_unregister_target(&origin_target); |
| 1523 | bad1: | 1537 | bad1: |
| 1524 | dm_unregister_target(&snapshot_target); | 1538 | dm_unregister_target(&snapshot_target); |
| 1539 | |||
| 1540 | bad_register_snapshot_target: | ||
| 1541 | dm_exception_store_exit(); | ||
| 1525 | return r; | 1542 | return r; |
| 1526 | } | 1543 | } |
| 1527 | 1544 | ||
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 376f1ab48a24..724efc63904d 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c | |||
| @@ -47,6 +47,7 @@ struct dm_io { | |||
| 47 | atomic_t io_count; | 47 | atomic_t io_count; |
| 48 | struct bio *bio; | 48 | struct bio *bio; |
| 49 | unsigned long start_time; | 49 | unsigned long start_time; |
| 50 | spinlock_t endio_lock; | ||
| 50 | }; | 51 | }; |
| 51 | 52 | ||
| 52 | /* | 53 | /* |
| @@ -578,8 +579,12 @@ static void dec_pending(struct dm_io *io, int error) | |||
| 578 | struct mapped_device *md = io->md; | 579 | struct mapped_device *md = io->md; |
| 579 | 580 | ||
| 580 | /* Push-back supersedes any I/O errors */ | 581 | /* Push-back supersedes any I/O errors */ |
| 581 | if (error && !(io->error > 0 && __noflush_suspending(md))) | 582 | if (unlikely(error)) { |
| 582 | io->error = error; | 583 | spin_lock_irqsave(&io->endio_lock, flags); |
| 584 | if (!(io->error > 0 && __noflush_suspending(md))) | ||
| 585 | io->error = error; | ||
| 586 | spin_unlock_irqrestore(&io->endio_lock, flags); | ||
| 587 | } | ||
| 583 | 588 | ||
| 584 | if (atomic_dec_and_test(&io->io_count)) { | 589 | if (atomic_dec_and_test(&io->io_count)) { |
| 585 | if (io->error == DM_ENDIO_REQUEUE) { | 590 | if (io->error == DM_ENDIO_REQUEUE) { |
| @@ -1226,6 +1231,7 @@ static void __split_and_process_bio(struct mapped_device *md, struct bio *bio) | |||
| 1226 | atomic_set(&ci.io->io_count, 1); | 1231 | atomic_set(&ci.io->io_count, 1); |
| 1227 | ci.io->bio = bio; | 1232 | ci.io->bio = bio; |
| 1228 | ci.io->md = md; | 1233 | ci.io->md = md; |
| 1234 | spin_lock_init(&ci.io->endio_lock); | ||
| 1229 | ci.sector = bio->bi_sector; | 1235 | ci.sector = bio->bi_sector; |
| 1230 | ci.sector_count = bio_sectors(bio); | 1236 | ci.sector_count = bio_sectors(bio); |
| 1231 | if (unlikely(bio_empty_barrier(bio))) | 1237 | if (unlikely(bio_empty_barrier(bio))) |
| @@ -1822,6 +1828,7 @@ static struct mapped_device *alloc_dev(int minor) | |||
| 1822 | bad_bdev: | 1828 | bad_bdev: |
| 1823 | destroy_workqueue(md->wq); | 1829 | destroy_workqueue(md->wq); |
| 1824 | bad_thread: | 1830 | bad_thread: |
| 1831 | del_gendisk(md->disk); | ||
| 1825 | put_disk(md->disk); | 1832 | put_disk(md->disk); |
| 1826 | bad_disk: | 1833 | bad_disk: |
| 1827 | blk_cleanup_queue(md->queue); | 1834 | blk_cleanup_queue(md->queue); |
diff --git a/drivers/mmc/host/at91_mci.c b/drivers/mmc/host/at91_mci.c index e556d42cc45a..63924e0c7ea9 100644 --- a/drivers/mmc/host/at91_mci.c +++ b/drivers/mmc/host/at91_mci.c | |||
| @@ -72,7 +72,6 @@ | |||
| 72 | #include <asm/irq.h> | 72 | #include <asm/irq.h> |
| 73 | #include <asm/gpio.h> | 73 | #include <asm/gpio.h> |
| 74 | 74 | ||
| 75 | #include <asm/mach/mmc.h> | ||
| 76 | #include <mach/board.h> | 75 | #include <mach/board.h> |
| 77 | #include <mach/cpu.h> | 76 | #include <mach/cpu.h> |
| 78 | #include <mach/at91_mci.h> | 77 | #include <mach/at91_mci.h> |
