Date: Mon, 26 Jan 2009 14:04:27 +0100 From: Lukasz Jaroszewski <lvj@nietykalni.org> To: Christoph Mallon <christoph.mallon@gmx.de> Cc: freebsd-hackers@freebsd.org, Hans Petter Selasky <hselasky@c2i.net> Subject: Re: write(2) to /dev/ad4 = EINVAL Message-ID: <3930e0780901260504m44f43958m82f2ba8902558906@mail.gmail.com> In-Reply-To: <497D9116.1040408@gmx.de> References: <3930e0780901260135j1428e77fmfe7392770fcd31fc@mail.gmail.com> <200901261109.43376.hselasky@c2i.net> <3930e0780901260224ye4acbabx7a629ec8da195138@mail.gmail.com> <497D9116.1040408@gmx.de>
next in thread | previous in thread | raw e-mail | index | archive | help
2009/1/26 Christoph Mallon <christoph.mallon@gmx.de>:
> Lukasz Jaroszewski schrieb:
>>
>> 2009/1/26 Hans Petter Selasky <hselasky@c2i.net>:
>>>
>>> On Monday 26 January 2009, Lukasz Jaroszewski wrote:
>>>>
>>>> Hi,
>>>> after opening /dev/ad4 with success for O_RDWR, I am getting [EINVAL]
>>>> from write(2), which according to man 2 write, means
>>>> `` [EINVAL] The pointer associated with d was
>>>> negative.'', as you can see below it is not true, I have tried
>>>> different block sizes, with same result.
>>>>
>>>> How can I write one byte to /dev/adN ?
>>>
>>> Hi,
>>>
>>> You cannot write one byte to /dev/adN, I think. Harddisks are block
>>> based.
>>> Please see:
>>>
>>> diskinfo -v ad4
>>>
>>> And especially the "sector size". When you seek and transfer data the
>>> offset
>>> and length must be a factor of the "sector size" or "block size". See
>>> also
>>> LBA, logical block address.
>>
>>
>> Yes, I have tried with bs=512 and multiplies, no luck.
>>
>> root@~(0) diskinfo -v ad4
>> ad4
>> 512 # sectorsize
>> 2029805568 # mediasize in bytes (1.9G)
>> 3964464 # mediasize in sectors
>> 3933 # Cylinders according to firmware.
>> 16 # Heads according to firmware.
>> 63 # Sectors according to firmware.
>> ad:CFx20CARDx200000190C # Disk ident.
>
> It would be helpful, if you showed the actual code, instead of letting us
> guess what you are doing.
Ok, I solved that, I were trying to dd with bs correctly set, tho
if=./s wasn't big enough plus I had code like below, where I didn't
check write for errors, just called perror, which gave me wrong errno.
So to change one byte, I need to read it, change it, and write it in
512 chunks? or play with kernel and add smth like ``write_byte'' to
ata?
I am sorry for bothering with my silly errors.
<includes>
#define S 0x200
int
main(int argc, char **argv){
int fd,i=0;
char *s;
s = malloc(S);
for(i=0;i<S;i++)
s[i] = 'B';
if((fd = open("/dev/ad4",
O_RDWR|O_CREAT|O_TRUNC,S_IRUSR|S_IWUSR|S_IRGRP|S_IWGRP|S_IROTH|S_IWOTH))==-1)
perror("open(2)");
lseek(fd, 0, SEEK_SET);
write(fd, s,S);
perror("write");
close(fd);
return 0;
}
Best Regards
Lukasz
>
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3930e0780901260504m44f43958m82f2ba8902558906>
