проблема в варианте команды копирования с использованием mmap () - PullRequest
0 голосов
/ 05 апреля 2020

У меня есть программа, которая является еще одним вариантом программы копирования в linux (На самом деле я использую Ma c OSX). Чтобы поддержать копирование больших файлов, я написал что-то вроде этого:

#include <stdio.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/time.h>
#include <sys/mman.h>
#define BUFFSIZE 65535
#define PAGESIZE 4096
int main(int argc, char **argv){
  char *source, *destination;
  int src_fd, dst_fd;
  unsigned long long bytes_read;
  int bytes = BUFFSIZE;
  struct timeval start, end;
  int overall_time = 0;
  unsigned long long offset = 0;
  struct stat statbuf;
  if(argc < 3){
    printf("copy <source> <destination>\n");
    exit(EXIT_FAILURE);
  }
source = argv[1];
  destination = argv[2];

  src_fd = open(source, O_RDONLY, 0777);
  if(src_fd < 0){
    perror("src_fd");
    exit(EXIT_FAILURE);
  }
  //bytes_read = lseek(src_fd, 0, SEEK_END);
  fstat(src_fd, &statbuf);
  bytes_read = statbuf.st_size;
  dst_fd = open(destination, O_RDWR | O_CREAT, 0777);
  if(dst_fd < 0){
    perror("dst_fd");
    exit(EXIT_FAILURE);
  }
  lseek(dst_fd, bytes_read -1, SEEK_SET);
  write(dst_fd, "", 1);

  gettimeofday(&start, NULL);
  while(bytes_read > 0){
    if(bytes_read < BUFFSIZE){
      bytes = bytes_read;
      bytes_read = 0;
    }
    else{
      bytes_read -= bytes;
    }
    void *src_map = mmap(NULL, bytes, PROT_READ, MAP_SHARED, src_fd, (off_t)offset);
    if(src_map == (void*) MAP_FAILED){
      perror("src_map");
      exit(EXIT_FAILURE);
    }

    void *dst_map = mmap(NULL, bytes, PROT_WRITE, MAP_SHARED, dst_fd, (off_t)offset);
    if(dst_map == (void*) MAP_FAILED){
      perror("dst_map");
      exit(EXIT_FAILURE);
    }

    memcpy(dst_map, src_map, bytes);

    int src_unmp = munmap(src_map, bytes);
    if(src_unmp == -1){
      perror("src_unmap");
      exit(EXIT_FAILURE);
    }
    int dst_unmp = munmap(dst_map, bytes);
    if(dst_unmp == -1){
      perror("dst_unmap");
      exit(EXIT_FAILURE);
    }
    offset += 4096;
    bytes_read -= bytes;
  }
  gettimeofday(&end, NULL);
  printf("overall = %d\n", (end.tv_usec - start.tv_usec));
  close(src_fd);
  close(dst_fd);
  return 0;
}

Цель состоит в том, чтобы измерить количество времени, затраченное на копирование большого файла, с помощью mmap ().

Приведенный выше код не работает для передачи файла объемом 1 ГБ.

Есть какие-нибудь подсказки для этого?

Спасибо

1 Ответ

1 голос
/ 05 апреля 2020

Да. Проблема в величине смещения. Значение смещения должно быть кратным размеру страницы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...