mirror of
https://github.com/vdsm/virtual-dsm.git
synced 2025-02-24 13:30:02 +08:00
Implement serial emulator
This commit is contained in:
parent
720d8ac704
commit
542ee066e0
@ -20,13 +20,13 @@ COPY generate-dhcpd-conf /run/
|
|||||||
COPY qemu-ifdown /run/
|
COPY qemu-ifdown /run/
|
||||||
COPY qemu-ifup /run/
|
COPY qemu-ifup /run/
|
||||||
COPY run.sh /run/
|
COPY run.sh /run/
|
||||||
COPY --from=builder /src/vdsm-serial/main /run/
|
COPY --from=builder /src/vdsm-serial/main /run/serial.bin
|
||||||
|
|
||||||
RUN ["chmod", "+x", "/run/generate-dhcpd-conf"]
|
RUN ["chmod", "+x", "/run/generate-dhcpd-conf"]
|
||||||
RUN ["chmod", "+x", "/run/qemu-ifdown"]
|
RUN ["chmod", "+x", "/run/qemu-ifdown"]
|
||||||
RUN ["chmod", "+x", "/run/qemu-ifup"]
|
RUN ["chmod", "+x", "/run/qemu-ifup"]
|
||||||
RUN ["chmod", "+x", "/run/run.sh"]
|
RUN ["chmod", "+x", "/run/run.sh"]
|
||||||
RUN ["chmod", "+x", "/run/main"]
|
RUN ["chmod", "+x", "/run/serial.bin"]
|
||||||
|
|
||||||
VOLUME /images
|
VOLUME /images
|
||||||
|
|
||||||
|
19
run.sh
19
run.sh
@ -1,5 +1,7 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
echo "Booting Synology DSM for Docker..."
|
||||||
|
|
||||||
FILE="/images/boot.img"
|
FILE="/images/boot.img"
|
||||||
if [ ! -f "$FILE" ]; then
|
if [ ! -f "$FILE" ]; then
|
||||||
echo "ERROR: Synology DSM boot-image does not exist ($FILE)"
|
echo "ERROR: Synology DSM boot-image does not exist ($FILE)"
|
||||||
@ -22,7 +24,6 @@ if [ ! -f "$FILE" ]; then
|
|||||||
exit 2
|
exit 2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
# A bridge of this name will be created to host the TAP interface created for
|
# A bridge of this name will be created to host the TAP interface created for
|
||||||
# the VM
|
# the VM
|
||||||
QEMU_BRIDGE='qemubr0'
|
QEMU_BRIDGE='qemubr0'
|
||||||
@ -70,16 +71,28 @@ touch /var/lib/misc/udhcpd.leases
|
|||||||
# Finally, start our DHCPD server
|
# Finally, start our DHCPD server
|
||||||
udhcpd -I $DUMMY_DHCPD_IP -f $DHCPD_CONF_FILE &
|
udhcpd -I $DUMMY_DHCPD_IP -f $DHCPD_CONF_FILE &
|
||||||
|
|
||||||
|
echo "Launching Synology Serial Emulator..."
|
||||||
|
|
||||||
|
# Start the Synology Serial Emulator
|
||||||
|
./run/serial.bin -vmmversion "2.6.1-12139" -buildnumber 42962 -vmmts 1650802981032 -cpu 1 -cpu_arch string "QEMU, Virtual CPU, X86_64" -guestsn "0000000000000" -hostsn "0000000000000" -guestuuid "ba13a19a-c0c1-4fef-9346-915ed3b98341" &
|
||||||
|
|
||||||
|
echo "Booting OS..."
|
||||||
|
|
||||||
# And run the VM! A brief explaination of the options here:
|
# And run the VM! A brief explaination of the options here:
|
||||||
# -enable-kvm: Use KVM for this VM (much faster for our case).
|
# -enable-kvm: Use KVM for this VM (much faster for our case).
|
||||||
# -nographic: disable SDL graphics.
|
# -nographic: disable SDL graphics.
|
||||||
# -serial mon:stdio: use "monitored stdio" as our serial output.
|
# -serial mon:stdio: use "monitored stdio" as our serial output.
|
||||||
exec qemu-system-x86_64 -enable-kvm -nographic -serial mon:stdio \
|
exec qemu-system-x86_64 -name Synology -enable-kvm -nographic -serial mon:stdio \
|
||||||
"$@" \
|
"$@" \
|
||||||
|
-device virtio-serial-pci,id=virtio-serial0,bus=pci.0,addr=0x3 -chardev pty,id=charserial0 \
|
||||||
|
-device isa-serial,chardev=charserial0,id=serial0 -chardev socket,id=charchannel0,host=127.0.0.1,port=12345,reconnect=10 \
|
||||||
|
-device virtserialport,bus=virtio-serial0.0,nr=1,chardev=charchannel0,id=channel0,name=vchannel \
|
||||||
-device virtio-net,netdev=tap0 -netdev tap,id=tap0,ifname=Tap,script=$QEMU_IFUP,downscript=$QEMU_IFDOWN \
|
-device virtio-net,netdev=tap0 -netdev tap,id=tap0,ifname=Tap,script=$QEMU_IFUP,downscript=$QEMU_IFDOWN \
|
||||||
-device virtio-scsi-pci,id=hw-synoboot,bus=pci.0,addr=0xa -drive file=/images/boot.img,if=none,id=drive-synoboot,format=raw,cache=none,aio=native,detect-zeroes=on \
|
-device virtio-scsi-pci,id=hw-synoboot,bus=pci.0,addr=0xa -drive file=/images/boot.img,if=none,id=drive-synoboot,format=raw,cache=none,aio=native,detect-zeroes=on \
|
||||||
-device scsi-hd,bus=hw-synoboot.0,channel=0,scsi-id=0,lun=0,drive=drive-synoboot,id=synoboot0,bootindex=1 \
|
-device scsi-hd,bus=hw-synoboot.0,channel=0,scsi-id=0,lun=0,drive=drive-synoboot,id=synoboot0,bootindex=1 \
|
||||||
-device virtio-scsi-pci,id=hw-synosys,bus=pci.0,addr=0xb -drive file=/images/system.img,if=none,id=drive-synosys,format=raw,cache=none,aio=native,detect-zeroes=on \
|
-device virtio-scsi-pci,id=hw-synosys,bus=pci.0,addr=0xb -drive file=/images/system.img,if=none,id=drive-synosys,format=raw,cache=none,aio=native,detect-zeroes=on \
|
||||||
-device scsi-hd,bus=hw-synosys.0,channel=0,scsi-id=0,lun=0,drive=drive-synosys,id=synosys0,bootindex=2 \
|
-device scsi-hd,bus=hw-synosys.0,channel=0,scsi-id=0,lun=0,drive=drive-synosys,id=synosys0,bootindex=2 \
|
||||||
-device virtio-scsi-pci,id=hw-userdata,bus=pci.0,addr=0xc -drive file=/images/data.img,if=none,id=drive-userdata,format=raw,cache=none,aio=native,detect-zeroes=on \
|
-device virtio-scsi-pci,id=hw-userdata,bus=pci.0,addr=0xc -drive file=/images/data.img,if=none,id=drive-userdata,format=raw,cache=none,aio=native,detect-zeroes=on \
|
||||||
-device scsi-hd,bus=hw-userdata.0,channel=0,scsi-id=0,lun=0,drive=drive-userdata,id=userdata0,bootindex=3
|
-device scsi-hd,bus=hw-userdata.0,channel=0,scsi-id=0,lun=0,drive=drive-userdata,id=userdata0,bootindex=3 \
|
||||||
|
-device piix3-usb-uhci,id=usb,bus=pci.0,addr=0x1.0x2
|
||||||
|
|
||||||
|
@ -8,7 +8,6 @@ import (
|
|||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"strconv"
|
"strconv"
|
||||||
"time"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type REQ struct {
|
type REQ struct {
|
||||||
@ -44,13 +43,8 @@ var ListenAddr = flag.String("addr", "0.0.0.0:12345", "Listen address")
|
|||||||
func main() {
|
func main() {
|
||||||
flag.Parse()
|
flag.Parse()
|
||||||
log.Println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!")
|
log.Println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!")
|
||||||
log.Println("!!! Just for experimental, please delete it after 24 hour !!!")
|
log.Println("!!! Synology Serial Emulator created by https://jxcn.org !!!")
|
||||||
log.Println("!!! See https://jxcn.org for update. !!!")
|
|
||||||
log.Println("!!! This program will be unavailable after 2022-12-31 !!!")
|
|
||||||
log.Println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!")
|
log.Println("!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!")
|
||||||
if time.Now().Year() >= 2023 {
|
|
||||||
log.Panic("Expired")
|
|
||||||
}
|
|
||||||
listener, err := net.Listen("tcp", *ListenAddr)
|
listener, err := net.Listen("tcp", *ListenAddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Error listening", err.Error())
|
log.Println("Error listening", err.Error())
|
||||||
|
Loading…
x
Reference in New Issue
Block a user