diff options
| author | Mauro Carvalho Chehab <m.chehab@samsung.com> | 2014-04-14 11:00:36 -0400 |
|---|---|---|
| committer | Mauro Carvalho Chehab <m.chehab@samsung.com> | 2014-04-14 11:00:36 -0400 |
| commit | 277a163c83d7ba93fba1e8980d29a9f8bfcfba6c (patch) | |
| tree | ccfd357d152292958957b6b8a993892e7a8cc95f /kernel/power/hibernate.c | |
| parent | a83b93a7480441a47856dc9104bea970e84cda87 (diff) | |
| parent | c9eaa447e77efe77b7fa4c953bd62de8297fd6c5 (diff) | |
Merge tag 'v3.15-rc1' into patchwork
Linux 3.15-rc1
* tag 'v3.15-rc1': (12180 commits)
Linux 3.15-rc1
mm: Initialize error in shmem_file_aio_read()
cifs: Use min_t() when comparing "size_t" and "unsigned long"
sym53c8xx_2: Set DID_REQUEUE return code when aborting squeue
powerpc: Don't try to set LPCR unless we're in hypervisor mode
futex: update documentation for ordering guarantees
ceph: fix pr_fmt() redefinition
vti: don't allow to add the same tunnel twice
gre: don't allow to add the same tunnel twice
drivers: net: xen-netfront: fix array initialization bug
missing bits of "splice: fix racy pipe->buffers uses"
cifs: fix the race in cifs_writev()
ceph_sync_{,direct_}write: fix an oops on ceph_osdc_new_request() failure
pktgen: be friendly to LLTX devices
r8152: check RTL8152_UNPLUG
net: sun4i-emac: add promiscuous support
net/apne: replace IS_ERR and PTR_ERR with PTR_ERR_OR_ZERO
blackfin: cleanup board files
bf609: clock: drop unused clock bit set/clear functions
Blackfin: bf537: rename "CONFIG_ADT75"
...
Diffstat (limited to 'kernel/power/hibernate.c')
| -rw-r--r-- | kernel/power/hibernate.c | 22 |
1 files changed, 12 insertions, 10 deletions
diff --git a/kernel/power/hibernate.c b/kernel/power/hibernate.c index 37170d4dd9a6..f4f2073711d3 100644 --- a/kernel/power/hibernate.c +++ b/kernel/power/hibernate.c | |||
| @@ -973,16 +973,20 @@ static ssize_t resume_show(struct kobject *kobj, struct kobj_attribute *attr, | |||
| 973 | static ssize_t resume_store(struct kobject *kobj, struct kobj_attribute *attr, | 973 | static ssize_t resume_store(struct kobject *kobj, struct kobj_attribute *attr, |
| 974 | const char *buf, size_t n) | 974 | const char *buf, size_t n) |
| 975 | { | 975 | { |
| 976 | unsigned int maj, min; | ||
| 977 | dev_t res; | 976 | dev_t res; |
| 978 | int ret = -EINVAL; | 977 | int len = n; |
| 978 | char *name; | ||
| 979 | 979 | ||
| 980 | if (sscanf(buf, "%u:%u", &maj, &min) != 2) | 980 | if (len && buf[len-1] == '\n') |
| 981 | goto out; | 981 | len--; |
| 982 | name = kstrndup(buf, len, GFP_KERNEL); | ||
| 983 | if (!name) | ||
| 984 | return -ENOMEM; | ||
| 982 | 985 | ||
| 983 | res = MKDEV(maj,min); | 986 | res = name_to_dev_t(name); |
| 984 | if (maj != MAJOR(res) || min != MINOR(res)) | 987 | kfree(name); |
| 985 | goto out; | 988 | if (!res) |
| 989 | return -EINVAL; | ||
| 986 | 990 | ||
| 987 | lock_system_sleep(); | 991 | lock_system_sleep(); |
| 988 | swsusp_resume_device = res; | 992 | swsusp_resume_device = res; |
| @@ -990,9 +994,7 @@ static ssize_t resume_store(struct kobject *kobj, struct kobj_attribute *attr, | |||
| 990 | printk(KERN_INFO "PM: Starting manual resume from disk\n"); | 994 | printk(KERN_INFO "PM: Starting manual resume from disk\n"); |
| 991 | noresume = 0; | 995 | noresume = 0; |
| 992 | software_resume(); | 996 | software_resume(); |
| 993 | ret = n; | 997 | return n; |
| 994 | out: | ||
| 995 | return ret; | ||
| 996 | } | 998 | } |
| 997 | 999 | ||
| 998 | power_attr(resume); | 1000 | power_attr(resume); |
