Hi, Monday, May 21, 2007, 3:57:56 PM, you wrote: TR> Hi, TR> Monday, May 21, 2007, 10:50:27 AM, you wrote: JV>> While I'm sure this is a stupid question and the solution will be JV>> obvious to everyone here, this is confusing me. JV>> I'm trying to control a device over a serial port using a PHP script, JV>> and one of the things I need to do is read a 26-byte string from an JV>> EEPROM, using a command that returns two bytes at a time, and write JV>> similar strings using a similar command. For example, to read the first JV>> two bytes of one such string beginning at address 0x484, I would send: JV>> 04 84 00 00 BB JV>> Here's the code I've written so far: JV>> $string = 1; //which of 200 strings I want to read JV>> $base = pack("H*",dechex((($string-1)*hexdec(0x1a))+hexdec(0x484))); JV>> //calculate the base address of the string (the first starts at 0x484) JV>> for($i=0;$i < 13;$i++) { //iterate 13 times (26 bytes / 2 bytes at a time) JV>> dio_write($serial,$base."\x00\x00\xbb",5); //send the command JV>> $output[] = dio_read($serial,1); // read first byte JV>> $output[] = dio_read($serial,1); // read second byte JV>> $base = pack("H*",dechex(hexdec(bin2hex($base))+2)); //increment address JV>> } JV>> There are two things wrong with this. First, the final line isn't doing JV>> what it's supposed to. Instead of adding 2 to the value of $base each JV>> time, It's producing a pattern like this: JV>> 0x484, 0x486, 0x73, 0x73, 0x73, 0x488, 0x48a, 0x48c, 0x48e, 0x490, 0x74, JV>> 0x74, 0x74 JV>> Second, the format of $base doesn't seem to be handled correctly in line JV>> 4 of the above code. Given a value of 0x484, this line should write the JV>> bytes "04 84", but it is obviously not doing so, given the response I JV>> get from the device (it sends "FF FF" instead of the expected value at JV>> that address, which I get when I remove the variable and manually JV>> specify the address). JV>> What are the solutions to these problems? JV>> Thanks, JV>> -Joe Veldhuis TR> Do your packing after all the calculations: TR> <?php TR> $output = array(); TR> $string = 1; TR> for( TR> $i=0, $base = (($string-1) * 26) + 0x484; TR> $i < 26; TR> $i++, $base += 2) TR> { TR> $binarydata = pack("nc*", $base, 0, 0, 0xBB); TR> dio_write($serial,$k=strlen($binarydata),5); //send the command TR> $output[] = dio_read($serial,1); // read first byte TR> $output[] = dio_read($serial,1); // read second byte TR> } TR> -- TR> regards, TR> Tom I left some sebug in there, that should have been: <?php $output = array(); $string = 1; for( $i=0, $base = (($string-1) * 26) + 0x484; $i < 26; $i++, $base += 2) { $binarydata = pack("nc*", $base, 0, 0, 0xBB); dio_write($serial,$binarydata,5); //send the command $output[] = dio_read($serial,1); // read first byte $output[] = dio_read($serial,1); // read second byte } -- regards, Tom -- PHP General Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php