维塔斯科技

 找回密码
 立即注册
楼主: 21wim7
打印 上一主题 下一主题

非官方编译,Hyper-V的Openwrt x86和x86-64版,Chaos Calmer正式版

[复制链接]

该用户从未签到

55

主题

369

帖子

809

积分

高级会员

Rank: 4

积分
809
11#
发表于 2016-3-29 12:35:34 | 只看该作者
修改的patch源代码如下:
diff --git a/config/Config-images.in b/config/Config-images.in

index a60dd50..f83317f 100644

--- a/config/Config-images.in

+++ b/config/Config-images.in

@@ -231,6 +231,16 @@ menu "Target Images"

                 select TARGET_IMAGES_PAD

                 select PACKAGE_kmod-e1000



+        config VHD_IMAGES

+                bool "Build Hyper-V image files (VHD)"

+                depends on TARGET_x86 || TARGET_x86_64

+                select GRUB_IMAGES

+                select TARGET_IMAGES_PAD

+                select PACKAGE_kmod-hyperv-balloon

+                select PACKAGE_kmod-hyperv-net-vsc

+                select PACKAGE_kmod-hyperv-util

+                select PACKAGE_kmod-hyperv-storage

+

         config VMDK_IMAGES

                 bool "Build VMware image files (VMDK)"

                 depends on TARGET_x86 || TARGET_x86_64
复制代码diff --git a/package/kernel/linux/modules/virtual.mk b/package/kernel/linux/modules/virtual.mk

index 4464fe9..d4b55ae 100644

--- a/package/kernel/linux/modules/virtual.mk

+++ b/package/kernel/linux/modules/virtual.mk

@@ -186,3 +186,85 @@ define KernelPackage/xen-pcidev/description

endef



$(eval $(call KernelPackage,xen-pcidev))

+

+#

+# Hyper-V Drives depends on x86 or x86_64.

+#

+define KernelPackage/hyperv-balloon

+  SUBMENU:=$(VIRTUAL_MENU)

+  DEPENDS:=@(TARGET_x86||TARGET_x86_64)

+  TITLE:=Microsoft Hyper-V Balloon Driver

+  KCONFIG:= \

+    CONFIG_HYPERV_BALLOON \

+    CONFIG_HYPERVISOR_GUEST=y \

+    CONFIG_PARAVIRT=n \

+    CONFIG_HYPERV=y

+  FILES:=$(LINUX_DIR)/drivers/hv/hv_balloon.ko

+  AUTOLOAD:=$(call AutoLoad,06,hv_balloon)

+endef

+

+define KernelPackage/hyperv-balloon/description

+  Microsofot Hyper-V balloon driver.

+endef

+

+$(eval $(call KernelPackage,hyperv-balloon))

+

+define KernelPackage/hyperv-net-vsc

+  SUBMENU:=$(VIRTUAL_MENU)

+  DEPENDS:=@(TARGET_x86||TARGET_x86_64)

+  TITLE:=Microsoft Hyper-V Network Driver

+  KCONFIG:= \

+    CONFIG_HYPERV_NET \

+    CONFIG_HYPERVISOR_GUEST=y \

+    CONFIG_PARAVIRT=n \

+    CONFIG_HYPERV=y

+  FILES:=$(LINUX_DIR)/drivers/net/hyperv/hv_netvsc.ko

+  AUTOLOAD:=$(call AutoLoad,35,hv_netvsc)

+endef

+

+define KernelPackage/hyperv-net-vsc/description

+  Microsoft Hyper-V Network Driver

+endef

+

+$(eval $(call KernelPackage,hyperv-net-vsc))

+

+define KernelPackage/hyperv-util

+  SUBMENU:=$(VIRTUAL_MENU)

+  DEPENDS:=@(TARGET_x86||TARGET_x86_64)

+  TITLE:=Microsoft Hyper-V Utility Driver

+  KCONFIG:= \

+    CONFIG_HYPERV_UTILS \

+    CONFIG_HYPERVISOR_GUEST=y \

+    CONFIG_PARAVIRT=n \

+    CONFIG_HYPERV=y

+  FILES:=$(LINUX_DIR)/drivers/hv/hv_util.ko

+  AUTOLOAD:=$(call AutoLoad,10,hv_util)

+endef

+

+define KernelPackage/hyperv-util/description

+  Microsoft Hyper-V Utility Driver

+endef

+

