From: "Roger Pau Monné" <roger.pau@citrix.com>
To: dmukhin@ford.com
Cc: xen-devel@lists.xenproject.org,
Andrew Cooper <andrew.cooper3@citrix.com>,
Jan Beulich <jbeulich@suse.com>, Julien Grall <julien@xen.org>,
Stefano Stabellini <sstabellini@kernel.org>
Subject: Re: [PATCH v2 01/35] xen: introduce resource.h
Date: Wed, 11 Dec 2024 12:01:54 +0100 [thread overview]
Message-ID: <Z1lxIlvZs449Pq5-@macbook.local> (raw)
In-Reply-To: <20241205-vuart-ns8250-v1-1-e9aa923127eb@ford.com>
On Thu, Dec 05, 2024 at 08:41:31PM -0800, Denis Mukhin via B4 Relay wrote:
> From: Denis Mukhin <dmukhin@ford.com>
>
> Move resource definitions to a new architecture-agnostic shared header file.
>
> It will be used in follow on NS8250 emulator code to describe legacy
> PC COM resources.
>
> Signed-off-by: Denis Mukhin <dmukhin@ford.com>
> ---
> xen/common/device-tree/device-tree.c | 21 +------------------
> xen/drivers/passthrough/arm/smmu.c | 15 +-------------
> xen/include/xen/resource.h | 40 ++++++++++++++++++++++++++++++++++++
> 3 files changed, 42 insertions(+), 34 deletions(-)
>
> diff --git a/xen/common/device-tree/device-tree.c b/xen/common/device-tree/device-tree.c
> index d0528c5825651f7cc9ebca0c949229c9083063c6..e8f810b2fe10890c033ed3a9d4ca627010ad019b 100644
> --- a/xen/common/device-tree/device-tree.c
> +++ b/xen/common/device-tree/device-tree.c
> @@ -24,6 +24,7 @@
> #include <xen/ctype.h>
> #include <asm/setup.h>
> #include <xen/err.h>
> +#include <xen/resource.h>
>
> const void *device_tree_flattened;
> dt_irq_xlate_func dt_irq_xlate;
> @@ -535,26 +536,6 @@ int dt_child_n_size_cells(const struct dt_device_node *parent)
> return __dt_n_size_cells(parent, true);
> }
>
> -/*
> - * These are defined in Linux where much of this code comes from, but
> - * are currently unused outside this file in the context of Xen.
> - */
> -#define IORESOURCE_BITS 0x000000ff /* Bus-specific bits */
> -
> -#define IORESOURCE_TYPE_BITS 0x00001f00 /* Resource type */
> -#define IORESOURCE_IO 0x00000100 /* PCI/ISA I/O ports */
> -#define IORESOURCE_MEM 0x00000200
> -#define IORESOURCE_REG 0x00000300 /* Register offsets */
> -#define IORESOURCE_IRQ 0x00000400
> -#define IORESOURCE_DMA 0x00000800
> -#define IORESOURCE_BUS 0x00001000
> -
> -#define IORESOURCE_PREFETCH 0x00002000 /* No side effects */
> -#define IORESOURCE_READONLY 0x00004000
> -#define IORESOURCE_CACHEABLE 0x00008000
> -#define IORESOURCE_RANGELENGTH 0x00010000
> -#define IORESOURCE_SHADOWABLE 0x00020000
> -
> /*
> * Default translator (generic bus)
> */
> diff --git a/xen/drivers/passthrough/arm/smmu.c b/xen/drivers/passthrough/arm/smmu.c
> index 03d22bce1e497e41834c273f9048b98dcbd48a54..aa6a968b574dce7cc753e8070fad3a6e585cd9e7 100644
> --- a/xen/drivers/passthrough/arm/smmu.c
> +++ b/xen/drivers/passthrough/arm/smmu.c
> @@ -50,6 +50,7 @@
> #include <xen/rbtree.h>
> #include <xen/sched.h>
> #include <xen/sizes.h>
> +#include <xen/resource.h>
> #include <asm/atomic.h>
> #include <asm/device.h>
> #include <asm/io.h>
> @@ -70,22 +71,8 @@
> #define of_property_read_u32(np, pname, out) (!dt_property_read_u32(np, pname, out))
> #define of_property_read_bool dt_property_read_bool
> #define of_parse_phandle_with_args dt_parse_phandle_with_args
> -
> -/* Xen: Helpers to get device MMIO and IRQs */
> -struct resource
> -{
> - paddr_t addr;
> - paddr_t size;
> - unsigned int type;
> -};
> -
> -#define resource_size(res) (res)->size;
> -
> #define platform_device dt_device_node
>
> -#define IORESOURCE_MEM 0
> -#define IORESOURCE_IRQ 1
> -
> static struct resource *platform_get_resource(struct platform_device *pdev,
> unsigned int type,
> unsigned int num)
> diff --git a/xen/include/xen/resource.h b/xen/include/xen/resource.h
> new file mode 100644
> index 0000000000000000000000000000000000000000..4962e17da8387b7f324317482b19cc9fe71433fc
> --- /dev/null
> +++ b/xen/include/xen/resource.h
> @@ -0,0 +1,40 @@
> +/* SPDX-License-Identifier: GPL-2.0 */
> +/*
> + * System resource description.
> + *
> + * Reference:
> + * include/linux/ioport.h
> + */
> +#if !defined(XEN__RESOURCE_H)
> +#define XEN__RESOURCE_H
> +
> +#define IORESOURCE_BITS 0x000000FFU /* Bus-specific bits */
> +
> +#define IORESOURCE_TYPE_BITS 0x00001F00U /* Resource type */
> +#define IORESOURCE_IO 0x00000100U /* PCI/ISA I/O ports */
> +#define IORESOURCE_MEM 0x00000200U
> +#define IORESOURCE_REG 0x00000300U /* Register offsets */
> +#define IORESOURCE_IRQ 0x00000400U
> +#define IORESOURCE_DMA 0x00000800U
> +#define IORESOURCE_BUS 0x00001000U
> +
> +#define IORESOURCE_PREFETCH 0x00002000U /* No side effects */
> +#define IORESOURCE_READONLY 0x00004000U
> +#define IORESOURCE_CACHEABLE 0x00008000U
> +#define IORESOURCE_RANGELENGTH 0x00010000U
> +#define IORESOURCE_SHADOWABLE 0x00020000U
> +
> +#define IORESOURCE_UNKNOWN (~0U)
> +
> +struct resource {
> + paddr_t addr;
> + paddr_t size;
> + unsigned int type;
> +};
> +
> +#define resource_size(res) (res)->size;
> +
> +#define foreach_resource(res) \
Nit: we usually name those for_each_foo instead of foreach_foo.
> + for (; res && res->type != IORESOURCE_UNKNOWN; res++)
Missing spaces between parentheses:
for ( ; res && res->type != IORESOURCE_UNKNOWN; res++ )
Note that this macro will modify (advance) the res pointer, which is
maybe unexpected by the caller?
Also, the current logic forces the array of resources to always have a
trailing IORESOURCE_UNKNOWN element in order to break the loop, it
might be better to pass an explicit number of elements to iterate
against if possible?
As Jan said, it would be helpful to have an example usage of the
macro.
Thanks, Roger.
next prev parent reply other threads:[~2024-12-11 11:02 UTC|newest]
Thread overview: 218+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-12-06 4:41 [PATCH v2 00/35] Introduce NS8250 UART emulator Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-06 4:41 ` [PATCH v2 01/35] xen: introduce resource.h Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:13 ` Jan Beulich
2025-01-04 2:23 ` Denis Mukhin
2024-12-11 11:01 ` Roger Pau Monné [this message]
2025-01-04 3:10 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 02/35] xen/irq: introduce NO_IRQ Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:17 ` Jan Beulich
2025-01-04 2:26 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 03/35] xen/ctype: introduce isconsole() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:22 ` Jan Beulich
2025-01-04 2:31 ` Denis Mukhin
2025-01-06 8:55 ` Jan Beulich
2024-12-06 4:41 ` [PATCH v2 04/35] arm/vuart: use guest_printk() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-06 4:41 ` [PATCH v2 05/35] arm/vuart: make domain_has_vuart() public Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-06 4:41 ` [PATCH v2 06/35] riscv/domain: introduce domain_has_vuart() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-06 4:41 ` [PATCH v2 07/35] ppc/domain: " Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:24 ` Jan Beulich
2024-12-06 4:41 ` [PATCH v2 08/35] x86/domain: " Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:26 ` Jan Beulich
2025-01-04 2:34 ` Denis Mukhin
2024-12-11 15:13 ` Roger Pau Monné
2025-01-04 3:11 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 09/35] x86/domain: print emulation_flags Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:30 ` Jan Beulich
2025-01-04 3:55 ` Denis Mukhin
2024-12-11 15:19 ` Roger Pau Monné
2024-12-12 11:53 ` Jan Beulich
2024-12-12 12:11 ` Roger Pau Monné
2024-12-12 12:50 ` Jan Beulich
2025-01-04 3:56 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 10/35] xen/domain: add get_initial_domain_id() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:50 ` Jan Beulich
2025-01-04 2:50 ` Denis Mukhin
2024-12-11 16:50 ` Roger Pau Monné
2025-01-04 4:44 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 11/35] xen/domain: enable max_init_domid for all architectures Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:57 ` Jan Beulich
2025-01-04 2:51 ` Denis Mukhin
2024-12-11 17:00 ` Roger Pau Monné
2025-01-04 3:13 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 12/35] xen/console: move vpl011-related code to vpl011 emulator Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 13:33 ` Jan Beulich
2025-01-04 2:49 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 13/35] xen/console: rename console_input_domain Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:01 ` Jan Beulich
2025-01-04 2:53 ` Denis Mukhin
2024-12-11 17:17 ` Roger Pau Monné
2025-01-04 3:13 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 14/35] xen/console: rename switch_serial_input() to console_find_owner() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:13 ` Jan Beulich
2024-12-11 17:22 ` Roger Pau Monné
2025-01-04 3:14 ` Denis Mukhin
2025-01-04 2:54 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 15/35] xen/console: rename console_rx to console_owner Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:23 ` Jan Beulich
2024-12-12 8:58 ` Roger Pau Monné
2025-01-04 3:20 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 16/35] xen/console: introduce printk_common() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:27 ` Jan Beulich
2025-01-04 2:57 ` Denis Mukhin
2025-01-06 9:04 ` Jan Beulich
2024-12-12 9:14 ` Roger Pau Monné
2024-12-12 11:57 ` Jan Beulich
2024-12-12 12:15 ` Roger Pau Monné
2024-12-12 12:52 ` Jan Beulich
2024-12-12 15:25 ` Roger Pau Monné
2024-12-13 1:03 ` Stefano Stabellini
2025-01-04 4:11 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 17/35] xen/console: introduce consoled_is_enabled() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:31 ` Jan Beulich
2025-01-04 3:00 ` Denis Mukhin
2025-01-06 9:05 ` Jan Beulich
2024-12-12 9:31 ` Roger Pau Monné
2025-01-04 3:21 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 18/35] xen/console: introduce use of 'is_console' flag Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 14:52 ` Jan Beulich
2025-01-04 3:05 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 19/35] xen/console: introduce console_set_owner() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 15:02 ` Jan Beulich
2025-01-04 3:07 ` Denis Mukhin
2025-01-06 9:08 ` Jan Beulich
2024-12-12 10:12 ` Roger Pau Monné
2024-12-12 11:59 ` Jan Beulich
2024-12-12 12:16 ` Roger Pau Monné
2025-01-04 3:31 ` Denis Mukhin
2025-01-04 3:30 ` Denis Mukhin
2025-01-06 9:58 ` Jan Beulich
2025-01-06 20:03 ` Denis Mukhin
2025-01-07 8:37 ` Jan Beulich
2024-12-06 4:41 ` [PATCH v2 20/35] xen/console: introduce console_owner_domid() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 22:11 ` Jason Andryuk
2024-12-11 7:33 ` Jan Beulich
2025-01-04 4:16 ` Denis Mukhin
2025-01-04 4:12 ` Denis Mukhin
2024-12-11 7:28 ` Jan Beulich
2025-01-04 4:15 ` Denis Mukhin
2025-01-06 9:14 ` Jan Beulich
2025-01-06 18:48 ` Stefano Stabellini
2025-01-07 8:40 ` Jan Beulich
2025-01-07 23:40 ` Stefano Stabellini
2025-01-08 7:28 ` Jan Beulich
2025-01-08 8:04 ` Roger Pau Monné
2025-01-08 8:13 ` Jan Beulich
2025-01-08 8:35 ` Roger Pau Monné
2025-01-08 22:15 ` Denis Mukhin
2025-01-09 0:29 ` Stefano Stabellini
2025-01-09 8:06 ` Roger Pau Monné
2025-01-09 23:46 ` Stefano Stabellini
2025-01-10 1:39 ` Denis Mukhin
2025-01-09 8:25 ` Jan Beulich
2025-01-09 8:27 ` Jan Beulich
2025-01-10 1:34 ` Denis Mukhin
2024-12-12 10:18 ` Roger Pau Monné
2025-01-04 4:11 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 21/35] xen/console: introduce console_init_owner() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-10 22:30 ` Jason Andryuk
2024-12-11 7:31 ` Jan Beulich
2025-01-04 3:22 ` Denis Mukhin
2024-12-12 10:23 ` Roger Pau Monné
2025-01-04 3:23 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 22/35] xen/console: introduce handle_keypress_in_domain() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 10:51 ` Roger Pau Monné
2025-01-04 3:25 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 23/35] xen/console: introduce console_write() Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 12:04 ` Roger Pau Monné
2025-01-04 3:50 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 24/35] xen/console: introduce hwdom_crashconsole= Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 12:29 ` Roger Pau Monné
2025-01-04 4:48 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 25/35] xen/console: simplify console owner switch hint Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-06 4:41 ` [PATCH v2 26/35] xen/console: make console buffer size configurable Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 12:47 ` Roger Pau Monné
2025-01-04 3:52 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 27/35] xen/console: flush console ring to physical console Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 14:21 ` Roger Pau Monné
2025-01-04 3:56 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 28/35] xen/8250-uart: add missing definitions Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 14:29 ` Roger Pau Monné
2025-01-04 4:01 ` Denis Mukhin
2024-12-12 15:07 ` Jan Beulich
2025-01-04 4:00 ` Denis Mukhin
2024-12-06 4:41 ` [PATCH v2 29/35] x86/hvm: add HVM-specific Kconfig Denis Mukhin
2024-12-06 4:41 ` Denis Mukhin via B4 Relay
2024-12-12 15:06 ` Roger Pau Monné
2025-01-04 3:58 ` Denis Mukhin
2024-12-06 4:42 ` [PATCH v2 30/35] x86/hvm: add helpers for raising guest IRQs Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-12 16:18 ` Roger Pau Monné
2025-01-04 4:02 ` Denis Mukhin
2024-12-06 4:42 ` [PATCH v2 31/35] x86/hvm: introduce NS8250 UART emulator Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-13 11:43 ` Roger Pau Monné
2025-01-04 6:28 ` Denis Mukhin
2024-12-16 15:04 ` Jan Beulich
2025-01-04 5:31 ` Denis Mukhin
2025-01-06 9:19 ` Jan Beulich
2025-01-06 20:16 ` Denis Mukhin
2025-01-07 8:43 ` Jan Beulich
2024-12-06 4:42 ` [PATCH v2 32/35] x86/hvm: add debugging facility to " Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-13 12:08 ` Roger Pau Monné
2025-01-04 4:31 ` Denis Mukhin
2024-12-16 15:08 ` Jan Beulich
2025-01-04 4:37 ` Denis Mukhin
2024-12-06 4:42 ` [PATCH v2 33/35] x86/domain: implement domain_has_vuart() Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-13 12:23 ` Roger Pau Monné
2024-12-13 20:45 ` Stefano Stabellini
2024-12-16 8:40 ` Roger Pau Monné
2025-01-04 5:26 ` Denis Mukhin
2025-01-04 5:19 ` Denis Mukhin
2025-01-07 15:16 ` Roger Pau Monné
2025-01-07 17:33 ` Denis Mukhin
2024-12-16 15:11 ` Jan Beulich
2025-01-04 5:26 ` Denis Mukhin
2024-12-06 4:42 ` [PATCH v2 34/35] xen/console: enable console owners w/ emulated NS8250 Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-10 22:46 ` Jason Andryuk
2024-12-11 7:35 ` Jan Beulich
2024-12-11 7:38 ` Jan Beulich
2025-01-04 3:12 ` Denis Mukhin
2025-01-04 3:08 ` Denis Mukhin
2024-12-06 4:42 ` [PATCH v2 35/35] docs/misc: update console documentation Denis Mukhin
2024-12-06 4:42 ` Denis Mukhin via B4 Relay
2024-12-14 18:05 ` [PATCH v2 00/35] Introduce NS8250 UART emulator Marek Marczykowski-Górecki
2024-12-16 9:04 ` Roger Pau Monné
2025-01-04 4:28 ` Denis Mukhin
2025-01-04 4:27 ` Denis Mukhin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=Z1lxIlvZs449Pq5-@macbook.local \
--to=roger.pau@citrix.com \
--cc=andrew.cooper3@citrix.com \
--cc=dmukhin@ford.com \
--cc=jbeulich@suse.com \
--cc=julien@xen.org \
--cc=sstabellini@kernel.org \
--cc=xen-devel@lists.xenproject.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.