xen-devel.lists.xenproject.org archive mirror
 help / color / mirror / Atom feed
From: Oleksii Kurochko <oleksii.kurochko@gmail.com>
To: xen-devel@lists.xenproject.org
Cc: "Oleksii Kurochko" <oleksii.kurochko@gmail.com>,
	"Bob Eshleman" <bobbyeshleman@gmail.com>,
	"Alistair Francis" <alistair.francis@wdc.com>,
	"Connor Davis" <connojdavis@gmail.com>,
	"Andrew Cooper" <andrew.cooper3@citrix.com>,
	"George Dunlap" <george.dunlap@citrix.com>,
	"Jan Beulich" <jbeulich@suse.com>,
	"Julien Grall" <julien@xen.org>,
	"Stefano Stabellini" <sstabellini@kernel.org>,
	"Wei Liu" <wl@xen.org>, "Paul Durrant" <paul@xen.org>,
	"Roger Pau Monné" <roger.pau@citrix.com>,
	"Doug Goldstein" <cardoe@cardoe.com>,
	"Konrad Rzeszutek Wilk" <konrad.wilk@oracle.com>,
	"Ross Lagerwall" <ross.lagerwall@citrix.com>
Subject: [PATCH v1 00/57] Enable build of full Xen for RISC-V
Date: Wed, 16 Aug 2023 13:19:10 +0300	[thread overview]
Message-ID: <cover.1692181079.git.oleksii.kurochko@gmail.com> (raw)

This patch series performs all of the additions necessary to drop the
build overrides for RISCV and enable the full Xen build. Except in cases
where compatibile implementations already exist (e.g. atomic.h and
bitops.h), the newly added definitions are simple.

Also the patch series has open question described in the patch 57

Patch 56 is only needed for test purposes and will be removed.

