summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app-emulation/parallels-workstation/files/parallels-workstation-2.2.2112-2.6.23.patch')
-rw-r--r--app-emulation/parallels-workstation/files/parallels-workstation-2.2.2112-2.6.23.patch452
1 files changed, 452 insertions, 0 deletions
diff --git a/app-emulation/parallels-workstation/files/parallels-workstation-2.2.2112-2.6.23.patch b/app-emulation/parallels-workstation/files/parallels-workstation-2.2.2112-2.6.23.patch
new file mode 100644
index 000000000000..47efd01ff125
--- /dev/null
+++ b/app-emulation/parallels-workstation/files/parallels-workstation-2.2.2112-2.6.23.patch
@@ -0,0 +1,452 @@
+--- data/drivers/drv_main/compat/compat_memory.h
++++ data/drivers/drv_main/compat/compat_memory.h
+123a124,136
+> /* change kmem_cache_t to kmem_cache */
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 22)
+> # define kmem_cache_compat struct kmem_cache
+> # if LINUX_VERSION_CODE >= KERNEL_VERSION(2, 6, 23)
+> # define compat_kmem_cache_create(a, b, c, d, e, f) (kmem_cache_create(a, b, c, d, e))
+> # else
+> # define compat_kmem_cache_create(a, b, c, d, e, f) (kmem_cache_create(a, b, c, d, e, f))
+> # endif
+> #else
+> # define kmem_cache_compat kmem_cache_t
+> # define compat_kmem_cache_create(a, b, c, d, e, f) (kmem_cache_create(a, b, c, d, e, f))
+> #endif
+>
+--- data/drivers/drv_main/Makefile
++++ data/drivers/drv_main/Makefile
+2c2
+< KSRC=/lib/modules/$(shell uname -r)/build
+---
+> KSRC ?= /lib/modules/$(shell uname -r)/build
+--- data/drivers/drv_main/mm/manager.c
++++ data/drivers/drv_main/mm/manager.c
+22a23
+> #include <linux/sched.h>
+268c269
+< vmGlobal.vmPmms.pmmRegionsSlab = kmem_cache_create("vmRegions", sizeof(struct pmm_region_t), 0,
+---
+> vmGlobal.vmPmms.pmmRegionsSlab = compat_kmem_cache_create("vmRegions", sizeof(struct pmm_region_t), 0,
+--- data/drivers/drv_main/mm/pages.c
++++ data/drivers/drv_main/mm/pages.c
+20a21
+> #include <linux/sched.h>
+--- data/drivers/drv_main/vmmain.h
++++ data/drivers/drv_main/vmmain.h
+23a24
+> #include "compat/compat_memory.h"
+196c197
+< kmem_cache_t *pmmRegionsSlab;
+---
+> kmem_cache_compat *pmmRegionsSlab;
+--- data/drivers/drv_net/linux/prlnet.c
++++ data/drivers/drv_net/linux/prlnet.c
+6c6
+< // $Id: parallels-workstation-2.2.2112-2.6.23.patch,v 1.1 2008/02/07 15:43:50 cardoe Exp $
+---
+> // $Id: parallels-workstation-2.2.2112-2.6.23.patch,v 1.1 2008/02/07 15:43:50 cardoe Exp $
+17a18
+> #include <linux/mm.h>
+33a35,38
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> #include <net/ip.h>
+> #endif
+>
+725a731,735
+>
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> skb_reset_mac_header(skb);
+> skb_set_network_header(skb, sizeof(skb->mac_header));
+> #else
+727a738
+> #endif
+783a795,797
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> eth = (eth_header_t *)skb_mac_header(skbout);
+> #else
+784a799
+> #endif
+875c890,895
+< prlnet_recv(struct sk_buff *skb, struct net_device *dev, struct packet_type *pt)
+---
+> prlnet_recv(
+> struct sk_buff *skb, struct net_device *dev, struct packet_type *pt
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,14)
+> , struct net_device *origdev
+> #endif
+> )
+884c904,909
+< && skb->ip_summed == CHECKSUM_HW;
+---
+> && skb->ip_summed ==
+> #ifdef CHECKSUM_HW
+> CHECKSUM_HW;
+> #else
+> CHECKSUM_PARTIAL;
+> #endif
+887a913,915
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> int len = skb->data - skb_mac_header(skb) + skb->len;
+> #else
+888a917
+> #endif
+891a921,936
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> // can't use skb_copy_and_csum_dev(skb, buf + 2) here
+> // because skb->h == skb->nh. opensource rules!
+> int hoff = sizeof(struct ethhdr) + ip_hdrlen(skb);
+> // IP header checksum is done by the kernel
+> skb_copy_bits(skb,
+> skb_mac_header(skb) - skb->data, buf + 2, hoff);
+>
+> // skb->csum is an offset from true skb->h.raw
+> *(unsigned short *)(buf + 2 + hoff + skb->csum) =
+> csum_fold(
+> // kernel does conceptual header too
+> skb_copy_and_csum_bits(skb,
+> skb_mac_header(skb) + hoff - skb->data,
+> buf + 2 + hoff, len - hoff, 0));
+> #else
+897a943
+>
+904a951
+> #endif
+906a954,957
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> skb_copy_bits(skb,
+> skb_mac_header(skb) - skb->data, buf + 2, len);
+> #else
+908a960
+> #endif
+910a963
+> kfree(buf);
+912d964
+< kfree(buf);
+922a975,977
+> #if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,22)
+> hw_recv(hw, skb_mac_header(skb), skb->data - skb_mac_header(skb) + skb->len);
+> #else
+923a979
+> #endif
+1010a1067
+> #if WIRELESS_EXT < 19
+1012a1070
+> #endif
+--- data/drivers/drv_net/linux/prlnet.h
++++ data/drivers/drv_net/linux/prlnet.h
+6c6
+< // $Id: parallels-workstation-2.2.2112-2.6.23.patch,v 1.1 2008/02/07 15:43:50 cardoe Exp $
+---
+> // $Id: parallels-workstation-2.2.2112-2.6.23.patch,v 1.1 2008/02/07 15:43:50 cardoe Exp $
+Только в data/drivers/drv_net/linux: vm-bridge.mod.c
+--- data/drivers/drv_virtualnic/vmvirtualnic.c
++++ data/drivers/drv_virtualnic/vmvirtualnic.c
+72c72
+< MODULE_DESCRIPTION("Transparen ethernet bridge");
+---
+> MODULE_DESCRIPTION("Virtual ethernet card");
+75,77d74
+< // Version
+< //static const char *version = "VMVirtualNIC.c:v1.01 VirtualNIC driver from Parallels Inc. http://www.parallelssoft.com/";
+<
+79c76
+< struct net_device* dev;
+---
+> struct net_device* devs[5];
+99d95
+<
+101c97
+< };
+---
+> }
+121d116
+<
+123c118
+< };
+---
+> }
+201a197,203
+> int maxdev = 1;
+> #if defined(module_param)
+> module_param(maxdev, int, 0);
+> #elif defined(MODULE_PARM)
+> MODULE_PARM(maxdev, "i");
+> #endif
+>
+217,222c219,233
+< // MAC address is hardwired to that value as in windows version
+< unsigned char station_addr[6] = { 0x00, 0x01, 0x23, 0x45, 0xBE, 0xEF };
+< #if 0
+< hypervisorPresentInSystem(); /* fake call to hypervisor -- ms */
+< #endif
+<
+---
+> // MAC address is hardwired to that value as in windows version
+> static const unsigned char station_addr[5][6] = {
+> { 0x00, 0x01, 0x23, 0x45, 0xBE, 0xEF },
+> { 0x00, 0x01, 0x23, 0x45, 0xCA, 0xFE },
+> { 0x00, 0x01, 0x23, 0x45, 0xDA, 0xCE },
+> { 0x00, 0x01, 0x23, 0x45, 0xEC, 0xAE },
+> { 0x00, 0x01, 0x23, 0x45, 0xFA, 0xDE }
+> };
+> int i;
+>
+> if (maxdev < 0)
+> maxdev = 1;
+> if (maxdev > 5)
+> maxdev = 5;
+> for (i = 0; i < maxdev; ++i) {
+224c235
+< dev = alloc_etherdev(sizeof(struct net_device_stats));
+---
+> devs[i] = alloc_etherdev(sizeof(struct net_device_stats));
+226,229c237,239
+< dev = init_etherdev(0, 0);
+< // May be it needed ?
+< ether_setup(dev);
+< dev->priv = kmalloc(sizeof(struct net_device_stats), GFP_KERNEL);
+---
+> devs[i] = init_etherdev(0, 0);
+> ether_setup(devs[i]);
+> devs[i]->priv = kmalloc(sizeof(struct net_device_stats), GFP_KERNEL);
+232,242c242,252
+< dev_alloc_name(dev, "vnic%d");
+< // Set MAC address
+< memcpy(dev->dev_addr, station_addr, ETH_ALEN);
+< memset(dev->priv, 0, sizeof(struct net_device_stats));
+<
+< // Set functions
+< dev->hard_start_xmit = &VNICXmit;
+< dev->get_stats = &VNICGetStats;
+< dev->open = &VNICOpen;
+< dev->stop = &VNICClose;
+< dev->set_mac_address = &VNICSetMAC;
+---
+> dev_alloc_name(devs[i], "vnic%d");
+> // Set MAC address
+> memcpy(devs[i]->dev_addr, station_addr[i], ETH_ALEN);
+> memset(devs[i]->priv, 0, sizeof(struct net_device_stats));
+>
+> // Set functions
+> devs[i]->hard_start_xmit = VNICXmit;
+> devs[i]->get_stats = VNICGetStats;
+> devs[i]->open = VNICOpen;
+> devs[i]->stop = VNICClose;
+> devs[i]->set_mac_address = VNICSetMAC;
+244c254
+< SET_MODULE_OWNER(dev);
+---
+> SET_MODULE_OWNER(devs[i]);
+248c258
+< register_netdev(dev);
+---
+> register_netdev(devs[i]);
+250,252c260,262
+<
+< return(0);
+< };
+---
+> }
+> return 0;
+> }
+268a279
+> int i;
+270,272c281,283
+< if (dev)
+< {
+< ndstat = dev->priv;
+---
+> for (i = 0; i < 5; ++i) {
+> if (devs[i]) {
+> ndstat = devs[i]->priv;
+274c285
+< unregister_netdev(dev);
+---
+> unregister_netdev(devs[i]);
+276c287
+< free_netdev(dev);
+---
+> free_netdev(devs[i]);
+278,280c289,291
+< kfree(ndstat);
+< dev->priv = NULL;
+< kfree(dev);
+---
+> kfree(ndstat);
+> devs[i]->priv = NULL;
+> kfree(devs[i]);
+281a293,294
+> devs[i] = NULL;
+> }
+--- data/drivers/hypervisor/hypercall.h
++++ data/drivers/hypervisor/hypercall.h
+19,20c19,22
+< #ifndef __HYPERCALL_H__
+< #define __HYPERCALL_H__
+---
+>
+>
+> #ifndef __PRL_HYPERCALL_H__
+> #define __PRL_HYPERCALL_H__
+115,116c117
+<
+< #endif /* __HYPERCALL_H__ */
+---
+> #endif /* __PRL_HYPERCALL_H__ */
+--- data/drivers/hypervisor/hypervisor.h
++++ data/drivers/hypervisor/hypervisor.h
+19,20c19,20
+< #ifndef __HYPERVISOR_H__
+< #define __HYPERVISOR_H__
+---
+> #ifndef __PRL_HYPERVISOR_H__
+> #define __PRL_HYPERVISOR_H__
+33a34
+> # include "compat_memory.h"
+130c131
+< kmem_cache_t *vmStateCache;
+---
+> kmem_cache_compat *vmStateCache;
+177c178
+< #endif /* __HYPERVISOR_H__ */
+---
+> #endif /* __PRL_HYPERVISOR_H__ */
+--- data/drivers/hypervisor/hypvmstate.c
++++ data/drivers/hypervisor/hypvmstate.c
+24a25
+> #include "compat_memory.h"
+169c170
+< if (!(hypState.vmStateCache = kmem_cache_create(VMSTATE_SLABNAME, sizeof(struct hyp_vmstate_t), 0,
+---
+> if (!(hypState.vmStateCache = compat_kmem_cache_create(VMSTATE_SLABNAME, sizeof(struct hyp_vmstate_t), 0,
+--- data/drivers/hypervisor/svm_init.h
++++ data/drivers/hypervisor/svm_init.h
+34a35,38
+> /// Definitions of AMD CPUID function to get SVM revision and feature identification
+> #define CPUID_SVM_REV 0x8000000a
+>
+>
+37a42,48
+> /// Definition of bit SVM_LOCK in edx after CPUID_SVM_REV fn
+> #define SVM_LOCK (1 << 2)
+>
+> /// Definition of bit SVM Disabled in VM_CR SMR
+> #define VM_CR_SVMDIS (1 << 4)
+>
+>
+45a57,83
+> /// Definition of address of VM_CR SMR
+> #define SMR_VM_CR 0xc0010114
+>
+>
+>
+> /**
+> * Check CPU provider.
+> */
+> static __inline__ int is_amd()
+> {
+> unsigned int _ebx, _ecx, _edx;
+>
+> __asm__ __volatile__(
+> "cpuid \n\t"
+> : /* out */ "=b" (_ebx), "=c" (_ecx), "=d" (_edx)
+> : /* in */ "a" (0)
+> : /* clo */ "memory"
+> );
+>
+> // "AuthenticAMD"
+> if ((_ebx == 0x68747541) &&
+> (_ecx == 0x444D4163) &&
+> (_edx == 0x69746E65))
+> return 1;
+>
+> return 0;
+> }
+66,67c104,147
+< /* Check SVM bit in CPUID extended features */
+< return cpuid_ecx(CPUID_PROCESSOR_SIGNATURE) & CPUID_SVM;
+---
+> // Don't initialize this variables !!!
+> // because gcc on OSx remove all checks with this variables
+> // and we can get wrmsr on locked msr register (which cause GP#) -- ms
+> unsigned long msr_edx, msr_eax;
+> unsigned int cpuid_1_ecx;
+> unsigned int cpuid_2_edx;
+>
+>
+> if (!is_amd())
+> return 0;
+>
+> msr_edx = 0;
+> msr_eax = 0;
+>
+> // Check SVM bit in CPUID extended features
+> cpuid_1_ecx = cpuid_ecx(CPUID_PROCESSOR_SIGNATURE);
+>
+> cpuid_2_edx = 0;
+>
+> // Check SVM bit in CPUID feature indentifiers
+> if ((cpuid_1_ecx & CPUID_SVM) == 0)
+> return 0; // SVM not available
+>
+>
+> // Get VM_CR MSR value
+> rdmsr(SMR_VM_CR, msr_eax, msr_edx);
+>
+> if((msr_eax & VM_CR_SVMDIS) == 0)
+> {
+> // set EFER.SVME
+> rdmsr(MSR_IA32_EFER, msr_eax, msr_edx);
+> wrmsr(MSR_IA32_EFER, msr_eax | EFER_SVME, msr_edx);
+> return 1; // SVM allowed
+> }
+>
+> // CPUID SVM Revision and Feature Identification EDX
+> cpuid_2_edx = cpuid_edx(CPUID_SVM_REV);
+>
+> if((cpuid_2_edx & SVM_LOCK) == 0)
+> {
+> return 0; // SVM disabled at bios not unlockable
+> }
+>
+> return 0; // SVM disabled with key
+70a151
+>
+--- data/drivers/hypervisor/vtx_init.h
++++ data/drivers/hypervisor/vtx_init.h
+75a76,97
+> /**
+> * Check CPU provider.
+> */
+> static __inline__ int is_intelPW22()
+> {
+> unsigned int _ebx, _ecx, _edx;
+>
+> __asm__ __volatile__(
+> "cpuid \n\t"
+> : /* out */ "=b" (_ebx), "=c" (_ecx), "=d" (_edx)
+> : /* in */ "a" (0)
+> : /* clo */ "memory"
+> );
+>
+> // "GenuineIntel"
+> if ((_ebx == 0x756e6547) &&
+> (_ecx == 0x6c65746e) &&
+> (_edx == 0x49656e69))
+> return 1;
+>
+> return 0;
+> }
+96a119,121
+> if (!is_intelPW22())
+> return 0;
+>
+--- data/drivers/Makefile
++++ data/drivers/Makefile
+0a1
+> KSRC ?= /lib/modules/$(shell uname -r)/build
+5c6
+< cd drv_main/ && $(MAKE) && cd ..
+---
+> cd drv_main/ && $(MAKE) KSRC=${KSRC} && cd ..