Download presentation
Presentation is loading. Please wait.
1
IN5350 – CMOS Image Sensor Design
Lecture 9 – CIS communication interfaces 25-October-2019
2
Project schedule ✅ ✅ ✅ ✅ ✅ Task/milestone Start Finish
Chose topic/scope 16-Sep 20-Sep Create project plan (tasks, milestones, schedule) 27-Sep MS1 – project plan approved by Johannes 30-Sep Study literature on the topic 4-Oct Design/simulation 25-Oct Write prelim report (2-3pages, inc references, goals, design, prelim results) 29-Oct MS2 – submit preliminary report to Johannes 15-Nov Write up final report (incl references, design, results) 22-Nov MS3 – submit final report to Johannes & presentation MS4 – grading (pass/fail) by Johannes & Tohid Exam 28-Nov 2019 ✅ ✅ ✅ ✅ ✅
3
Goal for this lecture Learn how the image sensor chip communciates with host CPU using industry standard interfaces Learn how I2C is used to write commands to the CMOS image sensor and to read register contents Learn about pros and cons of outputing pixel data with parallel and serial interfaces 26/10/2019
4
Package types Ref: Harris et al, CMOS VLSI Design, 4th Ed.
5
Camera HW examples Sensor eval board DSLR camera FPGA + USB board
6
Sensor eval board example
CIS chip
7
Digital input pads (next slide)
Ref: Harris et al, CMOS VLSI Design, 4th Ed.
8
ESD protection Ref: Harris et al, CMOS VLSI Design, 4th Ed.
9
Bidirectional pads Ref: Harris et al, CMOS VLSI Design, 4th Ed.
10
VDDIO power dissipation
Energy per transition (delivered by VDDIO): EIO = Cload x VDDIO2 Power delivered to output clock pin: PCLK = Cload x VDDIO2 x fCLK Power delivered to output pins: PIOpin = Cload x VDDIO2 x fCLK/2 Total power: PIO = Cload x VDDIO2 x fCLK x (1 + NDVP/2) Example: PIO=20pF (3.3V)2 100MHz (1+12/2) = 152mW(!)
11
Noise concern when DVP data toggles
Current in I/O pins during LOW to HIGH transition IVDDIO = Cload dVVDDIO/dT Typical pin load: Cload = 15pF HDTV (720p60) output clock frequency: fCLK = 74.25MHz (74.25Mpix/sec), i.e. Cycle time of 13.5ns Assume VDDIO=1.8V and rise time of ¼ cycle time IVDDIO = 15pF 1.8V/(13.5ns/4) = 8mA Assuming 0 to 1 transition on 12bit pixel value + clk 8mA/pin x (12+1)pins = 104mA (large current spikes on VDDIO!)
12
Industry trend from parallel to serial output
Driven by the megapixel raze E.g. 8MP 30fps => 240Mpix/sec CMOS DVP i/os limited to approx 100MHz Adding multiple DVPs could increase die size (cost) Driven by power and noise concerns Current spikes in I/Os inducing supply and gnd noise Driven by EMC requirements Reduced EM radiation from serial interfaces w/differential signalling
13
Example EMC test of digital VDD supply
14
Example EMC test of digital VDD supply
15
Low Voltage Differential Signaling
Ref: National Semiconductor, LVDS owners manual.
16
LVDS remarks Data rate >5Gbps per lane (1Gbps is typical)
Unaffected by common mode noise thanks to differential signalling At 2.5V supply voltage the power to drive 3.5 mA becomes 8.75 mW per lane Variations of LVDS for reduced power sub-LVDS (introduced by Nokia in 2004) uses 0.9V typical common mode voltage SLVS-400 specified in JEDEC where the power supply can be 800 mV and common mode voltage 400mV MIPI D-PHY uses 200mV differential signalling
17
I2C Inter-Integrated Circuit
VDDIO Master Slave Slave One device is Master, the others are Slaves (max 127) Only the Master drives the clock line (SCL) Pull-up resistors, Rp, typically 1.8kohms to 10kohms Speed grades: 100kHz, 400kHz, 1MHz, 3.3MHz
18
Start and stop sequence and data transmission
Data transmission: 8b data followed by 1b acknowledge from slave (i.e. SDA is pulled down by the slave device)
19
Addresssing an I2C device
7-bit device address, i.e. max 127 devices can be connected to the bus R/W bit informs slave that master wants to Read (‘1’) or Write (‘0’)
20
Write sequence Send a start sequence
Send the I2C address of the slave with the R/W bit low (even address) Send the internal register number you want to write to Send the data byte [Optionally, send any further data bytes] Send the stop sequence.
21
Read sequence Send a start sequence Send 0x<device address>
Send 0x<register address> Send a start sequence again (repeated start) Read data byte from device Send the stop sequence
22
Example read sequence NB. If slave is not ready for register read it can hold the SCL line low. This is called clock stretching. The master issues the first clock pulse of the read by making SCL high and then checks to see if it really has gone high. If its still low then it waits until it goes high before continuing. Example code:
23
Key takeaways Digital I/O pads with level shifting and ESD protection
Parallel outputs can be power hungry PIO = Cload x VDDIO2 x fCLK x (1 + NDVP/2) Industry trend from parallel to serial output (e.g. LVDS) due to higher datarates and lower EMC I2C: industry strandard protocol used to read/write 8b values to CMOS sensor (e.g. Integration time, gain, etc)
24
Thanks!
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.