Re: [Xen-devel] [PATCH RFC] xen-block: correctly define structuresin public headers
From: David Vrabel
Date: Tue Dec 03 2013 - 10:11:44 EST
On 03/12/13 13:41, Ian Campbell wrote:
> On Tue, 2013-12-03 at 11:59 +0000, David Vrabel wrote:
>> On 03/12/13 11:08, Ian Campbell wrote:
>>> On Tue, 2013-12-03 at 11:01 +0000, David Vrabel wrote:
>>>> On 03/12/13 10:57, Roger Pau Monne wrote:
>>>>> Using __packed__ on the public interface is not correct, this
>>>>> structures should be compiled using the native ABI, and __packed__
>>>>> should only be used in the backend counterpart of those structures
>>>>> (which needs to handle different ABIs).
>>>>>
>>>>> This was even worse in the ARM case, where the Linux kernel was
>>>>> incorrectly using the X86_32 protocol ABI. This patch fixes it, but
>>>>> also breaks compatibility, so an ARM DomU kernel compiled with
>>>>> this patch will fail to communicate with PV disk devices unless the
>>>>> Dom0 also has this patch.
>>>>
>>>> This ABI change needs to be justified. Why do you think it is
>>>> acceptable to break existing Linux guests? Because I don't think it is.
>>>
>>> As I explained in my reply those guests are buggy.
>>
>> The kernel has a strong policy on not changing ABIs, even to fix bugs.
>> I don't think a bug fix alone is sufficient justification for ABI breakage.
>
> This is not the kernels ABI to fix in stone. The ABI is defined by the
> upstream Xen project and Linux has failed to follow the specified ABI
> correctly.
I disagree. The working back and front end implementations have created
a new, different ABI.
> There is no deployed legacy of guests to support here.
I not sure I agree. It does seem to be widely used and I'm not sure we
have sufficient visibility on how Xen on Arm is being used to know if
this change will cause other people problems.
If Konrad and Boris agree that breaking the kernel's ABI in this way is
acceptable in this specific case, I'll defer to them.
David
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/