These could lead to undefined behaviour if e.g. a negative value from ftell was used to allocate memory. Also store result of ftell in a long; The result may previously have been truncated on some platforms