mirror of
https://github.com/TREX-CoE/trexio.git
synced 2025-01-08 20:33:36 +01:00
use strncpy instead of strcpy to avoid possible buffer overflows
This commit is contained in:
parent
c56bc49ddd
commit
1b0a60f2fe
@ -27,8 +27,8 @@ module trexio
|
|||||||
|
|
||||||
#+begin_src c :tangle prefix_front.h :noweb yes
|
#+begin_src c :tangle prefix_front.h :noweb yes
|
||||||
<<header>>
|
<<header>>
|
||||||
#ifndef _TREXIO_H
|
#ifndef TREXIO_H
|
||||||
#define _TREXIO_H
|
#define TREXIO_H
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
@ -228,8 +228,8 @@ trexio_t* trexio_open(const char* file_name, const char mode, const back_end_t b
|
|||||||
|
|
||||||
/* Data for the parent type */
|
/* Data for the parent type */
|
||||||
|
|
||||||
result->file_name = (char*) calloc(strlen(file_name)+1,sizeof(char));
|
result->file_name = CALLOC(strlen(file_name)+1, char);
|
||||||
strcpy(result->file_name, file_name);
|
strncpy(result->file_name, file_name, strlen(file_name)+1);
|
||||||
result->back_end = back_end;
|
result->back_end = back_end;
|
||||||
result->mode = mode;
|
result->mode = mode;
|
||||||
int irc = pthread_mutex_init ( &(result->thread_lock), NULL);
|
int irc = pthread_mutex_init ( &(result->thread_lock), NULL);
|
||||||
|
@ -14,10 +14,11 @@
|
|||||||
|
|
||||||
#+begin_src c :tangle prefix_hdf5.h :noweb yes
|
#+begin_src c :tangle prefix_hdf5.h :noweb yes
|
||||||
<<header>>
|
<<header>>
|
||||||
#ifndef _TREXIO_HDF5_H
|
#ifndef TREXIO_HDF5_H
|
||||||
#define _TREXIO_HDF5_H
|
#define TREXIO_HDF5_H
|
||||||
|
|
||||||
#include "trexio.h"
|
#include "trexio.h"
|
||||||
|
#include "trexio_private.h"
|
||||||
#include "trexio_s.h"
|
#include "trexio_s.h"
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
@ -272,7 +273,7 @@ trexio_exit_code trexio_hdf5_read_$group$_$group_dset$(const trexio_t* file, $gr
|
|||||||
if (dset_id <= 0) return TREXIO_INVALID_ID;
|
if (dset_id <= 0) return TREXIO_INVALID_ID;
|
||||||
|
|
||||||
// allocate space for the dimensions to be read
|
// allocate space for the dimensions to be read
|
||||||
hsize_t* ddims = (hsize_t*) calloc( (int) rank, sizeof(hsize_t));
|
hsize_t* ddims = CALLOC( (int) rank, hsize_t);
|
||||||
if (ddims == NULL) return TREXIO_FAILURE;
|
if (ddims == NULL) return TREXIO_FAILURE;
|
||||||
|
|
||||||
// read dimensions from the existing dataset
|
// read dimensions from the existing dataset
|
||||||
|
@ -29,8 +29,8 @@
|
|||||||
|
|
||||||
#+begin_src c :tangle prefix_text.h :noweb yes
|
#+begin_src c :tangle prefix_text.h :noweb yes
|
||||||
<<header>>
|
<<header>>
|
||||||
#ifndef _TREXIO_TEXT_H
|
#ifndef TREXIO_TEXT_H
|
||||||
#define _TREXIO_TEXT_H
|
#define TREXIO_TEXT_H
|
||||||
|
|
||||||
#include "trexio.h"
|
#include "trexio.h"
|
||||||
#include "trexio_private.h"
|
#include "trexio_private.h"
|
||||||
@ -139,14 +139,15 @@ trexio_exit_code trexio_text_init(trexio_t* file) {
|
|||||||
|
|
||||||
/* Create the lock file in the directory */
|
/* Create the lock file in the directory */
|
||||||
const char* lock_file_name = "/.lock";
|
const char* lock_file_name = "/.lock";
|
||||||
char* file_name =
|
|
||||||
CALLOC(strlen(file->file_name) + strlen(lock_file_name) + 1, char);
|
size_t str_size = strlen(file->file_name) + strlen(lock_file_name) + 1;
|
||||||
|
char* file_name = CALLOC(str_size, char);
|
||||||
|
|
||||||
if (file_name == NULL) {
|
if (file_name == NULL) {
|
||||||
return TREXIO_ALLOCATION_FAILED;
|
return TREXIO_ALLOCATION_FAILED;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy (file_name, file->file_name);
|
strncpy (file_name, file->file_name, str_size);
|
||||||
strcat (file_name, lock_file_name);
|
strcat (file_name, lock_file_name);
|
||||||
|
|
||||||
f->lock_file = open(file_name,O_WRONLY|O_CREAT|O_TRUNC, 0644);
|
f->lock_file = open(file_name,O_WRONLY|O_CREAT|O_TRUNC, 0644);
|
||||||
@ -259,16 +260,15 @@ $group$_t* trexio_text_read_$group$(trexio_text_t* file) {
|
|||||||
|
|
||||||
/* Build the file name */
|
/* Build the file name */
|
||||||
const char* $group$_file_name = "/$group$.txt";
|
const char* $group$_file_name = "/$group$.txt";
|
||||||
char * file_name = (char*)
|
size_t str_size = strlen(file->parent.file_name) + strlen($group$_file_name) + 1;
|
||||||
calloc( strlen(file->parent.file_name) + strlen($group$_file_name) + 1,
|
char * file_name = CALLOC(str_size, char);
|
||||||
sizeof(char));
|
|
||||||
|
|
||||||
if (file_name == NULL) {
|
if (file_name == NULL) {
|
||||||
FREE($group$);
|
FREE($group$);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcpy (file_name, file->parent.file_name);
|
strncpy (file_name, file->parent.file_name, str_size);
|
||||||
strcat (file_name, $group$_file_name);
|
strcat (file_name, $group$_file_name);
|
||||||
|
|
||||||
/* If the file exists, read it */
|
/* If the file exists, read it */
|
||||||
@ -280,7 +280,7 @@ $group$_t* trexio_text_read_$group$(trexio_text_t* file) {
|
|||||||
size_t sz = ftell(f);
|
size_t sz = ftell(f);
|
||||||
fseek(f, 0L, SEEK_SET);
|
fseek(f, 0L, SEEK_SET);
|
||||||
|
|
||||||
char* buffer = CALLOC(sz,char);
|
char* buffer = CALLOC(sz, char);
|
||||||
if (buffer == NULL) {
|
if (buffer == NULL) {
|
||||||
FREE(file_name);
|
FREE(file_name);
|
||||||
fclose(f);
|
fclose(f);
|
||||||
@ -370,7 +370,7 @@ $group$_t* trexio_text_read_$group$(trexio_text_t* file) {
|
|||||||
// START REPEAT GROUP_DSET
|
// START REPEAT GROUP_DSET
|
||||||
|
|
||||||
/* Allocate arrays */
|
/* Allocate arrays */
|
||||||
$group$->$group_dset$ = ($group_dset_dtype$*) calloc(size_$group_dset$, sizeof($group_dset_dtype$));
|
$group$->$group_dset$ = CALLOC(size_$group_dset$, $group_dset_dtype$);
|
||||||
assert (!($group$->$group_dset$ == NULL));
|
assert (!($group$->$group_dset$ == NULL));
|
||||||
if ($group$->$group_dset$ == NULL) {
|
if ($group$->$group_dset$ == NULL) {
|
||||||
FREE(buffer);
|
FREE(buffer);
|
||||||
@ -632,7 +632,7 @@ trexio_exit_code trexio_text_write_$group_dset$(const trexio_t* file, const $gro
|
|||||||
dim_size *= dims[i];
|
dim_size *= dims[i];
|
||||||
}
|
}
|
||||||
|
|
||||||
$group$->$group_dset$ = ($group_dset_dtype$*) calloc(dim_size, sizeof($group_dset_dtype$));
|
$group$->$group_dset$ = CALLOC(dim_size, $group_dset_dtype$);
|
||||||
|
|
||||||
for (uint64_t i=0 ; i<dim_size ; i++) {
|
for (uint64_t i=0 ; i<dim_size ; i++) {
|
||||||
$group$->$group_dset$[i] = $group_dset$[i];
|
$group$->$group_dset$[i] = $group_dset$[i];
|
||||||
@ -668,11 +668,11 @@ rdm_t* trexio_text_read_rdm(trexio_text_t* file) {
|
|||||||
|
|
||||||
/* Try to open the file. If the file does not exist, return */
|
/* Try to open the file. If the file does not exist, return */
|
||||||
const char* rdm_file_name = "/rdm.txt";
|
const char* rdm_file_name = "/rdm.txt";
|
||||||
char * file_name = (char*)
|
size_t str_size = strlen(file->parent.file_name) + strlen(rdm_file_name) + 1;
|
||||||
calloc( strlen(file->parent.file_name) + strlen(rdm_file_name) + 1,
|
char * file_name = CALLOC(str_size, char);
|
||||||
sizeof(char));
|
|
||||||
assert (file_name != NULL);
|
assert (file_name != NULL);
|
||||||
strcpy (file_name, file->parent.file_name);
|
strncpy (file_name, file->parent.file_name, str_size);
|
||||||
strcat (file_name, rdm_file_name);
|
strcat (file_name, rdm_file_name);
|
||||||
|
|
||||||
/* If the file exists, read it */
|
/* If the file exists, read it */
|
||||||
@ -683,7 +683,7 @@ rdm_t* trexio_text_read_rdm(trexio_text_t* file) {
|
|||||||
fseek(f, 0L, SEEK_END);
|
fseek(f, 0L, SEEK_END);
|
||||||
size_t sz = ftell(f);
|
size_t sz = ftell(f);
|
||||||
fseek(f, 0L, SEEK_SET);
|
fseek(f, 0L, SEEK_SET);
|
||||||
char* buffer = CALLOC(sz,char);
|
char* buffer = CALLOC(sz, char);
|
||||||
|
|
||||||
/* Read the dimensioning variables */
|
/* Read the dimensioning variables */
|
||||||
int rc;
|
int rc;
|
||||||
@ -695,7 +695,7 @@ rdm_t* trexio_text_read_rdm(trexio_text_t* file) {
|
|||||||
assert (rc == 1);
|
assert (rc == 1);
|
||||||
|
|
||||||
/* Allocate arrays */
|
/* Allocate arrays */
|
||||||
rdm->one_e = (double*) calloc(rdm->dim_one_e, sizeof(double));
|
rdm->one_e = CALLOC(rdm->dim_one_e, double);
|
||||||
assert (rdm->one_e != NULL);
|
assert (rdm->one_e != NULL);
|
||||||
|
|
||||||
/* Read one_e */
|
/* Read one_e */
|
||||||
@ -715,8 +715,9 @@ rdm_t* trexio_text_read_rdm(trexio_text_t* file) {
|
|||||||
|
|
||||||
rc = fscanf(f, "%s", buffer);
|
rc = fscanf(f, "%s", buffer);
|
||||||
assert (rc == 1);
|
assert (rc == 1);
|
||||||
rdm->two_e_file_name = CALLOC (strlen(buffer),char);
|
size_t str_size = strlen(buffer);
|
||||||
strcpy(rdm->two_e_file_name, buffer);
|
rdm->two_e_file_name = CALLOC(str_size,char);
|
||||||
|
strncpy(rdm->two_e_file_name, buffer, str_size);
|
||||||
|
|
||||||
FREE(buffer);
|
FREE(buffer);
|
||||||
fclose(f);
|
fclose(f);
|
||||||
|
Loading…
Reference in New Issue
Block a user