Difference between revisions of "Driverless mode 393"
From ElphelWiki
(→Example: 1600x1200 window) |
(→pre (editing files on the boot SD card)) |
||
(3 intermediate revisions by the same user not shown) | |||
Line 4: | Line 4: | ||
==Instructions== | ==Instructions== | ||
− | ===pre=== | + | ===pre (editing files on the boot SD card)=== |
− | * to load bitstream for MT9F002 appropriate changes need to be made to: | + | * Remove 10389 board if installed (otherwise will have to rewrite eeprom) |
− | ** device tree | + | * To load bitstream for MT9F002 appropriate changes need to be made to: |
+ | ** (not necessary, can skip) device tree | ||
<font size=2>set sensors to '''mt9f002''' in ''elphel393-detect_sensors,sensors'' entry</font> | <font size=2>set sensors to '''mt9f002''' in ''elphel393-detect_sensors,sensors'' entry</font> | ||
** /etc/elphel393/default_10389.xml for setup w/o 10389 or 10389's eeprom otherwise write '''MT9F002''' as application | ** /etc/elphel393/default_10389.xml for setup w/o 10389 or 10389's eeprom otherwise write '''MT9F002''' as application | ||
+ | Application name must be already added to '''/usr/local/autocampars.php''' | ||
* Disable driver | * Disable driver | ||
<font size=2>root@elphel393~# touch /etc/elphel393/disable_driver | <font size=2>root@elphel393~# touch /etc/elphel393/disable_driver | ||
Line 112: | Line 114: | ||
* Download and run [https://git.elphel.com/Elphel/x393/blob/master/py393/mt9f002_window_generator.py mt9f002_window_generator.py] | * Download and run [https://git.elphel.com/Elphel/x393/blob/master/py393/mt9f002_window_generator.py mt9f002_window_generator.py] | ||
* Then edit the code snippets for 1600x1200 according to the new window size | * Then edit the code snippets for 1600x1200 according to the new window size | ||
+ | * If getting raw sensor data 8-bit and 16-bit the membridge buffer is 4MB, so calculate accordingly: | ||
+ | for 8-bit : '''WxH < 4M''' | ||
+ | for 16-bit: '''WxH < 2M''' | ||
+ | If not then - the buffer is circular which will result in overwriting of the beginning of the image | ||
[[Category:393]] | [[Category:393]] |
Latest revision as of 12:11, 23 April 2019
Contents
Description
Instructions on how to disable sensor driver and get images from image sensor (for MT9F002 sensor)
Instructions
pre (editing files on the boot SD card)
- Remove 10389 board if installed (otherwise will have to rewrite eeprom)
- To load bitstream for MT9F002 appropriate changes need to be made to:
- (not necessary, can skip) device tree
set sensors to mt9f002 in elphel393-detect_sensors,sensors entry
- /etc/elphel393/default_10389.xml for setup w/o 10389 or 10389's eeprom otherwise write MT9F002 as application
Application name must be already added to /usr/local/autocampars.php
- Disable driver
root@elphel393~# touch /etc/elphel393/disable_driver # then reboot
init
- start python session:
root@elphel393~# cd /usr/local/verilog/; test_mcntrl.py @hargs-after
- init (if the driver is not disabled the i2c writes will not work):
setup_all_sensors True None 0x1 False 4384 3280 write_sensor_i2c 0 1 0 0x31c08000 # hispi timing write_sensor_i2c 0 1 0 0x030600b4 # pll multiplier write_sensor_i2c 0 1 0 0x31c68400 # hispi control status write_sensor_i2c 0 1 0 0x306e9280 # datapath select write_sensor_i2c 0 1 0 0x301a001c # reset and start streaming hispi_phases_adjust 0 write_sensor_i2c 0 1 0 0x301a001c # reset and start streaming setup_all_sensors True None 0x1 False 4384 3280 compressor_control all None None None None None 2 program_gamma all 0 0.57 0.04 write_sensor_i2c 0 1 0 0x3028000a # global gain write_sensor_i2c 0 1 0 0x302c000d # some gain write_sensor_i2c 0 1 0 0x302e0010 # some gain write_sensor_i2c 0 1 0 0x30120080 # coarse exposure jpeg_acquire_write #write_sensor_i2c 0 1 0 0x301a0018 # put to standby
- inspect image:
http://192.168.0.9/img.jpeg
Example: 1600x1200 window
8-bit compress to jpeg
- setup:
write_sensor_i2c 0 1 0 0x3002001e write_sensor_i2c 0 1 0 0x300604f5 write_sensor_i2c 0 1 0 0x034e04d8 write_sensor_i2c 0 1 0 0x300a056a write_sensor_i2c 0 1 0 0x30040090 write_sensor_i2c 0 1 0 0x300806cf write_sensor_i2c 0 1 0 0x034c0640 write_sensor_i2c 0 1 0 0x300c04c8 setup_all_sensors True None 0x1 False 1600 1200 compressor_control all None None None None None 2 write_sensor_i2c 0 1 0 0x301a001c # wait write_sensor_i2c 0 1 0 0x301a0018 jpeg_acquire_write
- inspect:
refresh http://192.168.0.9/img.jpeg
8-bit raw
- setup
same as above, no need to repeat if already done
- capture (copy-pasting the code below with comments will work)
setup_all_sensors True None 0x1 False 1600 1200 write_sensor_i2c 0 1 0 0x301a001c # wait write_sensor_i2c 0 1 0 0x301a0018 # notice membridge_start (under Setting membridge for sensor 0) # it can be different: 0x2e000000 or 0x2dc00000 membridge_start mem_save "/usr/local/verilog/sensor_dump" 0x2e000000 0x400000
- copy (from an ssh session in another terminal)
scp /usr/local/verilog/sensor_dump ip@host:/path/1600x1200_8bit.raw
- open:
Use imagej: File > Import > Raw...
16-bit raw
- setup
same as above, no need to repeat if already done
- capture (copy-pasting the code below with comments will work)
# Notice that the window width in 16 bit mode is 2x setup_all_sensors True 18 0x1 False 3200 1200 set_sensor_mode 0 1 1 True True enable_memcntrl_en_dis 12 True write_sensor_i2c 0 1 0 0x301a001c # wait write_sensor_i2c 0 1 0 0x301a0018 # notice membridge_start (under Setting membridge for sensor 0) # it can be different: 0x2e000000 or 0x2dc00000 membridge_start mem_save "/usr/local/verilog/sensor_dump" 0x2e000000 0x400000
- copy (from an ssh session in another terminal)
scp /usr/local/verilog/sensor_dump ip@host:/path/1600x1200_16bit.raw
- open:
Use imagej: File > Import > Raw...
Example: other window sizes
- Download and run mt9f002_window_generator.py
- Then edit the code snippets for 1600x1200 according to the new window size
- If getting raw sensor data 8-bit and 16-bit the membridge buffer is 4MB, so calculate accordingly:
for 8-bit : WxH < 4M for 16-bit: WxH < 2M If not then - the buffer is circular which will result in overwriting of the beginning of the image