×

INDI Library v2.0.7 is Released (01 Apr 2024)

Bi-monthly release with minor bug fixes and improvements

Help with DIY CCD driver

  • Posts: 13
  • Thank you received: 2
GIlles,

Thanks for the suggestion, it helped.

So I ran the indiserver from the command line and used KStars to connect to it as a remote on 127.0.0.1.

(Yes I did install the udev rules.)

So evidently I have a problem with ftdi connecting to the camera. So this was very bad, but see next block for an improvement,
indiserver -v -m 100 indi_cam84_ccd
2016-11-25T23:41:12: startup: indiserver -v -m 100 indi_cam84_ccd 
2016-11-25T23:41:12: Driver indi_cam84_ccd: pid=8414 rfd=3 wfd=6 efd=7
2016-11-25T23:41:12: listening to port 7624 on fd 4
2016-11-25T23:41:12: Driver indi_cam84_ccd: snooping on Telescope Simulator.EQUATORIAL_EOD_COORD
2016-11-25T23:41:12: Driver indi_cam84_ccd: snooping on Telescope Simulator.TELESCOPE_INFO
2016-11-25T23:41:12: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_SLOT
2016-11-25T23:41:12: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_NAME
2016-11-25T23:42:08: Client 0: new arrival from 127.0.0.1:54250 - welcome!
2016-11-25T23:42:18: Driver indi_cam84_ccd: USING LIBFTDI********************************
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error open interface A
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error open interface B
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error set bitbang mode interface B
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error set baud interface A (-3:USB device unavailable)
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error set baud interface B (-3:USB device unavailable)
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi BRA=-1 BRB=-1 TA=5000 TB=5000
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error set latency interface A
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error set latency interface B
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi BRA=-1 BRB=-1 TA=24000 TB=24000
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi interface A read chunksize 4096
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi interface B read chunksize 4096
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi interface A write chunksize 4096
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi interface B write chunksize 4096
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error purge RX interface A
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error purge TX interface A
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error purge RX interface B
2016-11-25T23:42:18: Driver indi_cam84_ccd: libftdi error purge TX interface B
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)
2016-11-25T23:42:18: Driver indi_cam84_ccd: write failed on channel 2)

Starting the indiserver using a sudo was much better but have tons of read errors and the image is garbage. At least values are being returned now.


sudo indiserver -v -m 100 indi_cam84_ccd
[sudo] password for michael: 
2016-11-26T03:10:53: startup: indiserver -v -m 100 indi_cam84_ccd 
2016-11-26T03:10:53: Driver indi_cam84_ccd: pid=8960 rfd=3 wfd=6 efd=7
2016-11-26T03:10:53: listening to port 7624 on fd 4
2016-11-26T03:10:53: Driver indi_cam84_ccd: snooping on Telescope Simulator.EQUATORIAL_EOD_COORD
2016-11-26T03:10:53: Driver indi_cam84_ccd: snooping on Telescope Simulator.TELESCOPE_INFO
2016-11-26T03:10:53: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_SLOT
2016-11-26T03:10:53: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_NAME
2016-11-26T03:11:53: Client 0: new arrival from 127.0.0.1:54440 - welcome!
2016-11-26T03:11:58: Driver indi_cam84_ccd: USING LIBFTDI********************************
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi BRA=1400000 BRB=5600000 TA=5000 TB=5000
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi BRA=1400000 BRB=5600000 TA=24000 TB=24000
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi interface A read chunksize 4096
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi interface B read chunksize 4096
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi interface A write chunksize 4096
2016-11-26T03:11:58: Driver indi_cam84_ccd: libftdi interface B write chunksize 4096
2016-11-26T03:12:13: Driver indi_cam84_ccd: libftdi BRA=800000 BRB=3200000 TA=24000 TB=24000
2016-11-26T03:12:23: Driver indi_cam84_ccd: libftdi BRA=800000 BRB=3200000 TA=24000 TB=24000
2016-11-26T03:12:25: Driver indi_cam84_ccd: libftdi BRA=800000 BRB=3200000 TA=24000 TB=24000
2016-11-26T03:12:26: Driver indi_cam84_ccd: libftdi BRA=800000 BRB=3200000 TA=24000 TB=24000
2016-11-26T03:12:27: Driver indi_cam84_ccd: libftdi BRA=800000 BRB=3200000 TA=24000 TB=24000
2016-11-26T03:12:29: Driver indi_cam84_ccd: Start exposure bin 1 x 0 y 0 w 3000 h 2000 s 1.000000 l 1
2016-11-26T03:12:30: Driver indi_cam84_ccd: write exp tick
2016-11-26T03:12:30: Driver indi_cam84_ccd: reading : begin
2016-11-26T03:12:30: Driver indi_cam84_ccd: write 15V tick
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 5715<>12000 - 7 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 11403<>12000 - 8 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 11659<>12000 - 10 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 11317<>12000 - 12 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 4864<>12000 - 13 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 10123<>12000 - 15 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 7221<>12000 - 16 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 11061<>12000 - 17 / 999 
2016-11-26T03:12:32: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 7766<>12000 - 18 / 999 
2016-11-26T03:12:33: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 7562<>12000 - 30 / 999 
2016-11-26T03:12:33: Driver indi_cam84_ccd: poseExecute bin==1 readfailed 4011<>12000 - 31 / 999 
 
