On 09/25/2012 05:20 PM, Will Deacon wrote: >> + case KVM_GET_REG_LIST: { >> + struct kvm_reg_list __user *user_list = argp; >> + struct kvm_reg_list reg_list; >> + unsigned n; >> + >> + if (copy_from_user(®_list, user_list, sizeof reg_list)) >> + return -EFAULT; >> + n = reg_list.n; >> + reg_list.n = kvm_arm_num_regs(vcpu); >> + if (copy_to_user(user_list, ®_list, sizeof reg_list)) >> + return -EFAULT; >> + if (n < reg_list.n) >> + return -E2BIG; >> + return kvm_arm_copy_reg_indices(vcpu, user_list->reg); > > kvm_reg_list sounds like it could be done using a regset instead. Wouldn't those regsets be userspace oriented? For example, the GPRs returned here include all the shadowed interrupt registers (or however they're called) while most user oriented APIs would only include the user visible registers. FWIW, we're trying to move to an architecture independent ABI for KVM registers, but that's a lot of work since we need to make sure all the weird x86 registers (and non-register state) fit into that. Maybe that ABI will be regset based, but I don't want to block the ARM port on this. -- error compiling committee.c: too many arguments to function -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html