Oleksii Kurochko (57):
  xen/riscv:introduce asm/byteorder.h
  xen/riscv: add public arch-riscv.h
  xen/riscv: introduce spinlock.h
  xen/riscv: introduce fence.h
  xen/riscv: introduce arch-riscv/hvm/save.h
  xen/riscv: introduce paging.h
  xen/riscv: introduce asm/cpufeature.h
  xen/riscv: introduce asm/device.h
  xen/riscv: introduce asm/event.h
  xen/riscv: introduce asm/grant_table.h
  xen/riscv: introduce asm/guest_atomics.h
  xen/riscv: introduce asm/hypercall.h
  xen/riscv: introduce asm/iocap.h
  xen/riscv: introduce asm/iommu.h
  xen/riscv: introduce asm/mem_access.h
  xen/riscv: introduce asm/nospec.h
  xen/riscv: introduce asm/pci.h
  xen/riscv: introduce asm/random.h
  xen/riscv: introduce asm/setup.h
  xen/riscv: introduce asm/system.h
  xen/riscv: introduce asm/xenoprof.h
  xen/riscv: introduce bitops.h
  xen/riscv: introduce flushtlb.h
  xen/riscv: introduce asm/percpu.h
  xen/riscv: introduce asm/smp.h
  xen/riscv: introduce asm/atomic.h
  xen/riscv: introduce cmpxchg.h
  xen/riscv: introduce asm/io.h
  xen/riscv: introduce asm/hardirq.h
  xen/riscv: introduce div64.h
  xen/riscv: define bug frame tables in xen.lds.S
  xen/riscv: introduce bit operations
  xen/riscv: introduce asm/altp2m.h
  xen/riscv: introduce asm/delay.h
  xen/riscv: introduce asm/domain.h
  xen/riscv: introduce asm/guest_access.h
  xen/riscv: introduce asm/irq.h
  xen/riscv: introduce asm/monitor.h
  xen/riscv: introduce asm/numa.h
  xen/riscv: introduce asm/p2m.h
  xen/riscv: introduce asm/regs.h
  xen/riscv: introduce asm/softirq.h
  xen/riscv: introduce asm/time.h
  xen/riscv: introduce asm/vm_event.h
  xen/riscv: add definition of __read_mostly
  xen/riscv: define an address of frame table
  xen/riscv: add required things to asm/current.h
  xen/riscv: add minimal stuff to asm/page.h to build full Xen
  xen/riscv: add minimal stuff to asm/processor.h to build full Xen
  xen/riscv: add minimal stuff to asm/smp.h to build full Xen
  xen: add RISCV support for pmu.h
  xen: add necessary headers to common to build full Xen for RISC-V
  xen/riscv: add minimal stuff to asm/mm.h to build full Xen
  xen/rirscv: add minimal amount of stubs to build full Xen
  xen/riscv: enable full Xen build
  test only riscv
  xxxen/riscv: WIP ( need advise )

 automation/gitlab-ci/analyze.yaml          |  16 -
 automation/gitlab-ci/build.yaml            | 544 ---------------------
 automation/gitlab-ci/test.yaml             | 308 ------------
 xen/arch/riscv/Kconfig                     |   1 +
 xen/arch/riscv/Makefile                    |  18 +-
 xen/arch/riscv/arch.mk                     |   4 -
 xen/arch/riscv/configs/tiny64_defconfig    |  19 +-
 xen/arch/riscv/early_printk.c              | 168 -------
 xen/arch/riscv/include/asm/altp2m.h        |  28 ++
 xen/arch/riscv/include/asm/asm_defns.h     |  44 ++
 xen/arch/riscv/include/asm/atomic.h        | 375 ++++++++++++++
 xen/arch/riscv/include/asm/bitops.h        | 288 +++++++++++
 xen/arch/riscv/include/asm/byteorder.h     |  16 +
 xen/arch/riscv/include/asm/cache.h         |   2 +
 xen/arch/riscv/include/asm/cmpxchg.h       | 373 ++++++++++++++
 xen/arch/riscv/include/asm/config.h        |  21 +
 xen/arch/riscv/include/asm/cpufeature.h    |  22 +
 xen/arch/riscv/include/asm/current.h       |  17 +
 xen/arch/riscv/include/asm/delay.h         |  17 +
 xen/arch/riscv/include/asm/device.h        |  55 +++
 xen/arch/riscv/include/asm/div64.h         |  22 +
 xen/arch/riscv/include/asm/domain.h        |  43 ++
 xen/arch/riscv/include/asm/event.h         |  34 ++
 xen/arch/riscv/include/asm/fence.h         |  12 +
 xen/arch/riscv/include/asm/flushtlb.h      |  31 ++
 xen/arch/riscv/include/asm/grant_table.h   |  61 +++
 xen/arch/riscv/include/asm/guest_access.h  |  29 ++
 xen/arch/riscv/include/asm/guest_atomics.h |  63 +++
 xen/arch/riscv/include/asm/hardirq.h       |  26 +
 xen/arch/riscv/include/asm/hypercall.h     |   4 +
 xen/arch/riscv/include/asm/io.h            | 132 +++++
 xen/arch/riscv/include/asm/iocap.h         |  16 +
 xen/arch/riscv/include/asm/iommu.h         |   7 +
 xen/arch/riscv/include/asm/irq.h           |  34 ++
 xen/arch/riscv/include/asm/livepatch.h     |   0
 xen/arch/riscv/include/asm/mem_access.h    |   4 +
 xen/arch/riscv/include/asm/mm.h            | 270 +++++++++-
 xen/arch/riscv/include/asm/monitor.h       |  53 ++
 xen/arch/riscv/include/asm/nospec.h        |  25 +
 xen/arch/riscv/include/asm/numa.h          |  38 ++
 xen/arch/riscv/include/asm/p2m.h           | 129 +++++
 xen/arch/riscv/include/asm/page.h          |  37 ++
 xen/arch/riscv/include/asm/paging.h        |   7 +
 xen/arch/riscv/include/asm/pci.h           |   7 +
 xen/arch/riscv/include/asm/percpu.h        |  33 ++
 xen/arch/riscv/include/asm/perfc_defn.h    |   0
 xen/arch/riscv/include/asm/processor.h     |  15 +
 xen/arch/riscv/include/asm/random.h        |   9 +
 xen/arch/riscv/include/asm/regs.h          |  27 +
 xen/arch/riscv/include/asm/setup.h         |   6 +
 xen/arch/riscv/include/asm/smp.h           |  23 +
 xen/arch/riscv/include/asm/softirq.h       |  16 +
 xen/arch/riscv/include/asm/spinlock.h      |  13 +
 xen/arch/riscv/include/asm/system.h        |  83 ++++
 xen/arch/riscv/include/asm/time.h          |  20 +
 xen/arch/riscv/include/asm/vm_event.h      |  52 ++
 xen/arch/riscv/include/asm/xenoprof.h      |   4 +
 xen/arch/riscv/lib/Makefile                |   1 +
 xen/arch/riscv/lib/find_next_bit.c         | 278 +++++++++++
 xen/arch/riscv/mm.c                        |  85 +++-
 xen/arch/riscv/setup.c                     |   9 +-
 xen/arch/riscv/stubs.c                     | 419 ++++++++++++++++
 xen/arch/riscv/traps.c                     |  25 +
 xen/arch/riscv/xen.lds.S                   |  10 +
 xen/common/memory.c                        |   1 +
 xen/common/symbols.c                       |   1 +
 xen/include/public/arch-riscv.h            |  90 ++++
 xen/include/public/arch-riscv/hvm/save.h   |  22 +
 xen/include/public/hvm/save.h              |   2 +
 xen/include/public/pmu.h                   |   2 +
 xen/include/public/xen.h                   |   2 +
 xen/include/xen/domain.h                   |   1 +
 xen/include/xen/iommu.h                    |   1 +
 xen/include/xen/sched.h                    |   1 +
 74 files changed, 3625 insertions(+), 1046 deletions(-)
 create mode 100644 xen/arch/riscv/include/asm/altp2m.h
 create mode 100644 xen/arch/riscv/include/asm/asm_defns.h
 create mode 100644 xen/arch/riscv/include/asm/atomic.h
 create mode 100644 xen/arch/riscv/include/asm/bitops.h
 create mode 100644 xen/arch/riscv/include/asm/byteorder.h
 create mode 100644 xen/arch/riscv/include/asm/cmpxchg.h
 create mode 100644 xen/arch/riscv/include/asm/cpufeature.h
 create mode 100644 xen/arch/riscv/include/asm/delay.h
 create mode 100644 xen/arch/riscv/include/asm/device.h
 create mode 100644 xen/arch/riscv/include/asm/div64.h
 create mode 100644 xen/arch/riscv/include/asm/domain.h
 create mode 100644 xen/arch/riscv/include/asm/event.h
 create mode 100644 xen/arch/riscv/include/asm/fence.h
 create mode 100644 xen/arch/riscv/include/asm/flushtlb.h
 create mode 100644 xen/arch/riscv/include/asm/grant_table.h
 create mode 100644 xen/arch/riscv/include/asm/guest_access.h
 create mode 100644 xen/arch/riscv/include/asm/guest_atomics.h
 create mode 100644 xen/arch/riscv/include/asm/hardirq.h
 create mode 100644 xen/arch/riscv/include/asm/hypercall.h
 create mode 100644 xen/arch/riscv/include/asm/io.h
 create mode 100644 xen/arch/riscv/include/asm/iocap.h
 create mode 100644 xen/arch/riscv/include/asm/iommu.h
 create mode 100644 xen/arch/riscv/include/asm/irq.h
 create mode 100644 xen/arch/riscv/include/asm/livepatch.h
 create mode 100644 xen/arch/riscv/include/asm/mem_access.h
 create mode 100644 xen/arch/riscv/include/asm/monitor.h
 create mode 100644 xen/arch/riscv/include/asm/nospec.h
 create mode 100644 xen/arch/riscv/include/asm/numa.h
 create mode 100644 xen/arch/riscv/include/asm/p2m.h
 create mode 100644 xen/arch/riscv/include/asm/paging.h
 create mode 100644 xen/arch/riscv/include/asm/pci.h
 create mode 100644 xen/arch/riscv/include/asm/percpu.h
 create mode 100644 xen/arch/riscv/include/asm/perfc_defn.h
 create mode 100644 xen/arch/riscv/include/asm/random.h
 create mode 100644 xen/arch/riscv/include/asm/regs.h
 create mode 100644 xen/arch/riscv/include/asm/setup.h
 create mode 100644 xen/arch/riscv/include/asm/smp.h
 create mode 100644 xen/arch/riscv/include/asm/softirq.h
 create mode 100644 xen/arch/riscv/include/asm/spinlock.h
 create mode 100644 xen/arch/riscv/include/asm/system.h
 create mode 100644 xen/arch/riscv/include/asm/time.h
 create mode 100644 xen/arch/riscv/include/asm/vm_event.h
 create mode 100644 xen/arch/riscv/include/asm/xenoprof.h
 create mode 100644 xen/arch/riscv/lib/Makefile
 create mode 100644 xen/arch/riscv/lib/find_next_bit.c
 create mode 100644 xen/arch/riscv/stubs.c
 create mode 100644 xen/include/public/arch-riscv.h
 create mode 100644 xen/include/public/arch-riscv/hvm/save.h

