On 07.06.2022 09:30, Penny Zheng wrote: > --- a/xen/arch/arm/domain_build.c > +++ b/xen/arch/arm/domain_build.c > @@ -3287,9 +3287,12 @@ void __init create_domUs(void) > if ( !dt_device_is_compatible(node, "xen,domain") ) > continue; > > + if ( dt_find_property(node, "xen,static-mem", NULL) ) > + flags |= CDF_staticmem; > + > if ( dt_property_read_bool(node, "direct-map") ) > { > - if ( !IS_ENABLED(CONFIG_STATIC_MEMORY) || > !dt_find_property(node, "xen,static-mem", NULL) ) > + if ( !IS_ENABLED(CONFIG_STATIC_MEMORY) || !(flags & > CDF_staticmem) ) > panic("direct-map is not valid for domain %s without static > allocation.\n", > dt_node_name(node));
I think there's either a change needed elsewhere (which you may have in a later patch, but which would look to belong here) or you may want to deal right here with CDF_staticmem being invalid without STATIC_MEMORY: if ( IS_ENABLED(CONFIG_STATIC_MEMORY) && dt_find_property(node, "xen,static-mem", NULL) ) flags |= CDF_staticmem; if ( dt_property_read_bool(node, "direct-map") ) { if ( !(flags & CDF_staticmem) ) panic("direct-map is not valid for domain %s without static allocation.\n", dt_node_name(node)); Another option would seem to be /* Is domain memory on static allocation? */ #ifdef CONFIG_STATIC_MEMORY # define CDF_staticmem (1U << 2) #else # define CDF_staticmem 0 #endif in xen/domain.h (at which point no IS_ENABLED() would be needed anymore afaict). Jan