init_syslog(LOG_DAEMON);
openlog("clvmd", LOG_PID, LOG_DAEMON);
- if (!(cmd = create_toolcontext(1, NULL))) {
+ if (!(cmd = create_toolcontext(1, NULL, 0))) {
log_error("Failed to allocate command context");
return 0;
}
# include <malloc.h>
#endif
+static const size_t linebuffer_size = 4096;
+
static int _get_env_vars(struct cmd_context *cmd)
{
const char *e;
/* Entry point */
struct cmd_context *create_toolcontext(unsigned is_long_lived,
- const char *system_dir)
+ const char *system_dir,
+ unsigned set_buffering)
{
struct cmd_context *cmd;
/* FIXME Make this configurable? */
reset_lvm_errno(1);
+ /* Set in/out stream buffering before glibc */
+ if (set_buffering) {
+ /* Allocate 2 buffers */
+ if (!(cmd->linebuffer = dm_malloc(2 * linebuffer_size))) {
+ log_error("Failed to allocate line buffer.");
+ goto out;
+ }
+ if ((setvbuf(stdin, cmd->linebuffer, _IOLBF, linebuffer_size) ||
+ setvbuf(stdout, cmd->linebuffer + linebuffer_size,
+ _IOLBF, linebuffer_size))) {
+ log_sys_error("setvbuf", "");
+ goto out;
+ }
+ /* Buffers are used for lines without '\n' */
+ }
+
/*
* Environment variable LVM_SYSTEM_DIR overrides this below.
*/
_destroy_tag_configs(cmd);
if (cmd->libmem)
dm_pool_destroy(cmd->libmem);
+
+ if (cmd->linebuffer) {
+ /* Reset stream buffering to defaults */
+ setlinebuf(stdin);
+ fflush(stdout);
+ setlinebuf(stdout);
+ dm_free(cmd->linebuffer);
+ }
+
dm_free(cmd);
release_log_memory();
const char *kernel_vsn;
unsigned rand_seed;
+ char *linebuffer;
const char *cmd_line;
struct command *command;
char **argv;
* The environment variable LVM_SYSTEM_DIR always takes precedence.
*/
struct cmd_context *create_toolcontext(unsigned is_long_lived,
- const char *system_dir);
+ const char *system_dir,
+ unsigned set_buffering);
void destroy_toolcontext(struct cmd_context *cmd);
int refresh_toolcontext(struct cmd_context *cmd);
int refresh_filters(struct cmd_context *cmd);
/* create context */
/* FIXME: split create_toolcontext */
/* FIXME: make all globals configurable */
- cmd = create_toolcontext(0, system_dir);
+ cmd = create_toolcontext(0, system_dir, 1);
if (!cmd)
return NULL;
if (!udev_init_library_context())
stack;
- if (!(cmd = create_toolcontext(0, NULL)))
+ if (!(cmd = create_toolcontext(0, NULL, 1)))
return_NULL;
_cmdline.arg_props = &_arg_props[0];