-- 
2.41.0



             reply	other threads:[~2023-08-16 10:20 UTC|newest]

Thread overview: 67+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-08-16 10:19 Oleksii Kurochko [this message]
2023-08-16 10:19 ` [PATCH v1 01/57] xen/riscv:introduce asm/byteorder.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 02/57] xen/riscv: add public arch-riscv.h Oleksii Kurochko
2023-08-17 15:00   ` Jan Beulich
2023-08-18  9:36     ` Oleksii
2023-08-16 10:19 ` [PATCH v1 03/57] xen/riscv: introduce spinlock.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 04/57] xen/riscv: introduce fence.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 05/57] xen/riscv: introduce arch-riscv/hvm/save.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 06/57] xen/riscv: introduce paging.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 07/57] xen/riscv: introduce asm/cpufeature.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 08/57] xen/riscv: introduce asm/device.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 09/57] xen/riscv: introduce asm/event.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 10/57] xen/riscv: introduce asm/grant_table.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 11/57] xen/riscv: introduce asm/guest_atomics.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 12/57] xen/riscv: introduce asm/hypercall.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 13/57] xen/riscv: introduce asm/iocap.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 14/57] xen/riscv: introduce asm/iommu.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 15/57] xen/riscv: introduce asm/mem_access.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 16/57] xen/riscv: introduce asm/nospec.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 17/57] xen/riscv: introduce asm/pci.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 18/57] xen/riscv: introduce asm/random.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 19/57] xen/riscv: introduce asm/setup.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 20/57] xen/riscv: introduce asm/system.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 21/57] xen/riscv: introduce asm/xenoprof.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 22/57] xen/riscv: introduce bitops.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 23/57] xen/riscv: introduce flushtlb.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 24/57] xen/riscv: introduce asm/percpu.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 25/57] xen/riscv: introduce asm/smp.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 26/57] xen/riscv: introduce asm/atomic.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 27/57] xen/riscv: introduce cmpxchg.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 28/57] xen/riscv: introduce asm/io.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 29/57] xen/riscv: introduce asm/hardirq.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 30/57] xen/riscv: introduce div64.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 31/57] xen/riscv: define bug frame tables in xen.lds.S Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 32/57] xen/riscv: introduce bit operations Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 33/57] xen/riscv: introduce asm/altp2m.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 34/57] xen/riscv: introduce asm/delay.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 35/57] xen/riscv: introduce asm/domain.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 36/57] xen/riscv: introduce asm/guest_access.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 37/57] xen/riscv: introduce asm/irq.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 38/57] xen/riscv: introduce asm/monitor.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 39/57] xen/riscv: introduce asm/numa.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 40/57] xen/riscv: introduce asm/p2m.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 41/57] xen/riscv: introduce asm/regs.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 42/57] xen/riscv: introduce asm/softirq.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 43/57] xen/riscv: introduce asm/time.h Oleksii Kurochko
2023-08-16 10:19 ` [PATCH v1 44/57] xen/riscv: introduce asm/vm_event.h Oleksii Kurochko
2023-08-21 16:43   ` Tamas K Lengyel
2023-08-22 15:08     ` Oleksii
2023-08-16 10:19 ` [PATCH v1 45/57] xen/riscv: add definition of __read_mostly Oleksii Kurochko
2023-08-22  6:22   ` Jan Beulich
2023-08-22 15:07     ` Oleksii
2023-08-16 10:19 ` [PATCH v1 46/57] xen/riscv: define an address of frame table Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 47/57] xen/riscv: add required things to asm/current.h Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 48/57] xen/riscv: add minimal stuff to asm/page.h to build full Xen Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 49/57] xen/riscv: add minimal stuff to asm/processor.h " Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 50/57] xen/riscv: add minimal stuff to asm/smp.h " Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 51/57] xen: add RISCV support for pmu.h Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 52/57] xen: add necessary headers to common to build full Xen for RISC-V Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 53/57] xen/riscv: add minimal stuff to asm/mm.h to build full Xen Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 54/57] xen/rirscv: add minimal amount of stubs " Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 55/57] xen/riscv: enable full Xen build Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 56/57] test only riscv Oleksii Kurochko
2023-08-16 10:20 ` [PATCH v1 57/57] xxxen/riscv: WIP ( need advise ) Oleksii Kurochko
2023-08-22 15:12   ` Oleksii
2023-10-19 11:53 ` [PATCH v1 00/57] Enable build of full Xen for RISC-V Jan Beulich
2023-10-23  9:24   ` Oleksii

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=cover.1692181079.git.oleksii.kurochko@gmail.com \
    --to=oleksii.kurochko@gmail.com \
    --cc=alistair.francis@wdc.com \
    --cc=andrew.cooper3@citrix.com \
    --cc=bobbyeshleman@gmail.com \
    --cc=cardoe@cardoe.com \
    --cc=connojdavis@gmail.com \
    --cc=george.dunlap@citrix.com \
    --cc=jbeulich@suse.com \
    --cc=julien@xen.org \
    --cc=konrad.wilk@oracle.com \
    --cc=paul@xen.org \
    --cc=roger.pau@citrix.com \
    --cc=ross.lagerwall@citrix.com \
    --cc=sstabellini@kernel.org \
    --cc=wl@xen.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).