..........................etc................

Note I need to run about 80 baud or so (at least with the Ascom drivers) or the image is partially or totally corrupted.

Michael

P.S. This is using the latest code that was just uploaded.
The following user(s) said Thank You: gehelem
Last edit: 7 years 4 months ago by Michael F. Toups. Reason: fix code snapsho
7 years 4 months ago #12656

Please Log in or Create an account to join the conversation.

  • Posts: 167
  • Thank you received: 54

Replied by gehelem on topic Help with DIY CCD driver

ok,

About permissions :
udev rules should prevent from using sudo, but clearly it doesn't...
is your user in group DIALOUT ?

About errors :
this is exactly what i'm working on, try to increase timer values, e.g. 100000, and reduce baudrate

If you're a player, there is a way to try with D2XX wich is much more stable (but makes losing usage of all other usual fdti devices),
just remove the comment //#define D2XX in the header, an recompile
(i think D2XX library are installed by default with ubuntu)
unload ftdi_sio before running indi :
sudo rmmod ftdi_sio

btw : are you using ubuntu ? wich version ?

Gilles.
Last edit: 7 years 4 months ago by gehelem.
7 years 4 months ago #12659

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
Won't have time until this evening to play with it.

Probably don't have the group memeberships correct yet. Evidently don't have a dialout group. Will fix.

Using Ubuntu 16.10 from a lubuntu distro.

Will try the D2XX lib as you suggested for debugging purposes. I had downloaded and initially tried it with the first attempt you posted. Was glad to see the port to libftdi since D2XX requires rmmod of ftdio_sio which breaks internet and lots of stuff on the netbook.
7 years 4 months ago #12668

Please Log in or Create an account to join the conversation.

  • Posts: 167
  • Thank you received: 54

Replied by gehelem on topic Help with DIY CCD driver

