mirror of
git://sourceware.org/git/lvm2.git
synced 2024-12-30 17:18:21 +03:00
lvcreate should close the initialised snapshot device immediately.
This commit is contained in:
parent
17823680fc
commit
ee8518bd9c
@ -406,11 +406,22 @@ static inline void _check_for_open_devices(void)
|
|||||||
|
|
||||||
void dev_cache_exit(void)
|
void dev_cache_exit(void)
|
||||||
{
|
{
|
||||||
|
if (_cache.names)
|
||||||
_check_for_open_devices();
|
_check_for_open_devices();
|
||||||
|
|
||||||
|
if (_cache.mem) {
|
||||||
pool_destroy(_cache.mem);
|
pool_destroy(_cache.mem);
|
||||||
if (_cache.names)
|
_cache.mem = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_cache.names) {
|
||||||
hash_destroy(_cache.names);
|
hash_destroy(_cache.names);
|
||||||
|
_cache.names = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
_cache.devices = NULL;
|
||||||
|
_cache.has_scanned = 0;
|
||||||
|
list_init(&_cache.dirs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int dev_cache_add_dir(const char *path)
|
int dev_cache_add_dir(const char *path)
|
||||||
|
@ -155,7 +155,7 @@ static int _aligned_io(struct device_area *where, void *buffer,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!block_size)
|
if (!block_size)
|
||||||
block_size = SECTOR_SIZE * 2;
|
block_size = getpagesize();
|
||||||
|
|
||||||
_widen_region(block_size, where, &widened);
|
_widen_region(block_size, where, &widened);
|
||||||
|
|
||||||
@ -353,7 +353,7 @@ static void _close(struct device *dev)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int dev_close(struct device *dev)
|
static int _dev_close(struct device *dev, int immediate)
|
||||||
{
|
{
|
||||||
if (dev->fd < 0) {
|
if (dev->fd < 0) {
|
||||||
log_error("Attempt to close device '%s' "
|
log_error("Attempt to close device '%s' "
|
||||||
@ -367,12 +367,22 @@ int dev_close(struct device *dev)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* FIXME lookup device in cache to get vgname and see if it's locked? */
|
/* FIXME lookup device in cache to get vgname and see if it's locked? */
|
||||||
if (--dev->open_count < 1 && !vgs_locked())
|
if (--dev->open_count < 1 && (immediate || !vgs_locked()))
|
||||||
_close(dev);
|
_close(dev);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int dev_close(struct device *dev)
|
||||||
|
{
|
||||||
|
return _dev_close(dev, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int dev_close_immediate(struct device *dev)
|
||||||
|
{
|
||||||
|
return _dev_close(dev, 1);
|
||||||
|
}
|
||||||
|
|
||||||
void dev_close_all(void)
|
void dev_close_all(void)
|
||||||
{
|
{
|
||||||
struct list *doh, *doht;
|
struct list *doh, *doht;
|
||||||
|
@ -54,6 +54,7 @@ int dev_open(struct device *dev);
|
|||||||
int dev_open_quiet(struct device *dev);
|
int dev_open_quiet(struct device *dev);
|
||||||
int dev_open_flags(struct device *dev, int flags, int append, int quiet);
|
int dev_open_flags(struct device *dev, int flags, int append, int quiet);
|
||||||
int dev_close(struct device *dev);
|
int dev_close(struct device *dev);
|
||||||
|
int dev_close_immediate(struct device *dev);
|
||||||
void dev_close_all(void);
|
void dev_close_all(void);
|
||||||
|
|
||||||
static inline int dev_fd(struct device *dev)
|
static inline int dev_fd(struct device *dev)
|
||||||
|
@ -347,7 +347,7 @@ static int _zero_lv(struct cmd_context *cmd, struct logical_volume *lv)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
dev_zero(dev, UINT64_C(0), (size_t) 4096);
|
dev_zero(dev, UINT64_C(0), (size_t) 4096);
|
||||||
dev_close(dev);
|
dev_close_immediate(dev);
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user