9aa57b6c53
1. virtio devics/drivers match and probe/remote mechanism; 2. virtio mmio transport layer based on OpenAmp (Compatible with both virtio mmio version 1 and 2); 3. virtio-serial driver based on new virtio framework; 4. virtio-rng driver based on new virtio framework; 5. virtio-net driver based on new virtio framework (IOB Offload implementation); 6. virtio-blk driver based on new virtio framework; 7. Remove the old virtio mmio framework, the old framework only support mmio transport layer, and the new framwork support more transport layer and this commit has implemented all the old virtio drivers; 8. Refresh the the qemu-arm64 and qemu-riscv virtio related configs, and update its README.txt; New virtio-net driver has better performance Compared with previous virtio-mmio-net: | | master/-c | master/-s | this/-c | this/-s | | :--------------------: | :-------: | :-------: | :-----: | :-----: | | qemu-armv8a:netnsh | 539Mbps | 524Mbps | 906Mbps | 715Mbps | | qemu-armv8a:netnsh_smp | 401Mbps | 437Mbps | 583Mbps | 505Mbps | | rv-virt:netnsh | 487Mbps | 512Mbps | 760Mbps | 634Mbps | | rv-virt:netnsh_smp | 387Mbps | 455Mbps | 447Mbps | 502Mbps | | rv-virt:netnsh64 | 602Mbps | 595Mbps | 881Mbps | 769Mbps | | rv-virt:netnsh64_smp | 414Mbps | 515Mbps | 491Mbps | 525Mbps | | rv-virt:knetnsh64 | 515Mbps | 457Mbps | 606Mbps | 540Mbps | | rv-virt:knetnsh64_smp | 308Mbps | 389Mbps | 415Mbps | 474Mbps | Note: Both CONFIG_IOB_NBUFFERS=64, using iperf command, all in Mbits/sec Tested in QEMU 7.2.2 Signed-off-by: wangbowen6 <wangbowen6@xiaomi.com> Signed-off-by: Zhe Weng <wengzhe@xiaomi.com>
212 lines
5.2 KiB
C
212 lines
5.2 KiB
C
/****************************************************************************
|
|
* drivers/drivers_initialize.c
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership. The
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations
|
|
* under the License.
|
|
*
|
|
****************************************************************************/
|
|
|
|
/****************************************************************************
|
|
* Included Files
|
|
****************************************************************************/
|
|
|
|
#include <nuttx/clk/clk_provider.h>
|
|
#include <nuttx/crypto/crypto.h>
|
|
#include <nuttx/drivers/drivers.h>
|
|
#include <nuttx/drivers/rpmsgdev.h>
|
|
#include <nuttx/drivers/rpmsgblk.h>
|
|
#include <nuttx/fs/loop.h>
|
|
#include <nuttx/fs/smart.h>
|
|
#include <nuttx/fs/loopmtd.h>
|
|
#include <nuttx/input/uinput.h>
|
|
#include <nuttx/mtd/mtd.h>
|
|
#include <nuttx/net/loopback.h>
|
|
#include <nuttx/net/tun.h>
|
|
#include <nuttx/net/telnet.h>
|
|
#include <nuttx/note/note_driver.h>
|
|
#include <nuttx/power/pm.h>
|
|
#include <nuttx/power/regulator.h>
|
|
#include <nuttx/segger/rtt.h>
|
|
#include <nuttx/sensors/sensor.h>
|
|
#include <nuttx/serial/pty.h>
|
|
#include <nuttx/syslog/syslog.h>
|
|
#include <nuttx/syslog/syslog_console.h>
|
|
#include <nuttx/usrsock/usrsock_rpmsg.h>
|
|
#include <nuttx/virtio/virtio.h>
|
|
|
|
/****************************************************************************
|
|
* Public Functions
|
|
****************************************************************************/
|
|
|
|
/****************************************************************************
|
|
* Name: drivers_initialize
|
|
*
|
|
* Description:
|
|
* drivers_initialize will be called once during OS initialization after
|
|
* the basic OS services have been initialized.
|
|
*
|
|
* drivers_initialize is called after the OS initialized but before the
|
|
* user initialization logic has been started and before the libraries
|
|
* have been initialized. OS services and driver services are available.
|
|
*
|
|
****************************************************************************/
|
|
|
|
void drivers_initialize(void)
|
|
{
|
|
/* Register devices */
|
|
|
|
syslog_initialize();
|
|
|
|
#ifdef CONFIG_SERIAL_RTT
|
|
serial_rtt_initialize();
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_NULL)
|
|
devnull_register(); /* Standard /dev/null */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_RANDOM)
|
|
devrandom_register(); /* Standard /dev/random */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_URANDOM)
|
|
devurandom_register(); /* Standard /dev/urandom */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_ZERO)
|
|
devzero_register(); /* Standard /dev/zero */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_LOOP)
|
|
loop_register(); /* Standard /dev/loop */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DEV_ASCII)
|
|
devascii_register(); /* Non-standard /dev/ascii */
|
|
#endif
|
|
|
|
#if defined(CONFIG_DRIVERS_NOTE)
|
|
note_initialize(); /* Non-standard /dev/note */
|
|
#endif
|
|
|
|
#if defined(CONFIG_CLK_RPMSG)
|
|
clk_rpmsg_server_initialize();
|
|
#endif
|
|
|
|
#if defined(CONFIG_REGULATOR_RPMSG)
|
|
regulator_rpmsg_server_init();
|
|
#endif
|
|
|
|
/* Initialize the serial device driver */
|
|
|
|
#ifdef CONFIG_RPMSG_UART
|
|
rpmsg_serialinit();
|
|
#endif
|
|
|
|
/* Initialize the console device driver (if it is other than the standard
|
|
* serial driver).
|
|
*/
|
|
|
|
#if defined(CONFIG_LWL_CONSOLE)
|
|
lwlconsole_init();
|
|
#elif defined(CONFIG_CONSOLE_SYSLOG)
|
|
syslog_console_init();
|
|
#endif
|
|
|
|
#ifdef CONFIG_PSEUDOTERM_SUSV1
|
|
/* Register the master pseudo-terminal multiplexor device */
|
|
|
|
ptmx_register();
|
|
#endif
|
|
|
|
#if defined(CONFIG_CRYPTO)
|
|
/* Initialize the HW crypto and /dev/crypto */
|
|
|
|
up_cryptoinitialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_CRYPTO_CRYPTODEV
|
|
devcrypto_register();
|
|
#endif
|
|
|
|
#ifdef CONFIG_UINPUT_TOUCH
|
|
uinput_touch_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_UINPUT_BUTTONS
|
|
uinput_button_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_UINPUT_KEYBOARD
|
|
uinput_keyboard_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_NET_LOOPBACK
|
|
/* Initialize the local loopback device */
|
|
|
|
localhost_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_NET_TUN
|
|
/* Initialize the TUN device */
|
|
|
|
tun_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_NETDEV_TELNET
|
|
/* Initialize the Telnet session factory */
|
|
|
|
telnet_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_USENSOR
|
|
usensor_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_SENSORS_RPMSG
|
|
sensor_rpmsg_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_DEV_RPMSG_SERVER
|
|
rpmsgdev_server_init();
|
|
#endif
|
|
|
|
#ifdef CONFIG_BLK_RPMSG_SERVER
|
|
rpmsgblk_server_init();
|
|
#endif
|
|
|
|
#ifdef CONFIG_RPMSGMTD_SERVER
|
|
rpmsgmtd_server_init();
|
|
#endif
|
|
|
|
#ifdef CONFIG_NET_USRSOCK_RPMSG_SERVER
|
|
/* Initialize the user socket rpmsg server */
|
|
|
|
usrsock_rpmsg_server_initialize();
|
|
#endif
|
|
|
|
#ifdef CONFIG_SMART_DEV_LOOP
|
|
smart_loop_register_driver();
|
|
#endif
|
|
|
|
#ifdef CONFIG_MTD_LOOP
|
|
mtd_loop_register();
|
|
#endif
|
|
|
|
#ifdef CONFIG_DRIVERS_VIRTIO
|
|
virtio_register_drivers();
|
|
#endif
|
|
}
|