don't spend too much time with D2XX, it is really not the good solution :lol:
Can you check if you can still use other usb devices, like a focuser or your mount ?
7 years 4 months ago #12675

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
D2XX isn't working for me, again probably user error. I can't connect to the camera with D2XX and the current build with D2XX enabled.
sudo indiserver -v -m 100 indi_cam84_ccd
2016-11-26T22:28:22: startup: indiserver -v -m 100 indi_cam84_ccd 
2016-11-26T22:28:22: Driver indi_cam84_ccd: pid=3386 rfd=3 wfd=6 efd=7
2016-11-26T22:28:22: listening to port 7624 on fd 4
2016-11-26T22:28:22: Driver indi_cam84_ccd: snooping on Telescope Simulator.EQUATORIAL_EOD_COORD
2016-11-26T22:28:22: Driver indi_cam84_ccd: snooping on Telescope Simulator.TELESCOPE_INFO
2016-11-26T22:28:22: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_SLOT
2016-11-26T22:28:22: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_NAME
2016-11-26T22:28:31: Client 0: new arrival from 127.0.0.1:57556 - welcome!
2016-11-26T22:28:34: Driver indi_cam84_ccd: USING D2XX***********************************
2016-11-26T22:28:34: Driver indi_cam84_ccd: unable to open ftdi device: 1 (2)
2016-11-26T22:28:34: Driver indi_cam84_ccd: stderr EOF
2016-11-26T22:28:34: Driver indi_cam84_ccd: restart #1
2016-11-26T22:28:34: Driver indi_cam84_ccd: pid=3393 rfd=3 wfd=7 efd=8
2016-11-26T22:28:34: Driver indi_cam84_ccd: snooping on Telescope Simulator.EQUATORIAL_EOD_COORD
2016-11-26T22:28:34: Driver indi_cam84_ccd: snooping on Telescope Simulator.TELESCOPE_INFO
2016-11-26T22:28:34: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_SLOT
2016-11-26T22:28:34: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_NAME
2016-11-26T22:29:23: Driver indi_cam84_ccd: USING D2XX***********************************
2016-11-26T22:29:23: Driver indi_cam84_ccd: unable to open ftdi device: 1 (2)
2016-11-26T22:29:23: Driver indi_cam84_ccd: stderr EOF
2016-11-26T22:29:23: Driver indi_cam84_ccd: restart #2
2016-11-26T22:29:23: Driver indi_cam84_ccd: pid=3396 rfd=3 wfd=7 efd=8
2016-11-26T22:29:24: Driver indi_cam84_ccd: snooping on Telescope Simulator.EQUATORIAL_EOD_COORD
2016-11-26T22:29:24: Driver indi_cam84_ccd: snooping on Telescope Simulator.TELESCOPE_INFO
2016-11-26T22:29:24: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_SLOT
2016-11-26T22:29:24: Driver indi_cam84_ccd: snooping on CCD Simulator.FILTER_NAME

But I can get the "read" example from the D2XX package.
 ./read
Library version = 0x10306
Opening port 0
FT_Open succeeded.  Handle is 0x823b680
FT_GetDeviceInfo succeeded.  Device is type 6.
FT_EE_Read succeeded.
 
Signature1 = 0
Signature2 = -1
Version = 3
VendorId = 0x0403
ProductId = 0x6010
Manufacturer = FTDI
ManufacturerId = CA
Description = cam8
SerialNumber = CAM8
MaxPower = 100
PnP = 1
SelfPowered = 0
RemoteWakeup = 0
Returning 0

Will shift back to the ftdi build and try to answer your other questions but any suggestions regarding D2XX, would like to have it for a comparison.
7 years 4 months ago #12684

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
Success, went back to the latest build with the ftdi lib and set the baudrate down to 50 baud, (and was playing with the timers also) and the read errors went away. Figuring out what settings do what will have to come later. I ended up with an image! So with the right settings the driver does work, just not sure what the right settings need to be.

Don't currently have any other indi items, cam8 is my first step down this path so not sure what I can use to test the usb serial adapter. I do have a Arduino that I am using to build a TEC controller and it uses the usb so that might be a good test. I'll have to dig it out later and test it while running the indi cam8 driver.

P.S. Tweaked a setting and now the image looks bad. Will need to investigate further but enough of this for one day.
Last edit: 7 years 4 months ago by Michael F. Toups. Reason: P.S.
7 years 4 months ago #12685

Please Log in or Create an account to join the conversation.

  • Posts: 167
  • Thank you received: 54

