spice/server/migration_protocol.h
Yonit Halperin 70f820ded2 seamless-migration: add migration_protocol.h
The file will hold the declarations of the different migration
data messages (depending on the channel), that will be passed
from the src server to the dst server, via the client, using
SPICE_MSG_MIGRATE_DATA.
2012-08-27 09:04:52 +03:00

50 lines
1.7 KiB
C

/*
Copyright (C) 2012 Red Hat, Inc.
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _H_MIGRATION_PROTOCOL
#define _H_MIGRATION_PROTOCOL
/* ************************************************
* src-server to dst-server migration data messages
* ************************************************/
/* increase the version when the version of any
* of the migration data messages is increased */
#define SPICE_MIGRATION_PROTOCOL_VERSION ~0
typedef struct __attribute__ ((__packed__)) SpiceMigrateDataHeader {
uint32_t magic;
uint32_t version;
} SpiceMigrateDataHeader;
static inline int migration_protocol_validate_header(SpiceMigrateDataHeader *header,
uint32_t magic,
uint32_t version)
{
if (header->magic != magic) {
spice_error("bad magic %u (!= %u)", header->magic, magic);
return FALSE;
}
if (header->version > version) {
spice_error("unsupported version %u (> %u)", header->version, version);
return FALSE;
}
return TRUE;
}
#endif