File: README

package info (click to toggle)
photopc 3.07-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,068 kB
  • sloc: ansic: 6,335; sh: 1,032; makefile: 175
file content (240 lines) | stat: -rw-r--r-- 9,450 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
	$Id: README,v 2.24 2001/08/03 09:40:38 crosser Exp $

	Copyright (c) 1997-2001 Eugene G. Crosser
	Copyright (c) 1998,1999 Bruce D. Lightner (DOS/Windows support)

	You may distribute and/or use for any purpose modified or unmodified
	copies of this software if you preserve the copyright notice above.

	THIS SOFTWARE IS PROVIDED AS IS AND COME WITH NO WARRANTY OF ANY
	KIND, EITHER EXPRESSED OR IMPLIED.  IN NO EVENT WILL THE
	COPYRIGHT HOLDER BE LIABLE FOR ANY DAMAGES RESULTING FROM THE
	USE OF THIS SOFTWARE.

This is a library and a command-line frontend to manipulate digital
still cameras based on Fujitsu chipset and Sierra Imaging firmware.  The
program is known to work with Agfa, Epson, Olympus, Sanyo and Nikon (at
least CoolPix 900, 950 and 8x0 but not CoolPix 600!) cameras.

The cameras typically come with software for Windows and for Mac, and no
description of the protocol.  With this tool, they are managable from a
UNIX box.  Bruce D. Lightner <lightner@lightner.net> has added support
for Win32 and DOS platforms.  Note that the program does not have any
GUI, it is plain command-line even on Windows.

I tried it under Linux/x86, FreeBSD, Solaris/SPARC and HP/UX, and it
should be straightforward for other UNIX systems.

Generally, UNIX system requirements are:
- ANSI C compiler (theoretically should work with K&R but unchecked)
- POSIX termios or BSD sgtty
- presence of a 16bit integer type
- serial port (with or without `modem control').

On UNIX, first run "./configure".  Then, typing `make' will result
in building the library and executables in the current directory.
`make install' will install the executables, library and manual pages.
If your `make' supports VPATH (e.g. GNU make), it is possible to build
objects and executables in a different directory; create target directory
and run /path/to/photopc/configure.  If you are building from CVS source
see instructions at the end of this file.

When building on NeXT, you may need to specify --without-termios because
termios is reportedly broken on NeXT.  The program will use BSD sgtty
style terminal control then.  When building on BeOS, you may need to
specify --enable-alarmed-read because on BeOS select() reportedly only
works on network sockets and not on other type of streams.

On UNIX systems that have sched_setcheduler() function the program can
set itself "realtime priority".  That makes it less vulnerable to
possible timeouts caused by high system load, and, more important, it
makes possible to use high-resolution mode of nanosleep() function.
That means that it may run a bit faster (but you probably will not
notice anyway).  Make the progrem setuid root to use this mode.  There
is hopefully no danger because it revokes root privileges really early
(even before processing command-line options).  If you are so paranoid
that you don't want even to compile in this feature, run configure with
--without-rtprio option.

To build for DOS and WIN32, chdir to "dos" or "win32" directories
respectively and there type "make" (or "nmake"). You need compiler
installed on your system.  TurboC works under DOS, "Development
Studio" (or how do they call it?) - under Win32.

.zip distribution includes DOS and Win32 binaries pre-built for you.

The runtime parameters are rather clear (hopefully).  Running
`photopc -h | more' will print the list of options and commands.
If you are going to use the library for your own application and need
the docs, tell me and I will write them.

Included file `protocol.htm' contains description of the protocol used
by the camera.

`usage.htm' is a "casual" user's guide, full description is in the man
pages.

If you run the program on a DOS box, you may want a JPEG viewer; I've
been told that a good free viewer `LXPIC' can be found at
http://home.t-online.de/home/stefan.peichl.  Also, there is a tool that
may help in discovering serial protocols (although *I* did not use it
when I examined that camera's protocol):
http://www.endymion.com/portfolio/software/comlite32.htm

Many commands may be unimplemented, esp. those specific for newer
models.  If you know how to do things that the program currently cannot
do, please let me know.

Two MOST COMMON PROBLEMS that you may face running the program are:
    ^^^^^^^^^^^^^^^^^^^^
1. You run the program, but nothing happens with the camera, and
   the program says "Error 10003: eph_waitsig got -2" several times.

   a) Camera not powered up, or not in "communication mode".
   b) Cable incorrectly wired, or bad contact.
   c) Computer serial chip is not wired to the right connector or
      disabled in the BIOS.
   d) OS driver not properly configured (e.g. "setserial" was not
      run on Linux, or wrong interrupt was assigned).
   e) Some other program is using the port (e.g. gpm or {a,m,uu}getty).

