diff options
| author | Ingo Molnar <mingo@elte.hu> | 2008-09-10 14:05:45 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2008-09-10 14:05:45 +0200 | 
| commit | 3ce9bcb583536c45a46c7302747029450e22279c (patch) | |
| tree | 7a4167189ffc6dc909151d1a5d040f9f0656a9f4 /arch/x86/kernel/cpuid.c | |
| parent | 26fd10517e810dd59ea050b052de24a75ee6dc07 (diff) | |
| parent | f7d0b926ac8c8ec0c7a83ee69409bd2e6bb39f81 (diff) | |
Merge branch 'core/xen' into x86/xen
Diffstat (limited to 'arch/x86/kernel/cpuid.c')
| -rw-r--r-- | arch/x86/kernel/cpuid.c | 15 | 
1 files changed, 11 insertions, 4 deletions
diff --git a/arch/x86/kernel/cpuid.c b/arch/x86/kernel/cpuid.c index 14b11b3be31..8e9cd6a8ec1 100644 --- a/arch/x86/kernel/cpuid.c +++ b/arch/x86/kernel/cpuid.c @@ -89,6 +89,8 @@ static ssize_t cpuid_read(struct file *file, char __user *buf,  	struct cpuid_regs cmd;  	int cpu = iminor(file->f_path.dentry->d_inode);  	u64 pos = *ppos; +	ssize_t bytes = 0; +	int err = 0;  	if (count % 16)  		return -EINVAL;	/* Invalid chunk size */ @@ -96,14 +98,19 @@ static ssize_t cpuid_read(struct file *file, char __user *buf,  	for (; count; count -= 16) {  		cmd.eax = pos;  		cmd.ecx = pos >> 32; -		smp_call_function_single(cpu, cpuid_smp_cpuid, &cmd, 1); -		if (copy_to_user(tmp, &cmd, 16)) -			return -EFAULT; +		err = smp_call_function_single(cpu, cpuid_smp_cpuid, &cmd, 1); +		if (err) +			break; +		if (copy_to_user(tmp, &cmd, 16)) { +			err = -EFAULT; +			break; +		}  		tmp += 16; +		bytes += 16;  		*ppos = ++pos;  	} -	return tmp - buf; +	return bytes ? bytes : err;  }  static int cpuid_open(struct inode *inode, struct file *file)  | 