+$(eval $(call KernelPackage,hyperv-util))

+

+#

+# Hyper-V Storage Drive needs to be in kernel rather than module to load the root fs.

+#

+define KernelPackage/hyperv-storage

+  SUBMENU:=$(VIRTUAL_MENU)

+  DEPENDS:=@(TARGET_x86||TARGET_x86_64) +kmod-scsi-core

+  TITLE:=Microsoft Hyper-V Storage Driver

+  KCONFIG:= \

+    CONFIG_HYPERV_STORAGE=y \

+    CONFIG_HYPERVISOR_GUEST=y \

+    CONFIG_PARAVIRT=n \

+    CONFIG_HYPERV=y

+  FILES:=$(LINUX_DIR)/drivers/scsi/hv_storvsc.ko

+  AUTOLOAD:=$(call AutoLoad,40,hv_storvsc)

+endef

+

+define KernelPackage/hyperv-storage/description

+  Microsoft Hyper-V Storage Driver

+endef

+

+$(eval $(call KernelPackage,hyperv-storage))
复制代码diff --git a/target/linux/x86/64/config-default b/target/linux/x86/64/config-default

index 1caad74..32c7648 100644

--- a/target/linux/x86/64/config-default

+++ b/target/linux/x86/64/config-default

@@ -99,6 +99,14 @@ CONFIG_HPET_MMAP=y

CONFIG_HW_RANDOM_INTEL=y

# CONFIG_HW_RANDOM_VIRTIO is not set

CONFIG_HYPERVISOR_GUEST=y

+# CONFIG_HYPERV is not set

+# CONFIG_HYPERV_BALLOON is not set

+# CONFIG_HYPERV_NET is not set

+# CONFIG_HYPERV_STORAGE is not set

+# CONFIG_HYPERV_UTILS is not set

+# CONFIG_FB_HYPERV is not set

+# CONFIG_HID_HYPERV_MOUSE is not set

+# CONFIG_HYPERV_KEYBOARD is not set

# CONFIG_I7300_IDLE is not set

# CONFIG_IA32_EMULATION is not set

CONFIG_ILLEGAL_POINTER_VALUE=0xdead000000000000


复制代码diff --git a/target/linux/x86/config-3.18 b/target/linux/x86/config-3.18

index d7a2d61..6dfdfd7 100644

--- a/target/linux/x86/config-3.18

+++ b/target/linux/x86/config-3.18

@@ -203,6 +203,17 @@ CONFIG_HW_RANDOM=y

CONFIG_HW_RANDOM_GEODE=y

CONFIG_HW_RANDOM_VIA=y

# CONFIG_HYPERVISOR_GUEST is not set

+

+# CONFIG_HYPERV is not set

+# CONFIG_HYPERV_BALLOON is not set

+# CONFIG_HYPERV_NET is not set

+# CONFIG_HYPERV_STORAGE is not set

+# CONFIG_HYPERV_UTILS is not set

+# CONFIG_FB_HYPERV is not set

+# CONFIG_HID_HYPERV_MOUSE is not set

+# CONFIG_VMWARE_BALLOON is not set

+# CONFIG_HYPERV_KEYBOARD is not set

+

CONFIG_HZ_PERIODIC=y

CONFIG_I8253_LOCK=y

# CONFIG_I8K is not set
复制代码diff --git a/target/linux/x86/image/Makefile b/target/linux/x86/image/Makefile

index e7e02f1..a52ec11 100644

--- a/target/linux/x86/image/Makefile

+++ b/target/linux/x86/image/Makefile

@@ -148,6 +148,15 @@ ifneq ($(CONFIG_VMDK_IMAGES),)

   endef

endif



+ifneq ($(CONFIG_VHD_IMAGES),)

+  define Image/Build/vhd

+        rm $(BIN_DIR)/$(IMG_PREFIX)-combined-$(1).vhd || true

+        qemu-img convert -f raw -O vpc \

+                $(BIN_DIR)/$(IMG_PREFIX)-combined-$(1).img \

+                $(BIN_DIR)/$(IMG_PREFIX)-combined-$(1).vhd

+  endef

+endif

+

define Image/Build/gzip

         gzip -f9 $(BIN_DIR)/$(IMG_PREFIX)-combined-$(1).img

         gzip -f9 $(BIN_DIR)/$(IMG_PREFIX)-rootfs-$(1).img

