X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Fmachine-image.h;h=bf41b2e78596d0dcea2009b52363db8ae654e7f4;hb=17384d7f95169dad5f769431374fc2c08101206d;hp=10e5d0a533e50320b19ce6ff8cbce865ad6dacc0;hpb=b6b1849830f5e4a6065c3b0c993668e500c954d3;p=elogind.git diff --git a/src/shared/machine-image.h b/src/shared/machine-image.h index 10e5d0a53..bf41b2e78 100644 --- a/src/shared/machine-image.h +++ b/src/shared/machine-image.h @@ -27,7 +27,7 @@ typedef enum ImageType { IMAGE_DIRECTORY, IMAGE_SUBVOLUME, - IMAGE_GPT, + IMAGE_RAW, _IMAGE_TYPE_MAX, _IMAGE_TYPE_INVALID = -1 } ImageType; @@ -41,10 +41,12 @@ typedef struct Image { usec_t crtime; usec_t mtime; - uint64_t size; - uint64_t size_exclusive; + uint64_t usage; + uint64_t usage_exclusive; uint64_t limit; uint64_t limit_exclusive; + + void *userdata; } Image; Image *image_unref(Image *i); @@ -63,3 +65,10 @@ int image_read_only(Image *i, bool b); const char* image_type_to_string(ImageType t) _const_; ImageType image_type_from_string(const char *s) _pure_; + +bool image_name_is_valid(const char *s) _pure_; + +int image_path_lock(const char *path, int operation, LockFile *global, LockFile *local); +int image_name_lock(const char *name, int operation, LockFile *ret); + +int image_set_limit(Image *i, uint64_t referenced_max);