diff --git a/[refs] b/[refs] index 12b0f9be8f26..2c6352aa7b36 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 15853af9f07673680439b224519c692f1352b959 +refs/heads/master: be56123568072d223263a6a70a087d1e7faabb83 diff --git a/trunk/block/elevator.c b/trunk/block/elevator.c index 73aa46b6db49..cacfff7418e4 100644 --- a/trunk/block/elevator.c +++ b/trunk/block/elevator.c @@ -762,13 +762,15 @@ static void elevator_switch(request_queue_t *q, struct elevator_type *new_e) ssize_t elv_iosched_store(request_queue_t *q, const char *name, size_t count) { char elevator_name[ELV_NAME_MAX]; + size_t len; struct elevator_type *e; - memset(elevator_name, 0, sizeof(elevator_name)); - strncpy(elevator_name, name, sizeof(elevator_name)); + elevator_name[sizeof(elevator_name) - 1] = '\0'; + strncpy(elevator_name, name, sizeof(elevator_name) - 1); + len = strlen(elevator_name); - if (elevator_name[strlen(elevator_name) - 1] == '\n') - elevator_name[strlen(elevator_name) - 1] = '\0'; + if (len && elevator_name[len - 1] == '\n') + elevator_name[len - 1] = '\0'; e = elevator_get(elevator_name); if (!e) {