@@ -219,6 +228,7 @@ define Image/Build

         $(call Image/Build/grub2,$(1))

         $(call Image/Build/vdi,$(1))

         $(call Image/Build/vmdk,$(1))

+        $(call Image/Build/vhd,$(1))

         $(CP) $(KDIR)/root.$(1) $(BIN_DIR)/$(IMG_PREFIX)-rootfs-$(1).img

   else

         $(CP) $(KDIR)/root.iso $(BIN_DIR)/$(IMG_PREFIX).iso


复制代码


回复 支持 反对

使用道具 举报

该用户从未签到

54

主题

412

帖子

894

积分

高级会员

Rank: 4

积分
894
12#
发表于 2016-3-29 12:35:35 | 只看该作者
tedaz 于 2015-9-11 14:36 编辑

是SMP(Symmetric multiprocessing)吗?
OpenWrt的x86-64默认就支持多核心和超过800MB的内存。
下面的截图是OpenWrt x86-64启动日志,显示4个处理器被激活。

虚拟机为4核心,16GB内存,虽然很怀疑OpenWrt是否真的可以充分利用这些资源,但是确实是可以支持的。
实际上x86和x86-64的OpenWrt与一般的Linux非常接近,很多一般Linux支持的功能都可以在OpenWrt上实现。







回复 支持 反对

使用道具 举报

该用户从未签到

65

主题

445

帖子

974

积分

高级会员

Rank: 4

积分
974
13#
发表于 2016-3-29 12:35:35 | 只看该作者

哪个帖子?

回复

使用道具 举报

该用户从未签到

37

主题

304

帖子

661

积分

高级会员

Rank: 4

积分
661
14#
发表于 2016-3-29 12:35:35 | 只看该作者

这种编译的vhd,在server 2012 r2上毫无问题,早就测试过。

话说,2008r2才是最困难的;
2012r2对linux的支持好了很多很多,有很多第三方的openwrt都能支持2012r2的。


回复 支持 反对

使用道具 举报

该用户从未签到

66

主题

475

帖子

1032

积分

金牌会员

Rank: 6Rank: 6

积分
1032
15#
发表于 2016-3-29 12:35:36 | 只看该作者

棒棒哒,晚上回去测试 。 你这个CPU 有点厉害

回复 支持 反对

使用道具 举报

该用户从未签到

68

主题

468

帖子

1020

积分

金牌会员

Rank: 6Rank: 6

积分
1020
16#
发表于 2016-3-29 12:35:36 | 只看该作者
为为我没搜到这个帖子


回复 支持 反对

使用道具 举报

该用户从未签到

54

主题

384

帖子

840

积分

高级会员

Rank: 4

积分
840
17#
发表于 2016-3-29 12:35:36 | 只看该作者
大神果然厉害

回复 支持 反对

使用道具 举报

该用户从未签到

53

主题

430

帖子

929

积分

高级会员

Rank: 4

积分
929
18#
发表于 2016-3-29 12:35:37 | 只看该作者
数不清 于 2015-9-11 19:35 编辑

不知道以后升级软件包是否会有影响

你这编译的机器哪找的,板子是Supermicro X10SDV-F-O ?

回复 支持 反对

使用道具 举报

该用户从未签到

82

主题

492

帖子

1086

积分

金牌会员

Rank: 6Rank: 6

积分
1086
19#
发表于 2016-3-29 12:35:37 | 只看该作者

(1)请问smt是什么?

(2)现在编译的版本,最大可以支持800MB内存,详见截图,请问这么大内存还不够用吗?
以我自己的实际体验,64MB内存可以支持4000个左右的并发连接+QoS,已经足够用了。








回复 支持 反对

使用道具 举报

该用户从未签到

80

主题

532

帖子

1160

积分

金牌会员

Rank: 6Rank: 6

积分
1160
20#
发表于 2016-3-29 12:35:38 | 只看该作者
Jasion 于 2015-9-11 17:58 编辑

所以说有点厉害,同系列的 D-1520 4核8线 缓存6M 居然也还是45W ,得益于intel 14nm工艺吧  频率如果做高点 也差不多65W的TDP

回复 支持 反对

使用道具 举报

发表回复
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

    移动客户端:
    关注我们:
  • 手机客户端:
  • 安卓版
  • 扫描二维码下载

Archiver|手机版|邢台网云科技有限公司 ( 冀ICP备16008275号 )

快速回复 返回顶部 返回列表