Replied by gehelem on topic Help with DIY CCD driver

good news, thank you for the report
did it work "without sudo" ? what did you change ?
there are many other drivers you can try, eg dslr, filterwheel, focuser, mounts, other cameras ...
7 years 4 months ago #12695

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
(Still using sudo.)

However, I think I found the key issue that is causing the read errors. It is that the ftdi library's ftdi_read_data and the D2XX FT_Read have very different behaviors. See developer.intra2net.com/mailarchive/html...i/2012/msg00149.html for example. Looks like we might need to implement some variant of the function given in the patch. However, that version appears to be windows specific but could easily be linux compatible (it uses windows timer function.)

Need to investigate further but I think this is the key issue; it looks like there should be an easy fix. I'll investigate further.
7 years 4 months ago #12723

Please Log in or Create an account to join the conversation.

  • Posts: 167
  • Thank you received: 54

Replied by gehelem on topic Help with DIY CCD driver

this is the conclusion i was afraid of, as understanding the way this library works is much beyond my skills...
thank you for your help Mikael !
Gilles.
7 years 4 months ago #12724

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
I am trying a few things. I think this is solvable with a modified version of ftdi_read_data. If so we should be able to make this work. Might be a while before I can work some more on this.

Michael
7 years 4 months ago #12725

Please Log in or Create an account to join the conversation.

  • Posts: 167
  • Thank you received: 54

Replied by gehelem on topic Help with DIY CCD driver

ok fine,
Here comes the cleaning time, many other points need to be checked, like binning and subframe
7 years 4 months ago #12726

Please Log in or Create an account to join the conversation.

  • Posts: 13
  • Thank you received: 2
Below are two diffs showing a quick mod that appears to take care of the "timing" issue due to the differences between D2XX and ftdi.

First I changed the calls to ftdi_read_data to ftdi_read_data_modified and created a new function ftdi_read_data_modified that continually calls ftdi_read_data until either too many attempts are made or all the data has been collected. This is a quick and dirty solution that appears to care of the problem. The number of tries and the usleep time are somewhat arbitrary and probably could be tuned. Not the cleanest solution, but this should allow your code to work with the ftdi library.

Michael

First in libcam84.h changes are
18,23d17
< #ifdef D2XX
< #else
< struct ftdi_context;
< int ftdi_read_data_modified(struct ftdi_context *ftdi, unsigned char *buf,  int size);
< #endif
< 

and in libcam84.c the changes are
312c312
<       dwBytesRead=ftdi_read_data_modified(CAM8A,FT_In_Buffer,0);
---
>       dwBytesRead=ftdi_read_data(CAM8A,FT_In_Buffer,0);
338c338
<       dwBytesRead=ftdi_read_data_modified(CAM8A,FT_In_Buffer, 8*mdeltX);
---
>       dwBytesRead=ftdi_read_data(CAM8A,FT_In_Buffer, 8*mdeltX);
367c367
< 	  dwBytesRead=ftdi_read_data_modified(CAM8A,FT_In_Buffer, 2*mdeltX);
---
> 	  dwBytesRead=ftdi_read_data(CAM8A,FT_In_Buffer, 2*mdeltX);
965,980d964
< }
< 
< int ftdi_read_data_modified(struct  ftdi_context * ftdi, unsigned char * buf, int size)
< {
< 	int rsize = ftdi_read_data(ftdi, buf, size);
< 	int nsize=size-rsize;
< 	int retry=0;
< 	while((nsize>0)&(retry<20))
< 	{
< 		retry++;
< 		usleep(500);
<  //	     	 fprintf(stderr,"Try %d since %d<>%d \n",retry, rsize,size);
< 	        rsize = rsize+ftdi_read_data(ftdi, buf+rsize, nsize);
< 		nsize = size - rsize;
< 	}
< 	return rsize;
7 years 4 months ago #12731

Please Log in or Create an account to join the conversation.

Time to create page: 0.809 seconds