Annotation of qemu/hw/vmport.c, revision 1.1.1.6

1.1       root        1: /*
                      2:  * QEMU VMPort emulation
                      3:  *
1.1.1.6 ! root        4:  * Copyright (C) 2007 HervĂ© Poussineau
1.1       root        5:  *
                      6:  * Permission is hereby granted, free of charge, to any person obtaining a copy
                      7:  * of this software and associated documentation files (the "Software"), to deal
                      8:  * in the Software without restriction, including without limitation the rights
                      9:  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
                     10:  * copies of the Software, and to permit persons to whom the Software is
                     11:  * furnished to do so, subject to the following conditions:
                     12:  *
                     13:  * The above copyright notice and this permission notice shall be included in
                     14:  * all copies or substantial portions of the Software.
                     15:  *
                     16:  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
                     17:  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
                     18:  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
                     19:  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
                     20:  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
                     21:  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
                     22:  * THE SOFTWARE.
                     23:  */
                     24: #include "hw.h"
                     25: #include "isa.h"
                     26: #include "pc.h"
1.1.1.3   root       27: #include "kvm.h"
1.1.1.4   root       28: #include "qdev.h"
1.1       root       29: 
1.1.1.2   root       30: //#define VMPORT_DEBUG
                     31: 
1.1       root       32: #define VMPORT_CMD_GETVERSION 0x0a
                     33: #define VMPORT_CMD_GETRAMSIZE 0x14
                     34: 
                     35: #define VMPORT_ENTRIES 0x2c
                     36: #define VMPORT_MAGIC   0x564D5868
                     37: 
                     38: typedef struct _VMPortState
                     39: {
1.1.1.4   root       40:     ISADevice dev;
1.1.1.5   root       41:     MemoryRegion io;
1.1       root       42:     IOPortReadFunc *func[VMPORT_ENTRIES];
                     43:     void *opaque[VMPORT_ENTRIES];
                     44: } VMPortState;
                     45: 
1.1.1.4   root       46: static VMPortState *port_state;
1.1       root       47: 
                     48: void vmport_register(unsigned char command, IOPortReadFunc *func, void *opaque)
                     49: {
                     50:     if (command >= VMPORT_ENTRIES)
                     51:         return;
                     52: 
1.1.1.4   root       53:     port_state->func[command] = func;
                     54:     port_state->opaque[command] = opaque;
1.1       root       55: }
                     56: 
                     57: static uint32_t vmport_ioport_read(void *opaque, uint32_t addr)
                     58: {
                     59:     VMPortState *s = opaque;
1.1.1.6 ! root       60:     CPUX86State *env = cpu_single_env;
1.1       root       61:     unsigned char command;
                     62:     uint32_t eax;
                     63: 
1.1.1.3   root       64:     cpu_synchronize_state(env);
                     65: 
1.1.1.2   root       66:     eax = env->regs[R_EAX];
1.1       root       67:     if (eax != VMPORT_MAGIC)
                     68:         return eax;
                     69: 
1.1.1.2   root       70:     command = env->regs[R_ECX];
1.1       root       71:     if (command >= VMPORT_ENTRIES)
                     72:         return eax;
                     73:     if (!s->func[command])
                     74:     {
1.1.1.2   root       75: #ifdef VMPORT_DEBUG
                     76:         fprintf(stderr, "vmport: unknown command %x\n", command);
                     77: #endif
1.1       root       78:         return eax;
                     79:     }
                     80: 
                     81:     return s->func[command](s->opaque[command], addr);
                     82: }
                     83: 
1.1.1.2   root       84: static void vmport_ioport_write(void *opaque, uint32_t addr, uint32_t val)
                     85: {
1.1.1.6 ! root       86:     CPUX86State *env = cpu_single_env;
1.1.1.2   root       87: 
                     88:     env->regs[R_EAX] = vmport_ioport_read(opaque, addr);
                     89: }
                     90: 