2. When you download pictures and disk activity happens, download
   aborts due to excessive retries.

   Serial driver is loosing incoming bytes.  This usually happens on
   Linux with ATA disk(s) when the driver is configured to run in PIO
   mode with disabled interrupts.  Read the documentation on "hdparm"
   command and try playing with various driver modes.  (Beware that on
   some combinations of chipset/disk this may cause data corruption!)
   Other possible causes are interrupt shared with another device, or
   another program trying to use the same serial port.

I can be contacted at <crosser@average.org>, fresh version of this tool
(if any) and related information can be got from the SorceForge at
http://photopc.sourceforge.net/.  For CVS see bottom of this file.
Some earlier and modified versions of the code accompanied by Win32 and
DOS executables and archived in .zip format can be found at
http://www.lightner.net/lightner/bruce/photopc/

Thanks to Jeff Tranter for contributing the man page and a few bugfixes,
Bruce Lightner for Windows and DOS support, Thierry Bousch for many
details of the protocol and advice, Sergey I. Panov for invaluable
investigation of the folder navigation means, John Bowman for Nikon
specific parts and other people who helped me to track down problems and
learn more about the protocol.

Trademarks are properties of their respective respected owners.
---

APPENDIX: Building from CVS source.
^^^^^^^^
You must have cvs, autoconf and automake installed on your system.

$ cd $your_src_dir
$ cvs -d :pserver:anonymous@cvs.photopc.sourceforge.net:/cvsroot/photopc login
Password:
   ( -- just press "Enter" for empty password)
$ cvs -d :pserver:anonymous@cvs.photopc.sourceforge.net:/cvsroot/photopc checkout photopc
$ cd photopc
$ aclocal
$ autoheader
$ automake --add-missing
$ autoconf
$ ./configure --$various_options
$ make
$ sudo make install
==========================================================================

	$Log: README,v $
	Revision 2.24  2001/08/03 09:40:38  crosser
	add "common problems" section, style changes
	
	Revision 2.23  2001/05/28 21:44:46  crosser
	fix cvs command in README
	
	Revision 2.22  2001/05/15 22:21:35  crosser
	README - reflect CVS and www server change to sourceforge
	eph_io.c - make waitsig() skip 0xff's in addition to NULs
	
	Revision 2.21  2000/05/09 13:20:54  crosser
	configure read() with alarm() better.
	Address signed vs. unsigned arguments
	other cleanups to make most notorious compilers happy
	
	Revision 2.20  2000/05/02 22:26:35  crosser
	A few things incorporated from John Bowman's Nikon specific diffs
	
	Revision 2.19  2000/01/24 20:25:23  crosser
	do better job in walking thru folder tree; credit to Sergey I. Panov
	
	Revision 2.18  1999/11/24 21:51:25  crosser
	instruction about building from cvs source
	
	Revision 2.17  1999/09/19 12:33:11  crosser
	Mention comlite32 in the README
	
	Revision 2.16  1999/08/26 16:11:57  crosser
	Change README to reflect new directory structure
	
	Revision 2.15  1999/08/01 22:13:10  crosser
	mention reltime priority things

	Revision 2.14  1999/08/01 21:36:54  crosser
	Modify source to suit ansi2knr
	(I hate the style that ansi2knr requires but you don't expect me
	to write another smarter ansi2knr implementation, right?)

	Revision 2.13  1999/04/28 08:28:53  crosser
	just don't like long copyrights

	Revision 2.12  1999/04/27 20:55:35  lightner
	Fix MS-DOS/Win32 makefile instructions

	Revision 2.11  1999/03/22 05:59:31  lightner
	Fix docs: Windows binaries go to win32/

	Revision 2.10  1999/03/21 20:21:04  crosser
	mention configure

	Revision 2.9  1999/01/17 09:51:16  crosser
	change Bruce's address

	Revision 2.8  1998/10/18 13:18:27  crosser
	Put RCS logs and I.D. into the source

	Revision 2.7  1998/07/21 22:56:52  crosser
	fix CP 900
	
	Revision 2.6  1998/06/07 13:55:20  crosser
	compatibilities and credits
	
	Revision 2.5  1998/05/09 18:22:42  crosser
	say that devices with modem control are allowable,
	minor fixes
	
	Revision 2.4  1998/03/01 18:57:04  crosser
	more credits
	
	Revision 2.3  1998/02/06 09:04:59  crosser
	mention DOS version
	
	Revision 2.2  1998/01/18 02:22:28  crosser
	change copyright
	
	Revision 2.1  1998/01/05 22:02:14  crosser
	add reference to Bruce's site
	
	Revision 2.0  1998/01/02 19:20:11  crosser
	Added support for Win32
	
	Revision 1.4  1997/12/24 00:30:14  crosser
	add vendors, add url, add credits.
	
	Revision 1.3  1997/11/15 19:29:47  crosser
	update for release 1.7
	
	Revision 1.2  1997/11/12 09:50:27  crosser
	mention photopc600, minor changes
	
	Revision 1.1  1997/08/17 09:06:54  crosser
	Initial revision