summaryrefslogtreecommitdiff
path: root/backend/mustek_usb_mid.h
diff options
context:
space:
mode:
Diffstat (limited to 'backend/mustek_usb_mid.h')
-rw-r--r--backend/mustek_usb_mid.h390
1 files changed, 390 insertions, 0 deletions
diff --git a/backend/mustek_usb_mid.h b/backend/mustek_usb_mid.h
new file mode 100644
index 0000000..d8701a7
--- /dev/null
+++ b/backend/mustek_usb_mid.h
@@ -0,0 +1,390 @@
+/* sane - Scanner Access Now Easy.
+
+ Copyright (C) 2000 Mustek.
+ Originally maintained by Tom Wang <tom.wang@mustek.com.tw>
+
+ Copyright (C) 2001, 2002 by Henning Meier-Geinitz.
+
+ This file is part of the SANE package.
+
+ This program is free software; you can redistribute it and/or
+ modify it under the terms of the GNU General Public License as
+ published by the Free Software Foundation; either version 2 of the
+ License, or (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful, but
+ WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place - Suite 330, Boston,
+ MA 02111-1307, USA.
+
+ As a special exception, the authors of SANE give permission for
+ additional uses of the libraries contained in this release of SANE.
+
+ The exception is that, if you link a SANE library with other files
+ to produce an executable, this does not by itself cause the
+ resulting executable to be covered by the GNU General Public
+ License. Your use of that executable is in no way restricted on
+ account of linking the SANE library code into it.
+
+ This exception does not, however, invalidate any other reasons why
+ the executable file might be covered by the GNU General Public
+ License.
+
+ If you submit changes to SANE to the maintainers to be included in
+ a subsequent release, you agree by submitting the changes that
+ those changes may be distributed with this exception intact.
+
+ If you write modifications of your own for SANE, it is your choice
+ whether to permit this exception to apply to your modifications.
+ If you do not wish that, delete this exception notice.
+
+ This file implements a SANE backend for Mustek 1200UB and similar
+ USB flatbed scanners. */
+
+#ifndef mustek_usb_mid_h
+#define mustek_usb_mid_h
+
+#include "mustek_usb_low.h"
+#include "../include/sane/sane.h"
+
+/* ---------------------------------- macros ------------------------------ */
+
+
+/* ---------------- sensor NEC 600 CCD function declarations -------------- */
+
+static SANE_Status usb_mid_n600_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_n600_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_n600_prepare_rgb_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_rgb_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_n600_prepare_mono_50_dpi (ma1017 * chip);
+
+/* ----------------- sensor 600 CIS function declarations ----------------- */
+
+static SANE_Status usb_mid_c600_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_c600_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_c600_prepare_rgb_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c600_prepare_mono_50_dpi (ma1017 * chip);
+
+/* -------------- sensor 300/600 CIS function declarations ---------------- */
+
+static SANE_Status usb_mid_c300600_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_c300600_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300600_prepare_mono_50_dpi (ma1017 * chip);
+
+/* ----------------- sensor 300 CIS function declarations ----------------- */
+
+static SANE_Status usb_mid_c300_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_c300_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_c300_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_rgb_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_mono_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_c300_prepare_mono_50_dpi (ma1017 * chip);
+
+/* --------------------- sensor function declarations -------------------- */
+
+static SANE_Bool usb_mid_sensor_is600_mode (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_sensor_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_sensor_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_sensor_get_dpi (ma1017 * chip, SANE_Word wanted_dpi, SANE_Word * dpi);
+
+/* ------------------- motor 1200 function declarations ------------------ */
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_1200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_1200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_400_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_mono_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor1200_prepare_rgb_half_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_rgb_bi_full_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_rgb_bi_full_x2300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_mono_half_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_mono_bi_full_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_mono_bi_full_x2300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor1200_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor1200_prepare_calibrate_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor1200_prepare_calibrate_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor1200_prepare_step (ma1017 * chip, SANE_Word step_count);
+
+static SANE_Status usb_mid_motor1200_prepare_home (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor1200_prepare_adjust (ma1017 * chip, Channel channel);
+
+static SANE_Word usb_mid_motor1200_rgb_capability (SANE_Word dpi);
+
+static SANE_Word usb_mid_motor1200_mono_capability (SANE_Word dpi);
+
+/* ---------------600 dpi motor function declarations --------------------- */
+
+static SANE_Status usb_mid_motor600_prepare_rgb_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_600_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_200_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_150_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_100_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_50_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_rgb_half_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor600_prepare_rgb_bi_full_300_dpi (ma1017 * chip);
+
+static SANE_Status usb_mid_motor600_prepare_mono_half_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor600_prepare_mono_bi_full_300_dpi (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor600_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor600_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor600_prepare_calibrate_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor600_prepare_calibrate_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor600_prepare_step (ma1017 * chip, SANE_Word step_count);
+
+static SANE_Status usb_mid_motor600_prepare_home (ma1017 * chip);
+
+static SANE_Status
+usb_mid_motor600_prepare_adjust (ma1017 * chip, Channel channel);
+
+static SANE_Word usb_mid_motor600_rgb_capability (SANE_Word dpi);
+
+static SANE_Word usb_mid_motor600_mono_capability (SANE_Word dpi);
+
+/* ------------------ motor function declarations ------------------------ */
+
+static SANE_Status usb_mid_motor_prepare_home (ma1017 * chip);
+
+static SANE_Status usb_mid_motor_prepare_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status usb_mid_motor_prepare_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor_prepare_adjust (ma1017 * chip, Channel channel);
+
+static SANE_Status
+usb_mid_motor_prepare_calibrate_rgb (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor_prepare_calibrate_mono (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor_prepare_step (ma1017 * chip, SANE_Word step_count);
+
+static SANE_Word usb_mid_motor_rgb_capability (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Word usb_mid_motor_mono_capability (ma1017 * chip, SANE_Word dpi);
+
+static SANE_Status
+usb_mid_motor_get_dpi (ma1017 * chip, SANE_Word wanted_dpi, SANE_Word * dpi);
+
+/* --------------------- frontend function declarations ------------------- */
+
+
+static SANE_Status
+usb_mid_front_set_front_end_mode (ma1017 * chip, SANE_Byte mode);
+
+static SANE_Status usb_mid_front_enable (ma1017 * chip, SANE_Bool is_enable);
+
+static SANE_Status
+usb_mid_front_set_top_reference (ma1017 * chip, SANE_Byte top);
+
+static SANE_Status
+usb_mid_front_set_red_offset (ma1017 * chip, SANE_Byte offset);
+
+static SANE_Status
+usb_mid_front_set_green_offset (ma1017 * chip, SANE_Byte offset);
+
+static SANE_Status
+usb_mid_front_set_blue_offset (ma1017 * chip, SANE_Byte offset);
+
+static SANE_Status usb_mid_front_set_red_pga (ma1017 * chip, SANE_Byte pga);
+
+static SANE_Status usb_mid_front_set_green_pga (ma1017 * chip, SANE_Byte pga);
+
+static SANE_Status usb_mid_front_set_blue_pga (ma1017 * chip, SANE_Byte pga);
+
+static SANE_Status usb_mid_front_set_rgb_signal (ma1017 * chip);
+
+#if 0
+/* CCD */
+static SANE_Word usb_mid_frontend_max_offset_index (ma1017 * chip);
+#define OFFSET_TABLE_SIZE 256
+#endif
+
+#endif /* mustek_usb_mid_h */