1.1       root       91: static uint32_t vmport_cmd_get_version(void *opaque, uint32_t addr)
                     92: {
1.1.1.6 ! root       93:     CPUX86State *env = cpu_single_env;
1.1       root       94:     env->regs[R_EBX] = VMPORT_MAGIC;
                     95:     return 6;
                     96: }
                     97: 
                     98: static uint32_t vmport_cmd_ram_size(void *opaque, uint32_t addr)
                     99: {
1.1.1.6 ! root      100:     CPUX86State *env = cpu_single_env;
1.1       root      101:     env->regs[R_EBX] = 0x1177;
                    102:     return ram_size;
                    103: }
                    104: 
1.1.1.4   root      105: /* vmmouse helpers */
                    106: void vmmouse_get_data(uint32_t *data)
1.1       root      107: {
1.1.1.6 ! root      108:     CPUX86State *env = cpu_single_env;
1.1.1.4   root      109: 
                    110:     data[0] = env->regs[R_EAX]; data[1] = env->regs[R_EBX];
                    111:     data[2] = env->regs[R_ECX]; data[3] = env->regs[R_EDX];
                    112:     data[4] = env->regs[R_ESI]; data[5] = env->regs[R_EDI];
                    113: }
                    114: 
                    115: void vmmouse_set_data(const uint32_t *data)
                    116: {
1.1.1.6 ! root      117:     CPUX86State *env = cpu_single_env;
1.1.1.4   root      118: 
                    119:     env->regs[R_EAX] = data[0]; env->regs[R_EBX] = data[1];
                    120:     env->regs[R_ECX] = data[2]; env->regs[R_EDX] = data[3];
                    121:     env->regs[R_ESI] = data[4]; env->regs[R_EDI] = data[5];
                    122: }
                    123: 
1.1.1.5   root      124: static const MemoryRegionPortio vmport_portio[] = {
                    125:     {0, 1, 4, .read = vmport_ioport_read, .write = vmport_ioport_write },
                    126:     PORTIO_END_OF_LIST(),
                    127: };
                    128: 
                    129: static const MemoryRegionOps vmport_ops = {
                    130:     .old_portio = vmport_portio
                    131: };
                    132: 
1.1.1.4   root      133: static int vmport_initfn(ISADevice *dev)
                    134: {
                    135:     VMPortState *s = DO_UPCAST(VMPortState, dev, dev);
1.1       root      136: 
1.1.1.5   root      137:     memory_region_init_io(&s->io, &vmport_ops, s, "vmport", 1);
                    138:     isa_register_ioport(dev, &s->io, 0x5658);
                    139: 
1.1.1.4   root      140:     port_state = s;
1.1       root      141:     /* Register some generic port commands */
1.1.1.2   root      142:     vmport_register(VMPORT_CMD_GETVERSION, vmport_cmd_get_version, NULL);
                    143:     vmport_register(VMPORT_CMD_GETRAMSIZE, vmport_cmd_ram_size, NULL);
1.1.1.4   root      144:     return 0;
                    145: }
                    146: 
1.1.1.6 ! root      147: static void vmport_class_initfn(ObjectClass *klass, void *data)
        !           148: {
        !           149:     DeviceClass *dc = DEVICE_CLASS(klass);
        !           150:     ISADeviceClass *ic = ISA_DEVICE_CLASS(klass);
        !           151:     ic->init = vmport_initfn;
        !           152:     dc->no_user = 1;
        !           153: }
        !           154: 
        !           155: static TypeInfo vmport_info = {
        !           156:     .name          = "vmport",
        !           157:     .parent        = TYPE_ISA_DEVICE,
        !           158:     .instance_size = sizeof(VMPortState),
        !           159:     .class_init    = vmport_class_initfn,
1.1.1.4   root      160: };
                    161: 
1.1.1.6 ! root      162: static void vmport_register_types(void)
1.1.1.4   root      163: {
1.1.1.6 ! root      164:     type_register_static(&vmport_info);
1.1       root      165: }
1.1.1.6 ! root      166: 
        !           167: type_init(vmport_register_types)

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.