|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: Refactor arm64/domctl.c 'subarch_do_domctl' to avoid unreachable break.
Hi Jan, On 23/10/2023 16:15, Jan Beulich wrote: On 23.10.2023 17:00, Julien Grall wrote:On 23/10/2023 15:51, Nicola Vetrini wrote:Hi,Hi Nicola, I am not sure why I would need to re-layout the switch. This should work (untested): diff --git a/xen/arch/arm/arm64/domctl.c b/xen/arch/arm/arm64/domctl.c index 14fc622e9956..8720d126c97d 100644 --- a/xen/arch/arm/arm64/domctl.c +++ b/xen/arch/arm/arm64/domctl.c@@ -33,27 +33,31 @@ static long switch_mode(struct domain *d, enum domain_type type)
return 0;
}
+static long set_address_size(struct domain *d, uint32_t address_size)
+{
+ switch ( address_size )
+ {
+ case 32:
+ if ( !cpu_has_el1_32 )
+ return -EINVAL;
+ /* SVE is not supported for 32 bit domain */
+ if ( is_sve_domain(d) )
+ return -EINVAL;
+ return switch_mode(d, DOMAIN_32BIT);
+ case 64:
+ return switch_mode(d, DOMAIN_64BIT);
+ default:
+ return -EINVAL;
+ }
+}
+
long subarch_do_domctl(struct xen_domctl *domctl, struct domain *d,
XEN_GUEST_HANDLE_PARAM(xen_domctl_t) u_domctl)
{
switch ( domctl->cmd )
{
case XEN_DOMCTL_set_address_size:
- switch ( domctl->u.address_size.size )
- {
- case 32:
- if ( !cpu_has_el1_32 )
- return -EINVAL;
- /* SVE is not supported for 32 bit domain */
- if ( is_sve_domain(d) )
- return -EINVAL;
- return switch_mode(d, DOMAIN_32BIT);
- case 64:
- return switch_mode(d, DOMAIN_64BIT);
- default:
- return -EINVAL;
- }
- break;
+ return set_address_size(d, domctl->u.address_size.size);
default:
return -ENOSYS;
Cheers,
--
Julien Grall
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |