Riley the Cat by Zankich, Nicholas
1 
 
Riley the Cat 
 By Nicholas Zankich  
 
Senior Project 
Computer Engineering Department  
California Polytechnic State University 
2012 
2 
 
 
Table of Contents 
Purpose ............................................................................................................................................. 4 
Introduction ...................................................................................................................................... 4 
Design ............................................................................................................................................... 4 
Development ..................................................................................................................................... 4 
List of Features .................................................................................................................................. 4 
Parts .................................................................................................................................................. 7 
Arduino Mega ............................................................................................................................ 7 
Homemade Sock Cat ................................................................................................................... 7 
OLED Screens ............................................................................................................................. 8 
Photoresistos ............................................................................................................................. 9 
Speaker .................................................................................................................................... 10 
Accelerometer .......................................................................................................................... 11 
RFID Reader ............................................................................................................................. 12 
Vibration Motor ....................................................................................................................... 12 
Microphone ............................................................................................................................. 13 
Servo ....................................................................................................................................... 14 
Battery ..................................................................................................................................... 15 
Switch ...................................................................................................................................... 15 
Future  Improvements...................................................................................................................... 16 
Conclusion .................................................................................................................................................. 17 
Appendix A: Arduino Code ............................................................................................................... 18 
Appendix B: Senior Project Analysis .......................................................................................................... 31 
Appendix C: Pin Mapping for Arduino Mega............................................................................................. 33 
 
 
Figures 
Riley the Cat completed .............................................................................................................. 4 
Data Flow ................................................................................................................................... 5 
3 
 
Overall Connections ................................................................................................................... 6 
Arduino Mega ............................................................................................................................ 7 
Stuffed Sock Cat ......................................................................................................................... 8 
OLED Screens ............................................................................................................................. 8 
Photoresistors ............................................................................................................................ 9 
Speaker .................................................................................................................................... 10 
Accelerometer .......................................................................................................................... 11 
ID-12 RFID Reader .................................................................................................................... 12 
Vibration Motor ....................................................................................................................... 13 
Vibration Motor Connection ..................................................................................................... 13 
Microphone ............................................................................................................................. 14 
Servo ....................................................................................................................................... 14 
Battery and Connector .............................................................................................................. 15 
On/Off Switch .......................................................................................................................... 15 
 
Tables 
Connection Protocols .................................................................................................................. 6 
Light inputs compared to pupil size  ...................................................................................... 10 
 
4 
 
Purpose:  
To create a toy that is a cross between a stuffed animal and a robot.   
 
Figure 1: Riley the Cat completed 
Introduction:  
There are many toys that exist that are comfort objects.  Generally these are toys that are 
soft such as blankets, stuffed animals, and pillows.  Robotic toys also exist such as games, 
interactive books, and instruments.  There exists a crossover market that includes Furbys, 
Tomagachi pets, and Fur Real Friends.  While being very popular, I believe that this crossover 
isn’t perfect, and that there is a lot of room for improvement.  Riley (Figure 1) was created to 
make something that is both completely a robot and a comfort object. 
 
Design: 
Cat: Riley is a stuffed animal filled with an Arduino Mega 2560 and several sensors.  Via several 
communication protocols (Table 1) through the Arduino’s various digital and analog inputs, 
Riley does a variety of activities including detecting objects, moving eyes and speaking.   
Connections to each of the sensors can be seen can be seen in figure 3.  Riley functions as a state 
machine.  The data flow is in figure 2. 
 
Development: 
Arduino Software:  Development was done within the open source Arduino software available at 
http://arduino.cc/en/Main/Software.   
Breadboard:  The electronic circuits were first built on a broad board to ensure functionality.  
They were then moved and soldered to a PC board.   
 
5 
 
 
List of features: 
 Oled eyes (x2) 
 Photoresistors (x6) 
 RFID reader 
 Accelerometer 
 Microphone 
 Speaker 
 Vibration motor 
 Arduino Mega  
 Servo 
 
 
Figure 2: Data Flow Diagram 
6 
 
 
 
 
Figure 3: Overall Connections 
 
Sensor Ports 
*ports correspond to the numbers on the Arduino 
schematic 
Communication 
protocol 
Photoresistors 0-5 in Analog in ports(I may multiplex these instead, but 
this gives the fastest feedback) 
ADC 
Microphone 7 Analog in port ADC 
Speaker 10 PWM 
Purr Motor 24 signal 
Tail Servo 5 PWM 
DIP Level shifter 
(connects to screens) 
22, 23, 51(Mosi), 52 (SCK), 53(CS) spi 
RFID 0 (RX) ttl 
Accelerometer Analog in ports 8-10 ADC built into 
MEGA 2560 
Table 1: Connection Protocols 
 
7 
 
Parts Description: 
The following is a list and descriptions of all the features in Riley.  Each will include name, simulated 
part, location in body, and part site. 
 
Part Name: Arduino Mega  
Simulated Part: Brain 
Location: Torso 
Part Site:  http://www.sparkfun.com/products/11061 
 
Figure 4: Arduino Mega 
 The Arduino Mega (figure 4) uses a C++ code that includes the image and sound 
libraries.  The code is a state machine that takes the different inputs and moves into other states.  
The idle state detects ambient light, RFID tags and accelerometer input. 
 
Part Name: Handmade Sock Cat 
Simulated Part: Skin 
Location: All 
Part Site:  http://www.etsy.com/listing/93816729/handmade-sock-cat-kitty-stuffed-
animal?ref=pr_shop 
8 
 
 
Figure 5: Stuffed Sock Cat 
 The body of Riley, a sock kitty (figure5) found on Etsy, was selected for its adorable 
looks to ensure Riley would serve as a comfort object.  Although the body did fit all of the 
electronics, a larger stuffed animal may have been preferred for ease of assembly.   
 
Part Name: Oled Screens  
Simulated Part: Eyes (visual) 
Location: Head 
Part Site:  http://www.adafruit.com/products/326 
 
Figure 6: OLED Screens 
9 
 
 The screens that act as Riley’s eyes, are Monochrome 128x64 oled screens (figure 6).  
The supplied libraries were extremely slow (2 frames per second) as they were meant for 
displaying static data vs animation.  I found an update on a forum that addressed this using 
hardware acceleration.  I had to edit it to work with my board which was different than the 
specified code.  After the update the refresh rate was closer to 10 frames per second.  Since the 
screens were LEDs, no flicker from the slower frame rate was experienced.  The frame rate was 
directly affected by how much I was writing to the screens and did other things in the 
background.   
 The Screens are connected in parallel to a level shifter chip which is connected to the 
board.  The chip changes the 5V outputs of the Arduino into the 3V ones the screens require.   
The information displayed on the screen was created in different ways.  For the images I 
converted an image into a 128x64 monochrome bitmap.  This essentially turned each pixel into a 
1 or 0.  Then I used a program called LCD assistant (http://en.radzio.dxp.pl/bitmap_converter/) 
to turn the image into an array of chars that could be copy and pasted over to my program.  For 
the eye animation I first drew an image of a white oval.  Then I used the screen libraries to draw 
a rectangle over them.  The width and location of the rectangle depended on the photoresistor 
input. 
 
Part Name: Photoresistors 
Simulated Part: Eye (sensing) 
Location: Front Paws 
Part Site: http://www.adafruit.com/products/161 
 
Figure 7: Photoresistors 
 The photoresistor (figure 7) circuit consisted of a photoresistor tied to high and an output/ 
resistor tied to ground.  The photoresistor increases it resistance under light.  The brighter the 
light, the lower the output voltage. There are 6 photoresistors spread in an array on Riley’s paws 
10 
 
and the output voltage of each photoresistor is connected to an analog input on the Arduino.  If 
an object were to go in front of one of the photoresistors, the Arduino would sense the voltage 
change and cause Riley’s eyes to react.  The choice of resistance was important because the light 
sensitivity changed based on the value.  The input of light vs the resistance of the photoresistor 
was not linear, so a value that reflected a natural light value was necessary.  Based on a chart of 
sensitivities found on http://www.ladyada.net/learn/sensors/cds.html I made a chart of expected 
sensitivities at different light ambiance.  
 The equation for solving the different pupil sizes was 1000/(darkest resistor) * 30 + 20.  
The typical analog value from the resistors was approximately 200 – 800.  The 1000 *30 
coefficient was used to give an appropriate scaling.  The offset, 20, was included to ensure the 
pupils never got smaller than 20 pixels.  A check was also done to ensure that the size was never 
over 50 pixels. 
Ambient light Ambient 
light (lux) 
Photocell 
resistance (Ω) 
LDR + R (Ω) Current thru 
LDR+R 
Pupil Size 
Moonlit night 1 lux 70 KΩ 0.07 mA 0.1 V 50 pixels 
Dark Room 10 lux 10 KΩ 0.45 mA 0.5 V 49 pixels 
Dark overcast day 
/ Bright room 
100 lux 1.5 KΩ 2 mA 2.0 V 30 pixels 
Overcast day 1000 lux 300 Ω 3.8 mA 3.8 V 23 pixels 
Full daylight 10,000 lux 100 Ω 4.5 mA 4.5 V 20 pixels 
Table 2: Light inputs compared to pupil size 
Part Name: Speaker 
Simulated Part: Voice 
Location: Torso 
Part Site:  http://www.sparkfun.com/products/9151 
 
Figure 8: Speaker 
  
11 
 
A speaker (figure 8) output sound was output using interrupts.  I edited a library from 
http://www.arduino.cc/playground/Code/PCMAudio to take multiple sounds (the original only took 
one).  The interrupts ensure that the playback is accurately timed. 
To create sounds output by the speakers 
1. I converted the sound into a PCM (pulse code modulation) unsigned 8 bit mono output.  
PCM is a digital representation of analog signals.  I used GoldWave for this step 
http://www.goldwave.com/.  This took the mp3 image and output it into char data.   
2. Since the library only takes input chars in the form of numbers delimited by commas, I 
wrote a c program script to format the data appropriately.  
3.  I then copied the output over to my program.  The array is stored in the SRAM on 
startup. 
 
Part Name: Accelerometer 
Simulated Part: Balance 
Location: Torso 
Part Site:  http://www.sparkfun.com/products/9652 
 
Figure 9: Accelerometer 
The accelerometer (figure 9) senses a difference by reading a value, then comparing it to the 
previous value.  Based on the current tilt, the accelerometer output different analog values from 
its x, y, and z ports.  These outs are wired to the analog ins on the Arduino.  The analog reader on 
the Arduino does an internal 5V comparison.  The values are gauged from 0 – 1024, 1024 being 
5V.  On each iteration of the purr function each of the current directions is compared to the 
previous value of the direction.  If the difference large enough, the purr motor will begin.  For 
Riley, the difference chosen (though experimentation) was 300.  Even at rest the analog values of 
the accelerometer fluxuate wildly.  Differences smaller than 300 would cause the check to go off 
12 
 
randomly even when Riley wasn’t being handled.  Differences greater than 300 wouldn’t be 
detected.   
 
Part Name: RFID Reader  
Simulated Part: Object detection 
Location: Head 
Part Site:  http://www.sparkfun.com/products/8419 
 
Figure 10: ID-12 RFID reader 
 The RFID reader is ID-12 (125 kHz) (figure 10).  The reader does not include an antenna 
so I designed my own using copper wire.  The range of the reader with the antenna was 2-3 cms.  
Initially I used tags http://www.sparkfun.com/products/10169 but they were too large to fit inside 
the cloth toys envisioned for Riley so I used smaller, button RFID tags 
https://www.adafruit.com/products/363 instead.  Unfortunately, these tags provided even more 
reduced range (1cm).    
 
Part Name: Vibration Motor 
Simulated Part: Purr 
Location: Torso 
Part Site:  http://www.radioshack.com/product/index.jsp?productId=2914700 
13 
 
 
Figure 11: Vibration Motor 
 The vibration motor (figure 11)  needed a small enough current that a signal alone from 
the Arduino could power it.  The problem was that the Arduino only outputs 5V and the limit of 
the motor was 3V.  I had to use a voltage regulator circuit (figure 12)  in order to output a safe 
3V to it.  The voltage regulator was a variable voltage regulator that required me to change its 
values via a pair of resistors.  The equation was V = 1.25(1+(R2/R1)).  I made the values of the 
resistors 220 for R1 and 165 for R2. 
 
Figure 12: Vibration Motor connection 
 
Part Name: Microphone 
Simulated Part: Ears 
Location: Torso 
Part Site:  http://www.sparkfun.com/products/8635 
14 
 
 
Figure 13: Microphone 
 The microphone (figure 13) used a standard analog input.  I then mapped the input to a 
Fourier Transform algorithm I found at http://www.arduino.cc/cgi-
bin/yabb2/YaBB.pl?num=1286718155.  To prove that the data was detecting frequencies I mapped 
them to different points on the screen to make a kind of audio analyzer.   
 
Part Name: Servo 
Simulated Part: Tail 
Location: Torso/back 
Part Site: http://www.radioshack.com/product/index.jsp?productId=12296088 
 
Figure 14: Servo (servo used was slightly different model) 
 A servo (figure 14)  controlled Riley’s tail.  Tail operation was simple.  The high and 
ground were connected to the Arduino.  The direction was controlled by pulse width modulation.  
The equation for the tail direction was 255 minus desired angle.  255 is the largest value that can 
15 
 
be written to an 8 bit PWM and maps to the signal being on continuously.  The range of the 
servo was 0 – 179 so the lowest value was 76 (255 – 179).  To make the tail move randomly I 
used the Arduino’s random function to find a random angle, and then wrote the value to the 
servo. 
 
Part Name: Battery 
Simulated Part: Energy 
Location: Back Left foot 
Part Site: http://www.radioshack.com/product/index.jsp?productId=2062219 (connector) 
http://www.radioshack.com/product/index.jsp?productId=3897297 (battery) 
 
Figure 15: Battery and connector 
 Riley can be powered via the Arduino’s usb port or through a 9V battery (figure 15) .  
With all of Riley’s sensors connected the battery only lasts approximately 17 minutes.  To reduce 
power requirements turn off the servo. 
 
Part Name: On/Off Switch 
Simulated Part: Sleep 
Location: Back Right foot 
Part Site: http://www.radioshack.com/product/index.jsp?productId=12688419 
 
Figure 16: On/Off switch 
16 
 
 This switch (figure 16)  was included to easily short or open the battery input.  It will not 
affect Riley if the USB is plugged in. 
 
Future improvements: 
Cost: 
Arduino: 
To lower the cost, this board could potentially be replaced with an Uno or smaller 
board.  However to maintain functionality, the analog inputs would have to be 
multiplexed as there are fewer analog inputs on the Uno bard.  Also EEPROM or external 
memory may have to be used in order to support Riley’s eye images and purring sounds. 
Screens: 
 The oled screens are beautifully crisp, but could be taken out for a much cheaper 
alternative.  Examples include a SPI TFT screen (http://www.adafruit.com/products/618) that 
would provide color support or a Nokia 5110 screen (http://www.adafruit.com/products/338) 
would give a larger screen.  Both are half the price of the OLEDs.   
 
Performance:  
Speaker:   
 If the speaker were to be amplified, it would have had a much higher volume.  
The tone function was loud enough but the PCM sound image was very quiet. 
Battery: 
 Recharable batteries would be the most desirable for a toy so they won’t have to 
be switched out so often.  They may also give a longer life.  The servo’s moving arm also 
drained the battery.  If the tail wasn’t moving the life would be much longer.   
Photoresitors: 
While the lower power usage of the photoresistors was good on battery life, 
another form of object detection would probably be more effective.  Possible alternatives 
would include a web cam with vision code or arrayed sound sensor. 
Microphone:   
17 
 
The input was very weak and even pounding on the microphone gave very little 
change.  In the future for an effective output, there should be an amplified circuit with a 
good filter. 
RFID: 
In the future I would use a more expensive version of the reader (either the ID2 or 
ID20) which have built in antennas.  These would have given a much better range. 
Wiring:  
What may have been easier and more stable way of wiring would be to make an 
Arduino shield and solder everything into it.  It would make for much less wiring and 
have more reliability 
 
Conclusion: 
 With some more work Riley could be a functional toy that could be enjoyed by children.  
If a PC board was specialized the wiring would be much more solid and Riley could be cheaper.  
With some market research, liked features could be improved and added while unwanted ones 
could be dropped.  Robotics are becoming much more prevalent today, especially in toys.  Riley 
could potentially share some of that market. 
18 
 
Appendix A: Arduino Code 
#define OLED_DC 23 
#define OLED_CS 53 
#define OLED_CLK 52 
#define OLED_MOSI 51 
#define OLED_RESET 22 
#define PHOTO0 0 
#define PHOTO1 1 
#define PHOTO2 2 
#define PHOTO4 3 
#define PHOTO5 4 
#define PHOTO6 5 
#define MICRO 7 
#define ACCX 8  
#define ACCY 9  
#define ACCZ 10 
#define SPEAKER 10  
#define RFIDResetPin 50 
#define PURM 24 
#define FOLLOWLEN 3000 
#define SERV 5 
 
#define READCARD 15  //how often card is read.  1 is every time, more is less times 
 
//blinkrand must be devisable by blinkdec 
//how often blink 
#define BLINKRAND 200 
//increase of chance they will blink in future 
#define BLINKDEC 2  
//Speed eye will move to follow object 
#define EYESPEED 5 
//Eye sensitiy to change (If eye is twitching increase) 
#define EYETWITCH 10 
#define IRISCHANGE 1 
 
#define MAXPURLEN 5 
 
#include <SSD1306.h> 
#include <SPI.h> 
#include <stdint.h> 
#include <avr/interrupt.h> 
#include <avr/io.h> 
#include <avr/pgmspace.h> 
#include <fix_fft.h> 
 
#define SAMPLE_RATE 8000 
 
SSD1306 oled(OLED_MOSI, OLED_CLK, OLED_DC, OLED_RESET, OLED_CS); 
19 
 
 
int sounddata_length=5000; 
 
static unsigned int pc = 0; 
 
int curBl = 0; 
int curRand = BLINKRAND; 
int eyeDir = 0; 
int irisSize = 16; 
char tagString[13]; 
int purLen = 0; //length of purr 
 
char tag1[13] = "8400338D3C06"; 
char tag2[13] = "84003364D102"; 
char tag3[13] = "8400336635E4"; 
char tag4[13] = "8400338A93AE"; 
char tag5[13] = "4E0004467D71"; 
 
 
void setup()   {                 
  Serial.begin(9600); 
  Serial1.begin(9600); 
  pinMode(PURM, OUTPUT); 
  digitalWrite(PURM, HIGH); 
  pinMode(RFIDResetPin, OUTPUT); 
  digitalWrite(RFIDResetPin, HIGH); 
  SPI.begin (); 
  oled.ssd1306_init(SSD1306_SWITCHCAPVCC); 
  oled.display(); 
  oled.clear(); 
 
  pinMode(SERV, OUTPUT); 
  pinMode(29, INPUT); 
  pinMode(28, OUTPUT); 
  pinMode(31, OUTPUT); 
  digitalWrite(31, LOW); 
  digitalWrite(28, HIGH); 
} 
 
//int DEBUG = 0; 
 
char serv = 0; 
int tailcur; 
void loop() { 
  eyeControl(); 
  oled.display(); 
  pc++; 
  if (!(pc%READCARD)) { 
20 
 
    readTag(); 
  }   
  if (!(purLen)) {     
     purr(); 
  }  else { 
     purLen--; 
  }   
   
  if (!(pc%30)){ 
    tailcur = tail(); 
  } else if (!(pc%10)){ 
    analogWrite(SERV, tailcur + 10 - random(10)); 
  } 
} 
 
int tail() { 
   int temp = 250 - random(170); 
   analogWrite(SERV, temp); 
   Serial.println(temp); 
   return temp; 
} 
 
char servoSafe[] = {}; 
 
void tailTest(){ 
   for(int i = 0; i < 170; i++){  
      int temp = 250 - i; 
      analogWrite(SERV, temp); 
      Serial.println(temp); 
      delay(3000); 
    } 
} 
 
char im[128]; 
char data[128]; 
void tapFollow(){ 
  int static i = 0; 
  if (i < 128){ 
    data[i] = analogRead(MICRO) / 4; 
    im[i] = 0; 
    i++;   
  } 
  else{ 
    fix_fft(data,im,7,0); 
    oled.clear(); 
    for (i=0; i< 64;i++){ 
      oled.setpixel(i, data[i] + 20, WHITE); 
    } 
21 
 
     
    oled.display(); 
  } 
} 
 
void lineAnimate(unsigned  char  pic[], int times) { 
   int i, offset;     
   for (i = 0; i < times; i ++){ 
      oled.clear(); 
      offset = i%4; 
      offset*= 4; 
      lines(offset); 
      oled.drawbitmap(0, 0, pic, 128, 64, WHITE); 
      oled.display(); 
   } 
   oled.clear(); 
} 
 
int xpos = 200 , ypos = 200 , zpos = 200; 
void purr(){ 
  boolean mOn = false; 
   
  int temp = xpos;   
   
  digitalWrite(PURM, HIGH);   
   
  xpos = analogRead(ACCX);   
  mOn = (abs(temp - xpos) > 300); 
  temp = ypos; 
  ypos = analogRead(ACCY); 
  if (!mOn) { 
     
    mOn = (abs(temp - ypos) > 300); 
  }   
   
  temp = zpos; 
  zpos = analogRead(ACCZ); 
  if (!mOn) {    
     
    mOn = (abs(temp - zpos) > 300); 
  }    
  if (mOn) { 
    startPlayback(meow, 5000); 
    purLen = MAXPURLEN; 
    digitalWrite(PURM, LOW); 
  } 
} 
 
22 
 
void drawCircle(int xMidPoint, int  yMidPoint, int radius){ 
    int f = 1 - radius; 
    int ddF_x = 1; 
    int ddF_y = -2 * radius; 
    int x = 0; 
    int y = radius; 
    //Top Middle 
    oled.setpixel(xMidPoint, yMidPoint - radius, WHITE); 
    while( x < y ) 
    { 
        if(f >= 0)  
        { 
            y--; 
            ddF_y += 2; 
            f += ddF_y; 
        } 
        x++; 
        ddF_x += 2; 
        f += ddF_x;     
        for( int i = 0; i < 5; i++) { 
           //Top Right 
           oled.setpixel(xMidPoint + x, yMidPoint - y - i, WHITE); 
           oled.setpixel(xMidPoint + y, yMidPoint - x - i, WHITE); 
 
          
           //Top Left 
           oled.setpixel(xMidPoint - x, yMidPoint - y - i, WHITE); 
           oled.setpixel(xMidPoint - y, yMidPoint - x - i, WHITE); 
        } 
    } 
} 
 
void testAccel(){ 
  char str[10];  
  int temp, i; 
  oled.clear(); 
  for (i = 300; i > 0; i--) { 
    temp = analogRead(ACCX);   
    itoa(temp, str, 10); 
    oled.drawstring(0, 0, str); 
   
    temp =  analogRead(ACCY); 
    itoa(temp, str, 10); 
    oled.drawstring(0, 1, str); 
   
    temp = analogRead(ACCZ); 
    itoa(temp, str, 10); 
    oled.drawstring(0, 2, str); 
23 
 
    oled.display(); 
  } 
  oled.clear(); 
} 
 
void love() { 
  digitalWrite(PURM, LOW); 
  lineAnimate(heart, 90); 
  digitalWrite(PURM, HIGH); 
} 
 
 
int eyeMove = 8; 
void food() {     
  digitalWrite(PURM, LOW); 
  lineAnimate(fish, 30);   
  startPlayback(munch, 20000);  
  for (int i = 0; i < 150; i++) { 
    oled.clear(); 
    drawCircle(65,70 + eyeMove++, 60); 
    eyeMove%=15; 
    oled.display();  
  } 
  oled.clear(); 
  digitalWrite(PURM, HIGH); 
} 
 
void microphone(){ 
  int tot = 0; 
  for (int i = 0; i < 10; i++) {  
    tot += analogRead(MICRO); 
  }   
  tot/=10;   
  Serial.println(tot);    
} 
 
void water() { 
  digitalWrite(PURM, LOW); 
   lineAnimate(drop, 100); 
   digitalWrite(PURM, HIGH); 
} 
 
void readTag(){   
  int index = 0, readByte; 
  boolean reading = false; 
 
  while(Serial1.available()){ 
 
24 
 
    readByte = Serial1.read(); //read next available byte 
 
    if(readByte == 2) reading = true; //begining of tag 
    if(readByte == 3) reading = false; //end of tag 
 
    if(reading && readByte != 2 && readByte != 10 && readByte != 13){ 
      tagString[index++] = readByte; 
    } 
  } 
  if(index) { 
     checkTag(tagString); //Check if it is a match      
     clearTag(tagString); //Clear the char of all value 
     resetReader(); //eset the RFID reader 
  }   
} 
 
void checkTag(char tag[]){ 
  tone(SPEAKER, 2000, 100); 
  if(compareTag(tag, tag1)){ // if matched tag1, do this 
    water(); 
  } else if(compareTag(tag, tag2)){ //if matched tag2, do this 
    food(); 
  }else if(compareTag(tag, tag3)){ 
    for (int i = 0; i < 4000; i++) { 
       tapFollow(); 
    } 
  }else if(compareTag(tag, tag4)){ 
     love(); 
  }else if(compareTag(tag, tag5)){ 
    water(); 
  } else{ 
    Serial.println(tag); //read out any unknown tag 
  } 
} 
 
void resetReader(){ 
  digitalWrite(RFIDResetPin, LOW); 
  digitalWrite(RFIDResetPin, HIGH); 
  delay(150); 
} 
 
void clearTag(char one[]){ 
  for(int i = 0; i < 12; i++){ 
    one[i] = 0; 
  } 
} 
 
boolean compareTag(char one[], char two[]){ 
25 
 
  for(int i = 0; i < 12; i++){ 
    if(one[i] != two[i]) { 
      return false; 
    } 
  } 
  return true; //no mismatches 
} 
 
void lines(int offset){ 
  int LINETHICK = 1; 
  int LINEEND = 128 - LINETHICK; 
   
  oled.fillrect(offset     , 0, LINETHICK, 64, WHITE); 
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);   
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
  if ((offset += 16) > LINEEND) { 
    offset %= 122; 
  } 
  oled.fillrect(offset, 0, LINETHICK, 64, WHITE);  
} 
 
void draweye(int dir, int blin, int thick) { 
   //blin is 0 - 32 where 0 is no blink and 32 is closed eye 
   //dir is direction of eye where 0 is center and +- 128 is where the iris is 
   //think is the width of the iris 0-64 
    
26 
 
   //eyeball 
   oled.drawbitmap(0, 0, eye, 128, 64, WHITE); 
   //iris 
   oled.fillrect(62 + dir, 0, thick, 64, BLACK);    
   //top eye lid 
   oled.fillrect(0, 0, 128, blin, BLACK); 
   //bottom eye lid 
   oled.fillrect(0, 64 - blin, 128, blin, BLACK); 
} 
 
volatile uint16_t sample; 
byte lastSample; 
unsigned char *sounddata_data = meow; 
 
ISR(TIMER1_COMPA_vect) { 
   if (sample >= sounddata_length) { 
       if (sample == sounddata_length + lastSample) { 
          stopPlayback(); 
       } 
       else { 
         OCR2A = sounddata_length + lastSample - sample; 
      } 
   } 
   else { 
      OCR2A = pgm_read_byte(&sounddata_data[sample]); 
   } 
   ++sample; 
} 
 
 
void startPlayback(unsigned char sound[], int length) 
{ 
    sounddata_data = sound; 
    sounddata_length = length; 
    pinMode(SPEAKER, OUTPUT); 
    // Set up Timer 2 to do pulse width modulation on the speaker 
    // pin. 
    // Use internal clock (datasheet p.160) 
    ASSR &= ~(_BV(EXCLK) | _BV(AS2)); 
 
    // Set fast PWM mode   
    TCCR2A |= _BV(WGM21) | _BV(WGM20); 
    TCCR2B &= ~_BV(WGM22); 
 
    // Do non-inverting PWM on pin OC2A  
    // On the Arduino this is pin 11. 
    TCCR2A = (TCCR2A | _BV(COM2A1)) & ~_BV(COM2A0); 
    TCCR2A &= ~(_BV(COM2B1) | _BV(COM2B0)); 
27 
 
 
    // No prescaler (p.158) 
    TCCR2B = (TCCR2B & ~(_BV(CS12) | _BV(CS11))) | _BV(CS10); 
 
    // Set initial pulse width to the first sample. 
    OCR2A = pgm_read_byte(&sounddata_data[0]); 
 
    // Set up Timer 1 to send a sample every interrupt. 
 
    cli(); 
    // Set CTC mode (Clear Timer on Compare Match) 
    // Have to set OCR1A *after*, otherwise it gets reset to 0! 
    TCCR1B = (TCCR1B & ~_BV(WGM13)) | _BV(WGM12); 
    TCCR1A = TCCR1A & ~(_BV(WGM11) | _BV(WGM10)); 
 
    // No prescaler (p.134) 
    TCCR1B = (TCCR1B & ~(_BV(CS12) | _BV(CS11))) | _BV(CS10); 
 
    // Set the compare register (OCR1A). 
    // OCR1A is a 16-bit register, so we have to do this with 
    // interrupts disabled to be safe. 
    OCR1A = F_CPU / SAMPLE_RATE;    // 16e6 / 8000 = 2000 
 
    // Enable interrupt when TCNT1 == OCR1A (p.136) 
    TIMSK1 |= _BV(OCIE1A); 
 
    lastSample = pgm_read_byte(&sounddata_data[sounddata_length-1]); 
    sample = 0; 
    sei(); 
} 
 
void stopPlayback() 
{ 
    // Disable playback per-sample interrupt. 
    TIMSK1 &= ~_BV(OCIE1A); 
 
    // Disable the per-sample timer completely. 
    TCCR1B &= ~_BV(CS10); 
 
    // Disable the PWM timer. 
    TCCR2B &= ~_BV(CS10); 
 
    digitalWrite(SPEAKER, LOW); 
} 
 
void testEyeSens() { 
  char str[10];  
  int temp = analogRead(PHOTO0);   
28 
 
  itoa(temp, str, 10); 
  oled.drawstring(0, 0, str); 
   
  temp =  analogRead(PHOTO1); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 1, str); 
   
  temp = analogRead(PHOTO2); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 2, str); 
  
  temp = analogRead(PHOTO4); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 4, str); 
  
  temp = analogRead(PHOTO5); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 5, str); 
  
  temp = analogRead(PHOTO6); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 6, str);   
   
  temp = pulseIn(8, 0); 
  //temp = analogRead(8); 
  itoa(temp, str, 10); 
  oled.drawstring(0, 7, str); 
} 
 
void eyeControl() { 
  int newDir = getDir(); 
  if (newDir - EYETWITCH > eyeDir){ 
    eyeDir += EYESPEED; 
  } else if (newDir +  EYETWITCH < eyeDir) { 
    eyeDir -= EYESPEED; 
  } 
  if (!curBl) { //see if want to blink 
     
    if (!random(curRand)) { 
      curBl = 1; 
      curRand = BLINKRAND; 
    } 
    curRand -= BLINKDEC; 
    draweye(eyeDir, curBl, irisSize); 
  } else if (curBl >= 64) { 
    curBl = 0; 
  } else if (curBl < 32 && curBl > 0)  { //opening 
     draweye(eyeDir, curBl, irisSize); 
29 
 
     curBl += 8; 
  } else if (curBl >= 32){ //closing 
      draweye(eyeDir, 64 - curBl, irisSize); 
      curBl += 8; 
  } 
} 
 
int getDir(){ 
  //set largest value to  
  //if largest value > current Current += IRISCHANGE 
  //else current -= irisChange   
  //may want to put in sensitivity 
   
  int bottomPin = 0; 
  int tempIris = analogRead(PHOTO0); 
  int piny = analogRead(PHOTO1) + 40; 
  if (piny < tempIris) { 
    bottomPin = 1; 
    tempIris = piny;     
  } 
  piny = analogRead(PHOTO2); 
  if (piny < tempIris) { 
    bottomPin = 2; 
    tempIris = piny;     
  } 
  piny = analogRead(PHOTO4); 
  if (piny < tempIris) { 
    bottomPin = 4; 
    tempIris = piny;     
  } 
  piny = analogRead(PHOTO5); 
  if (piny < tempIris) { 
    bottomPin = 5; 
    tempIris = piny;     
  } 
  piny = analogRead(PHOTO6); 
  if (piny < tempIris) { 
    bottomPin = 6; 
    tempIris = piny;     
  } 
  tempIris = 1000/tempIris * 3 + 20; 
  tempIris = (tempIris < 50) ? tempIris : 50; 
   
  if (tempIris < irisSize + 10) { 
     irisSize--; 
  } else if (tempIris > irisSize + 10){ 
    irisSize++; 
  } 
30 
 
  return bottomPin * 10 - 35; //7 * num - num/2 * 7 
} 
31 
 
Appendix B: Senior Project analysis 
• Summary of Functional Requirements 
Describe the overall capabilities of functions of your project or design. Describe what your 
project does. (Do not describe how you designed it.) 
 Riley is a stuffed animal cat that uses an Arduino to interface to many sensors.  Features include, 
light detection, object following, tone recognition, sound output, tilt sensing, and  RFID reading.  
• Primary Constraints 
Describe significant challenges or difficulties associated with your project or implementation. 
For example, what were limiting factors or other issues that impacted your approach? What made 
your project difficult? What parameters or specifications limited your options or directed your 
approach? 
 Each of the sensors took time to implement.  Combining all of their functionality to the overall 
software was also a challenge.  Fitting everything in the final stuffed animal also proved to be a 
challenge.  Memory limits and sensor sensitivity were the largest limiting factors of the project. 
• Economic 
o Original estimated cost of component parts (as of the start of your project) - approximately $150 
o Original estimated development time (as of the start of your project) - approximately 70 hours 
o Actual development time (at the end of your project) - about 100 hours. 
• If manufactured on a commercial basis: 
o Estimated number of devices to be sold per year - 10,000 
o Estimated manufacturing cost for each device - (depending on parts) $50 
o Estimated purchase price for each device  - $100 
o Estimated profit per year - $500,000 
o Estimated cost for user to operate device, per unit time (specify time interval) - n/a 
• Environmental 
Describe any environmental impact associated with manufacturing or use.  
 - Proper recycling of electronic parts and battery  
• Manufacturability 
 Describe any issues or challenges associated with manufacturing. 
  - Instead of an Arduino, a dedicated IC chip should be used to minimize expense/ resources 
• Sustainability 
o Describe any issues or challenges associated with maintaining the completed device or 
system.  
 The wirered connections are sensitive and physical shock or distress to the project may cause 
some of the wires to short/ open 
o Describe how the project impacts the sustainable use of resources.  - 
 - Oled screens use less energy than standard screens.  Nothing within the project is using rare 
materials, and production would minimally effect the use of sustainable resources 
o Describe any upgrades that would improve the design of the project. 
  - see senior project report.  Improvements include different object detection, filters and 
amplifiers on the microphone and speaker.   
o Describe any issues or challenges associated with upgrading the design.  
 - see senior project report.  Expenses or power consumption could increase depending on the 
upgrade 
• Ethical 
Describe ethical implications relating to the design, manufacture, use or misuse of the project.   
 The sock animal was purchased in China.  Factory conditions should be checked before full scale 
manufacturing. 
• Health and Safety 
Describe any health and safety concerns associated with design, manufacture or use. 
32 
 
 Any standard health and safety concerns with the development of electronic parts should be 
considered.  Nothing in particular would be dangerous while producing Riley. 
• Social and Political 
Describe any social and political concerns associated with design, manufacture or use.  
 As a comfort object Riley could help during developmental stages.  As a robot, Riley could 
potentially interest children in engineering at a young age.  Riley is also gender neutral and could appeal 
to girls as much as boy.  
• Development 
Describe any new tools or techniques used for either development or analysis that you learned 
independently during the course of your project.   
 Arduino IDE, how to interface any of my sensors, communication protocols through Arduino 
33 
 
Apendix C: Pin Mapping for Arduino 
ATmega2560-Arduino Pin Mapping 
Below is the pin mapping for the Atmega2560. The chip used in Arduino 2560. There are pin 
mappings to Atmega8 andAtmega 168/328 as well. 
Arduino Mega 2560 PIN diagram 
 
34 
 
The source SVG file is also available for download: 
PinMapping2560.zip 
Arduino Mega 2560 PIN mapping table 
Pin Number Pin Name Mapped Pin Name 
1 PG5 ( OC0B ) Digital pin 4 (PWM) 
2 PE0 ( RXD0/PCINT8 ) Digital pin 0 (PWM) (RX0) 
3 PE1 ( TXD0 ) Digital pin 1 (PWM) (TX0) 
4 PE2 ( XCK0/AIN0 )   
5 PE3 ( OC3A/AIN1 ) Digital pin 5 (PWM) 
6 PE4 ( OC3B/INT4 ) Digital pin 2 (PWM) 
7 PE5 ( OC3C/INT5 ) Digital pin 3 (PWM) 
8 PE6 ( T3/INT6 )   
9 PE7 ( CLKO/ICP3/INT7 )   
10 VCC VCC 
11 GND GND 
12 PH0 ( RXD2 ) Digital pin 17 (PWM) 
13 PH1 ( TXD2 ) Digital pin 16 (PWM) 
14 PH2 ( XCK2 ) (TX3) 
15 PH3 ( OC4A ) Digital pin 6 (PWM)(RX3 ) 
16 PH4 ( OC4B ) Digital pin 7 (PWM)(TX2) 
17 PH5 ( OC4C ) Digital pin 8 (PWM)(RX2 ) 
35 
 
18 PH6 ( OC2B ) Digital pin 9 (PWM)(TX1) 
19 PB0 ( SS/PCINT0 ) Digital pin 53 (PWM)(RX1) 
20 PB1 ( SCK/PCINT1 ) Digital pin 52 (PWM)(SDA) 
21 PB2 ( MOSI/PCINT2 ) Digital pin 51 (PWM)(SCL) 
22 PB3 ( MISO/PCINT3 ) Digital pin 50 
23 PB4 ( OC2A/PCINT4 ) Digital pin 10 (PWM) 
24 PB5 ( OC1A/PCINT5 ) Digital pin 11 (PWM) 
25 PB6 ( OC1B/PCINT6 ) Digital pin 12 (PWM) 
26 PB7 ( OC0A/OC1C/PCINT7 ) Digital pin 13 (PWM) 
27 PH7 ( T4 )   
28 PG3 ( TOSC2 )   
29 PG4 ( TOSC1 )   
30 RESET RESET 
31 VCC VCC 
32 GND GND 
33 XTAL2 XTAL2 
34 XTAL1 XTAL1 
35 PL0 ( ICP4 ) Digital pin 49 
36 PL1 ( ICP5 ) Digital pin 48 
37 PL2 ( T5 ) Digital pin 47 
36 
 
38 PL3 ( OC5A ) Digital pin 46 (PWM) 
39 PL4 ( OC5B ) Digital pin 45 (PWM) 
40 PL5 ( OC5C ) Digital pin 44 (PWM) 
41 PL6 Digital pin 43 
42 PL7 Digital pin 42 
43 PD0 ( SCL/INT0 ) Digital pin 21 (SCL) 
44 PD1 ( SDA/INT1 ) Digital pin 20 (SDA) 
45 PD2 ( RXDI/INT2 ) Digital pin 19 
46 PD3 ( TXD1/INT3 ) Digital pin 18 
47 PD4 ( ICP1 )   
48 PD5 ( XCK1 )   
49 PD6 ( T1 )   
50 PD7 ( T0 ) Digital pin 38 
51 PG0 ( WR ) Digital pin 41 
52 PG1 ( RD ) Digital pin 40 
53 PC0 ( A8 ) Digital pin 37 
54 PC1 ( A9 ) Digital pin 36 
55 PC2 ( A10 ) Digital pin 35 
56 PC3 ( A11 ) Digital pin 34 
57 PC4 ( A12 ) Digital pin 33 
37 
 
58 PC5 ( A13 ) Digital pin 32 
59 PC6 ( A14 ) Digital pin 31 
60 PC7 ( A15 ) Digital pin 30 
61 VCC VCC 
62 GND GND 
63 PJ0 ( RXD3/PCINT9 ) Digital pin 15 
64 PJ1 ( TXD3/PCINT10 ) Digital pin 14 
65 PJ2 ( XCK3/PCINT11 )   
66 PJ3 ( PCINT12 )   
67 PJ4 ( PCINT13 )   
68 PJ5 ( PCINT14 )   
69 PJ6 ( PCINT 15 )   
70 PG2 ( ALE ) Digital pin 39 
71 PA7 ( AD7 ) Digital pin 29 
72 PA6 ( AD6 ) Digital pin 28 
73 PA5 ( AD5 ) Digital pin 27 
74 PA4 ( AD4 ) Digital pin 26 
75 PA3 ( AD3 ) Digital pin 25 
76 PA2 ( AD2 ) Digital pin 24 
77 PA1 ( AD1 ) Digital pin 23 
38 
 
78 PA0 ( AD0 ) Digital pin 22 
79 PJ7   
80 VCC VCC 
81 GND GND 
82 PK7 ( ADC15/PCINT23 ) Analog pin 15 
83 PK6 ( ADC14/PCINT22 ) Analog pin 14 
84 PK5 ( ADC13/PCINT21 ) Analog pin 13 
85 PK4 ( ADC12/PCINT20 ) Analog pin 12 
86 PK3 ( ADC11/PCINT19 ) Analog pin 11 
87 PK2 ( ADC10/PCINT18 ) Analog pin 10 
88 PK1 ( ADC9/PCINT17 ) Analog pin 9 
89 PK0 ( ADC8/PCINT16 ) Analog pin 8 
90 PF7 ( ADC7/PCINT15 ) Analog pin 7 
91 PF6 ( ADC6/PCINT14 ) Analog pin 6 
92 PF5 ( ADC5/TMS ) Analog pin 5 
93 PF4 ( ADC4/TMK ) Analog pin 4 
94 PF3 ( ADC3 ) Analog pin 3 
95 PF2 ( ADC2 ) Analog pin 2 
96 PF1 ( ADC1 ) Analog pin 1 
97 PF0 ( ADC0 ) Analog pin 0 
39 
 
98 AREF Analog Reference 
99 GND GND 
100 AVCC VCC 
 
40 
 
  
 
ID Innovations EM module series V21 
ID2 / ID12 / ID20 PIN-OUT 
ID SERIES DATASHEET Mar 01, 2005 
 
 
 
 
The ID2. ID12 and ID20 are similar to the obsolete ID0, 
ID10 and ID15 MK(ii) series devices, but they have extra 
pins that allow Magnetic Emulation output to be included 
in the functionality. The ID-12 and ID-20 come with 
internal antennas, and have read ranges of 12+ cm and 
16+ cm, respectively. With an external antenna, the ID-2 
can deliver read ranges of up to 25 cm. All three readers 
support ASCII, Wiegand26 and Magnetic ABA Track2 
data formats. 
 
 
1. GND 
2. RES (Reset Bar) 
3. ANT (Antenna) 
4. ANT (Antenna) 
5. CP 
6. Future 
7. +/-  (Format Selector) 
8. D1 (Data Pin 1) 
9. D0 (Data Pin 0) 
10. LED (LED / Beeper) 
11. +5V 
 
 
Operational and Physical Characteristics 
Parameters ID-2 ID-12 ID-20 
Read Range N/A (no internal antenna) 12+ cm 16+ cm 
Dimensions 21 mm x 19 mm x 6 mm 26 mm x 25 mm x 7 mm 40 mm x 40 mm x 9 mm 
Frequency 125 kHz 125 kHz 125 kHz 
Card Format EM 4001 or compatible EM 4001 or compatible EM 4001 or compatible 
Encoding Manchester 64-bit, modulus 64 Manchester 64-bit, modulus 64 Manchester 64-bit, modulus 64 
Power Requirement 5 VDC @ 13mA nominal 5 VDC @ 30mA nominal 5 VDC @ 65mA nominal 
I/O Output Current +/-200mA PK - - 
Voltage Supply Range +4.6V through +5.4V +4.6V through +5.4V +4.6V through +5.4V 
 
Pin Description & Output Data Formats 
Pin 
No. Description ASCII Magnet Emulation Wiegand26 
Pin 1 Zero Volts and Tuning Capacitor Ground GND 0V GND 0V GND 0V 
Pin 2 Strap to +5V Reset Bar Reset Bar Reset Bar 
Pin 3 To External Antenna and Tuning Capacitor Antenna Antenna Antenna 
Pin 4 To External Antenna Antenna Antenna Antenna 
Pin 5 Card Present  No function Card Present  * No function 
 
 
 
ID-2/ID-12 Brief Data
ID Innovations EM module series V21 
Pin 6 Future Future Future Future 
Pin 7 Format Selector (+/-) Strap to GND Strap to Pin 10 Strap to +5V 
Pin 8 Data 1 CMOS Clock * One Output * 
Pin 9 Data 0 TTL Data (inverted) Data  * Zero Output * 
Pin 10 3.1 kHz Logic Beeper / LED Beeper / LED Beeper / LED 
Pin 11 DC Voltage Supply +5V +5V +5V 
                                                                        
* Requires 4K7 Pull-up resistor to +5V   
Circuit Diagram for the ID2 
8
10
ID2
5
7
2 9
BOTTOM VIEW
11
6
1
3
4
 Power In
+5 Volt
Beeper
Tune
Capacitor
Antenna
D1
R2
R3
+
C2
Q1
+
C1
R1
D2
LED
C3 L1
U1 LM7805
IN
1
C
O
M
2
OUT
3
 
 
Circuit Diagram for the ID-12/ID20 
 
ID Innovations EM module series V21 
ID2 / ID12 / ID20 PIN-OUT 
 
 
The ID2-RW, ID12-RW and ID15-RW are a new series 
of Read/Write modules for the Temec Q5 tag. It has full 
functionality including password. They contain built-in 
algorithms to assist customers programming the popular 
Sokymat Unique type tag. Password protection is 
allowed. Control is via a host computer using a simple 
terminal program such as hyper terminal or Qmodem.  
 
 
1 GND 
2 RES (Reset Bar) 
3 ANT (Antenna) 
4 ANT (Antenna) 
5 Future 
6 Program LED 
7 ASCII in 
8 Future 
9 ASCII Out 
10 Read (LED / Beeper) 
11 +5V 
 
 
 
Operational and Physical Characteristics 
Parameters ID-2RW ID-12RW ID-20RW 
Read Range N/A (no internal antenna) 12+ cm (Unique Format) 15+ cm (Unique Format) 
Dimensions 21 mm x 19 mm x 6 mm 26 mm x 25 mm x 7 mm 40 mm x 40 mm x 9 mm 
Frequency 125 kHz 125 kHz 125 kHz 
Card Format Temec Q5555 Temec Q5555 Temec Q5555 
Read Encoding Manchester modulus 64 Manchester modulus 64 Manchester modulus 64 
Power Requirement 5 VDC @ 13mA nominal 5 VDC @ 30mA nominal 5 VDC @ 50mA nominal 
I/O Output Current +/-200mA PK - - 
Voltage Supply Range +4.6V through +5.4V +4.6V through +5.4V +4.6V through +5.4V 
Coil Detail L = 0.6mH - 1.5mH, Q =  15-30 -  - 
Description 
A simple terminal program such as Qmodem or Hyper-terminal can be used to send commands to the 
module. The blocks are individually programmable. The command interface is simple to use and easily 
understood. The programmer also has two types of internal reader. One of these is provided to read 
Sokymat ‘Unique’ type tag configuration.  The module does not require a MAX232 type chip interface. 
The module does not need an RS232 interface such as a MAX232 IC. The input pin7 goes to the computer 
through a 4k7 resistor and the output goes to the computer through a 100R resistor. 
 
 
 
 
 
 
 
 
         
 
ID-2RW/ID-12RW Brief Data
ID Innovations EM module series V21 
DATA FORMATS 
 
Output Data Structure – ASCII 
STX (02h) DATA (10 ASCII) CHECK SUM (2 ASCII) CR LF ETX (03h) 
[The 1byte (2 ASCII characters) Check sum is the “Exclusive OR” of the 5 hex bytes (10 ASCII) Data characters.] 
 
Output Data Structure – Wiegand26 
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
P E E E E E E E E E E E E O O O O O O O O O O O O P
Even parity (E) Odd parity (O) 
 
P = Parity start bit and stop bit 
  
Output Data Magnetic ABA Track2 
10 Leading Zeros SS Data ES LCR 10 Ending Zeros 
[SS is the Start Character of 11010, ES is the end character of 11111, LRC is the Longitudinal Redundancy Check.] 
Magnetic Emulation Waveforms 
 
 
 
Start and End Sequences For Magnetic Timing 
 
 
DATA TIMINGS FOR MAGNETIC EMULATION 
ID Innovations EM module series V21 
 
 
The magnetic Emulation Sequence starts with the Card Present Line going active (down). There next 
follows 10 clocks with Zero ‘0’ data. At the end of the 10 leading clocks the start character (11010) is sent 
and this is followed by the data. At the end of the data the end character is sent followed by the LCR. 
Finally 10 trailing clocks are sent and the card present line is raised. 
The data bit duration is approximately 330uS. The approximate clock duration is 110uS. Because of the 
symmetry data can be clocked off either the rising or falling edge of the clock.  
 
Dimensions (Top View) (mm) 
 
 ID-0/ID-2wr ID-10/ID-12wr ID-15/ID-20wr 
 Nom. Min. Max. Nom. Min. Max. Nom. Min. Max 
A 12.0 11.6 12.4 12.0 11.6 12.4 12.0 11.6 12.4 
B 8.0 7.6 8.4 8.0 7.6 8.4 8.0 7.6 8.4 
C 15.0 14.6 15.4 15.0 14.6 15.4 15.0 14.6 15.4 
D 20.5 20.0 21.5 25.3 24.9 25.9 40.3 40.0 41.0 
E 18.5 18.0 19.2 20.3 19.8 20.9 27.8 27.5 28.5 
F 14.0 13.0 14.8 16.3 15.8 16.9 22.2 21.9 23.1 
G 22.0 21.6 22.4 26.4 26.1 27.1 38.5 38.2 39.2 
P 2.0 1.8 2.2 2.0 1.8 2.2 2.0 1.8 2.2 
H 5.92 5.85 6.6 6.0 5.8 6.6 6.8 6.7 7.0 
J 9.85 9.0 10.5 9.9 9.40 10.5 9.85 9.4 10.6 
W 0.66 0.62 0.67 0.66 0.62 0.67 0.66 0.62 0.67 
Note – measurements do not include any burring of edges.  
NOTICE - Innovated Devices reserve the right to change these specifications without prior notice. 
ID Innovations EM module series V21 
Designing Coils for ID2 
 
The recommended Inductance is 1.08mH to be used with an internal tuning capacitor of 1n5.  In general 
the bigger the antenna the better, provided the reader is generating enough field strength to excite the tag. 
The ID-2 is relatively low power so a maximum coil size of 15x15cm is recommended if it is intended to 
read ISO cards. If the reader is intended to read glass tags the maximum coil size should be smaller, say 
10x10cm. 
 
There is a science to determine the exact size of an antenna but there are so many variables that in general it 
is best to get a general idea after which a degree of ‘Try it and see’ is unavoidable. 
 
If the reader is located in a position where there is a lot of heavy interference then less range cannot be 
avoided. In this situation the coil should be made smaller to increase the field strength and coupling. 
 
It is difficult to give actual examples of coils for hand wounding because the closeness and tightness of the 
winding will significantly change the inductance. A professionally wound coil will have much more 
inductance than a similar hand wound coil. 
 
For those who want a starting point into practical antenna winding it was found that 63 turns on a 120mm 
diameter former gave an inductance of 1.08mH. For those contemplating adding an additional tuning 
capacitor it was found that 50 turns on a 120mm diameter former gave 700uH. The wire diameter is not 
important.  
Anybody who wishes to be more theoretical we recommend a trip to the Microchip Website where we 
found an application sheet for Loop Antennas. 
http://ww1.microchip.com/downloads/en/AppNotes/00831b.pdf 
The Tuning Capacitor 
It is recommended that the internal 1n% capacitor is used for tuning, however a capacitor may be also be 
added externally. The combined capacitance should not exceed 2n7. Do not forget that the choice of tuning 
capacitor can also substantially affect the quality of your system. The Id12 is basically an ID2 with an 
internal antenna. The loss in an ID12 series antenna is required to be fairly high to limit the series current. 
A low Q will hide a lot of the shortcomings of the capacitor, but for quality and reliability and repeatability 
the following capacitors are recommend. 
 
Polypropylene  Good Readily available. Ensure AC voltage at 125kHz is sufficient. 
COG/NPO  Excellent. Best Choice 
Silver Mica  Excellent but expensive 
Polycarbonate  Good Readily available. Ensure AC voltage at 125kHz is sufficient. 
 
 
 
Voltage Working. 
 A capacitor capable of withstanding the RMS voltage at 125KHz MUST be chosen. The working voltage 
will depend on the coil design. I suggest the designer start with rugged 1n5 Polypropylene 630v capacitor 
to do his experiments and the come down to a suitable size/value. The capacitor manufacturer will supply 
information on their capacitors. Do not simply go by the DC voltage. This means little. A tolerance of 2% 
is preferable. A tolerance of 5% is acceptable. 
 
 
 
Fine Tuning 
We recommend using an oscilloscope for fine-tuning. Connect the oscilloscope to observe the 125KHz AC 
voltage across the coil. Get a sizeable piece of ferrite and bring it up to the antenna loop. If the voltage 
increases then you need more inductance (or more capacitance). If the voltage decreases as you bring the 
ferrite up to the antenna then the inductance is too great. If you have no ferrite then a piece of aluminum 
ID Innovations EM module series V21 
sheet may be used for testing in a slightly different way. Opposing currents will flow in the aluminum and 
it will act as a negative inductance. If the 125kH AC voltage increases as the aluminum sheet approaches 
the antenna then the inductance is too high. Note it may be possible that the voltage will first maximize 
then decrease. This simply means that you are near optimum tuning. If you are using ferrite then the coil is 
a little under value and if you are using an aluminum sheet then the coil is a over under value. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
ID Innovations  
Advanced Digital Reader Technology       
----Better by Design 
                    PRODUCT SPECIFICATION        Doc:   MD9745APZ-F
This specification applies to the electret condenser microphone outlined within this document. 
Model Number: MD9745APZ-F
4.5x
II.     Mechanical Characteristics
ITEM SYMBOL TEST CONDITION MINIMUM STANDARD MAXIMUM UNITS
Sensitivity S f=1kHz, Pin=1Pa dB
0dB=1V/Pa
Impedance Zout   kΩ
Directivity  
Current Consumption I mA
S/N Ratio S/N (A)  f=1kHz, Pin=1Pa
A Curve
dB
Sensitivity Reduction ∆S dB
Frequency Range
 
-44-46 -42
f=1kHz, Pin=1Pa 2.2
OMNI-DIRECTIONAL  
  0.5 
55   
  -3
  100-10,000  Hz
Frequency Response
Schematic Diagram of 
Circuit
Dimensions 9.7∅ 
I.    Electrical Characteristics
See Drawing in Section IV
Weight 1.0Less than          g
Solderering Heat Shock To be no  interferance in operation after soldering temperature exposure at 260°C +/-5°C  
for 2 +/- 0.5 seconds.
Terminal Mechanical 
Strength
Not Applicable
Absolute Maximum 
Ratings
10
Operating Voltage Storage Temperature 
Range
Vs (V) Tstg °C
-25°C to +60°C
  
 f=1kHz, Pin=1Pa
Vs= 2.0 1.5-
Test Condition (Vs=        V, RL=           k ohm, Ta=20°C, RH=65%)2.0 2.2
Operation Temperature 
Range
Tope °C 
-25°C to +55°C
Issued Date: 2004/6/10 Version: A
                    PRODUCT SPECIFICATION        Doc:   MD9745APZ-F
III.     Reliability Tests
Vibration Test The microphone to have no interferance in operation after vibrations, 10Hz to 55Hz for 1 
minute full amplitude 1.52mm, for 2 hours at three axises.
Drop Test The microphone unit must operate when dropped three times once on each axis from a 
height of 1m onto a metal plate.
Temperature Test The microphone unit must operate within its sensitivity specifications after 
subjected to the following conditions: +60°C for 240 hrs, and exposed to room 
temperature for 2 hrs.
The microphone unit must operate within its sensitivity specifications after 
subjected to the following conditions: -25°C for 240 hrs, and exposed to room 
temperature for 2 hrs.
High
Low
Humidity Test +40°C at 95%RH for 240 hrs
Temperature Cycle Test After exposure at -25°C for 30 minutes, at+20°C for 10 minutes, at +60°C for 30 minutes, at 
+20°C for 10 minutes, 5 cycles.  (The measurement to be done after 2 hrs of conditioning at 
+20°C.)
After any of the following tests performed, the sensitivity of the microphone unit 
shall not deviate more than ±3dB from its initial value.  The microphone shall 
maintain its initial operation and appearance.  Measurements for tests with 
thermal requirements are to be done after 2hrs of condistioning at 20°C.
Note:
IV.     Dimensional Drawing
The information contained in this literature is based on our experience to date and is believed to be reliable and it is subject to change without notice.  It 
is intended as a guide for use by persons having technical skill at their own discretion and risk.  We do not guarantee  favorable results or assume any 
liability in connection with its use.  Dimensions contained herein are for reference purposes only.  For specific dimensional requirements consult 
factory.  This publication is not to be taken as a license to operate under, or recommendation to infringe any existing patents.  This supersedes and 
voids all previous literature.
V.     Other
 
Issued Date: 2004/6/10 Version: A
Document Number: MMA7361L
Rev 0, 04/2008
Freescale Semiconductor
Technical Data±1.5g, ±6g Three Axis Low-g 
Micromachined Accelerometer
The MMA7361L is a low power, low profile capacitive micromachined 
accelerometer featuring signal conditioning, a 1-pole low pass filter, 
temperature compensation, self test, 0g-Detect which detects linear freefall, 
and g-Select which allows for the selection between 2 sensitivities. Zero-g 
offset and sensitivity are factory set and require no external devices. The 
MMA7361L includes a Sleep Mode that makes it ideal for handheld battery 
powered electronics.
Features
• 3mm x 5mm x 1.0mm LGA-14 Package
• Low Current Consumption: 400 μA
• Sleep Mode: 3 μA
• Low Voltage Operation: 2.2 V – 3.6 V
• High Sensitivity (800 mV/g @ 1.5g)
• Selectable Sensitivity (±1.5g, ±6g)
• Fast Turn On Time (0.5 ms Enable Response Time)
• Self Test for Freefall Detect Diagnosis
• 0g-Detect for Freefall Protection
• Signal Conditioning with Low Pass Filter
• Robust Design, High Shocks Survivability
• RoHS Compliant
• Environmentally Preferred Product
• Low Cost
Typical Applications
• 3D Gaming: Tilt and Motion Sensing, Event Recorder
• HDD MP3 Player: Freefall Detection
• Laptop PC: Freefall Detection, Anti-Theft
• Cell Phone: Image Stability, Text Scroll, Motion Dialing, E-Compass
• Pedometer: Motion Sensing
• PDA: Text Scroll
• Navigation and Dead Reckoning: E-Compass Tilt Compensation
• Robotics: Motion Sensing
ORDERING INFORMATION
Part Number Temperature Range
Package 
Drawing Package Shipping
MMA7361LT –40 to +85°C 1977-01 LGA-14 Tray
MMA7361LR1 –40 to +85°C 1977-01 LGA-14 7” Tape & Reel
MMA7361LR2 –40 to +85°C 1977-01 LGA-14 13” Tape & Reel
MMA7361L
MMA7361L: XYZ AXIS
ACCELEROMETER
±1.5g, ±6g
14 LEAD
LGA
CASE 1977-01
Bottom View
Figure 1. Pin Connections
Top View
1
2
3
4
5
6
7
8
9
1
0
1
1
1
2
1
3
1
4
N/C
XOUT
ZOUT
YOUT
VSS
VDD
Sleep
N/C
0g-Detect
g-Select
Self Test
N/C
N/C
N/C© Freescale Semiconductor, Inc., 2008. All rights reserved.
Figure 2. Simplified Accelerometer Functional Block Diagram
ELECTRO STATIC DISCHARGE (ESD)
WARNING: This device is sensitive to electrostatic 
discharge.
Although the Freescale accelerometer contains internal 
2000 V ESD protection circuitry, extra precaution must be 
taken by the user to protect the chip from ESD. A charge of 
over 2000 volts can accumulate on the human body or 
associated test equipment. A charge of this magnitude can 
alter the performance or cause failure of the chip. When 
handling the accelerometer, proper ESD precautions should 
be followed to avoid exposing the device to discharges which 
may be detrimental to its performance.
Table 1. Maximum Ratings
(Maximum ratings are the limits to which the device can be exposed without causing permanent damage.)
Rating Symbol Value Unit
Maximum Acceleration (all axis) gmax ±5000 g
Supply Voltage VDD –0.3 to +3.6 V
Drop Test(1)
1. Dropped onto concrete surface from any axis.
Ddrop 1.8 m
Storage Temperature Range Tstg –40 to +125 °C
Sleep
Self Test
C to V
CONVERTER
XOUT
YOUT
ZOUT
OSCILLATOR CLOCKGEN
g-Select
X-TEMP
COMP
G-CELL
SENSOR
GAIN
+
FILTER
CONTROL LOGIC
NVM TRIM
CIRCUITS
Y-TEMP
COMP
Z-TEMP
COMP
VDD
VSS
0g-Detect
SELFTESTSensors
2 Freescale Semiconductor
MMA7361L
Table 2. Operating Characteristics 
Unless otherwise noted: -40°C < TA < 85°C, 2.2 V < VDD < 3.6 V, Acceleration = 0g, Loaded output(1)
Characteristic Symbol Min Typ Max Unit
Operating Range(2)
Supply Voltage(3)
Supply Current(4)
Supply Current at Sleep Mode(4)
Operating Temperature Range
Acceleration Range, X-Axis, Y-Axis, Z-Axis
g-Select: 0
g-Select: 1
VDD
IDD
IDD
TA
gFS
gFS
2.2
—
—
-40
—
—
3.3
400
3
—
±1.5
±6.0
3.6
600
10
+85
—
—
V
μA
μA
°C
g
g
Output Signal
Zero-g (TA = 25°C, VDD = 3.3 V)(5), (6)
Zero-g(4)
Sensitivity (TA = 25°C, VDD = 3.3 V)
1.5g
6g
Sensitivity(4)
Bandwidth Response
XY
Z
Output Impedance
0g-Detect
VOFF
VOFF, TA
S1.5g
S6g
S,TA
f-3dBXY
f-3dBZ
ZO
0gdetect
1.485
-2.0
740
190.6
-0.0075
—
—
—
-0.4
1.65
±0.5
800
206
±0.002
400
300
32
0
1.815
+2.0
860
221.5
+0.0075
—
—
—
+0.4
V
mg/°C
mV/g
mV/g
%/°C
Hz
Hz
kΩ
g
Self Test
Output Response
XOUT, YOUT
ZOUT
Input Low
Input High
ΔgSTXY
ΔgSTZ
VIL
VIH
+0.05
+0.8
VSS
0.7 VDD
-0.1
+1.0
—
—
—
+1.2
0.3 VDD
VDD
g
g
V
V
Noise
Power Spectral Density RMS (0.1 Hz – 1 kHz)(4) nPSD — 350 — μg/
Control Timing
Power-Up Response Time(7)
Enable Response Time(8)
Self Test Response Time(9)
Sensing Element Resonant Frequency
XY
Z
Internal Sampling Frequency
tRESPONSE
tENABLE
tST
fGCELLXY
fGCELLZ
fCLK
—
—
—
—
—
—
1.0
0.5
2.0
6.0
3.4
11
2.0
2.0
5.0
—
—
—
ms
ms
ms
kHz
kHz
kHz
Output Stage Performance
Full-Scale Output Range (IOUT = 3 µA) VFSO VSS+0.1 — VDD–0.1 V
Nonlinearity, XOUT, YOUT, ZOUT NLOUT -1.0 — +1.0 %FSO
Cross-Axis Sensitivity(10) VXY, XZ, YZ -5.0 — +5.0 %
1. For a loaded output, the measurements are observed after an RC filter consisting of an internal 32kΩ resistor and an external 3.3nF capacitor 
(recommended as a minimum to filter clock noise) on the analog output for each axis and a 0.1μF capacitor on VDD - GND. The output sensor 
bandwidth is determined by the Capacitor added on the output. f = 1/2π * (32 x 103) * C. C = 3.3 nF corresponds to BW = 1507HZ, which is 
the minimum to filter out internal clock noise.
2. These limits define the range of operation for which the part will meet specification.
3. Within the supply range of 2.2 and 3.6 V, the device operates as a fully calibrated linear accelerometer. Beyond these supply limits the device 
may operate as a linear device but is not guaranteed to be in calibration.
4. This value is measured with g-Select in 1.5g mode.
5. The device can measure both + and – acceleration. With no input acceleration the output is at midsupply. For positive acceleration the output 
will increase above VDD/2. For negative acceleration, the output will decrease below VDD/2.
6. For optimal 0g offset performance, adhere to AN3484 and AN3447
7. The response time between 10% of full scale VDD input voltage and 90% of the final operating output voltage.
8. The response time between 10% of full scale Sleep Mode input voltage and 90% of the final operating output voltage.
9. The response time between 10% of the full scale self test input voltage and 90% of the self test output voltage.
10. A measure of the device’s ability to reject an acceleration applied 90° from the true axis of sensitivity.
HzSensors
Freescale Semiconductor 3
MMA7361L
PRINCIPLE OF OPERATION
The Freescale accelerometer is a surface-micromachined 
integrated-circuit accelerometer.
The device consists of a surface micromachined 
capacitive sensing cell (g-cell) and a signal conditioning ASIC 
contained in a single package. The sensing element is sealed 
hermetically at the wafer level using a bulk micromachined 
cap wafer.
The g-cell is a mechanical structure formed from 
semiconductor materials (polysilicon) using semiconductor 
processes (masking and etching). It can be modeled as a set 
of beams attached to a movable central mass that move 
between fixed beams. The movable beams can be deflected 
from their rest position by subjecting the system to an 
acceleration (Figure 3).
As the beams attached to the central mass move, the 
distance from them to the fixed beams on one side will 
increase by the same amount that the distance to the fixed 
beams on the other side decreases. The change in distance 
is a measure of acceleration.
The g-cell beams form two back-to-back capacitors 
(Figure 3). As the center beam moves with acceleration, the 
distance between the beams changes and each capacitor's 
value will change, (C = Aε/D). Where A is the area of the 
beam, ε is the dielectric constant, and D is the distance 
between the beams.
The ASIC uses switched capacitor techniques to measure 
the g-cell capacitors and extract the acceleration data from 
the difference between the two capacitors. The ASIC also 
signal conditions and filters (switched capacitor) the signal, 
providing a high level output voltage that is ratiometric and 
proportional to acceleration.
Figure 3. Simplified Transducer Physical Model
SPECIAL FEATURES
0g-Detect
The sensor offers a 0g-Detect feature that provides a logic 
high signal when all three axes are at 0g. This feature 
enables the application of Linear Freefall protection if the 
signal is connected to an interrupt pin or a poled I/O pin on a 
microcontroller.
Self Test
The sensor provides a self test feature that allows the 
verification of the mechanical and electrical integrity of the 
accelerometer at any time before or after installation. This 
feature is critical in applications such as hard disk drive 
protection where system integrity must be ensured over the 
life of the product. Customers can use self test to verify the 
solderability to confirm that the part was mounted to the PCB 
correctly. To use this feature to verify the 0g-Detect function, 
the accelerometer should be held upside down so that the 
z-axis experiences -1g. When the self test function is 
initiated, an electrostatic force is applied to each axis to 
cause it to deflect. The x- and y-axis are deflected slightly 
while the z-axis is trimmed to deflect 1g. This procedure 
assures that both the mechanical (g-cell) and electronic 
sections of the accelerometer are functioning.
g-Select
The g-Select feature allows for the selection between two 
sensitivities. Depending on the logic input placed on pin 10, 
the device internal gain will be changed allowing it to function 
with a 1.5g or 6g sensitivity (Table 3). This feature is ideal 
when a product has applications requiring two different 
sensitivities for optimum performance. The sensitivity can be 
changed at anytime during the operation of the product. The 
g-Select pin can be left unconnected for applications 
requiring only a 1.5g sensitivity as the device has an internal 
pull-down to keep it at that sensitivity (800mV/g)). 
Sleep Mode
The 3 axis accelerometer provides a Sleep Mode that is 
ideal for battery operated products. When Sleep Mode is 
active, the device outputs are turned off, providing significant 
reduction of operating current. A low input signal on pin 7 
(Sleep Mode) will place the device in this mode and reduce 
the current to 3 μA typ. For lower power consumption, it is 
recommended to set g-Select to 1.5g mode. By placing a high 
input signal on pin 7, the device will resume to normal mode 
of operation. 
Filtering
The 3 axis accelerometer contains an onboard single-pole 
switched capacitor filter. Because the filter is realized using 
switched capacitor techniques, there is no requirement for 
external passive components (resistors and capacitors) to set 
the cut-off frequency.
Ratiometricity
Ratiometricity simply means the output offset voltage and 
sensitivity will scale linearly with applied supply voltage. That 
is, as supply voltage is increased, the sensitivity and offset 
increase linearly; as supply voltage decreases, offset and 
sensitivity decrease linearly. This is a key feature when 
interfacing to a microcontroller or an A/D converter because 
it provides system level cancellation of supply induced errors 
in the analog to digital conversion process.
Acceleration
Table 3. g-Select Pin Description
g-Select g-Range Sensitivity
0 1.5g 800 mV/g
1 6g 206 mV/gSensors
4 Freescale Semiconductor
MMA7361L
BASIC CONNECTIONS
Pin Descriptions
Figure 4. Pinout Description
Figure 5. Accelerometer with Recommended
Connection Diagram
PCB Layout 
Figure 6. Recommended PCB Layout for Interfacing 
Accelerometer to Microcontroller
NOTES:
1. Use 0.1 µF capacitor on VDD to decouple the power 
source.
2. Physical coupling distance of the accelerometer to 
the microcontroller should be minimal.
3. Place a ground plane beneath the accelerometer to 
reduce noise, the ground plane should be attached to 
all of the open ended terminals shown in Figure 6. 
4. Use a 3.3nF capacitor on the outputs of the 
accelerometer to minimize clock noise (from the 
switched capacitor filter circuit).
5. PCB layout of power and ground should not couple 
power supply noise.
6. Accelerometer and microcontroller should not be a 
high current path.
7. A/D sampling rate and any external power supply 
switching frequency should be selected such that 
they do not interfere with the internal accelerometer 
sampling frequency (11 kHz for the sampling 
frequency). This will prevent aliasing errors. 
8. 10MΩ or higher is recommended on XOUT, YOUT and 
ZOUT to prevent loss due to the voltage divider 
relationship between the internal 32 kΩ resistor and 
the measurement input impedance.
Table 4. Pin Descriptions
Pin No. Pin Name Description
1 N/C No internal connection
Leave unconnected
2 XOUT X direction output voltage
3 YOUT Y direction output voltage
4 ZOUT Z direction output voltage
5 VSS Power Supply Ground
6 VDD Power Supply Input
7 Sleep Logic input pin to enable product or Sleep Mode
8 NC No internal connection
Leave unconnected
9 0g-Detect Linear Freefall digital logic output signal
10 g-Select Logic input pin to select g level
11 N/C Unused for factory trim
Leave unconnected
12 N/C Unused for factory trim
Leave unconnected
13 Self Test Input pin to initiate Self Test
14 N/C Unused for factory trim
Leave unconnected
1
2
3
4
5
6
7
8
9
1
0
1
1
1
2
1
3
1
4
N/C
XOUT
ZOUT
YOUT
VSS
VDD
Sleep
N/C
0g-Detect
g-Select
Self Test
N/C
N/C
N/C
Top View
2
3
4
3.3 nF
3.3 nF
3.3 nF
13
10
6
5
7Logic
Input
Logic
Input
Logic
Input
0.1 μF
VDD
VDD
VSS
g-Select
Self Test
Sleep
XOUT
YOUT
ZOUT
MMA7361L
9
0g-Detect
POWER SUPPLY
VDD
VSS
Sleep
g-Select
0g-Detect
XOUT
YOUT
ZOUT
Ac
ce
ler
om
et
er
VDD
VSS
VRH
P0
P1
P2
A/DIN
A/DIN
A/DIN
C C C
C
C
C
Mi
cr
oc
on
tro
lle
r
Self Test P3Sensors
Freescale Semiconductor 5
MMA7361L
Side View
X
OUT
@ 0g = 1.65 V
Y
OUT
@ +1g = 2.45 V
Z
OUT
@ 0g = 1.65 V
X
OUT
@ +1g = 2.45 V
Y
OUT
@ 0g = 1.65 V
Z
OUT
@ 0g = 1.65 V
X
OUT
@ -1g = 0.85 V
Y
OUT
@ 0g = 1.65 V
Z
OUT
@ 0g = 1.65 V
X
OUT
@ 0g = 1.65 V
Y
OUT
@ -1g = 0.85 V
Z
OUT
@ 0g = 1.65 V
Direction of Earth's gravity field.*
Top View
X
OUT
@ 0g = 1.65 V
Y
OUT
@ 0g = 1.65 V
Z
OUT
@ -1g =0.85 V
X
OUT
@ 0g = 1.65 V
Y
OUT
@ 0g = 1.65 V
Z
OUT
@ +1g = 2.45 V
Top
Top
Bottom
Bottom
123456
7
8 9 10 11 12 13
14
1
2
3
4
5
6
7
8
9
1
0
1
1
1
2
1
3
1
4
13 12 11 10 9 8
1 2 3 4 5 6
14 7
1
2
3
4
5
6
7
8
9
1
0
1
1
1
2
1
3
1
4
Top View
Side View+Y
-Y
+X +Z-X -ZTo
p
B
o
tt
o
m
: Arrow indicates direction of package movement.14-Pin LGA Package
123456
7
8 9 10 11 12 13
14
DYNAMIC ACCELERATION
STATIC ACCELERATION
* When positioned as shown, the Earth’s gravity will result in a positive 1g output.Sensors
6 Freescale Semiconductor
MMA7361L
Figure 7. MMA7361L Temperature Coefficient of Offset (TCO) and 
Temperature Coefficient of Sensitivity (TCS) Distribution Charts
LSL USLTarget
-2 -1 0 1 2
X-TCO mg/degC
LSL USLTarget
-2 -1 0 1 2
Y-TCO mg/degC
LSL USLTarget
-2 -1 0 1 2
Z-TCO mg/degC
LSL USLTarget
-0.01 -0.005 0 .005 .01
X-TCS %/degC
LSL USLTarget
-0.01 -0.005 0 .005 .01
Y-TCS %/degC
LSL USLTarget
-0.01 -0.005 0 .005 .01
Z-TCS %/degCSensors
Freescale Semiconductor 7
MMA7361L
MINIMUM RECOMMENDED FOOTPRINT FOR SURFACE MOUNTED APPLICATIONS
PCB Mounting Recommendations
MEMS based sensors are sensitive to Printed Circuit 
Board (PCB) reflow processes. For optimal zero-g offset after 
PCB mounting, care must be taken to PCB layout and reflow 
conditions. Reference application note AN3484 for best 
practices to minimize the zero-g offset shift after PCB 
mounting.
Surface mount board layout is a critical portion of the total 
design. The footprint for the surface mount packages must be 
the correct size to ensure proper solder connection interface 
between the board and the package.
With the correct footprint, the packages will self-align when 
subjected to a solder reflow process. It is always 
recommended to design boards with a solder mask layer to 
avoid bridging and shorting between solder pads. 6x2 
12x1 
14x0.9 
14x0.6 
10x0.8 
1 13 
6
8Sensors
8 Freescale Semiconductor
MMA7361L
PACKAGE DIMENSIONS
CASE 1977-01
ISSUE A
14-LEAD LGASensors
Freescale Semiconductor 9
MMA7361L
PACKAGE DIMENSIONS
CASE 1977-01
ISSUE A
14-LEAD LGASensors
10 Freescale Semiconductor
MMA7361L
MMA7361L
Rev. 0
04/2008
How to Reach Us:
Home Page:
www.freescale.com
Web Support:
http://www.freescale.com/support
USA/Europe or Locations Not Listed:
Freescale Semiconductor, Inc.
Technical Information Center, EL516
2100 East Elliot Road
Tempe, Arizona 85284
+1-800-521-6274 or +1-480-768-2130
www.freescale.com/support
Europe, Middle East, and Africa:
Freescale Halbleiter Deutschland GmbH
Technical Information Center
Schatzbogen 7
81829 Muenchen, Germany
+44 1296 380 456 (English)
+46 8 52200080 (English)
+49 89 92103 559 (German)
+33 1 69 35 48 48 (French)
www.freescale.com/support
Japan:
Freescale Semiconductor Japan Ltd.
Headquarters
ARCO Tower 15F
1-8-1, Shimo-Meguro, Meguro-ku,
Tokyo 153-0064
Japan
0120 191014 or +81 3 5437 9125
support.japan@freescale.com
Asia/Pacific:
Freescale Semiconductor Hong Kong Ltd.
Technical Information Center
2 Dai King Street
Tai Po Industrial Estate
Tai Po, N.T., Hong Kong
+800 2666 8080
support.asia@freescale.com
For Literature Requests Only:
Freescale Semiconductor Literature Distribution Center
P.O. Box 5405
Denver, Colorado 80217
1-800-441-2447 or 303-675-2140
Fax: 303-675-2150
LDCForFreescaleSemiconductor@hibbertgroup.com
Information in this document is provided solely to enable system and software 
implementers to use Freescale Semiconductor products. There are no express or 
implied copyright licenses granted hereunder to design or fabricate any integrated 
circuits or integrated circuits based on the information in this document.
Freescale Semiconductor reserves the right to make changes without further notice to 
any products herein. Freescale Semiconductor makes no warranty, representation or 
guarantee regarding the suitability of its products for any particular purpose, nor does 
Freescale Semiconductor assume any liability arising out of the application or use of any 
product or circuit, and specifically disclaims any and all liability, including without 
limitation consequential or incidental damages. “Typical” parameters that may be 
provided in Freescale Semiconductor data sheets and/or specifications can and do vary 
in different applications and actual performance may vary over time. All operating 
parameters, including “Typicals”, must be validated for each customer application by 
customer’s technical experts. Freescale Semiconductor does not convey any license 
under its patent rights nor the rights of others. Freescale Semiconductor products are 
not designed, intended, or authorized for use as components in systems intended for 
surgical implant into the body, or other applications intended to support or sustain life, 
or for any other application in which the failure of the Freescale Semiconductor product 
could create a situation where personal injury or death may occur. Should Buyer 
purchase or use Freescale Semiconductor products for any such unintended or 
unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor and 
its officers, employees, subsidiaries, affiliates, and distributors harmless against all 
claims, costs, damages, and expenses, and reasonable attorney fees arising out of, 
directly or indirectly, any claim of personal injury or death associated with such 
unintended or unauthorized use, even if such claim alleges that Freescale 
Semiconductor was negligent regarding the design or manufacture of the part. 
Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc.
All other product or service names are the property of their respective owners.
© Freescale Semiconductor, Inc. 2008. All rights reserved.
RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical 
characteristics of their non-RoHS-compliant and/or non-Pb-free counterparts. For further
information, see http:/www.freescale.com or contact your Freescale sales representative.
For information on Freescale’s Environmental Products program, go to http://www.freescale.com/epp.
SOLOMON SYSTECH  
SEMICONDUCTOR TECHNICAL DATA 
 
This document contains information on a new product. Specifications and information herein are subject to change without 
notice. 
 
http://www.solomon-systech.com 
SSD1306 Rev 1.1 P 1/59 Apr 2008  Copyright © 2008 Solomon Systech Limited  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
 
Advance Information 
 
 
 
 
 
 
 
 
 
 
 
 
 
SSD1306 
128 x 64 Dot Matrix 
OLED/PLED Segment/Common Driver with Controller  
  
Solomon Systech  Apr 2008 P 2/59 Rev 1.1 SSD1306  
 
 CONTENTS 
1 GENERAL DESCRIPTION .......................................................................................................6 
2 FEATURES...................................................................................................................................6 
3 ORDERING INFORMATION ...................................................................................................6 
4 BLOCK DIAGRAM ....................................................................................................................7 
5 DIE PAD FLOOR PLAN ............................................................................................................8 
6 PIN ARRANGEMENT..............................................................................................................11 
6.1 SSD1306TR1 PIN ASSIGNMENT.......................................................................................................................... 11 
7 PIN DESCRIPTION ..................................................................................................................13 
8 FUNCTIONAL BLOCK DESCRIPTIONS.............................................................................15 
8.1 MCU INTERFACE SELECTION.............................................................................................................................. 15 
8.1.1 MCU Parallel 6800-series Interface.......................................................................................................... 15 
8.1.2 MCU Parallel 8080-series Interface.......................................................................................................... 16 
8.1.3 MCU Serial Interface (4-wire SPI) ............................................................................................................ 17 
8.1.4 MCU Serial Interface (3-wire SPI) ............................................................................................................ 18 
8.1.5 MCU I2C Interface..................................................................................................................................... 19 
8.2 COMMAND DECODER ......................................................................................................................................... 22 
8.3 OSCILLATOR CIRCUIT AND DISPLAY TIME GENERATOR..................................................................................... 22 
8.4 FR SYNCHRONIZATION ....................................................................................................................................... 23 
8.5 RESET CIRCUIT ................................................................................................................................................... 23 
8.6 SEGMENT DRIVERS / COMMON DRIVERS ............................................................................................................ 24 
8.7 GRAPHIC DISPLAY DATA RAM (GDDRAM)..................................................................................................... 25 
8.8 SEG/COM DRIVING BLOCK ............................................................................................................................... 26 
8.9 POWER ON AND OFF SEQUENCE ........................................................................................................................ 27 
9 COMMAND TABLE .................................................................................................................28 
9.1 DATA READ / WRITE .......................................................................................................................................... 33 
10 COMMAND DESCRIPTIONS .............................................................................................34 
10.1 FUNDAMENTAL COMMAND ................................................................................................................................ 34 
10.1.1 Set Lower Column Start Address for Page Addressing Mode (00h~0Fh) ................................................. 34 
10.1.2 Set Higher Column Start Address for Page Addressing Mode (10h~1Fh) ................................................ 34 
10.1.3 Set Memory Addressing Mode (20h).......................................................................................................... 34 
10.1.4 Set Column Address (21h) ......................................................................................................................... 35 
10.1.5 Set Page Address (22h).............................................................................................................................. 36 
10.1.6 Set Display Start Line (40h~7Fh) .............................................................................................................. 36 
10.1.7 Set Contrast Control for BANK0 (81h)...................................................................................................... 36 
10.1.8 Set Segment Re-map (A0h/A1h) ................................................................................................................. 36 
10.1.9 Entire Display ON   (A4h/A5h) .................................................................................................................. 37 
10.1.10 Set Normal/Inverse Display (A6h/A7h).................................................................................................. 37 
10.1.11 Set Multiplex Ratio (A8h)....................................................................................................................... 37 
10.1.12 Set Display ON/OFF (AEh/AFh) ........................................................................................................... 37 
10.1.13 Set Page Start Address for Page Addressing Mode (B0h~B7h)............................................................. 37 
10.1.14 Set COM Output Scan Direction (C0h/C8h).......................................................................................... 37 
10.1.15 Set Display Offset (D3h) ........................................................................................................................ 37 
10.1.16 Set Display Clock Divide Ratio/ Oscillator Frequency (D5h) ............................................................... 40 
10.1.17 Set Pre-charge Period (D9h) ................................................................................................................. 40 
10.1.18 Set COM Pins Hardware Configuration (DAh)..................................................................................... 40 
10.1.19 Set VCOMH  Deselect Level (DBh) ........................................................................................................... 43 
  
SSD1306 Rev 1.1 P 3/59 Apr 2008  Solomon Systech
 
10.1.20 NOP (E3h) ............................................................................................................................................. 43 
10.1.21 Status register Read ............................................................................................................................... 43 
10.2 GRAPHIC ACCELERATION COMMAND................................................................................................................. 44 
10.2.1 Horizontal Scroll Setup (26h/27h) ............................................................................................................. 44 
10.2.2 Continuous Vertical and Horizontal Scroll Setup (29h/2Ah)..................................................................... 45 
10.2.3 Deactivate Scroll (2Eh).............................................................................................................................. 46 
10.2.4 Activate Scroll (2Fh).................................................................................................................................. 46 
10.2.5 Set Vertical Scroll Area(A3h) .................................................................................................................... 46 
11 MAXIMUM RATINGS..........................................................................................................47 
12 DC CHARACTERISTICS.....................................................................................................48 
13 AC CHARACTERISTICS.....................................................................................................49 
14 APPLICATION EXAMPLE..................................................................................................55 
15 PACKAGE INFORMATION................................................................................................56 
15.1 SSD1306TR1 DETAIL DIMENSION..................................................................................................................... 56 
15.2 SSD1306Z DIE TRAY INFORMATION.................................................................................................................. 58 
  
Solomon Systech  Apr 2008 P 4/59 Rev 1.1 SSD1306  
 
TABLES 
TABLE 5-1 : SSD1306Z BUMP DIE PAD COORDINATES...................................................................................................... 10 
TABLE 6-1 : SSD1306TR1 PIN ASSIGNMENT TABLE.......................................................................................................... 12 
TABLE 7-1 : MCU BUS INTERFACE PIN SELECTION............................................................................................................ 14 
TABLE 8-1 : MCU INTERFACE ASSIGNMENT UNDER DIFFERENT BUS INTERFACE MODE ...................................................... 15 
TABLE 8-2 : CONTROL PINS OF 6800 INTERFACE................................................................................................................. 15 
TABLE 8-3 : CONTROL PINS OF 8080 INTERFACE................................................................................................................. 17 
TABLE 8-4 : CONTROL PINS OF 4-WIRE SERIAL INTERFACE................................................................................................. 17 
TABLE 8-5 : CONTROL PINS OF 3-WIRE SERIAL INTERFACE................................................................................................. 18 
TABLE 9-1: COMMAND TABLE ........................................................................................................................................... 28 
TABLE 9-2 : READ COMMAND TABLE................................................................................................................................. 33 
TABLE 9-3 : ADDRESS INCREMENT TABLE (AUTOMATIC) ................................................................................................... 33 
TABLE 10-1 : EXAMPLE OF SET DISPLAY OFFSET AND DISPLAY START LINE WITH NO REMAP.......................................... 38 
TABLE 10-2 :EXAMPLE OF SET DISPLAY OFFSET AND DISPLAY START LINE WITH REMAP ................................................ 39 
TABLE 10-3 : COM PINS HARDWARE CONFIGURATION ..................................................................................................... 40 
TABLE 11-1 : MAXIMUM RATINGS (VOLTAGE REFERENCED TO VSS)................................................................................ 47 
TABLE 12-1 : DC CHARACTERISTICS.................................................................................................................................. 48 
TABLE 13-1 : AC CHARACTERISTICS.................................................................................................................................. 49 
TABLE 13-2 : 6800-SERIES MCU PARALLEL INTERFACE TIMING CHARACTERISTICS......................................................... 50 
TABLE 13-3 : 8080-SERIES MCU PARALLEL INTERFACE TIMING CHARACTERISTICS......................................................... 51 
TABLE 13-4 : 4-WIRE SERIAL INTERFACE TIMING CHARACTERISTICS ................................................................................ 52 
TABLE 13-5 : 3-WIRE SERIAL INTERFACE TIMING CHARACTERISTICS ................................................................................ 53 
TABLE 13-6 :I2C INTERFACE TIMING CHARACTERISTICS.................................................................................................... 54 
  
SSD1306 Rev 1.1 P 5/59 Apr 2008  Solomon Systech
 
FIGURES 
FIGURE 4-1 SSD1306 BLOCK DIAGRAM .............................................................................................................................. 7 
FIGURE 5-1 : SSD1306Z DIE DRAWING ............................................................................................................................... 8 
FIGURE 5-2 : SSD1306Z ALIGNMENT MARK DIMENSIONS .................................................................................................... 9 
FIGURE 6-1 : SSD1306TR1 PIN ASSIGNMENT ................................................................................................................. 11 
FIGURE 7-1 PIN DESCRIPTION............................................................................................................................................. 13 
FIGURE 8-1 : DATA READ BACK PROCEDURE - INSERTION OF DUMMY READ ....................................................................... 16 
FIGURE 8-2 : EXAMPLE OF WRITE PROCEDURE IN 8080 PARALLEL INTERFACE MODE......................................................... 16 
FIGURE 8-3 : EXAMPLE OF READ PROCEDURE IN 8080 PARALLEL INTERFACE MODE .......................................................... 16 
FIGURE 8-4 : DISPLAY DATA READ BACK PROCEDURE - INSERTION OF DUMMY READ......................................................... 17 
FIGURE 8-5 : WRITE PROCEDURE IN 4-WIRE SERIAL INTERFACE MODE............................................................................... 18 
FIGURE 8-6 : WRITE PROCEDURE IN 3-WIRE SERIAL INTERFACE MODE............................................................................... 18 
FIGURE 8-7 : I2C-BUS DATA FORMAT .................................................................................................................................. 20 
FIGURE 8-8 : DEFINITION OF THE START AND STOP CONDITION ......................................................................................... 21 
FIGURE 8-9 : DEFINITION OF THE ACKNOWLEDGEMENT CONDITION ................................................................................... 21 
FIGURE 8-10 : DEFINITION OF THE DATA TRANSFER CONDITION ......................................................................................... 21 
FIGURE 8-11 : OSCILLATOR CIRCUIT AND DISPLAY TIME GENERATOR .............................................................................. 22 
FIGURE 8-12 : SEGMENT OUTPUT WAVEFORM IN THREE PHASES ....................................................................................... 24 
FIGURE 8-13 : GDDRAM PAGES STRUCTURE OF SSD1306................................................................................................ 25 
FIGURE 8-14 : ENLARGEMENT OF GDDRAM (NO ROW RE-MAPPING AND COLUMN-REMAPPING)...................................... 25 
FIGURE 8-15 : IREF  CURRENT SETTING BY RESISTOR VALUE ............................................................................................. 26 
FIGURE 8-16 : THE POWER ON SEQUENCE.......................................................................................................................... 27 
FIGURE 8-17 : THE POWER OFF SEQUENCE ........................................................................................................................ 27 
FIGURE 10-1 : ADDRESS POINTER MOVEMENT OF PAGE ADDRESSING MODE ..................................................................... 34 
FIGURE 10-2 : EXAMPLE OF GDDRAM ACCESS POINTER SETTING IN PAGE ADDRESSING MODE (NO ROW AND COLUMN-
REMAPPING) ............................................................................................................................................................... 34 
FIGURE 10-3 : ADDRESS POINTER MOVEMENT OF HORIZONTAL ADDRESSING MODE ......................................................... 35 
FIGURE 10-4 : ADDRESS POINTER MOVEMENT OF VERTICAL ADDRESSING MODE.............................................................. 35 
FIGURE 10-5 : EXAMPLE OF COLUMN AND ROW ADDRESS POINTER MOVEMENT .............................................................. 36 
FIGURE 10-6 :TRANSITION BETWEEN DIFFERENT MODES .................................................................................................... 37 
FIGURE 10-7 : HORIZONTAL SCROLL EXAMPLE: SCROLL RIGHT BY 1 COLUMN................................................................. 44 
FIGURE 10-8 : HORIZONTAL SCROLL EXAMPLE: SCROLL LEFT BY 1 COLUMN ................................................................... 44 
FIGURE 10-9 : HORIZONTAL SCROLLING SETUP EXAMPLE................................................................................................... 44 
FIGURE 10-10 : CONTINUOUS VERTICAL AND HORIZONTAL SCROLLING SETUP EXAMPLE.................................................. 45 
FIGURE 13-1 : 6800-SERIES MCU PARALLEL INTERFACE CHARACTERISTICS...................................................................... 50 
FIGURE 13-2 : 8080-SERIES PARALLEL INTERFACE CHARACTERISTICS................................................................................ 51 
FIGURE 13-3 : 4-WIRE SERIAL INTERFACE CHARACTERISTICS............................................................................................. 52 
FIGURE 13-4 : 3-WIRE SERIAL INTERFACE CHARACTERISTICS............................................................................................. 53 
 FIGURE 13-5 : I2C INTERFACE TIMING CHARACTERISTICS.................................................................................................. 54 
FIGURE 14-1 : APPLICATION EXAMPLE OF SSD1306Z ....................................................................................................... 55 
FIGURE 15-1 SSD1306TR1 DETAIL DIMENSION ................................................................................................................ 56 
FIGURE 15-2 : SSD1306Z DIE TRAY INFORMATION ............................................................................................................ 58 
  
  
Solomon Systech  Apr 2008 P 6/59 Rev 1.1 SSD1306  
 
1 GENERAL DESCRIPTION 
SSD1306 is a single-chip CMOS OLED/PLED driver with controller for organic / polymer light emitting 
diode dot-matrix graphic display system. It consists of 128 segments and 64commons. This IC is 
designed for Common Cathode type OLED panel. 
 
The SSD1306 embeds with contrast control, display RAM and oscillator, which reduces the number of 
external components and power consumption. It has 256-step brightness control. Data/Commands are 
sent from general MCU through the hardware selectable 6800/8000 series compatible Parallel Interface, 
I2C interface or Serial Peripheral Interface. It is suitable for many compact portable applications, such as 
mobile phone sub-display, MP3 player and calculator, etc. 
 
2 FEATURES 
• Resolution: 128 x 64 dot matrix panel 
• Power supply 
o VDD = 1.65V to 3.3V   for IC logic 
o VCC = 7V to 15V       for Panel driving   
• For matrix display 
o OLED driving output voltage, 15V maximum   
o Segment maximum source current: 100uA 
o Common maximum sink current: 15mA  
o 256 step contrast brightness current control  
• Embedded 128 x 64 bit SRAM display buffer 
• Pin selectable MCU Interfaces: 
o 8-bit 6800/8080-series parallel interface 
o 3 /4 wire Serial Peripheral Interface 
o I2C Interface 
• Screen saving continuous scrolling function in both horizontal and vertical direction 
• RAM write synchronization signal 
• Programmable Frame Rate and Multiplexing Ratio                                                     
• Row Re-mapping and Column Re-mapping 
• On-Chip Oscillator 
• Chip layout for COG & COF 
• Wide range of operating temperature: -40°C to 85°C 
 
3 ORDERING INFORMATION  
Table 3-1: Ordering Information 
Ordering Part Number SEG COM Package Form Reference Remark 
SSD1306Z 128 64 COG 8 
o Min SEG pad pitch : 47um 
o Min COM pad pitch : 40um 
o Die thickness: 300 +/- 25um 
SSD1306TR1 104 48 TAB 11, 56 
o 35mm film, 4 sprocket hole, Folding TAB
o 8-bit 80 / 8-bit 68 / SPI / I2C interface  
o SEG, COM lead pitch 0.1mm x 0.997 
=0.0997mm 
o Die thickness: 457 +/- 25um 
 
  
SSD1306 Rev 1.1 P 7/59 Apr 2008  Solomon Systech
 
4 BLOCK DIAGRAM 
 
Figure 4-1 SSD1306 Block Diagram 
 
C
om
m
on
D
riv
er
O
sc
ill
at
or
G
ra
ph
ic
 D
is
pl
ay
 D
at
a
R
A
M
 (G
D
D
R
A
M
)
M
C
U
In
te
rf
ac
e
C
om
m
an
d
D
ec
od
er
RES#
CS#
D/C#
E (RD#)
R/W#(WR#)
BS2
BS1
BS0
D7
D6
D5
D4
D3
D2
D1
D0
C
ur
re
nt
 C
on
tro
l
V
ol
ta
ge
 C
on
tro
l
VDD
SEG0
SEG1
|
|
SEG126
SEG127
C
L
C
LS
COM1
COM3
|
|
COM61
COM63
COM62
COM60
|
|
COM2
COM0
D
is
pl
ay
 C
on
tro
lle
r
FR
VSSVLSS
C
om
m
on
D
riv
er
Se
gm
en
t
D
riv
er
VCC
V
C
O
M
H
I R
EF
                      
  
Solomon Systech  Apr 2008 P 8/59 Rev 1.1 SSD1306  
 
5 DIE PAD FLOOR PLAN 
Figure 5-1 : SSD1306Z Die Drawing 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
              
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Pad 1 
SSD
1306Z
Die size 6.76mm x 0.86mm 
Die thickness 300 +/- 25um 
Min I/O pad pitch 60um 
Min SEG pad pitch 47um 
Min COM pad pitch 40um 
Bump height Nominal 15um 
 
 
Bump size   
Pad 1, 106, 124, 256 80um x 50um 
Pad 2-18, 89-105, 107-123, 257-273 25ium x 80um 
Pad 19-88 40um x 89um 
Pad 125-255 31um x 59um 
Pad 274-281 (TR pads) 30um x 50um 
 
Alignment 
mark Position Size 
+ shape (-2973, 0) 75um x 75um 
+ shape (2973, 0) 75um x 75um 
Circle (2466.665, 7.575) R37.5um, inner 18um 
SSL Logo (-2862.35, 144.82) - 
(For details dimension please see p.9 ) 
 
Note 
(1)  Diagram showing the Gold bumps face up. 
(2)  Coordinates are referenced to center of the chip. 
(3)  Coordinate units and size of all alignment marks are in um. 
(4)  All alignment keys do not contain gold 
 
Pad 1,2,3,…->281
Gold Bumps face up
SSD1306 X
Y
  
SSD1306 Rev 1.1 P 9/59 Apr 2008  Solomon Systech
 
 
 
Figure 5-2 : SSD1306Z alignment mark dimensions 
 
 
 
 
 
 
 
 
T shape 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
+ shape 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
Circle 
 
 
 
 
 
 
 
*All units are in um 
 
 
 
  
Solomon Systech  Apr 2008 P 10/59 Rev 1.1 SSD1306  
 
Table 5-1 : SSD1306Z Bump Die Pad Coordinates 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Pad no. Pad Name X-pos Y-pos Pad no. Pad Name X-pos Y-pos Pad no. Pad Name X-pos Y-pos Pad no. Pad Name X-pos Y-pos
1 NC -3315 -377.5 81 VCOMH 1875.585 -352.83 161 SEG35 1364.5 356 241 SEG114 -2398.5 356
2 VSS -3084.77 -362.5 82 VCC 1967.185 -352.83 162 SEG36 1317.5 356 242 SEG115 -2445.5 356
3 COM49 -3044.77 -362.5 83 VCC 2027.185 -352.83 163 SEG37 1270.5 356 243 SEG116 -2492.5 356
4 COM50 -3004.77 -362.5 84 VLSS 2109.185 -352.83 164 SEG38 1223.5 356 244 SEG117 -2539.5 356
5 COM51 -2964.77 -362.5 85 VLSS 2169.185 -352.83 165 SEG39 1176.5 356 245 SEG118 -2586.5 356
6 COM52 -2924.77 -362.5 86 VLSS 2254.185 -352.83 166 SEG40 1129.5 356 246 SEG119 -2633.5 356
7 COM53 -2884.77 -362.5 87 NC 2314.185 -352.83 167 SEG41 1082.5 356 247 SEG120 -2680.5 356
8 COM54 -2844.77 -362.5 88 NC 2374.185 -352.83 168 SEG42 1035.5 356 248 SEG121 -2727.5 356
9 COM55 -2804.77 -362.5 89 VSS 2444.77 -362.5 169 SEG43 988.5 356 249 SEG122 -2774.5 356
10 COM56 -2764.77 -362.5 90 COM31 2484.77 -362.5 170 SEG44 941.5 356 250 SEG123 -2821.5 356
11 COM57 -2724.77 -362.5 91 COM30 2524.77 -362.5 171 SEG45 894.5 356 251 SEG124 -2868.5 356
12 COM58 -2684.77 -362.5 92 COM29 2564.77 -362.5 172 SEG46 847.5 356 252 SEG125 -2915.5 356
13 COM59 -2644.77 -362.5 93 COM28 2604.77 -362.5 173 SEG47 800.5 356 253 SEG126 -2962.5 356
14 COM60 -2604.77 -362.5 94 COM27 2644.77 -362.5 174 SEG48 753.5 356 254 SEG127 -3009.5 356
15 COM61 -2564.77 -362.5 95 COM26 2684.77 -362.5 175 SEG49 706.5 356 255 NC -3056.5 356
16 COM62 -2524.77 -362.5 96 COM25 2724.77 -362.5 176 SEG50 659.5 356 256 NC -3315 367.5
17 COM63 -2484.77 -362.5 97 COM24 2764.77 -362.5 177 SEG51 612.5 356 257 COM32 -3315 315
18 VCOMH -2444.77 -362.5 98 COM23 2804.77 -362.5 178 SEG52 565.5 356 258 COM33 -3315 275
19 NC -2334.965 -352.83 99 COM22 2844.77 -362.5 179 SEG53 518.5 356 259 COM34 -3315 235
20 C2P -2278.265 -352.83 100 COM21 2884.77 -362.5 180 SEG54 471.5 356 260 COM35 -3315 195
21 C2P -2218.265 -352.83 101 COM20 2924.77 -362.5 181 SEG55 424.5 356 261 COM36 -3315 155
22 C2N -2136.715 -352.83 102 COM19 2964.77 -362.5 182 SEG56 377.5 356 262 COM37 -3315 115
23 C2N -2055.465 -352.83 103 COM18 3004.77 -362.5 183 SEG57 330.5 356 263 COM38 -3315 75
24 C1P -1995.465 -352.83 104 COM17 3044.77 -362.5 184 SEG58 283.5 356 264 COM39 -3315 35
25 C1P -1904.115 -352.83 105 VSS 3084.77 -362.5 185 SEG59 236.5 356 265 COM40 -3315 -5
26 C1N -1844.115 -352.83 106 NC 3315 -377.5 186 SEG60 189.5 356 266 COM41 -3315 -45
27 C1N -1762.865 -352.83 107 COM16 3315 -325 187 SEG61 142.5 356 267 COM42 -3315 -85
28 VBAT -1679.31 -352.83 108 COM15 3315 -285 188 SEG62 95.5 356 268 COM43 -3315 -125
29 VBAT -1619.31 -352.83 109 COM14 3315 -245 189 SEG63 48.5 356 269 COM44 -3315 -165
30 VBREF -1537.51 -352.83 110 COM13 3315 -205 190 SEG64 1.5 356 270 COM45 -3315 -205
31 BGGND -1477.51 -352.83 111 COM12 3315 -165 191 SEG65 -45.5 356 271 COM46 -3315 -245
32 VCC -1416.01 -352.83 112 COM11 3315 -125 192 SEG66 -92.5 356 272 COM47 -3315 -285
33 VCC -1356.01 -352.83 113 COM10 3315 -85 193 SEG67 -139.5 356 273 COM48 -3315 -325
34 VCOMH -1266.955 -352.83 114 COM9 3315 -45 194 SEG68 -186.5 356
35 VCOMH -1206.955 -352.83 115 COM8 3315 -5 195 SEG69 -233.5 356 Pad no. Pad Name X-pos Y-pos
36 VLSS -1125.155 -352.83 116 COM7 3315 35 196 SEG70 -280.5 356 Pin# Pin name X-dir Y-dir
37 VLSS -1043.355 -352.83 117 COM6 3315 75 197 SEG71 -327.5 356 274 TR0 2757.05 114.8
38 VLSS -983.355 -352.83 118 COM5 3315 115 198 SEG72 -374.5 356 275 TR1 2697.05 114.8
39 VSS -920 -352.83 119 COM4 3315 155 199 SEG73 -421.5 356 276 TR2 2637.05 114.8
40 VSS -856 -352.83 120 COM3 3315 195 200 SEG74 -468.5 356 277 TR3 2577.05 114.8
41 VSS -796 -352.83 121 COM2 3315 235 201 SEG75 -515.5 356 278 VSS 2517.05 114.8
42 VDD -732.645 -352.83 122 COM1 3315 275 202 SEG76 -562.5 356 279 TR4 2457.05 114.8
43 VDD -672.645 -352.83 123 COM0 3315 315 203 SEG77 -609.5 356 280 TR5 2397.05 114.8
44 BS0 -595.655 -352.83 124 NC 3315 367.5 204 SEG78 -656.5 356 281 TR6 2337.05 114.8
45 VSS -531.955 -352.83 125 NC 3055.5 356 205 SEG79 -703.5 356
46 BS1 -467.655 -352.83 126 SEG0 3009.5 356 206 SEG80 -750.5 356
47 VDD -403.155 -352.83 127 SEG1 2962.5 356 207 SEG81 -797.5 356
48 VDD -342.555 -352.83 128 SEG2 2915.5 356 208 SEG82 -844.5 356
49 BS2 -279.705 -352.83 129 SEG3 2868.5 356 209 SEG83 -891.5 356
50 VSS -215.705 -352.83 130 SEG4 2821.5 356 210 NC -940 356
51 FR -151.955 -352.83 131 SEG5 2774.5 356 211 SEG84 -988.5 356
52 CL -89.815 -352.83 132 SEG6 2727.5 356 212 SEG85 -1035.5 356
53 VSS -25.665 -352.83 133 SEG7 2680.5 356 213 SEG86 -1082.5 356
54 CS# 38.635 -352.83 134 SEG8 2633.5 356 214 SEG87 -1129.5 356
55 RES# 109.835 -352.83 135 SEG9 2586.5 356 215 SEG88 -1176.5 356
56 D/C# 182.425 -352.83 136 SEG10 2539.5 356 216 SEG89 -1223.5 356
57 VSS 246.125 -352.83 137 SEG11 2492.5 356 217 SEG90 -1270.5 356
58 R/W# 310.425 -352.83 138 SEG12 2445.5 356 218 SEG91 -1317.5 356
59 E 373.125 -352.83 139 SEG13 2398.5 356 219 SEG92 -1364.5 356
60 VDD 457.175 -352.83 140 SEG14 2351.5 356 220 SEG93 -1411.5 356
61 VDD 517.175 -352.83 141 SEG15 2304.5 356 221 SEG94 -1458.5 356
62 D0 609.275 -352.83 142 SEG16 2257.5 356 222 SEG95 -1505.5 356
63 D1 692.475 -352.83 143 SEG17 2210.5 356 223 SEG96 -1552.5 356
64 D2 765.675 -352.83 144 SEG18 2163.5 356 224 SEG97 -1599.5 356
65 D3 828.875 -352.83 145 SEG19 2116.5 356 225 SEG98 -1646.5 356
66 VSS 890.325 -352.83 146 SEG20 2069.5 356 226 SEG99 -1693.5 356
67 D4 951.275 -352.83 147 SEG21 2022.5 356 227 SEG100 -1740.5 356
68 D5 1013.315 -352.83 148 SEG22 1975.5 356 228 SEG101 -1787.5 356
69 D6 1075.355 -352.83 149 SEG23 1928.5 356 229 SEG102 -1834.5 356
70 D7 1137.395 -352.83 150 SEG24 1881.5 356 230 SEG103 -1881.5 356
71 VSS 1220.735 -352.83 151 SEG25 1834.5 356 231 SEG104 -1928.5 356
72 VSS 1280.735 -352.83 152 SEG26 1787.5 356 232 SEG105 -1975.5 356
73 CLS 1362.585 -352.83 153 SEG27 1740.5 356 233 SEG106 -2022.5 356
74 VDD 1425.285 -352.83 154 SEG28 1693.5 356 234 SEG107 -2069.5 356
75 VDD 1485.885 -352.83 155 SEG29 1646.5 356 235 SEG108 -2116.5 356
76 VDD 1553.185 -352.83 156 SEG30 1599.5 356 236 SEG109 -2163.5 356
77 VDD 1613.185 -352.83 157 SEG31 1552.5 356 237 SEG110 -2210.5 356
78 IREF 1684.585 -352.83 158 SEG32 1505.5 356 238 SEG111 -2257.5 356
79 IREF 1744.585 -352.83 159 SEG33 1458.5 356 239 SEG112 -2304.5 356
80 VCOMH 1815.585 -352.83 160 SEG34 1411.5 356 240 SEG113 -2351.5 356
  
SSD1306 Rev 1.1 P 11/59 Apr 2008  Solomon Systech
 
6 PIN ARRANGEMENT 
6.1 SSD1306TR1 pin assignment 
 
 
Figure 6-1 : SSD1306TR1 Pin Assignment 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Note: 
(1) COM sequence (Split) is under command setting: DAh, 12h 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 12/59 Rev 1.1 SSD1306  
 
Table 6-1 : SSD1306TR1 Pin Assignment Table 
 Pin no. Pin Name Pin no. Pin Name Pin no. Pin Name1 NC 81 SEG90 161 SEG10
2 VCC 82 SEG89 162 SEG9
3 VCOMH 83 SEG88 163 SEG8
4 IREF 84 SEG87 164 SEG7
5 D7 85 SEG86 165 SEG6
6 D6 86 SEG85 166 SEG5
7 D5 87 SEG84 167 SEG4
8 D4 88 SEG83 168 SEG3
9 D3 89 SEG82 169 SEG2
10 D2 90 SEG81 170 SEG1
11 D1 91 SEG80 171 SEG0
12 D0 92 SEG79 172 NC
13 E/RD# 93 SEG78 173 NC
14 R/W# 94 SEG77 174 NC
15 D/C# 95 SEG76 175 NC
16 RES# 96 SEG75 176 NC
17 CS# 97 SEG74 177 NC
18 NC 98 SEG73 178 NC
19 BS2 99 SEG72 179 NC
20 BS1 100 SEG71 180 NC
21 VDD 101 SEG70 181 NC
22 NC 102 SEG69 182 COM0
23 NC 103 SEG68 183 COM2
24 NC 104 SEG67 184 COM4
25 NC 105 SEG66 185 COM6
26 NC 106 SEG65 186 COM8
27 NC 107 SEG64 187 COM10
28 NC 108 SEG63 188 COM12
29 NC 109 SEG62 189 COM14
30 VSS 110 SEG61 190 COM16
31 NC 111 SEG60 191 COM18
32 NC 112 SEG59 192 COM20
33 NC 113 SEG58 193 COM22
34 COM47 114 SEG57 194 COM24
35 COM45 115 SEG56 195 COM26
36 COM43 116 SEG55 196 COM28
37 COM41 117 SEG54 197 COM30
38 COM39 118 SEG53 198 COM32
39 COM37 119 SEG52 199 COM34
40 COM35 120 SEG51 200 COM36
41 COM33 121 SEG50 201 COM38
42 COM31 122 SEG49 202 COM40
43 COM29 123 SEG48 203 COM42
44 COM27 124 SEG47 204 COM44
45 COM25 125 SEG46 205 COM46
46 COM23 126 SEG45 206 NC
47 COM21 127 SEG44 207 NC
48 COM19 128 SEG43
49 COM17 129 SEG42
50 COM15 130 SEG41
51 COM13 131 SEG40
52 COM11 132 SEG39
53 COM9 133 SEG38
54 COM7 134 SEG37
55 COM5 135 SEG36
56 COM3 136 SEG35
57 COM1 137 SEG34
58 NC 138 SEG33
59 NC 139 SEG32
60 NC 140 SEG31
61 NC 141 SEG30
62 NC 142 SEG29
63 NC 143 SEG28
64 NC 144 SEG27
65 NC 145 SEG26
66 NC 146 SEG25
67 NC 147 SEG24
68 SEG103 148 SEG23
69 SEG102 149 SEG22
70 SEG101 150 SEG21
71 SEG100 151 SEG20
72 SEG99 152 SEG19
73 SEG98 153 SEG18
74 SEG97 154 SEG17
75 SEG96 155 SEG16
76 SEG95 156 SEG15
77 SEG94 157 SEG14
78 SEG93 158 SEG13
79 SEG92 159 SEG12
80 SEG91 160 SEG11
  
SSD1306 Rev 1.1 P 13/59 Apr 2008  Solomon Systech
 
 
7 PIN DESCRIPTION 
 
Key: 
I = Input NC = Not Connected 
O =Output Pull LOW= connect to Ground 
I/O = Bi-directional (input/output) Pull HIGH= connect to VDD 
P = Power pin  
 
Figure 7-1 Pin Description 
Pin Name Type Description 
VDD P Power supply pin for core logic operation. 
VCC P Power supply for panel driving voltage.  This is also the most positive power voltage 
supply pin.  
 
VSS P This is a ground pin.   
 
VLSS P This is an analog ground pin. It should be connected to VSS externally. 
 
VCOMH O The pin for COM signal deselected voltage level.   
A capacitor should be connected between this pin and VSS.   
 
VBAT P Reserved pin.  It should be connected to VDD. 
 
BGGND P Reserved pin.  It should be connected to ground. 
 
C1P/C1N 
C2P/C2N 
I Reserved pin.  It should be kept NC. 
 
VBREF P Reserved pin.  It should be kept NC.   
 
BS[2:0] 
 
I MCU bus interface selection pins. Please refer to Table 7-1 for the details of setting. 
 
IREF 
 
I This is segment output current reference pin.   
A resistor should be connected between this pin and VSS to maintain the IREF current at 
12.5 uA.  Please refer to Figure 8-15 for the details of resistor value. 
 
FR O This pin outputs RAM write synchronization signal.  Proper timing between MCU data 
writing and frame display timing can be achieved to prevent tearing effect.  
It should be kept NC if it is not used. Please refer to Section 8.4 for details usage. 
 
CL I This is external clock input pin. 
When internal clock is enabled (i.e. HIGH in CLS pin), this pin is not used and should be 
connected to VSS. When internal clock is disabled (i.e. LOW in CLS pin), this pin is the 
external clock source input pin. 
 
CLS I This is internal clock enable pin. When it is pulled HIGH (i.e. connect to VDD), internal 
clock is enabled. When it is pulled LOW, the internal clock is disabled; an external clock 
source must be connected to the CL pin for normal operation. 
 
RES# 
I 
This pin is reset signal input.  When the pin is pulled LOW, initialization of the chip is 
executed. Keep this pin HIGH (i.e. connect to VDD) during normal operation.  
 
CS# I This pin is the chip select input. (active LOW).  
  
Solomon Systech  Apr 2008 P 14/59 Rev 1.1 SSD1306  
 
Pin Name Type Description 
D/C# I This is Data/Command control pin. When it is pulled HIGH (i.e. connect to VDD), the data 
at D[7:0] is treated as data. When it is pulled LOW, the data at D[7:0] will be transferred 
to the command register.  
In I2C mode, this pin acts as SA0 for slave address selection. 
When 3-wire serial interface is selected, this pin must be connected to VSS. 
 
For detail relationship to MCU interface signals, please refer to the Timing Characteristics 
Diagrams: Figure 13-1 to  Figure 13-5. 
 
E (RD#) I When interfacing to a 6800-series microprocessor, this pin will be used as the Enable (E) 
signal. Read/write operation is initiated when this pin is pulled HIGH (i.e. connect to VDD) 
and the chip is selected. 
When connecting to an 8080-series microprocessor, this pin receives the Read (RD#) 
signal. Read operation is initiated when this pin is pulled LOW and the chip is selected.  
When serial or I2C interface is selected, this pin must be connected to VSS. 
 
R/W#(WR#) I This is read / write control input pin connecting to the MCU interface.  
When interfacing to a 6800-series microprocessor, this pin will be used as Read/Write 
(R/W#) selection input. Read mode will be carried out when this pin is pulled HIGH (i.e. 
connect to VDD) and write mode when LOW.  
When 8080 interface mode is selected, this pin will be the Write (WR#) input. Data write 
operation is initiated when this pin is pulled LOW and the chip is selected. 
When serial or I2C interface is selected, this pin must be connected to VSS. 
 
D[7:0] IO These are 8-bit bi-directional data bus to be connected to the microprocessor’s data bus. 
When serial interface mode is selected, D0 will be the serial clock input: SCLK; D1 will 
be the serial data input: SDIN and D2 should be kept NC. 
When I2C mode is selected, D2, D1 should be tied together and serve as SDAout, SDAin in 
application and D0 is the serial clock input, SCL. 
 
TR0-TR6 - Testing reserved pins. It should be kept NC. 
 
SEG0 ~ 
SEG127 
O These pins provide Segment switch signals to OLED panel. These pins are VSS state when 
display is OFF. 
 
COM0 ~ 
COM63 
O These pins provide Common switch signals to OLED panel. They are in high impedance 
state when display is OFF.  
 
NC - This is dummy pin. Do not group or short NC pins together. 
 
 
 
Table 7-1 : MCU Bus Interface Pin Selection 
SSD1306            
Pin Name 
I2C Interface 6800-parallel 
interface  
(8 bit) 
8080-parallel 
interface 
(8 bit) 
4-wire Serial 
interface 
3-wire Serial 
interface 
BS0 0 0 0 0 1 
BS1 1 0 1 0 0 
BS2 0 1 1 0 0 
 
Note 
(1) 0 is connected to VSS 
(2) 1 is connected to VDD 
 
  
SSD1306 Rev 1.1 P 15/59 Apr 2008  Solomon Systech
 
8 FUNCTIONAL BLOCK DESCRIPTIONS 
8.1 MCU Interface selection  
SSD1306 MCU interface consist of 8 data pins and 5 control pins.  The pin assignment at different interface 
mode is summarized in Table 8-1. Different MCU mode can be set by hardware selection on BS[2:0] pins 
(please refer to  Table 7-1 for BS[2:0] setting). 
 
Table 8-1 : MCU interface assignment under different bus interface mode 
Data/Command Interface Control Signal       Pin Name  
Bus         
Interface D7 D6 D5 D4 D3 D2 D1 D0 E R/W# CS# D/C# RES# 
8-bit 8080 D[7:0] RD# WR# CS# D/C# RES# 
8-bit 6800  D[7:0] E R/W# CS# D/C# RES# 
3-wire SPI Tie LOW NC SDIN SCLK Tie LOW CS# Tie LOW RES# 
4-wire SPI Tie LOW NC SDIN SCLK Tie LOW CS# D/C# RES# 
I2C  Tie LOW SDAOUT SDAIN SCL Tie LOW SA0 RES# 
 
 
8.1.1 MCU Parallel 6800-series Interface  
The parallel interface consists of 8 bi-directional data pins (D[7:0]), R/W#, D/C#, E  and CS#.  
 
A LOW in R/W# indicates WRITE operation and HIGH in R/W# indicates READ operation. 
A LOW in D/C# indicates COMMAND read/write and HIGH in D/C# indicates DATA read/write. 
The E input serves as data latch signal while CS# is LOW.  Data is latched at the falling edge of E signal. 
 
Table 8-2 : Control pins of 6800 interface 
Function E R/W# CS# D/C#
Write command ↓ L L L 
Read status ↓ H L L 
Write data ↓ L L H 
Read data ↓ H L H 
 
Note 
(1) ↓ stands for falling edge of signal 
   H stands for HIGH in signal 
   L stands for LOW in signal 
 
In order to match the operating frequency of display RAM with that of the microprocessor, some pipeline 
processing is internally performed which requires the insertion of a dummy read before the first actual display 
data read. This is shown in Figure 8-1. 
 
 
  
Solomon Systech  Apr 2008 P 16/59 Rev 1.1 SSD1306  
 
Figure 8-1 : Data read back procedure - insertion of dummy read 
N n n+1 n+2
R/W#
E
Databus
Write column
address Read 1st  dataDummy read Read 2nd  data Read 3rd  data  
 
8.1.2 MCU Parallel 8080-series Interface  
The parallel interface consists of 8 bi-directional data pins (D[7:0]), RD#, WR#, D/C# and CS#.      
 
A LOW in D/C# indicates COMMAND read/write and HIGH in D/C# indicates DATA read/write. 
A rising edge of RD# input serves as a data READ latch signal while CS# is kept LOW.   
A rising edge of WR# input serves as a data/command WRITE latch signal while CS# is kept LOW.   
 
Figure 8-2 : Example of Write procedure in 8080 parallel interface mode 
CS#
WR#
D[7:0]
D/C#
RD#
high
low  
 
Figure 8-3 : Example of Read procedure in 8080 parallel interface mode 
CS#
WR#
D[7:0]
D/C#
RD#
high
low  
 
  
SSD1306 Rev 1.1 P 17/59 Apr 2008  Solomon Systech
 
Table 8-3 : Control pins of 8080 interface 
Function RD# WR# CS# D/C# 
Write command H ↑ L L 
Read status ↑ H L L 
Write data H ↑ L H 
Read data ↑ H L H 
Note 
(1) ↑ stands for rising edge of signal 
(2)  H stands for HIGH in signal 
(3)  L stands for LOW in signal 
 
In order to match the operating frequency of display RAM with that of the microprocessor, some pipeline 
processing is internally performed which requires the insertion of a dummy read before the first actual display 
data read. This is shown in Figure 8-4. 
Figure 8-4 : Display data read back procedure - insertion of dummy read 
 
 
N n n+1 n+2
WR#
RD#
Databus
Write column
address Read 1st  dataDummy read Read 2nd  data Read 3rd  data  
 
 
 
8.1.3 MCU Serial Interface (4-wire SPI) 
  
The 4-wire serial interface consists of serial clock: SCLK, serial data: SDIN, D/C#, CS#. In 4-wire SPI mode, 
D0 acts as SCLK, D1 acts as SDIN. For the unused data pins, D2 should be left open. The pins from D3 to 
D7, E and R/W# (WR#)# can be connected to an external ground. 
Table 8-4 : Control pins of 4-wire Serial interface 
Function E(RD#) R/W#(WR#) CS# D/C# D0 
Write command Tie LOW Tie LOW L L ↑ 
Write data Tie LOW Tie LOW L H ↑ 
 
Note 
(1) H stands for HIGH in signal 
(2) L stands for LOW in signal 
 
SDIN is shifted into an 8-bit shift register on every rising edge of SCLK in the order of D7, D6, ... D0. D/C# 
is sampled on every eighth clock and the data byte in the shift register is written to the Graphic Display Data 
RAM (GDDRAM) or command register in the same clock.  
 
Under serial mode, only write operations are allowed.  
  
Solomon Systech  Apr 2008 P 18/59 Rev 1.1 SSD1306  
 
Figure 8-5 : Write procedure in 4-wire Serial interface mode 
 
 
 
8.1.4 MCU Serial Interface (3-wire SPI) 
The 3-wire serial interface consists of serial clock SCLK, serial data SDIN and CS#.  
In 3-wire SPI mode, D0 acts as SCLK, D1 acts as SDIN. For the unused data pins, D2 should be left open. 
The pins from D3 to D7, R/W# (WR#)#, E and D/C# can be connected to an external ground. 
 
The operation is similar to 4-wire serial interface while D/C# pin is not used. There are altogether 9-bits will 
be shifted into the shift register on every ninth clock in sequence: D/C# bit, D7 to D0 bit. The D/C# bit (first 
bit of the sequential data) will determine the following data byte in the shift register is written to the Display 
Data RAM (D/C# bit = 1) or the command register (D/C# bit = 0). Under serial mode, only write operations 
are allowed.  
Table 8-5 : Control pins of 3-wire Serial interface 
Function E(RD#) R/W#(WR#) CS# D/C# D0
Write command Tie LOW Tie LOW L Tie LOW ↑
Write data Tie LOW Tie LOW L Tie LOW ↑
Note 
(1) L stands for LOW in signal
 
Figure 8-6 : Write procedure in 3-wire Serial interface mode 
 
 
 
 
 
 
 
 
 
 
D7 D6 D5 D4 D3 D2 D1 D0 
SCLK 
(D0) 
SDIN(D1) 
DB1 DB2 DBn
CS# 
D/C# 
SDIN/ 
SCLK 
D7 D6 D5 D4 D3 D2 D1 D0 
SCLK 
(D0) 
SDIN(D1) 
DB1 DB2 DBn
CS# 
D/C# 
SDIN/ 
SCLK 
  
SSD1306 Rev 1.1 P 19/59 Apr 2008  Solomon Systech
 
 
8.1.5 MCU I2C Interface  
The I2C communication interface consists of slave address bit SA0, I2C-bus data signal SDA (SDAOUT/D2 for 
output and SDAIN/D1 for input) and I2C-bus clock signal SCL (D0). Both the data and clock signals must be 
connected to pull-up resistors. RES# is used for the initialization of device. 
 
a) Slave address bit (SA0) 
SSD1306 has to recognize the slave address before transmitting or receiving any information by the 
I2C-bus. The device will respond to the slave address following by the slave address bit (“SA0” bit) 
and the read/write select bit (“R/W#” bit) with the following byte format,  
b7 b6 b5 b4 b3 b2 b1     b0  
0  1  1   1  1   0  SA0 R/W# 
“SA0” bit provides an extension bit for the slave address. Either “0111100” or “0111101”, can be 
selected as the slave address of SSD1306. D/C# pin acts as SA0 for slave address selection. 
“R/W#” bit is used to determine the operation mode of the I2C-bus interface.  R/W#=1, it is in read 
mode.  R/W#=0, it is in write mode.   
b) I2C-bus data signal (SDA) 
SDA acts as a communication channel between the transmitter and the receiver. The data and the 
acknowledgement are sent through the SDA.  
It should be noticed that the ITO track resistance and the pulled-up resistance at “SDA” pin becomes 
a voltage potential divider. As a result, the acknowledgement would not be possible to attain a valid 
logic 0 level in “SDA”.  
“SDAIN” and “SDAOUT” are tied together and serve as SDA. The “SDAIN” pin must be connected to 
act as SDA. The “SDAOUT” pin may be disconnected. When “SDAOUT” pin is disconnected, the 
acknowledgement signal will be ignored in the I2C-bus.  
c) I2C-bus clock signal (SCL) 
The transmission of information in the I2C-bus is following a clock signal, SCL. Each transmission of 
data bit is taken place during a single clock period of SCL. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 20/59 Rev 1.1 SSD1306  
 
 
 
8.1.5.1 I2C-bus Write data  
 
The I2C-bus interface gives access to write data and command into the device. Please refer to Figure 8-7 for 
the write mode of I2C-bus in chronological order. 
 Figure 8-7 : I2C-bus data format 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
8.1.5.2 Write mode for I2C    
1) The master device initiates the data communication by a start condition. The definition of the start 
condition is shown in Figure 8-8. The start condition is established by pulling the SDA from HIGH to 
LOW while the SCL stays HIGH.  
2) The slave address is following the start condition for recognition use. For the SSD1306, the slave 
address is either “b0111100” or “b0111101” by changing the SA0 to LOW or HIGH (D/C pin acts as 
SA0).  
3) The write mode is established by setting the R/W# bit to logic “0”.  
4) An acknowledgement signal will be generated after receiving one byte of data, including the slave 
address and the R/W# bit. Please refer to the Figure 8-9 for the graphical representation of the 
acknowledge signal. The acknowledge bit is defined as the SDA line is pulled down during the HIGH 
period of the acknowledgement related clock pulse.  
5) After the transmission of the slave address, either the control byte or the data byte may be sent across 
the SDA. A control byte mainly consists of Co and D/C# bits following by six “0” ‘s. 
a. If the Co bit is set as logic “0”, the transmission of the following information will contain 
data bytes only.  
b. The D/C# bit determines the next data byte is acted as a command or a data. If the D/C# bit is 
set to logic “0”, it defines the following data byte as a command. If the D/C# bit is set to 
logic “1”, it defines the following data byte as a data which will be stored at the GDDRAM. 
The GDDRAM column address pointer will be increased by one automatically after each 
data write. 
6) Acknowledge bit will be generated after receiving each control byte or data byte. 
7) The write mode will be finished when a stop condition is applied. The stop condition is also defined 
in Figure 8-8. The stop condition is established by pulling the “SDA in” from LOW to HIGH while 
the “SCL” stays HIGH. 
0 1 1 1 1
P
Slave Address m ≥ 0 words n  ≥  0 bytes 
MSB ……………….LSB
   1 byte 
Write mode 
SSD1306 
Slave Address 
R
/W
#
  
D
/C
#
C
o
A
C
K
A
C
KControl byte Data byte Control byte  
A
C
K Data byte 
A
C
K
S
 0  1  1  1  1  0 
  S
A
0
  R
/W
#
C
o
D
/C
A
C
K
Control byte 
Note: Co – Continuation bit 
D/C# – Data / Command Selection bit 
ACK – Acknowledgement 
SA0 – Slave address bit 
R/W# – Read / Write Selection bit 
S – Start Condition / P – Stop Condition 
 0  0  0  0  0  0 
 0 1 1 1 1 0 
D
/C
#
C
o
A
C
K
  
SSD1306 Rev 1.1 P 21/59 Apr 2008  Solomon Systech
 
Figure 8-8 : Definition of the Start and Stop Condition 
 
 
Figure 8-9 : Definition of the acknowledgement condition 
 
 
 
Please be noted that the transmission of the data bit has some limitations. 
1. The data bit, which is transmitted during each SCL pulse, must keep at a stable state within the “HIGH” 
period of the clock pulse. Please refer to the  Figure 8-10 for graphical representations. Except in start or 
stop conditions, the data line can be switched only when the SCL is LOW. 
2. Both the data line (SDA) and the clock line (SCL) should be pulled up by external resistors.  
 
 
 Figure 8-10 : Definition of the data transfer condition  
 
SDA 
SCL 
Data line is 
stable 
Change 
of data
DATA OUTPUT  
BY RECEIVER 
DATA OUTPUT  
BY TRANSMITTER 
SCL FROM  
MASTER 
S 
 
START 
Condition 
Clock pulse for acknowledgement 
1 8 9 
Non-acknowledge 
2
Acknowledge 
S 
 
START condition 
SDA 
SCL 
P 
 
STOP condition
SDA
SCL
tHSTART tSSTOP 
  
Solomon Systech  Apr 2008 P 22/59 Rev 1.1 SSD1306  
 
8.2 Command Decoder 
This module determines whether the input data is interpreted as data or command. Data is interpreted based 
upon the input of the D/C# pin. 
 
If D/C# pin is HIGH, D[7:0] is interpreted as display data written to Graphic Display Data RAM (GDDRAM). 
If it is LOW, the input at D[7:0] is interpreted as a command.  Then data input will be decoded and written to 
the corresponding command register. 
  
8.3 Oscillator Circuit and Display Time Generator 
Figure 8-11 : Oscillator Circuit and Display Time Generator 
Divider
Internal
Oscillator
Fosc
M
U
XCL
CLK DCLK
Display
Clock
CLS
 
 
This module is an on-chip LOW power RC oscillator circuitry.  The operation clock (CLK) can be generated 
either from internal oscillator or external source CL pin.  This selection is done by CLS pin.  If CLS pin is 
pulled HIGH, internal oscillator is chosen and CL should be left open.  Pulling CLS pin LOW disables 
internal oscillator and external clock must be connected to CL pins for proper operation.  When the internal 
oscillator is selected, its output frequency Fosc can be changed by command D5h A[7:4]. 
 
The display clock (DCLK) for the Display Timing Generator is derived from CLK. The division factor “D” 
can be programmed from 1 to 16 by command D5h  
DCLK = FOSC / D 
 
The frame frequency of display is determined by the following formula. 
MuxofNo.K D
F
F oscFRM
××
=  
where 
• D stands for clock divide ratio. It is set by command D5h A[3:0]. The divide ratio has the range from 1 to 
16. 
• K is the number of display clocks per row.  The value is derived by  
K = Phase 1 period + Phase 2 period + BANK0 pulse width 
   =  2 + 2 + 50 = 54 at power on reset 
(Please refer to Section 8.6 “Segment Drivers / Common Drivers” for the details of the “Phase”) 
• Number of multiplex ratio is set by command A8h.  The power on reset value is 63 (i.e. 64MUX). 
• FOSC is the oscillator frequency. It can be changed by command D5h A[7:4]. The higher the register 
setting results in higher frequency. 
 
 
  
SSD1306 Rev 1.1 P 23/59 Apr 2008  Solomon Systech
 
8.4 FR synchronization 
FR synchronization signal can be used to prevent tearing effect. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
The starting time to write a new image to OLED driver is depended on the MCU writing speed.  If MCU can 
finish writing a frame image within one frame period, it is classified as fast write MCU.  For MCU needs 
longer writing time to complete (more than one frame but within two frames), it is a slow write one. 
 
For fast write MCU: MCU should start to write new frame of ram data just after rising edge of FR pulse and 
should be finished well before the rising edge of the next FR pulse. 
 
For slow write MCU: MCU should start to write new frame ram data after the falling edge of the 1st FR 
pulse and must be finished before the rising edge of the 3rd FR pulse. 
  
8.5 Reset Circuit 
When RES# input is LOW, the chip is initialized with the following status: 
1. Display is OFF 
2. 128 x 64 Display Mode 
3. Normal segment and display data column address and row address mapping (SEG0 mapped to 
address 00h and COM0 mapped to address 00h) 
4. Shift register data clear in serial interface 
5. Display start line is set at display RAM address 0 
6. Column address counter is set at 0 
7. Normal scan direction of the COM outputs 
8. Contrast control register is set at 7Fh 
9. Normal display mode (Equivalent to A4h command) 
 
 
 
 
 
 
 
 
Fast write MCU 
Slow write MCU 
SSD1306 displaying memory updates to OLED screen 
One frame 
FR 
100% 
 
 
 
 
0% 
Memory 
Access 
Process 
Time 
  
Solomon Systech  Apr 2008 P 24/59 Rev 1.1 SSD1306  
 
8.6 Segment Drivers / Common Drivers 
Segment drivers deliver 128 current sources to drive the OLED panel. The driving current can be adjusted 
from 0 to 100uA with 256 steps. Common drivers generate voltage-scanning pulses. 
 
The segment driving waveform is divided into three phases:  
1. In phase 1, the OLED pixel charges of previous image are discharged in order to prepare for next 
image content display. 
2. In phase 2, the OLED pixel is driven to the targeted voltage. The pixel is driven to attain the 
corresponding voltage level from VSS.  The period of phase 2 can be programmed in length from 1 to 
15 DCLKs.  If the capacitance value of the pixel of OLED panel is larger, a longer period is required 
to charge up the capacitor to reach the desired voltage. 
3. In phase 3, the OLED driver switches to use current source to drive the OLED pixels and this is the 
current drive stage.  
 
Figure 8-12 : Segment Output Waveform in three phases 
 
 
 
 
 
 
 
 
 
 
 
 
After finishing phase 3, the driver IC will go back to phase 1 to display the next row image data.  This three-
step cycle is run continuously to refresh image display on OLED panel. 
 
 
In phase 3, if the length of current drive pulse width is set to 50, after finishing 50 DCLKs in current drive 
phase, the driver IC will go back to phase 1 for next row display. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Segment  
VSS  
Phase:   1 2                      3 Time 
  
SSD1306 Rev 1.1 P 25/59 Apr 2008  Solomon Systech
 
8.7 Graphic Display Data RAM (GDDRAM) 
The GDDRAM is a bit mapped static RAM holding the bit pattern to be displayed. The size of the RAM is 
128 x 64 bits and the RAM is divided into eight pages, from PAGE0 to PAGE7, which are used for 
monochrome 128x64 dot matrix display, as shown in Figure 8-13.    
 
Figure 8-13 : GDDRAM pages structure of SSD1306 
 
  Row re-mapping 
PAGE0 (COM0-COM7)  Page 0 PAGE0 (COM 63-COM56) 
PAGE1 (COM8-COM15)  Page 1 PAGE1 (COM 55-COM48) 
PAGE2 (COM16-COM23) Page 2 PAGE2 (COM47-COM40) 
PAGE3 (COM24-COM31) Page 3 PAGE3 (COM39-COM32) 
PAGE4 (COM32-COM39)  Page 4 PAGE4 (COM31-COM24) 
PAGE5 (COM40-COM47) Page 5 PAGE5 (COM23-COM16) 
PAGE6 (COM48–COM55) Page 6 PAGE6 (COM15-COM8) 
PAGE7 (COM56-COM63) Page 7 PAGE7 (COM 7-COM0) 
 SEG0 ---------------------------------------------SEG127  
Column re-mapping SEG127 ---------------------------------------------SEG0  
 
  
 
When one data byte is written into GDDRAM, all the rows image data of the same page of the current 
column are filled (i.e. the whole column (8 bits) pointed by the column address pointer is filled.). Data bit D0 
is written into the top row, while data bit D7 is written into bottom row as shown in Figure 8-14. 
 
 
Figure 8-14 : Enlargement of GDDRAM (No row re-mapping and column-remapping) 
 
 
For mechanical flexibility, re-mapping on both Segment and Common outputs can be selected by software as 
shown in Figure 8-13. 
 
For vertical shifting of the display, an internal register storing the display start line can be set to control the 
portion of the RAM data to be mapped to the display (command D3h).  
 
LSB D0 
MSB D7 
Each box represents one bit of image data 
....................PAGE2 
COM16
COM17
: 
: 
: 
: 
: 
COM23
SE
G
0 
SE
G
1 
SE
G
2 
SE
G
3 
SE
G
4 
SE
G
12
3 
SE
G
13
4 
SE
G
12
5 
SE
G
12
6 
SE
G
12
7 
....................
  
Solomon Systech  Apr 2008 P 26/59 Rev 1.1 SSD1306  
 
8.8 SEG/COM Driving block 
This block is used to derive the incoming power sources into the different levels of internal use voltage and 
current.  
• VCC is the most positive voltage supply.  
• VCOMH is the Common deselected level.  It is internally regulated. 
• VLSS is the ground path of the analog and panel current. 
• IREF is a reference current source for segment current drivers ISEG.  The relationship between reference 
current and segment current of a color is:   
 
ISEG = Contrast / 256 x IREF x scale factor  
 
in which  
the contrast (0~255) is set by Set Contrast command 81h; and  
the scale factor is 8 by default. 
 
The magnitude of IREF is controlled by the value of resistor, which is connected between IREF pin and 
VSS as shown in Figure 8-15.  It is recommended to set IREF to 12.5 ± 2uA so as to achieve ISEG = 
100uA at maximum contrast 255. 
 
Figure 8-15 : IREF  Current Setting by Resistor Value 
 
 
 
 
 
Since the voltage at IREF pin is VCC – 2.5V, the value of resistor R1 can be found as below: 
 
For IREF = 12.5uA, VCC =12V: 
 
R1 = (Voltage at IREF – VSS) / IREF 
 =  (12 – 2.5) / 12.5uA 
 =  760KΩ 
 
SSD1306 
IREF (voltage at 
this pin = 
VCC – 2.5) 
R1
VSS
IREF ~ 12.5uA
  
SSD1306 Rev 1.1 P 27/59 Apr 2008  Solomon Systech
 
8.9 Power ON and OFF sequence 
The following figures illustrate the recommended power ON and power OFF sequence of SSD1306  
 
Power ON sequence: 
1. Power ON VDD  
2. After VDD become stable, set RES# pin LOW (logic low) for at least 3us (t1) (4) and then HIGH (logic 
high). 
3. After set RES# pin LOW (logic low), wait for at least 3us (t2). Then Power ON VCC.(1) 
4. After VCC become stable, send command AFh for display ON. SEG/COM will be ON after 100ms 
(tAF). 
 Figure 8-16 : The Power ON sequence 
 
 
Power OFF sequence: 
1. Send command AEh for display OFF. 
2. Power OFF VCC.(1), (2), (3) 
3. Power OFF VDD after tOFF. (5) (Typical tOFF=100ms) 
Figure 8-17 : The Power OFF sequence 
 
 
Note: 
(1) Since an ESD protection circuit is connected between VDD and VCC, VCC becomes lower than VDD whenever VDD is 
ON and VCC is OFF as shown in the dotted line of VCC in Figure 8-16  and Figure 8-17. 
(2)
 VCC should be kept float (i.e. disable) when it is OFF.  
(3) Power Pins (VDD , VCC) can never be pulled to ground under any circumstance.  
(4) The register values are reset after t1. 
(5) VDD should not be Power OFF before VCC Power OFF. 
OFF 
ON VDD     RES# ON VCC      Send AFh command for Display ON 
VDD  
RES# 
OFF 
   t1      
SEG/COM 
 tAF  
ON
 
OFF
VCC 
GND 
t2   
OFF VDD 
VDD  
VCC 
Send command AEh for display OFF  OFF VCC 
OFF 
OFF 
tOFF 
  
Solomon Systech  Apr 2008 P 28/59 Rev 1.1 SSD1306  
 
 
9 COMMAND TABLE  
Table 9-1: Command Table 
(D/C#=0, R/W#(WR#) = 0, E(RD#=1) unless specific setting is stated) 
1. Fundamental Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 81 1 0 0 0 0 0 0 1 
0 A[7:0] A7 A6 A5 A4 A3 A2 A1 A0
          
Set Contrast Control Double byte command to select 1 out of 256 
contrast steps. Contrast increases as the value 
increases.  
(RESET = 7Fh ) 
 
0 A4/A5 1 0 1 0 0 1 0 X0 Entire Display ON  A4h, X0=0b: Resume to RAM content display 
(RESET) 
               Output follows RAM content   
A5h, X0=1b: Entire display ON 
                Output ignores RAM content 
0 A6/A7 1 0 1 0 0 1 1 X0
  
        
Set Normal/Inverse 
Display 
A6h, X[0]=0b: Normal display (RESET) 
               0 in RAM: OFF in display panel 
               1 in RAM: ON in display panel  
A7h, X[0]=1b: Inverse display 
                0 in RAM: ON in display panel 
               1 in RAM: OFF in display panel 
0 AE 1 0 1 0 1 1 1 X0
 AF         
          
Set Display ON/OFF
 
AEh, X[0]=0b:Display OFF (sleep mode) 
(RESET) 
AFh  X[0]=1b:Display ON in normal mode 
 
       
 
 
  
 
 
2. Scrolling Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 26/27 0 0 1 0 0 1  1 X0 
0 A[7:0] 0 0 0 0 0 0 0 0 
0 B[2:0] * * * * * B2 B1 B0
0 C[2:0] * * * * * C2 C1 C0
0 D[2:0] * * * * * D2 D1 D0
0 E[7:0] 0 0 0 0 0 0 0 0 
0 F[7:0] 1 1 1 1 1 1 1 1 
Continuous 
Horizontal Scroll 
Setup 
26h, X[0]=0, Right Horizontal Scroll    
27h, X[0]=1, Left Horizontal Scroll   
(Horizontal scroll by 1 column) 
A[7:0] : Dummy byte  (Set as 00h) 
B[2:0] : Define start page address 
000b – PAGE0 011b – PAGE3 110b – PAGE6
001b – PAGE1 100b – PAGE4 111b – PAGE7
010b – PAGE2 101b – PAGE5  
C[2:0] : Set time interval between each scroll step in  
terms of  frame frequency 
000b – 5 frames 100b – 3 frames 
001b – 64 frames 101b – 4 frames 
010b – 128 frames 110b – 25 frame 
011b – 256 frames 111b – 2 frame 
D[2:0] : Define end page address 
000b – PAGE0 011b – PAGE3 110b – PAGE6
001b – PAGE1 100b – PAGE4 111b – PAGE7
010b – PAGE2 101b – PAGE5  
             The value of D[2:0] must be larger or equal  
to B[2:0] 
E[7:0] : Dummy byte (Set as 00h) 
 
F[7:0] : Dummy byte (Set as FFh) 
 
  
SSD1306 Rev 1.1 P 29/59 Apr 2008  Solomon Systech
 
2. Scrolling Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 29/2A 0 0 1 0 1 0 X1 X0
0 A[2:0] 0 0 0 0 0 0 0 0 
0 B[2:0] * * * * * B2 B1 B0
0 C[2:0] * * * * * C2 C1 C0
0 D[2:0] * * * * * D2 D1 D0
0 E[5:0] * * E5 E4 E3 E2 E1 E0
Continuous 
Vertical and 
Horizontal Scroll 
Setup 
29h, X1X0=01b : Vertical and Right Horizontal Scroll
2Ah, X1X0=10b : Vertical and Left Horizontal Scroll
 (Horizontal scroll by 1 column) 
A[7:0] : Dummy byte 
 
B[2:0] : Define start page address 
000b – PAGE0 011b – PAGE3 110b – PAGE6
001b – PAGE1 100b – PAGE4 111b – PAGE7
010b – PAGE2 101b – PAGE5  
 
 
 
C[2:0] : Set time interval between each scroll step in  
terms of  frame frequency 
000b – 5 frames 100b – 3 frames 
001b – 64 frames 101b – 4 frames 
010b – 128 frames 110b – 25 frame 
011b – 256 frames 111b – 2 frame 
 
 
D[2:0] : Define end page address 
000b – PAGE0 011b – PAGE3 110b – PAGE6
001b – PAGE1 100b – PAGE4 111b – PAGE7
010b – PAGE2 101b – PAGE5  
             The value of D[2:0] must be larger or equal  
              to B[2:0] 
 
E[5:0] : Vertical scrolling offset 
              e.g. E[5:0]= 01h  refer to offset =1 row 
                     E[5:0] =3Fh refer to offset =63 rows 
Note 
(1)  No continuous vertical scrolling is available. 
 
0 2E 0 0 1 0 1 1 1 0 
          
Deactivate scroll Stop scrolling that is configured by command 
26h/27h/29h/2Ah. 
 
 
Note 
(1)  After sending 2Eh command to deactivate the scrolling 
action, the ram data needs to be rewritten. 
 
0 2F 0 0 1 0 1 1 1 1 
          
Activate scroll Start scrolling that is configured by the scrolling setup 
commands :26h/27h/29h/2Ah with the following valid 
sequences: 
 
 
 
Valid command sequence 1: 26h ;2Fh. 
Valid command sequence 2: 27h ;2Fh. 
Valid command  sequence 3: 29h ;2Fh. 
Valid command  sequence 4: 2Ah ;2Fh. 
 
For example,  if “26h; 2Ah; 2Fh.” commands are 
issued, the setting in the last scrolling setup command, 
i.e. 2Ah in this case, will be executed. In other words, 
setting in the last scrolling setup command overwrites 
the setting in the previous scrolling setup commands.
 
  
Solomon Systech  Apr 2008 P 30/59 Rev 1.1 SSD1306  
 
2. Scrolling Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 A3 1 0 1 0 0 0 1 1 
0 A[5:0] * * A5 A4 A3 A2 A1 A0
0 B[6:0] * B6 B5 B4 B3 B2 B1 B0
Set Vertical Scroll 
Area 
A[5:0] : Set No. of rows in top fixed area. The No. of 
rows in top fixed area is referenced to the 
top of the GDDRAM (i.e. row 0).[RESET = 
0] 
 
B[6:0] : Set No. of rows in scroll area. This is the 
number of rows to be used for vertical 
scrolling. The scroll area starts in the first 
row below the top fixed area. [RESET = 64]
Note 
(1) A[5:0]+B[6:0] <= MUX ratio 
(2)  B[6:0] <= MUX ratio 
(3a) Vertical scrolling offset (E[5:0] in 29h/2Ah) < 
B[6:0] 
(3b) Set Display Start Line (X5X4X3X2X1X0 of 
40h~7Fh) < B[6:0] 
(4) The last row of the scroll area shifts to the first row 
of the scroll area. 
(5) For 64d MUX  display 
   A[5:0] = 0, B[6:0]=64 : whole area scrolls 
   A[5:0]= 0, B[6:0] < 64 : top area scrolls 
   A[5:0]  + B[6:0] < 64 : central area scrolls 
   A[5:0]  + B[6:0] = 64 : bottom area scrolls 
  
 
  3. Addressing Setting Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 00~0F 0 0 0 0 X3 X2 X1 X0
          
Set Lower Column 
Start Address for 
Page Addressing 
Mode 
Set the lower nibble of the column start address 
register for Page Addressing Mode using X[3:0] 
as data bits. The initial display line register is 
reset to 0000b after RESET. 
 
Note 
(1) This command is only for page addressing mode 
 
0 10~1F 0 0 0 1 X3 X2 X1 X0
          
Set Higher Column 
Start Address for 
Page Addressing 
Mode 
Set the higher nibble of the column start address 
register for Page Addressing Mode using X[3:0] 
as data bits. The initial display line register is 
reset to 0000b after RESET. 
 
Note 
(1) This command is only for page addressing mode 
 
0 20 0 0 1 0 0 0 0 0 
0 A[1:0] * * * * * * A1 A0
          
Set Memory 
Addressing Mode 
A[1:0] = 00b, Horizontal Addressing Mode 
A[1:0] = 01b, Vertical Addressing Mode 
A[1:0] = 10b, Page Addressing Mode (RESET)
A[1:0] = 11b, Invalid  
 
0 21 0 0 1 0 0 0 0 1 
0 A[6:0] * A6 A5 A4 A3 A2 A1 A0
0 B[6:0] * B6 B5 B4 B3 B2 B1 B0
          
Set Column Address Setup column start and end address 
A[6:0] : Column start address, range : 0-127d, 
(RESET=0d) 
 
B[6:0]: Column end address, range : 0-127d,   
(RESET =127d) 
Note 
(1) This command is only for horizontal or vertical 
addressing mode.    
 
  
SSD1306 Rev 1.1 P 31/59 Apr 2008  Solomon Systech
 
  3. Addressing Setting Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 22 0 0 1 0 0 0 1 0 
0 A[2:0] * * * * * A2 A1 A0
0 B[2:0] * * * * * B2 B1 B0
          
Set Page Address Setup page start and end address 
A[2:0] : Page start Address, range : 0-7d,  
(RESET = 0d) 
B[2:0] : Page end Address, range : 0-7d,  
(RESET = 7d) 
Note 
(1) This command is only for horizontal or vertical 
addressing mode.    
 
0 B0~B7 1 0 1 1 0 X2 X1 X0
  
        
Set Page Start 
Address for Page 
Addressing Mode 
Set GDDRAM Page Start Address 
(PAGE0~PAGE7) for Page Addressing Mode 
using X[2:0]. 
 
Note 
(1) This command is only for page addressing mode 
 
 
  
 
 
4. Hardware Configuration (Panel resolution & layout related) Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 40~7F 0 1 X5 X4 X3 X2 X1 X0
          
Set Display Start LineSet display RAM display start line register from 
0-63 using X5X3X2X1X0. 
Display start line register is reset to 000000b 
during RESET. 
 
0 A0/A1 1 0 1 0 0 0 0 X0 
          
Set Segment Re-map A0h, X[0]=0b: column address 0 is mapped to 
SEG0 (RESET) 
A1h, X[0]=1b: column address 127 is mapped to 
           SEG0 
 
0 A8 1 0 1 0 1 0 0 0 
0 A[5:0] * * A5 A4 A3 A2 A1 A0
Set Multiplex Ratio Set MUX ratio to N+1 MUX 
N=A[5:0] : from 16MUX to 64MUX, RESET= 
111111b (i.e. 63d, 64MUX) 
A[5:0] from 0 to 14 are invalid entry. 
 
0 C0/C8 1 1 0 0 X3 0 0 0 
          
Set COM Output 
Scan Direction 
C0h, X[3]=0b: normal mode (RESET) Scan from 
COM0 to COM[N –1] 
C8h, X[3]=1b: remapped mode. Scan from 
COM[N-1] to COM0 
Where N is the Multiplex ratio. 
 
0 D3 1 1 0 1 0 0 1 1 
0 A[5:0] * * A5 A4 A3 A2 A1 A0
          
Set Display Offset Set vertical shift by COM from 0d~63d 
The value is reset to 00h after RESET. 
0 DA 1 1 0 1 1 0 1 0 
0 A[5:4] 0 0 A5 A4 0 0 1 0 
          
Set COM Pins 
Hardware 
Configuration 
A[4]=0b, Sequential COM pin configuration 
A[4]=1b(RESET), Alternative COM pin 
configuration  
 
A[5]=0b(RESET), Disable COM Left/Right 
remap 
A[5]=1b, Enable COM Left/Right remap 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 32/59 Rev 1.1 SSD1306  
 
 
5. Timing & Driving Scheme Setting Command Table 
D/C#Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 D5 1 1 0 1 0 1 0 1 
0 A[7:0] A7 A6 A5 A4 A3 A2 A1 A0
          
Set Display Clock 
Divide 
Ratio/Oscillator 
Frequency 
A[3:0] : Define the divide ratio (D) of the 
display clocks (DCLK):  
Divide ratio= A[3:0] + 1, RESET is 
0000b (divide ratio = 1) 
 
A[7:4] : Set the Oscillator Frequency, FOSC. 
Oscillator Frequency increases with 
the value of A[7:4] and vice versa.  
RESET is 1000b 
Range:0000b~1111b   
Frequency increases as setting value 
increases.  
0 D9 1 1 0 1 1 0 0 1 
0 A[7:0] A7 A6 A5 A4 A3 A2 A1 A0
Set Pre-charge Period A[3:0] : Phase 1 period of up to 15 DCLK 
clocks 0 is invalid entry   
(RESET=2h) 
 
A[7:4] : Phase 2 period of up to 15 DCLK 
clocks 0 is invalid entry   
(RESET=2h ) 
0 DB 1 1 0 1 1 0 1 1 
0 A[6:4] 0 A6 A5 A4 0 0 0 0 
Set VCOMH Deselect 
Level 
  
A[6:4] Hex 
code 
V COMH deselect level 
000b 00h ~ 0.65 x VCC 
010b 20h ~ 0.77 x VCC (RESET) 
011b 30h ~ 0.83 x VCC 
0 E3 1 1 1 0 0 0 1 1 
          
NOP Command for no operation 
 
 
 
Note 
(1) “*” stands for “Don’t care”. 
  
SSD1306 Rev 1.1 P 33/59 Apr 2008  Solomon Systech
 
Table 9-2 : Read Command Table 
Bit Pattern Command Description 
 D7D6D5D4D3D2D1D0 
 
 
Status Register Read  
 
D[7] : Reserved 
D[6] : “1” for display OFF / “0” for display ON
D[5] : Reserved 
D[4]  : Reserved 
D[3]  : Reserved 
D[2]  : Reserved 
D[1]  : Reserved 
D[0]  : Reserved 
 
Note 
(1) Patterns other than those given in the Command Table are prohibited to enter the chip as a command; as unexpected 
results can occur. 
 
 
9.1 Data Read / Write 
To read data from the GDDRAM, select HIGH for both the R/W# (WR#) pin and the D/C# pin for 6800-
series parallel mode and select LOW for the E (RD#) pin and HIGH for the D/C# pin for 8080-series parallel 
mode. No data read is provided in serial mode operation. 
In normal data read mode the GDDRAM column address pointer will be increased automatically by one after 
each data read.  
Also, a dummy read is required before the first data read.  
To write data to the GDDRAM, select LOW for the R/W# (WR#) pin and HIGH for the D/C# pin for both 
6800-series parallel mode and 8080-series parallel mode. The serial interface mode is always in write mode. 
The GDDRAM column address pointer will be increased automatically by one after each data write. 
 
Table 9-3 : Address increment table (Automatic) 
D/C# R/W# (WR#) Comment Address Increment 
0 0 Write Command No 
0 1 Read Status No 
1 0 Write Data Yes 
1 1 Read Data Yes  
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 34/59 Rev 1.1 SSD1306  
 
10 COMMAND DESCRIPTIONS  
10.1 Fundamental Command 
10.1.1 Set Lower Column Start Address for Page Addressing Mode (00h~0Fh) 
This command specifies the lower nibble of the 8-bit column start address for the display data RAM under 
Page Addressing Mode. The column address will be incremented by each data access. Please refer to Section 
Table 9-1  and Section 10.1.3 for details. 
10.1.2 Set Higher Column Start Address for Page Addressing Mode (10h~1Fh) 
This command specifies the higher nibble of the 8-bit column start address for the display data RAM under 
Page Addressing Mode. The column address will be incremented by each data access. Please refer to Section 
Table 9-1 and Section 10.1.3  for details. 
10.1.3 Set Memory Addressing Mode (20h) 
There are 3 different memory addressing mode in SSD1306: page addressing mode, horizontal addressing 
mode and vertical addressing mode. This command sets the way of memory addressing into one of the above 
three modes. In there, “COL” means the graphic display data RAM column. 
 
Page addressing mode (A[1:0]=10xb)  
In page addressing mode, after the display RAM is read/written, the column address pointer is increased 
automatically by 1.  If the column address pointer reaches column end address, the column address pointer is 
reset to column start address and page address pointer is not changed. Users have to set the new page and 
column addresses in order to access the next page RAM content. The sequence of movement of the PAGE 
and column address point for page addressing mode is shown in Figure 10-1. 
Figure 10-1 : Address Pointer Movement of Page addressing mode 
 COL0 COL 1 ….. COL 126 COL 127 
PAGE0      
PAGE1      
: : : : : : 
PAGE6      
PAGE7      
 
In normal display data RAM read or write and page addressing mode, the following steps are required to 
define the starting RAM access pointer location: 
• Set the page start address of the target display location by command B0h to B7h. 
• Set the lower start column address of pointer by command 00h~0Fh.  
• Set the upper start column address of pointer by command 10h~1Fh. 
For example, if the page address is set to B2h, lower column address is 03h and upper column address is 10h, 
then that means the starting column is SEG3 of PAGE2. The RAM access pointer is located as shown in 
Figure 10-2.  The input data byte will be written into RAM position of column 3. 
Figure 10-2 : Example of GDDRAM access pointer setting in Page Addressing Mode (No row and column-
remapping) 
 
 
 
 
 
 
 
 
 
LSB D0 
MSB D7 
Each lattice represents 
one bit of image data 
....................PAGE2 
(Starting page) 
COM16
COM17
: 
: 
: 
: 
: 
COM23
SEG0       SEG3 (Starting column)                                                                                SEG127 
RAM access pointer
  
SSD1306 Rev 1.1 P 35/59 Apr 2008  Solomon Systech
 
Horizontal addressing mode (A[1:0]=00b) 
In horizontal addressing mode, after the display RAM is read/written, the column address pointer is increased 
automatically by 1.  If the column address pointer reaches column end address, the column address pointer is 
reset to column start address and page address pointer is increased by 1.  The sequence of movement of the 
page and column address point for horizontal addressing mode is shown in Figure 10-3. When both column 
and page address pointers reach the end address, the pointers are reset to column start address and page start 
address (Dotted line in Figure 10-3.) 
 
  Figure 10-3 : Address Pointer Movement of Horizontal addressing mode 
 COL0 COL 1 ….. COL 126 COL 127 
PAGE0      
PAGE1      
: : : : : : 
PAGE6      
PAGE7      
 
 
Vertical addressing mode: (A[1:0]=01b) 
In vertical addressing mode, after the display RAM is read/written, the page address pointer is increased 
automatically by 1.  If the page address pointer reaches the page end address, the page address pointer is reset 
to page start address and column address pointer is increased by 1. The sequence of movement of the page 
and column address point for vertical addressing mode is shown in Figure 10-4. When both column and page 
address pointers reach the end address, the pointers are reset to column start address and page start address 
(Dotted line in Figure 10-4.) 
 
Figure 10-4 : Address Pointer Movement of Vertical addressing mode 
 COL0 COL 1 ….. COL 126 COL 127 
PAGE0   …..   
PAGE1   …..   
:   :   
PAGE6   …..   
PAGE7   …..   
 
 
 
In normal display data RAM read or write and horizontal / vertical addressing mode, the following steps are 
required to define the RAM access pointer location: 
• Set the column start and end address of the target display location by command 21h. 
• Set the page start and end address of the target display location by command 22h. 
Example is shown in Figure 10-5. 
 
10.1.4 Set Column Address (21h) 
This triple byte command specifies column start address and end address of the display data RAM. This 
command also sets the column address pointer to column start address.  This pointer is used to define the 
current read/write column address in graphic display data RAM.  If horizontal address increment mode is 
enabled by command 20h, after finishing read/write one column data, it is incremented automatically to the 
next column address.  Whenever the column address pointer finishes accessing the end column address, it is 
reset back to start column address and the row address is incremented to the next row.   
 
 
 
  
Solomon Systech  Apr 2008 P 36/59 Rev 1.1 SSD1306  
 
10.1.5 Set Page Address (22h) 
This triple byte command specifies page start address and end address of the display data RAM. This 
command also sets the page address pointer to page start address.  This pointer is used to define the current 
read/write page address in graphic display data RAM. If vertical address increment mode is enabled by 
command 20h, after finishing read/write one page data, it is incremented automatically to the next page 
address.  Whenever the page address pointer finishes accessing the end page address, it is reset back to start 
page address. 
 
The figure below shows the way of column and page address pointer movement through the example: column 
start address is set to 2 and column end address is set to 125, page start address is set to 1 and page end 
address is set to 6;  Horizontal address increment mode is enabled by command 20h.  In this case, the graphic 
display data RAM column accessible range is from column 2 to column 125 and from page 1 to page 6 only.  
In addition, the column address pointer is set to 2 and page address pointer is set to 1.  After finishing 
read/write one pixel of data, the column address is increased automatically by 1 to access the next RAM 
location for next read/write operation (solid line in Figure 10-5).  Whenever the column address pointer 
finishes accessing the end column 125, it is reset back to column 2 and page address is automatically 
increased by 1 (solid line in Figure 10-5).  While the end page 6 and end column 125 RAM location is 
accessed, the page address is reset back to 1 and the column address is reset back to 2 (dotted line in Figure 
10-5).  .   
Figure 10-5 : Example of Column and Row Address Pointer Movement 
 Col 0 Col 1 Col 2 ….. ……. Col 125 Col 126 Col 127 
PAGE0         
PAGE1         
:    :     
PAGE6         
PAGE7    :     
 
10.1.6 Set Display Start Line (40h~7Fh) 
This command sets the Display Start Line register to determine starting address of display RAM, by selecting 
a value from 0 to 63. With value equal to 0, RAM row 0 is mapped to COM0. With value equal to 1, RAM 
row 1 is mapped to COM0 and so on.    
 
Refer to Table 10-1 for more illustrations. 
 
10.1.7 Set Contrast Control for BANK0 (81h) 
This command sets the Contrast Setting of the display. The chip has 256 contrast steps from 00h to FFh. The 
segment output current increases as the contrast step value increases. 
 
 
10.1.8  Set Segment Re-map (A0h/A1h) 
This command changes the mapping between the display data column address and the segment driver. It 
allows flexibility in OLED module design. Please refer to Table 9-1. 
 
This command only affects subsequent data input.  Data already stored in GDDRAM will have no changes. 
  
  
SSD1306 Rev 1.1 P 37/59 Apr 2008  Solomon Systech
 
10.1.9  Entire Display ON   (A4h/A5h) 
A4h command enable display outputs according to the GDDRAM contents. 
If A5h command is issued, then by using A4h command, the display will resume to the GDDRAM contents. 
In other words, A4h command resumes the display from entire display “ON” stage.  
A5h command forces the entire display to be “ON”, regardless of the contents of the display data RAM. 
 
10.1.10  Set Normal/Inverse Display (A6h/A7h) 
This command sets the display to be either normal or inverse. In normal display a RAM data of 1 indicates an 
“ON” pixel while in inverse display a RAM data of 0 indicates an “ON” pixel. 
 
10.1.11  Set Multiplex Ratio (A8h) 
This command switches the default 63 multiplex mode to any multiplex ratio, ranging from 16 to 63. The 
output pads COM0~COM63 will be switched to the corresponding COM signal.  
 
10.1.12 Set Display ON/OFF (AEh/AFh) 
These single byte commands are used to turn the OLED panel display ON or OFF.   
When the display is ON, the selected circuits by Set Master Configuration command will be turned ON.   
When the display is OFF, those circuits will be turned OFF and the segment and common output are in VSS 
state and high impedance state, respectively. These commands set the display to one of the two states: 
o AEh : Display OFF 
o AFh : Display ON 
 
 Figure 10-6 :Transition between different modes 
 
 
 
 
10.1.13 Set Page Start Address for Page Addressing Mode (B0h~B7h) 
This command positions the page start address from 0 to 7 in GDDRAM under Page Addressing Mode. 
Please refer to Table 9-1  and Section 10.1.3  for details. 
 
10.1.14  Set COM Output Scan Direction (C0h/C8h) 
This command sets the scan direction of the COM output, allowing layout flexibility in the OLED module 
design. Additionally, the display will show once this command is issued. For example, if this command is 
sent during normal display then the graphic display will be vertically flipped immediately. Please refer to 
Table 10-3 for details. 
 
10.1.15  Set Display Offset (D3h) 
This is a double byte command. The second command specifies the mapping of the display start line to one of 
COM0~COM63 (assuming that COM0 is the display start line then the display start line register is equal to 0).  
 
For example, to move the COM16 towards the COM0 direction by 16 lines the 6-bit data in the second byte 
should be given as 010000b. To move in the opposite direction by 16 lines the 6-bit data should be given by 
64 – 16, so the second byte would be 100000b. The following two tables (Table 10-1, Table 10-2) show the 
example of setting the command C0h/C8h and D3h. 
 
 
Normal mode Sleep mode 
AFh 
AEh
  
Solomon Systech  Apr 2008 P 38/59 Rev 1.1 SSD1306  
 
Table 10-1 : Example of Set Display Offset and Display Start Line with no Remap 
 
 
 
 
 
 
 Set MUX ratio(A8h)
COM Normal / Remapped (C0h / C8h)
Display offset (D3h)
Display start line (40h - 7Fh)
COM0 Row0 RAM0 Row8 RAM8 Row0 RAM8 Row0 RAM0 Row8 RAM8 Row0 RAM8
COM1 Row1 RAM1 Row9 RAM9 Row1 RAM9 Row1 RAM1 Row9 RAM9 Row1 RAM9
COM2 Row2 RAM2 Row10 RAM10 Row2 RAM10 Row2 RAM2 Row10 RAM10 Row2 RAM10
COM3 Row3 RAM3 Row11 RAM11 Row3 RAM11 Row3 RAM3 Row11 RAM11 Row3 RAM11
COM4 Row4 RAM4 Row12 RAM12 Row4 RAM12 Row4 RAM4 Row12 RAM12 Row4 RAM12
COM5 Row5 RAM5 Row13 RAM13 Row5 RAM13 Row5 RAM5 Row13 RAM13 Row5 RAM13
COM6 Row6 RAM6 Row14 RAM14 Row6 RAM14 Row6 RAM6 Row14 RAM14 Row6 RAM14
COM7 Row7 RAM7 Row15 RAM15 Row7 RAM15 Row7 RAM7 Row15 RAM15 Row7 RAM15
COM8 Row8 RAM8 Row16 RAM16 Row8 RAM16 Row8 RAM8 Row16 RAM16 Row8 RAM16
COM9 Row9 RAM9 Row17 RAM17 Row9 RAM17 Row9 RAM9 Row17 RAM17 Row9 RAM17
COM10 Row10 RAM10 Row18 RAM18 Row10 RAM18 Row10 RAM10 Row18 RAM18 Row10 RAM18
COM11 Row11 RAM11 Row19 RAM19 Row11 RAM19 Row11 RAM11 Row19 RAM19 Row11 RAM19
COM12 Row12 RAM12 Row20 RAM20 Row12 RAM20 Row12 RAM12 Row20 RAM20 Row12 RAM20
COM13 Row13 RAM13 Row21 RAM21 Row13 RAM21 Row13 RAM13 Row21 RAM21 Row13 RAM21
COM14 Row14 RAM14 Row22 RAM22 Row14 RAM22 Row14 RAM14 Row22 RAM22 Row14 RAM22
COM15 Row15 RAM15 Row23 RAM23 Row15 RAM23 Row15 RAM15 Row23 RAM23 Row15 RAM23
COM16 Row16 RAM16 Row24 RAM24 Row16 RAM24 Row16 RAM16 Row24 RAM24 Row16 RAM24
COM17 Row17 RAM17 Row25 RAM25 Row17 RAM25 Row17 RAM17 Row25 RAM25 Row17 RAM25
COM18 Row18 RAM18 Row26 RAM26 Row18 RAM26 Row18 RAM18 Row26 RAM26 Row18 RAM26
COM19 Row19 RAM19 Row27 RAM27 Row19 RAM27 Row19 RAM19 Row27 RAM27 Row19 RAM27
COM20 Row20 RAM20 Row28 RAM28 Row20 RAM28 Row20 RAM20 Row28 RAM28 Row20 RAM28
COM21 Row21 RAM21 Row29 RAM29 Row21 RAM29 Row21 RAM21 Row29 RAM29 Row21 RAM29
COM22 Row22 RAM22 Row30 RAM30 Row22 RAM30 Row22 RAM22 Row30 RAM30 Row22 RAM30
COM23 Row23 RAM23 Row31 RAM31 Row23 RAM31 Row23 RAM23 Row31 RAM31 Row23 RAM31
COM24 Row24 RAM24 Row32 RAM32 Row24 RAM32 Row24 RAM24 Row32 RAM32 Row24 RAM32
COM25 Row25 RAM25 Row33 RAM33 Row25 RAM33 Row25 RAM25 Row33 RAM33 Row25 RAM33
COM26 Row26 RAM26 Row34 RAM34 Row26 RAM34 Row26 RAM26 Row34 RAM34 Row26 RAM34
COM27 Row27 RAM27 Row35 RAM35 Row27 RAM35 Row27 RAM27 Row35 RAM35 Row27 RAM35
COM28 Row28 RAM28 Row36 RAM36 Row28 RAM36 Row28 RAM28 Row36 RAM36 Row28 RAM36
COM29 Row29 RAM29 Row37 RAM37 Row29 RAM37 Row29 RAM29 Row37 RAM37 Row29 RAM37
COM30 Row30 RAM30 Row38 RAM38 Row30 RAM38 Row30 RAM30 Row38 RAM38 Row30 RAM38
COM31 Row31 RAM31 Row39 RAM39 Row31 RAM39 Row31 RAM31 Row39 RAM39 Row31 RAM39
COM32 Row32 RAM32 Row40 RAM40 Row32 RAM40 Row32 RAM32 Row40 RAM40 Row32 RAM40
COM33 Row33 RAM33 Row41 RAM41 Row33 RAM41 Row33 RAM33 Row41 RAM41 Row33 RAM41
COM34 Row34 RAM34 Row42 RAM42 Row34 RAM42 Row34 RAM34 Row42 RAM42 Row34 RAM42
COM35 Row35 RAM35 Row43 RAM43 Row35 RAM43 Row35 RAM35 Row43 RAM43 Row35 RAM43
COM36 Row36 RAM36 Row44 RAM44 Row36 RAM44 Row36 RAM36 Row44 RAM44 Row36 RAM44
COM37 Row37 RAM37 Row45 RAM45 Row37 RAM45 Row37 RAM37 Row45 RAM45 Row37 RAM45
COM38 Row38 RAM38 Row46 RAM46 Row38 RAM46 Row38 RAM38 Row46 RAM46 Row38 RAM46
COM39 Row39 RAM39 Row47 RAM47 Row39 RAM47 Row39 RAM39 Row47 RAM47 Row39 RAM47
COM40 Row40 RAM40 Row48 RAM48 Row40 RAM48 Row40 RAM40 Row48 RAM48 Row40 RAM48
COM41 Row41 RAM41 Row49 RAM49 Row41 RAM49 Row41 RAM41 Row49 RAM49 Row41 RAM49
COM42 Row42 RAM42 Row50 RAM50 Row42 RAM50 Row42 RAM42 Row50 RAM50 Row42 RAM50
COM43 Row43 RAM43 Row51 RAM51 Row43 RAM51 Row43 RAM43 Row51 RAM51 Row43 RAM51
COM44 Row44 RAM44 Row52 RAM52 Row44 RAM52 Row44 RAM44 Row52 RAM52 Row44 RAM52
COM45 Row45 RAM45 Row53 RAM53 Row45 RAM53 Row45 RAM45 Row53 RAM53 Row45 RAM53
COM46 Row46 RAM46 Row54 RAM54 Row46 RAM54 Row46 RAM46 Row54 RAM54 Row46 RAM54
COM47 Row47 RAM47 Row55 RAM55 Row47 RAM55 Row47 RAM47 Row55 RAM55 Row47 RAM55
COM48 Row48 RAM48 Row56 RAM56 Row48 RAM56 Row48 RAM48 - - Row48 RAM56
COM49 Row49 RAM49 Row57 RAM57 Row49 RAM57 Row49 RAM49 - - Row49 RAM57
COM50 Row50 RAM50 Row58 RAM58 Row50 RAM58 Row50 RAM50 - - Row50 RAM58
COM51 Row51 RAM51 Row59 RAM59 Row51 RAM59 Row51 RAM51 - - Row51 RAM59
COM52 Row52 RAM52 Row60 RAM60 Row52 RAM60 Row52 RAM52 - - Row52 RAM60
COM53 Row53 RAM53 Row61 RAM61 Row53 RAM61 Row53 RAM53 - - Row53 RAM61
COM54 Row54 RAM54 Row62 RAM62 Row54 RAM62 Row54 RAM54 - - Row54 RAM62
COM55 Row55 RAM55 Row63 RAM63 Row55 RAM63 Row55 RAM55 - - Row55 RAM63
COM56 Row56 RAM56 Row0 RAM0 Row56 RAM0 - - Row0 RAM0 - -
COM57 Row57 RAM57 Row1 RAM1 Row57 RAM1 - - Row1 RAM1 - -
COM58 Row58 RAM58 Row2 RAM2 Row58 RAM2 - - Row2 RAM2 - -
COM59 Row59 RAM59 Row3 RAM3 Row59 RAM3 - - Row3 RAM3 - -
COM60 Row60 RAM60 Row4 RAM4 Row60 RAM4 - - Row4 RAM4 - -
COM61 Row61 RAM61 Row5 RAM5 Row61 RAM5 - - Row5 RAM5 - -
COM62 Row62 RAM62 Row6 RAM6 Row62 RAM6 - - Row6 RAM6 - -
COM63 Row63 RAM63 Row7 RAM7 Row63 RAM7 - - Row7 RAM7 - -
Display 
examples
(e) (f)(a) (b) (c) (d)
0 8 0
0 0 8
56 56 56
Normal Normal Normal
64
Normal
0
8
Output
Hardware 
pin name 0
0
Normal
64 64
Normal
8
0
(a) (b) (d)(c)
(e) (f) 
(RAM)
  
SSD1306 Rev 1.1 P 39/59 Apr 2008  Solomon Systech
 
Table 10-2 :Example of Set Display Offset and Display Start Line with Remap 
 
 
 
 
 
 
 
 
 
 
 
 
 
(a) (b) (d)(c)
(e) (f) (g) (RAM) 
Set MUX ratio(A8h)
COM Normal / Remapped (C0h / C8h)
Display offset (D3h)
Display start line (40h - 7Fh)
COM0 Row63 RAM63 Row7 RAM7 Row63 RAM7 Row47 RAM47 - - Row47 RAM55 - -
COM1 Row62 RAM62 Row6 RAM6 Row62 RAM6 Row46 RAM46 - - Row46 RAM54 - -
COM2 Row61 RAM61 Row5 RAM5 Row61 RAM5 Row45 RAM45 - - Row45 RAM53 - -
COM3 Row60 RAM60 Row4 RAM4 Row60 RAM4 Row44 RAM44 - - Row44 RAM52 - -
COM4 Row59 RAM59 Row3 RAM3 Row59 RAM3 Row43 RAM43 - - Row43 RAM51 - -
COM5 Row58 RAM58 Row2 RAM2 Row58 RAM2 Row42 RAM42 - - Row42 RAM50 - -
COM6 Row57 RAM57 Row1 RAM1 Row57 RAM1 Row41 RAM41 - - Row41 RAM49 - -
COM7 Row56 RAM56 Row0 RAM0 Row56 RAM0 Row40 RAM40 - - Row40 RAM48 - -
COM8 Row55 RAM55 Row63 RAM63 Row55 RAM63 Row39 RAM39 Row47 RAM47 Row39 RAM47 Row47 RAM63
COM9 Row54 RAM54 Row62 RAM62 Row54 RAM62 Row38 RAM38 Row46 RAM46 Row38 RAM46 Row46 RAM62
COM10 Row53 RAM53 Row61 RAM61 Row53 RAM61 Row37 RAM37 Row45 RAM45 Row37 RAM45 Row45 RAM61
COM11 Row52 RAM52 Row60 RAM60 Row52 RAM60 Row36 RAM36 Row44 RAM44 Row36 RAM44 Row44 RAM60
COM12 Row51 RAM51 Row59 RAM59 Row51 RAM59 Row35 RAM35 Row43 RAM43 Row35 RAM43 Row43 RAM59
COM13 Row50 RAM50 Row58 RAM58 Row50 RAM58 Row34 RAM34 Row42 RAM42 Row34 RAM42 Row42 RAM58
COM14 Row49 RAM49 Row57 RAM57 Row49 RAM57 Row33 RAM33 Row41 RAM41 Row33 RAM41 Row41 RAM57
COM15 Row48 RAM48 Row56 RAM56 Row48 RAM56 Row32 RAM32 Row40 RAM40 Row32 RAM40 Row40 RAM56
COM16 Row47 RAM47 Row55 RAM55 Row47 RAM55 Row31 RAM31 Row39 RAM39 Row31 RAM39 Row39 RAM55
COM17 Row46 RAM46 Row54 RAM54 Row46 RAM54 Row30 RAM30 Row38 RAM38 Row30 RAM38 Row38 RAM54
COM18 Row45 RAM45 Row53 RAM53 Row45 RAM53 Row29 RAM29 Row37 RAM37 Row29 RAM37 Row37 RAM53
COM19 Row44 RAM44 Row52 RAM52 Row44 RAM52 Row28 RAM28 Row36 RAM36 Row28 RAM36 Row36 RAM52
COM20 Row43 RAM43 Row51 RAM51 Row43 RAM51 Row27 RAM27 Row35 RAM35 Row27 RAM35 Row35 RAM51
COM21 Row42 RAM42 Row50 RAM50 Row42 RAM50 Row26 RAM26 Row34 RAM34 Row26 RAM34 Row34 RAM50
COM22 Row41 RAM41 Row49 RAM49 Row41 RAM49 Row25 RAM25 Row33 RAM33 Row25 RAM33 Row33 RAM49
COM23 Row40 RAM40 Row48 RAM48 Row40 RAM48 Row24 RAM24 Row32 RAM32 Row24 RAM32 Row32 RAM48
COM24 Row39 RAM39 Row47 RAM47 Row39 RAM47 Row23 RAM23 Row31 RAM31 Row23 RAM31 Row31 RAM47
COM25 Row38 RAM38 Row46 RAM46 Row38 RAM46 Row22 RAM22 Row30 RAM30 Row22 RAM30 Row30 RAM46
COM26 Row37 RAM37 Row45 RAM45 Row37 RAM45 Row21 RAM21 Row29 RAM29 Row21 RAM29 Row29 RAM45
COM27 Row36 RAM36 Row44 RAM44 Row36 RAM44 Row20 RAM20 Row28 RAM28 Row20 RAM28 Row28 RAM44
COM28 Row35 RAM35 Row43 RAM43 Row35 RAM43 Row19 RAM19 Row27 RAM27 Row19 RAM27 Row27 RAM43
COM29 Row34 RAM34 Row42 RAM42 Row34 RAM42 Row18 RAM18 Row26 RAM26 Row18 RAM26 Row26 RAM42
COM30 Row33 RAM33 Row41 RAM41 Row33 RAM41 Row17 RAM17 Row25 RAM25 Row17 RAM25 Row25 RAM41
COM31 Row32 RAM32 Row40 RAM40 Row32 RAM40 Row16 RAM16 Row24 RAM24 Row16 RAM24 Row24 RAM40
COM32 Row31 RAM31 Row39 RAM39 Row31 RAM39 Row15 RAM15 Row23 RAM23 Row15 RAM23 Row23 RAM39
COM33 Row30 RAM30 Row38 RAM38 Row30 RAM38 Row14 RAM14 Row22 RAM22 Row14 RAM22 Row22 RAM38
COM34 Row29 RAM29 Row37 RAM37 Row29 RAM37 Row13 RAM13 Row21 RAM21 Row13 RAM21 Row21 RAM37
COM35 Row28 RAM28 Row36 RAM36 Row28 RAM36 Row12 RAM12 Row20 RAM20 Row12 RAM20 Row20 RAM36
COM36 Row27 RAM27 Row35 RAM35 Row27 RAM35 Row11 RAM11 Row19 RAM19 Row11 RAM19 Row19 RAM35
COM37 Row26 RAM26 Row34 RAM34 Row26 RAM34 Row10 RAM10 Row18 RAM18 Row10 RAM18 Row18 RAM34
COM38 Row25 RAM25 Row33 RAM33 Row25 RAM33 Row9 RAM9 Row17 RAM17 Row9 RAM17 Row17 RAM33
COM39 Row24 RAM24 Row32 RAM32 Row24 RAM32 Row8 RAM8 Row16 RAM16 Row8 RAM16 Row16 RAM32
COM40 Row23 RAM23 Row31 RAM31 Row23 RAM31 Row7 RAM7 Row15 RAM15 Row7 RAM15 Row15 RAM31
COM41 Row22 RAM22 Row30 RAM30 Row22 RAM30 Row6 RAM6 Row14 RAM14 Row6 RAM14 Row14 RAM30
COM42 Row21 RAM21 Row29 RAM29 Row21 RAM29 Row5 RAM5 Row13 RAM13 Row5 RAM13 Row13 RAM29
COM43 Row20 RAM20 Row28 RAM28 Row20 RAM28 Row4 RAM4 Row12 RAM12 Row4 RAM12 Row12 RAM28
COM44 Row19 RAM19 Row27 RAM27 Row19 RAM27 Row3 RAM3 Row11 RAM11 Row3 RAM11 Row11 RAM27
COM45 Row18 RAM18 Row26 RAM26 Row18 RAM26 Row2 RAM2 Row10 RAM10 Row2 RAM10 Row10 RAM26
COM46 Row17 RAM17 Row25 RAM25 Row17 RAM25 Row1 RAM1 Row9 RAM9 Row1 RAM9 Row9 RAM25
COM47 Row16 RAM16 Row24 RAM24 Row16 RAM24 Row0 RAM0 Row8 RAM8 Row0 RAM8 Row8 RAM24
COM48 Row15 RAM15 Row23 RAM23 Row15 RAM23 - - Row7 RAM7 - - Row7 RAM23
COM49 Row14 RAM14 Row22 RAM22 Row14 RAM22 - - Row6 RAM6 - - Row6 RAM22
COM50 Row13 RAM13 Row21 RAM21 Row13 RAM21 - - Row5 RAM5 - - Row5 RAM21
COM51 Row12 RAM12 Row20 RAM20 Row12 RAM20 - - Row4 RAM4 - - Row4 RAM20
COM52 Row11 RAM11 Row19 RAM19 Row11 RAM19 - - Row3 RAM3 - - Row3 RAM19
COM53 Row10 RAM10 Row18 RAM18 Row10 RAM18 - - Row2 RAM2 - - Row2 RAM18
COM54 Row9 RAM9 Row17 RAM17 Row9 RAM17 - - Row1 RAM1 - - Row1 RAM17
COM55 Row8 RAM8 Row16 RAM16 Row8 RAM16 - - Row0 RAM0 - - Row0 RAM16
COM56 Row7 RAM7 Row15 RAM15 Row7 RAM15 - - - - - - - -
COM57 Row6 RAM6 Row14 RAM14 Row6 RAM14 - - - - - - - -
COM58 Row5 RAM5 Row13 RAM13 Row5 RAM13 - - - - - - - -
COM59 Row4 RAM4 Row12 RAM12 Row4 RAM12 - - - - - - - -
COM60 Row3 RAM3 Row11 RAM11 Row3 RAM11 - - - - - - - -
COM61 Row2 RAM2 Row10 RAM10 Row2 RAM10 - - - - - - - -
COM62 Row1 RAM1 Row9 RAM9 Row1 RAM9 - - - - - - - -
COM63 Row0 RAM0 Row8 RAM8 Row0 RAM8 - - - - - - - -
Display 
examples
48
Remap
8
16
8 0
0 8
48 48
Remap Remap
48
Remap
0
0
0
0 0 8
Hardware 
pin name
Output
64 64 64
Remap Remap Remap
0 8
(e) (f) (g)(a) (b) (c) (d)
  
Solomon Systech  Apr 2008 P 40/59 Rev 1.1 SSD1306  
 
 
10.1.16 Set Display Clock Divide Ratio/ Oscillator Frequency (D5h) 
This command consists of two functions: 
 
• Display Clock Divide Ratio (D)(A[3:0]) 
Set the divide ratio to generate DCLK (Display Clock) from CLK.  The divide ratio is from 1 to 16, 
with reset value = 1.  Please refer to section 8.3 for the details relationship of DCLK and CLK. 
 
• Oscillator Frequency (A[7:4]) 
Program the oscillator frequency Fosc that is the source of CLK if CLS pin is pulled high.  The 4-bit 
value results in 16 different frequency settings available as shown below.  The default setting is 
1000b. 
10.1.17 Set Pre-charge Period (D9h) 
This command is used to set the duration of the pre-charge period. The interval is counted in number of 
DCLK, where RESET equals 2 DCLKs. 
 
10.1.18 Set COM Pins Hardware Configuration (DAh) 
This command sets the COM signals pin configuration to match the OLED panel hardware layout. The table 
below shows the COM pin configuration under different conditions (for MUX ratio =64): 
Table 10-3 : COM Pins Hardware Configuration 
Conditions COM pins Configurations 
1 Sequential COM pin configuration (DAh A[4] =0) 
COM output Scan direction: from COM0 to COM63 (C0h)
Disable COM Left/Right remap (DAh A[5] =0) 
 
2 Sequential COM pin configuration (DAh A[4] =0) 
COM output Scan direction: from COM0 to COM63 (C0h)
Enable COM Left/Right remap (DAh A[5] =1) 
 
        
 
128 x 64 
ROW32
ROW63 
ROW0 
ROW31
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 
COM63 
COM32 
        
 
128x 64 
ROW0 
ROW31 ROW32
ROW63
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 
COM31 
COM32
COM63
  
SSD1306 Rev 1.1 P 41/59 Apr 2008  Solomon Systech
 
Conditions COM pins Configurations 
3 Sequential COM pin configuration (DAh A[4] =0) 
COM output Scan direction: from COM63 to COM0 (C8h)
Disable COM Left/Right remap (DAh A[5] =0) 
 
4 Sequential COM pin configuration (DAh A[4] =0) 
COM output Scan direction: from COM63 to COM0 (C8h)
Enable COM Left/Right remap (DAh A[5] =1) 
 
5 Alternative COM pin configuration (DAh A[4] =1) 
COM output Scan direction: from COM0 to COM63 (C0h)
Disable COM Left/Right remap (DAh A[5] =0) 
 
 
        
 
128 x 64 
ROW0 
ROW62 
ROW1 
ROW63
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0
COM31 
COM32
COM63 
ROW61
COM62
ROW2 
COM1
        
 
128 x 64 
ROW31
ROW0 
ROW63
ROW32
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 
COM31 COM63 
COM32 
        
 
128 x 64 
ROW63
ROW32 ROW31
ROW0 
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 
COM31 
COM32
COM63
  
Solomon Systech  Apr 2008 P 42/59 Rev 1.1 SSD1306  
 
Conditions COM pins Configurations 
6 Alternative COM pin configuration (DAh A[4] =1) 
COM output Scan direction: from COM0 to COM63 (C0h)
Enable COM Left/Right remap (DAh A[5] =1) 
 
7 Alternative COM pin configuration (DAh A[4] =1) 
COM output Scan direction: from COM63 to COM0(C8h) 
Disable COM Left/Right remap (DAh A[5] =0) 
 
8 Alternative COM pin configuration (DAh A[4] =1) 
COM output Scan direction: from COM63 to COM0(C8h) 
Enable COM Left/Right remap (DAh A[5] =1) 
 
 
  
 
 
 
        
 
128 x 64 
ROW61
ROW0 
ROW63
ROW1 
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 COM32
COM63 
ROW2 
COM33
ROW62
COM31 
COM30
        
 
128 x 64 
ROW63
ROW1 
ROW62
ROW0 
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0
COM31 
COM32
COM63 
ROW2 
COM62
ROW61
COM1
        
 
128 x 64 
ROW2 
ROW63 
ROW0
ROW62
Pad 1,2,3,…->126 
Gold Bumps face up 
SSD1306Z 
COM0 COM32
COM63 
ROW61
COM33
ROW1 
COM31 
COM30
  
SSD1306 Rev 1.1 P 43/59 Apr 2008  Solomon Systech
 
10.1.19  Set VCOMH  Deselect Level (DBh) 
This command adjusts the VCOMH regulator output.  
  
  
10.1.20 NOP (E3h) 
No Operation Command 
 
 
10.1.21  Status register Read 
This command is issued by setting D/C# ON LOW during a data read (See Figure 13-1 to  Figure 13-2 for 
parallel interface waveform). It allows the MCU to monitor the internal status of the chip. No status read is 
provided for serial mode. 
 
  
Solomon Systech  Apr 2008 P 44/59 Rev 1.1 SSD1306  
 
10.2 Graphic Acceleration Command 
10.2.1 Horizontal Scroll Setup (26h/27h) 
 
This command consists of  consecutive bytes to set up the horizontal scroll parameters and determines the 
scrolling start page, end page and scrolling speed. 
 
Before issuing this command the horizontal scroll must be deactivated (2Eh). Otherwise, RAM content may 
be corrupted.  
 
The SSD1306 horizontal scroll is designed for 128 columns scrolling. The following two figures (Figure 10-7, 
Figure 10-8, Figure 10-9) show the examples of using the horizontal scroll:  
 
Figure 10-7 : Horizontal scroll example: Scroll RIGHT by 1 column 
Original Setting SE
G
0 
SE
G
1 
SE
G
2 
SE
G
3 
SE
G
4 
SE
G
5 …
 
…
 
…
 
SE
G
12
2 
SE
G
12
3 
SE
G
12
4 
SE
G
12
5 
SE
G
12
6 
SE
G
12
7 
After one scroll 
step 
SE
G
12
7 
SE
G
0 
SE
G
1 
SE
G
2 
SE
G
3 
SE
G
4 
…
 
…
 
…
 
SE
G
12
1 
SE
G
12
2 
SE
G
12
3 
SE
G
12
4 
SE
G
12
5 
SE
G
12
6 
 
 
Figure 10-8 : Horizontal scroll example: Scroll LEFT by 1 column 
Original 
Setting S
EG
0 
SE
G
1 
SE
G
2 
SE
G
3 
SE
G
4 
SE
G
5 …
 
…
 
…
 
SE
G
12
2 
SE
G
12
3 
SE
G
12
4 
SE
G
12
5 
SE
G
12
6 
SE
G
12
7 
After one 
scroll step S
EG
1 
SE
G
2 
SE
G
3 
SE
G
4 
SE
G
5 
SE
G
6 …
 
…
 
…
 
SE
G
12
3 
SE
G
12
4 
SE
G
12
5 
SE
G
12
6 
SE
G
12
7 
SE
G
0 
 
Figure 10-9 : Horizontal scrolling setup example 
 
 
 
 
 
  
SSD1306 Rev 1.1 P 45/59 Apr 2008  Solomon Systech
 
10.2.2 Continuous Vertical and Horizontal Scroll Setup (29h/2Ah) 
 
This command consists of 6 consecutive bytes to set up the continuous vertical scroll parameters and 
determines the scrolling start page, end page, scrolling speed and vertical scrolling offset. 
 
The bytes B[2:0], C[2:0] and D[2:0] of command 29h/2Ah are for the setting of the continuous horizontal 
scrolling.  The byte E[5:0] is for the setting of the continuous vertical scrolling offset. All these bytes together 
are for the setting of continuous diagonal (horizontal + vertical) scrolling. If the vertical scrolling offset byte 
E[5:0] is set to zero, then only horizontal scrolling is  performed (like command 26/27h).  
  
 
Before issuing this command the scroll must be deactivated (2Eh). Otherwise, RAM content may be 
corrupted. The following figure (Figure 10-10 ) show the example of using the continuous vertical and 
horizontal scroll:  
 
 
 
 
 
Figure 10-10 : Continuous Vertical and Horizontal scrolling setup example 
 
 
 
 
  
Solomon Systech  Apr 2008 P 46/59 Rev 1.1 SSD1306  
 
 
10.2.3 Deactivate Scroll (2Eh) 
This command stops the motion of scrolling.  After sending 2Eh command to deactivate the scrolling action, 
the ram data needs to be rewritten. 
 
10.2.4 Activate Scroll (2Fh) 
This command starts the motion of scrolling and should only be issued after the scroll setup parameters have 
been defined by the scrolling setup commands :26h/27h/29h/2Ah . The setting in the last scrolling setup 
command overwrites the setting in the previous scrolling setup commands. 
  
 
The following actions are prohibited after the scrolling is activated 
1. RAM access (Data write or read) 
2. Changing the horizontal scroll setup parameters  
 
  
 
 
 
10.2.5 Set Vertical Scroll Area(A3h) 
This command consists of 3 consecutive bytes to set up the vertical scroll area. For the continuous vertical 
scroll function (command 29/2Ah), the number of rows that in vertical scrolling can be set smaller or equal to 
the MUX ratio.   
  
  
SSD1306 Rev 1.1 P 47/59 Apr 2008  Solomon Systech
 
11 MAXIMUM RATINGS 
Table 11-1 : Maximum Ratings (Voltage Referenced to VSS) 
Symbol Parameter Value Unit 
VDD  -0.3 to +4 V 
VCC 
Supply Voltage 0 to 16 V 
VSEG SEG output voltage 0 to VCC V 
VCOM COM output voltage 0 to 0.9*VCC V 
Vin Input voltage VSS-0.3 to VDD+0.3 V 
TA Operating Temperature -40 to +85 ºC 
Tstg Storage Temperature Range -65 to +150 ºC 
 
 
Maximum ratings are those values beyond which damages to the device may occur. Functional operation should be restricted to the 
limits in the Electrical Characteristics tables or Pin Description section 
 
This device may be light sensitive. Caution should be taken to avoid exposure of this device to any light source during normal 
operation. This device is not radiation protected. 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 48/59 Rev 1.1 SSD1306  
 
12 DC CHARACTERISTICS 
 
 Condition (Unless otherwise specified): 
Voltage referenced to VSS 
VDD = 1.65 to 3.3V  
TA = 25°C  
 
Table 12-1 : DC Characteristics 
Symbol Parameter Test Condition Min Typ Max Unit
VCC Operating Voltage - 7 - 15 V 
VDD Logic Supply Voltage - 1.65 - 3.3 
V 
 
VOH High Logic Output Level IOUT = 100uA, 3.3MHz 0.9 x VDD  - - V 
VOL Low Logic Output Level IOUT = 100uA, 3.3MHz - - 0.1 x VDD V 
VIH High Logic Input Level - 0.8 x VDD - - V 
VIL Low Logic Input Level - - - 0.2 x VDD V 
ICC, SLEEP 
 
ICC,  Sleep mode Current VDD = 1.65V~3.3V, VCC = 7V~15V 
Display OFF, No panel attached - - 10 uA 
IDD, SLEEP 
 
IDD,  Sleep mode Current VDD = 1.65V~3.3V, VCC = 7V~15V 
Display OFF, No panel attached - - 10 uA 
ICC 
VCC Supply Current 
VDD = 2.8V, VCC = 12V,        
IREF = 12.5uA 
No loading, Display ON, All 
ON 
- 430 780 uA 
IDD 
 
VDD Supply Current 
VDD = 2.8V, VCC = 12V,        
IREF = 12.5uA 
No loading, Display ON, All 
ON 
Contrast  = FFh 
 
- 50 150 
 
uA 
 
Contrast=FFh - 100 - 
Contrast=AFh - 69 - ISEG 
Segment Output Current  
 
VDD=2.8V, VCC=12V, 
IREF=12.5uA, Display ON. Contrast=3Fh - 25 - 
uA 
Dev Segment output current uniformity 
Dev = (ISEG – IMID)/IMID 
IMID = (IMAX + IMIN)/2 
ISEG[0:131] = Segment current at 
contrast = FFh 
-3 - +3 % 
Adj. Dev Adjacent pin output current uniformity (contrast = FF) 
Adj Dev = (I[n]-I[n+1]) / 
(I[n]+I[n+1]) -2 - +2 % 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
SSD1306 Rev 1.1 P 49/59 Apr 2008  Solomon Systech
 
13 AC CHARACTERISTICS 
 
Conditions: 
Voltage referenced to VSS 
VDD=1.65 to3.3V 
TA = 25°C 
 
Table 13-1 : AC Characteristics 
Symbol Parameter Test Condition Min Typ Max Unit
FOSC (1) Oscillation Frequency of Display 
Timing Generator 
VDD = 2.8V 
 
333 370 407 kHz
FFRM Frame Frequency for 64 MUX 
Mode 
128x64 Graphic Display Mode, 
Display ON, Internal Oscillator 
Enabled 
- FOSC x 1/(DxKx64) 
(2) 
- Hz 
RES# Reset low pulse width  3 - - us 
  
 
Note 
(1) FOSC stands for the frequency value of the internal oscillator and the value is measured when command D5h A[7:4] is 
in default value. 
 
(2) D: divide ratio (default value = 1) 
     K: number of display clocks (default value = 54) 
   Please refer to Table 9-1 (Set Display Clock Divide Ratio/Oscillator Frequency, D5h) for detailed description 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 50/59 Rev 1.1 SSD1306  
 
 
Table 13-2 : 6800-Series MCU Parallel Interface Timing Characteristics 
(VDD - VSS = 1.65V to 3.3V, TA = 25°C) 
Symbol Parameter Min Typ Max Unit 
tcycle Clock Cycle Time 300 - - ns 
tAS Address Setup Time 0 - - ns 
tAH Address Hold Time 0 - - ns 
tDSW Write Data Setup Time 40 - - ns 
tDHW Write Data Hold Time 7 - - ns 
tDHR Read Data Hold Time 20 - - ns 
tOH Output Disable Time - - 70 ns 
tACC Access Time - - 140 ns 
PWCSL 
Chip Select Low Pulse Width (read) 
Chip Select Low Pulse Width (write) 
120 
60 - - ns 
PWCSH 
Chip Select High Pulse Width (read) 
Chip Select High Pulse Width (write) 
60 
60 - - ns 
tR Rise Time - - 40 ns 
tF Fall Time - - 40 ns 
 
 
Figure 13-1 : 6800-series MCU parallel interface characteristics 
 
      D[7:0](WRITE)
       D[7:0](READ)
E
CS#
R/W#
PWCSL
tR
tF tDHW
tOH
tACC tDHR
Valid Data
tDSW
Valid Data
tcycle
PWCSH
tAHtAS
D/C#
 
 
 
 
 
  
SSD1306 Rev 1.1 P 51/59 Apr 2008  Solomon Systech
 
Table 13-3 : 8080-Series MCU Parallel Interface Timing Characteristics 
(VDD - VSS = 1.65V to 3.3V, TA = 25°C) 
Symbol Parameter Min Typ Max Unit
tcycle Clock Cycle Time 300 - - ns 
tAS Address Setup Time 10 - - ns 
tAH Address Hold Time 0 - - ns 
tDSW Write Data Setup Time 40 - - ns 
tDHW Write Data Hold Time 7 - - ns 
tDHR Read Data Hold Time 20 - - ns 
tOH Output Disable Time - - 70 ns 
tACC Access Time - - 140 ns 
tPWLR Read Low Time 120 - - ns 
tPWLW Write Low Time 60 - - ns 
tPWHR Read High Time 60 - - ns 
tPWHW Write High Time 60 - - ns 
tR Rise Time - - 40 ns 
tF Fall Time - - 40 ns 
tCS Chip select setup time 0 - - ns 
tCSH Chip select hold time to read signal 0 - - ns 
tCSF Chip select hold time 20 - - ns 
 
Figure 13-2 : 8080-series parallel interface characteristics  
 
Write Cycle 
 
WR#
D[7:0]
tAS
D/C#
CS#
tCS
tAH
tPWLW
tcycle
tDSW tDHW
tPWHW
tCSF
tF tR
 
 
 
Read cycle 
RD#
D[7:0]
tAS
D/C#
CS#
tCS
tAH
tPWLR
tcycle
tPWHR
tCSH
tACC tDHR
tOH
tF tR
 
 
 
 
  
Solomon Systech  Apr 2008 P 52/59 Rev 1.1 SSD1306  
 
Table 13-4 : 4-wire Serial Interface Timing Characteristics 
 
(VDD - VSS = 1.65V to 3.3V, TA = 25°C) 
Symbol Parameter Min Typ Max Unit 
tcycle Clock Cycle Time 100 - - ns 
tAS Address Setup Time 15 - - ns 
tAH Address Hold Time 15 - - ns 
tCSS Chip Select Setup Time 20 - - ns 
tCSH Chip Select Hold Time 10 - - ns 
tDSW Write Data Setup Time 15 - - ns 
tDHW Write Data Hold Time 15 - - ns 
tCLKL Clock Low Time 20 - - ns 
tCLKH Clock High Time 20 - - ns 
tR Rise Time - - 40 ns 
tF Fall Time - - 40 ns 
 
 
Figure 13-3 : 4-wire Serial interface characteristics 
 
 
 
 
 
 
 
 
 
 
 
t AHtAS
D/C# 
Valid Data
tDHW
t CLKL
tDSW
t CLKH 
tcycle
t CSS tCSH
t F tR
SDIN(D 1 ) 
CS# 
SCLK(D 0 ) 
D7SDIN(D1) 
CS# 
SCLK(D 0 ) 
D6 D5 D4 D3 D2 D1 D0
  
SSD1306 Rev 1.1 P 53/59 Apr 2008  Solomon Systech
 
 
Table 13-5 : 3-wire Serial Interface Timing Characteristics 
 
(VDD - VSS = 1.65V to 3.3V, TA = 25°C) 
Symbol Parameter Min Typ Max Unit 
tcycle Clock Cycle Time 100 - - ns 
tCSS Chip Select Setup Time 20 - - ns 
tCSH Chip Select Hold Time 10 - - ns 
tDSW Write Data Setup Time 15 - - ns 
tDHW Write Data Hold Time 15 - - ns 
tCLKL Clock Low Time 20 - - ns 
tCLKH Clock High Time 20 - - ns 
tR Rise Time - - 40 ns 
tF Fall Time - - 40 ns 
 
 
 
Figure 13-4 : 3-wire Serial interface characteristics 
 
 
 
 
 
 
  
 
 
 
SDIN 
CS# 
SCLK 
D7 D6 D5 D4 D3 D2 D1 D0 D/C# 
Valid Data
tDSH
t CLKL 
t DSW 
tCLKH
tCYCLE
t CSS tCSH
t F tR
SDIN 
CS# 
SCLK 
  
Solomon Systech  Apr 2008 P 54/59 Rev 1.1 SSD1306  
 
 
Conditions: 
VDD - VSS = VDD - VSS = 1.65V to 3.3V 
TA = 25°C 
 
 Table 13-6 :I2C Interface Timing Characteristics 
  
Symbol Parameter Min Typ Max Unit 
tcycle Clock Cycle Time 2.5 - - us 
tHSTART Start condition Hold Time 0.6 - - us 
Data Hold Time (for “SDAOUT” pin) 0 - - ns tHD 
Data Hold Time (for “SDAIN” pin) 300 - - ns 
tSD Data Setup Time  100 - - ns 
tSSTART Start condition Setup Time (Only relevant for a repeated 
Start condition) 
0.6 - - us 
tSSTOP Stop condition Setup Time  0.6 - - us 
tR Rise Time for data and clock pin - - 300 ns 
tF Fall Time for data and clock pin - - 300 ns 
tIDLE Idle Time before a new transmission can start  1.3 - - us 
 
 
 Figure 13-5 : I2C interface Timing characteristics 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
// //
  
SDA 
SCL 
tHSTART 
tCYCLE
tHD 
tR 
tF 
tSD tSSTART tSSTOP 
tIDLE 
  
SSD1306 Rev 1.1 P 55/59 Apr 2008  Solomon Systech
 
The configuration for 8080-parallel interface mode is shown in the following diagram: 
(VDD=2.8V, VCC =12V, IREF=12.5uA) 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
Pin connected to MCU interface: D[7:0], E, R/W#, D/C#, CS#, RES# 
Pin internally connected to VSS: BS0, CL 
Pin internally connected to VDD: CLS 
C2P, C2N, C1P, C1N, VBREF, FB should be left open. 
 
C1: 1.0uF (1) 
C2: 2.2uF (1) 
C3: 2.2uF (1) 
 
 
  
 
Voltage at IREF = VCC – 2.5V. For VCC = 12V, IREF = 12.5uA: 
R1 = (Voltage at IREF - VSS) / IREF 
        = (12-2.5) / 12.5u 
        =760KΩ   
 
 
Note 
(1) The capacitor value is recommended value. Select appropriate value against module application. 
14 Application Example 
 
Figure 14-1 : Application Example of SSD1306Z 
 
 
DISPLAY PANEL   
128 x 64 
C
O
M
62
 
C
O
M
60
 
. . C
O
M
2 
C
O
M
0 
    SE
G
0 
. . . . . . . . . . . . SE
G
12
7 
    C
O
M
1 
C
O
M
3 
. . C
O
M
61
 
C
O
M
63
 
SSD1306Z 
                                                                                                                                               
 
 
 BGGND            VCC   VCOMH   IREF   D[7:0]   E (RD#)  R/W#(W/R#)  D/C#   RES#   CS#    BS1   BS2      VDD     VBAT  VBREF      FR            VSS                 C1N   C1P   C2N  C2P
R1 
 D[7:0]   E (RD#)  R/W# (W/R#)   D/C#    RES#    CS#                          VDD                                           VSS 
C1
C2 
 VSS 
[GND] 
 C3 
VCC 
  
Solomon Systech  Apr 2008 P 56/59 Rev 1.1 SSD1306  
 
15 PACKAGE INFORMATION 
15.1 SSD1306TR1 Detail Dimension 
Figure 15-1 SSD1306TR1 Detail Dimension 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
SS
D1
30
6T
  
SSD1306 Rev 1.1 P 57/59 Apr 2008  Solomon Systech
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
Solomon Systech  Apr 2008 P 58/59 Rev 1.1 SSD1306  
 
15.2 SSD1306Z Die Tray Information 
Figure 15-2 : SSD1306Z die tray information 
 
        
 
 
  
          
  
SSD1306 Rev 1.1 P 59/59 Apr 2008  Solomon Systech
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Solomon Systech reserves the right to make changes without notice to any products herein. Solomon Systech makes no warranty, 
representation or guarantee regarding the suitability of its products for any particular purpose, nor does Solomon Systech assume any 
liability arising out of the application or use of any product or circuit, and specifically disclaims any, and all, liability, including without 
limitation consequential or incidental damages. “Typical” parameters can and do vary in different applications. All operating parameters, 
including “Typical” must be validated for each customer application by the customer’s technical experts. Solomon Systech does not con-
vey any license under its patent rights nor the rights of others. Solomon Systech products are not designed, intended, or authorized for use 
as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any 
other application in which the failure of the Solomon Systech product could create a situation where personal injury or death may occur. 
Should Buyer purchase or use Solomon Systech products for any such unintended or unauthorized application, Buyer shall indemnify and 
hold Solomon Systech and its offices, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and 
expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such 
unintended or unauthorized use, even if such claim alleges that Solomon Systech was negligent regarding the design or manufacture of the 
part. 
 
 
All Solomon Systech Products complied with six (6) hazardous substances limitation requirement per European Union (EU) “Restriction of 
Hazardous Substance (RoHS) Directive (2002/95/EC)” and China standard “电子信息产品污染控制标识要求 (SJ/T11364-2006)” with 
control Marking Symbol         .  Hazardous Substances test report is available upon requested. 
 
 
http://www.solomon-systech.com 
SOLOMON SYSTECH  
SEMICONDUCTOR APPLICATION NOTE 
 
 
 
 
This document contains information on a new product. Specifications and information herein are subject to 
change without notice. 
 
http://www.solomon-systech.com 
SSD1306 App Note Rev 0.4 P 1/6 Jan 2009  Copyright  2008 Solomon Systech Limited  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Application Note 
 
128 x 64 Dot Matrix  
OLED/PLED Segment/Common Driver with Controller 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
SSD1306 
  
Solomon Systech  Jan 2009 P 2/6 Rev 0.4 SSD1306 App note
 
TABLE OF CONTENTS 
1 INTRODUCTION 3 
2 CHARGE PUMP REGULATOR 3 
2.1 Command Table for Charge Bump Setting 3 
3 SOFTWARE CONFIGURATION 5 
 
TABLE OF FIGURES 
 
Figure 1 : Application Example of SSD1306Z with charge bump........................................................... 4 
Figure 2 : Software Initialization Flow Chart ........................................................................................... 5 
 
  
SSD1306 App Note Rev 0.4 P 3/6 Jan 2009  Solomon Systech
 
 
1 Introduction  
 
This application note of SSD1306 is written to explain the charge pump regulator function of 
SSD1306.  SSD1306 is a single-chip CMOS OLED/PLED driver with controller for organic / polymer 
light emitting diode dot-matrix graphic display system.  It consists of 128 segments and 64 commons. 
This IC is designed for Common Cathode type OLED panel.   
 
For the detailed characteristics of the driver IC, please refer to SSD1306 datasheet. 
 
 
2 Charge Pump Regulator 
 
The internal regulator circuit in SSD1306 accompanying only 2 external capacitors can generate a 
7.5V voltage supply, VCC, from a low voltage supply input, VBAT. The VCC is the voltage supply to the 
OLED driver block. This is a switching capacitor regulator circuit, designed for handheld applications.  
This regulator can be turned on/off by software command setting. 
 
 
• Power supply 
o VDD = 1.65V to 3.3V,<VBAT for IC logic 
o VBAT = 3.3V to 4.2V   for charge pump regulator circuit 
  
 
• Pins description for related pins of the charge pump regulator 
o VBAT – Power supply for charge pump regulator circuit.  
Status VBAT VDD VCC 
Enable 
charge pump 
Connect to external 
VBAT source 
Connect to external 
VDD source 
A capacitor should be connected 
between this pin and VSS  
Disable 
charge pump 
Connect with VDD  
pin 
Connect to external 
VDD source 
Connect to external VCC source 
 
o C1P/C1N – Pin for charge pump capacitor; Connect to each other with a capacitor 
o C2P/C2N – Pin for charge pump capacitor; Connect to each other with a capacitor 
 
 
2.1 Command Table for Charge Bump Setting 
 
1. Charge Pump Command Table 
D/C# Hex D7 D6 D5 D4 D3 D2 D1 D0 Command Description 
0 8D 1 0 0 0 1 1 0 1 
0 A[7:0] * * 0 1 0 A2 0 0 
          
Charge 
Pump 
Setting 
A[2] = 0b, Disable charge 
pump(RESET) 
A[2] = 1b, Enable charge pump 
during display on 
 
Note 
(1)  The Charge Pump must be 
enabled by the following command: 
8Dh ; Charge Pump Setting 
14h ; Enable Charge Pump 
AFh; Display ON 
 
 
  
Solomon Systech  Jan 2009 P 4/6 Rev 0.4 SSD1306 App note
 
The configuration for 8080-parallel interface mode is shown in the following diagram: 
(VDD= 1.65V ~ 3.3V, < VBAT     , VBAT=3.3V~4.2V, IREF=12.5uA) 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
Pin connected to MCU interface: D[7:0], E, R/W#, D/C#, CS#, RES# 
Pin internally connected to VSS: BS0, CL 
Pin internally connected to VDD: CLS 
VBREF, FR should be left open. 
 
C1, C4, C6, C7: 1.0uF (1) 
C2, C3: 2.2uF (1) 
 
 
Voltage at IREF = VCC – 2.5V. For VCC = 7.5V, IREF = 12.5uA: 
R1 = (Voltage at IREF - VSS) / IREF 
        = (7.5-2.5) / 12.5u 
        =400KΩ 
 
 
Note 
(1) The capacitor value is recommended value. Select appropriate value against module application. 
Figure 1 : Application Example of SSD1306Z with charge bump 
 
 
 
DISPLAY PANEL   
104 x 16 
C
O
M
14
 
C
O
M
12
 
. . C
O
M
2 
C
O
M
0 
    S
E
G
0 
. . . . . . . . . . . . S
E
G
10
3 
    C
O
M
1 
C
O
M
3 
. . C
O
M
13
 
C
O
M
15
 
SSD1306Z 
                                                                                                                                               
 
 
 BGGND               VCC   VCOMH IREF  D[7:0]  E (RD#)  R/W#(W/R#)  D/C#  RES#  CS#  BS1  BS2    VDD   VBAT  VBREF   FR           VSS C1N   C1P   C2N  C2P
R1 
 D[7:0]   E (RD#)  R/W# (W/R#)   D/C#    RES#    CS#                VDD     VBAT                             VSS 
C1 
 
 
C4 C2 
 VSS 
[GND] 
 C3 
C6        C7 
  
SSD1306 App Note Rev 0.4 P 5/6 Jan 2009  Solomon Systech
 
 
3 Software Configuration 
SSD1306 has internal command registers that are used to configure the operations of the driver IC.  
After reset, the registers should be set with appropriate values in order to function well.  The registers 
can be accessed by MPU interface in either 6800, 8080, SPI type with D/C# pin pull low or using I2C 
interface.  Below is an example of initialization flow of SSD1306.  The values of registers depend on 
different condition and application.  
 
Figure 2 : Software Initialization Flow Chart 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Enable charge 
pump regulator
8Dh, 14h 
Set MUX 
Ratio 
A8h, 3Fh 
Set Display 
Offset 
D3h, 00h 
Set Display 
Start Line 
40h 
Set Segment  
re-map 
A0h/A1h 
Set COM Output 
Scan Direction 
C0h/C8h 
Set Contrast 
Control 
81h, 7Fh 
Disable Entire 
Display On 
A4h 
Set Normal 
Display 
A6h 
Set Osc 
Frequency 
 D5h, 80h 
Set COM Pins 
hardware 
configuration 
DAh, 02 
Display On 
 AFh 
  
Solomon Systech  Jan 2009 P 6/6 Rev 0.4 SSD1306 App note
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  
 
 
 
 
 
 
 
 
 
All Solomon Systech Products complied with six (6) hazardous substances limitation requirement per European Union (EU) 
“Restriction of Hazardous Substance (RoHS) Directive (2002/95/EC)” and China standard “电子信息产品污染控制标识要求 
(SJ/T11364-2006)” with control Marking Symbol         .  Hazardous Substances test report is available upon requested. 
 
 
http://www.solomon-systech.com 
 
 
Solomon Systech reserves the right to make changes without notice to any products herein. Solomon Systech makes no warranty, 
representation or guarantee regarding the suitability of its products for any particular purpose, nor does Solomon Systech assume 
any liability arising out of the application or use of any product or circuit, and specifically disclaims any, and all, liability, including 
without limitation consequential or incidental damages. “Typical” parameters can and do vary in different applications. All operating 
parameters, including “Typical” must be validated for each customer application by the customer’s technical experts. Solomon 
Systech does not convey any license under its patent rights nor the rights of others. Solomon Systech products are not designed, 
intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended 
to support or sustain life, or for any other application in which the failure of the Solomon Systech product could create a situation 
where personal injury or death may occur. Should Buyer purchase or use Solomon Systech products for any such unintended or 
unauthorized application, Buyer shall indemnify and hold Solomon Systech and its offices, employees, subsidiaries, affiliates, and 
distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or 
indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that 
Solomon Systech was negligent regarding the design or manufacture of the part.
 Product Specification 
 
 
Part Name: OEL Display Module 
Part ID: UG-2864HSWEG01 
Doc No.: SAS1-9046-B 
 
 
Customer:  
 Approved by 
 
 
 
From: Univision Technology Inc. 
 Approved by 
 
 
Univision Technology Inc. 
8, Kebei RD 2, Science Park, Chu-Nan, Taiwan 350, R.O.C. 
 
 
 
Notes: 
1. Please contact Univision Technology Inc. before assigning your product based on this 
module specification 
2. The information contained herein is presented merely to indicate the characteristics and 
performance of our products.  No responsibility is assumed by Univision Technology 
Inc. for any intellectual property claims or other problems that may result from 
application based on the module described herein. 
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
Revised History 
Part Number Revision Revision Content Revised on 
UG-2864HSWEG01 A New February 17, 2009
UG-2864HSWEG01 B 
Page 5~6  Section 1.6 
Update Application Circuit 
Page 7  Section 2 
Update Absolute Maximum Ratings 
Page 8  Section 3.1 & 3.2 
Modify Brightness 
VCC Supplied Externally 
(Min/Typ)  80/100?100/120 
VCC Generated by Internal DC/DC 
(Min/Typ)  50/60?70/90 
Update DC Characteristics 
Page 15  Section 4.4 
Update Initialization 
June 5, 2009 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
   
 i
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
Notice: 
 
No part of this material may be reproduces or duplicated in any form or by any means 
without the written permission of Univision Technology Inc.  Univision Technology Inc. 
reserves the right to make changes to this material without notice.  Univision Technology 
Inc. does not assume any liability of any kind arising out of any inaccuracies contained in this 
material or due to its application or use in any product or circuit and, further, there is no 
representation that this material is applicable to products requiring high level reliability, such 
as, medical products.  Moreover, no license to any intellectual property rights is granted by 
implication or otherwise, and there is no representation or warranty that anything made in 
accordance with this material will be free from any patent or copyright infringement of a 
third party.  This material or portions thereof may contain technology or the subject relating 
to strategic products under the control of Foreign Exchange and Foreign Trade Law of 
Taiwan and may require an export license from the Ministry of International Trade and 
Industry or other approval from another government agency. 
 
© Univision Technology Inc. 2009, All rights reserved. 
 
All other product names mentioned herein are trademarks and/or registered trademarks of 
their respective companies. 
 ii
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
Contents 
 
Revision History ................................................................................................... i 
Notice ................................................................................................................... ii 
Contents .............................................................................................................. iii 
1. Basic Specifications .................................................................................. 1~6 
1.1 Display Specifications .................................................................................................1 
1.2 Mechanical Specifications ...........................................................................................1 
1.3 Active Area & Pixel Construction ...............................................................................1 
1.4 Mechanical Drawing....................................................................................................2 
1.5 Pin Definition...............................................................................................................3 
1.6 Block Diagram.............................................................................................................5 
1.6.1 VCC Supplied Externally ....................................................................................5 
1.6.2 VCC Generated by Internal DC/DC Circuit........................................................6 
2. Absolute Maximum Ratings .......................................................................... 7 
3. Optics & Electrical Characteristics ......................................................... 8~13 
3.1 Optics Characteristics ..................................................................................................8 
3.2 DC Characteristics .......................................................................................................8 
3.3 AC Characteristics .......................................................................................................9 
3.3.1 68XX-Series MPU Parallel Interface Timing Characteristics ...........................9 
3.3.2 80XX-Series MPU Parallel Interface Timing Characteristics .........................10 
3.3.3 Serial Interface Timing Characteristics (4-wire SPI).......................................11 
3.3.4 Serial Interface Timing Characteristics (3-wire SPI).......................................12 
3.3.5 I2C Interface Timing Characteristics ...............................................................13 
4. Functional Specification ....................................................................... 14~15 
4.1 Commands .................................................................................................................14 
4.2 Power down and Power up Sequence ........................................................................14 
4.2.1 Power up Sequence ..........................................................................................14 
4.2.2 Power down Sequence .....................................................................................14 
4.3 Reset Circuit...............................................................................................................14 
4.4 Actual Application Example ......................................................................................15 
5. Reliability...................................................................................................... 16 
5.1 Contents of Reliability Tests......................................................................................16 
5.2 Lifetime......................................................................................................................16 
5.3 Failure Check Standard..............................................................................................16 
6. Outgoing Quality Control Specifications.............................................. 17~21 
6.1 Environment Required ...............................................................................................17 
6.2 Sampling Plan ............................................................................................................17 
6.3 Criteria & Acceptable Quality Level .........................................................................17 
6.3.1 Cosmetic Check (Display Off) in Non-Active Area ........................................17 
6.3.2 Cosmetic Check (Display Off) in Active Area.................................................20 
 iii
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6.3.3 Pattern Check (Display On) in Active Area.....................................................21 
7. Package Specifications ................................................................................ 22 
8. Precautions When Using These OEL Display Modules....................... 23~25 
8.1 Handling Precautions .................................................................................................23 
8.2 Storage Precautions....................................................................................................24 
8.3 Designing Precautions ...............................................................................................24 
8.4 Precautions when disposing of the OEL display modules.........................................25 
8.5 Other Precautions.......................................................................................................25 
 
 iv
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
1. Basic Specifications 
1.1 Display Specifications 
1) Display Mode: Passive Matrix 
2) Display Color: Monochrome (White) 
3) Drive Duty: 1/64 Duty 
 
 
1.2 Mechanical Specifications 
1) Outline Drawing: According to the annexed outline drawing 
2) Number of Pixels: 128 × 64 
3) Panel Size: 26.70 × 19.26 × 1.45 (mm) 
4) Active Area: 21.744 × 10.864 (mm) 
5) Pixel Pitch: 0.17 × 0.17 (mm) 
6) Pixel Size: 0.154 × 0.154 (mm) 
7) Weight: 1.54 (g) 
 
 
1.3 Active Area & Pixel Construction 
"A"
Segment 0
( Column 128 )
Common 0
( Row 64 )
Common 31
( Row 2 )
Segment 127
( Column 1 )
Common 32
( Row 63 )
Common 63
( Row 1 )
Detail "A"
Scale (10:1)
P0.17x128-0.016=21.744
P0
.1
7x
64
-0
.0
16
=1
0.
86
4
0.154
0.17
0.
15
4
0.
17
 
 1
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
1.4 Mechanical Drawing 
 
 
B
2-
R
0.
4±
0.
05
Contact Side
Contact Side
Remove Tape
t=0.15mm Max
Polarizer
t=0.2mm
3M #1318B
15x8x0.063mm
21
.7
44
 (A
/A
)
10.864 (A/A)(2.1)(
2.
47
8)
26
.7
±0
.2
 (C
ap
 S
iz
e)
15.5±0.2 (Cap Size)
19.26±0.2 (Panel Size)
1.
45
±0
.1
N
ot
es
:
1.
 C
ol
or
: W
hi
te
2.
 D
riv
er
 IC
: S
SD
13
06
3.
 F
PC
 N
um
be
r: 
U
T-
02
06
-P
05
4.
 In
te
rf
ac
e:
   
 8
-b
it 
68
X
X
/8
0X
X
 P
ar
al
le
l, 
3-
/4
-w
ire
 S
PI
, I
2C
5.
 G
en
er
al
 T
ol
er
an
ce
: ±
0.
30
6.
 T
he
 to
ta
l t
hi
ck
ne
ss
 (1
.5
5 
M
ax
) i
s w
ith
ou
t p
ol
ar
iz
er
 p
ro
te
ct
iv
e 
fil
m
 &
 re
m
ov
e 
ta
pe
.
   
 T
he
 a
ct
ua
l a
ss
em
bl
ed
 to
ta
l t
hi
ck
ne
ss
 w
ith
 a
bo
ve
 m
at
er
ia
ls
 sh
ou
ld
 b
e 
1.
80
 M
ax
.
5
10
8
23
.7
44
 (V
/A
)
(1
.4
78
)
25
.7
±0
.5
 (P
ol
ar
iz
er
)
0.
5±
0.
5
(2
.3
5)
Se
gm
en
t 0
( C
ol
um
n 
12
8 
)
C
om
m
on
 0
( R
ow
 6
4 
)
C
om
m
on
 3
1
( R
ow
 2
 )
Se
gm
en
t 1
27
( C
ol
um
n 
1 
)
C
om
m
on
 3
2
( R
ow
 6
3 
)
C
om
m
on
 6
3
( R
ow
 1
 )
A
ct
iv
e 
A
re
a 
0.
96
"
12
8 
x 
64
 P
ix
el
s
P0
.7
0x
(3
0-
1)
=2
0.
3±
0.
05
 (W
0.
40
±0
.0
3)
0.
85
±0
.1
16
±0
.1
 (A
lig
nm
en
t M
ar
k)
22
±0
.2
4
6.887
11
(1.6) (1
.6
13
)
(20.86)
4.75
D
et
ai
l "
A
"
Sc
al
e 
(1
0:
1)
The drawing contained herein is the exclusive property of Univision.  It is not allowed to copy, reproduce and or disclose in any formats without permission of Univision.
U
ni
vi
si
on
 T
ec
hn
ol
og
y 
In
c.
U
G
-2
86
4H
SW
EG
01
 F
ol
di
ng
 T
yp
e 
O
EL
 D
is
pl
ay
 M
od
ul
e
   
 P
ix
el
 N
um
be
r: 
12
8 
x 
64
, M
on
oc
hr
om
e,
 C
O
G
 P
ac
ka
ge
±0
.3
m
m
U
nl
es
s O
th
er
w
is
e 
Sp
ec
ifi
ed
U
ni
t
To
le
ra
nc
e
A
ng
le
D
im
en
si
on
G
en
er
al
 R
ou
gh
ne
ss
Ti
tle
D
at
e
B
y
D
ra
w
n
D
ra
w
in
g 
N
um
be
r
1 
of
 1
Sh
ee
t
M
at
er
ia
l
Pa
ne
l /
 E
.
E.
E.
1:
1
Sc
al
e
A
3
Si
ze
D
at
e
Ite
m
R
em
ar
k
R
ev
.
So
da
 L
im
e 
/ P
ol
yi
m
id
e
C
us
to
m
er
 A
pp
ro
va
l
Si
gn
at
ur
e
±1
B
D
M
X
28
64
SD
G
F4
6
H
um
ph
re
y 
Li
n
20
08
09
10
A
O
rig
in
al
 D
ra
w
in
g
P.
M
.
(10.55)
8
C
S#
R
/W
#
E/
R
D
#
Sy
m
bo
l
B
S1
2 5 76431Pi
n
N
.C
. (
G
N
D
)
9 10
D
/C
#
18
IR
EF
R
ES
#
B
S2 D
0
12 15 1716141311
V
C
O
M
H
19 20
D
1
D
2
D
3
D
4
D
5
D
6
D
7
V
C
C
V
LS
S
"A
"
26
.7
±0
.2
 (P
an
el
 S
iz
e)
12.864 (V/A)(1.1)
14.4±0.5 (Polarizer)0.5±0.5
(31.26)
0.
1±
0.
03
P0
.1
7x
12
8-
0.
01
6=
21
.7
44
P0.17x64-0.016=10.864
0.
15
40.
17
0.154
0.17
12±0.3
Ja
m
es
 W
an
g
Iv
y 
Lo
C
he
rr
y 
Li
n
Glue
20
09
01
20
B
C
ha
ng
e 
FP
C
 &
 M
od
ify
 P
in
 D
ef
in
iti
on
20
09
01
20
20
09
01
20
20
09
01
20
20
09
01
20
2822 25 2726242321 29 30
N
.C
. (
G
N
D
)
B
S0
V
D
D
V
SS
N
.C
.
V
B
A
T
C
1P
C
1NC
2P
C
2N
1
D7
D6
D5
D4
D3
D2
D1
D0
BS1
BS0
N.C.
VBAT
C1N
C1P
C2N
C2P
N.C. (GND)
30 N.C. (GND)
VLSS
VCC
VCOMH
IREF
E/RD#
R/W#
D/C#
RES#
CS#
BS2
B
VDD
VSS
2±0.3
12
±0
.2
 
 2
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
 3
1.5 Pin Definition 
Pin Number Symbol Type Function 
Power Supply 
9 VDD P 
Power Supply for Logic 
This is a voltage supply pin.  It must be connected to
external source. 
8 VSS P 
Ground of Logic Circuit 
This is a ground pin.  It acts as a reference for the logic
pins.  It must be connected to external ground. 
28 VCC P 
Power Supply for OEL Panel 
This is the most positive voltage supply pin of the chip.
A stabilization capacitor should be connected between
this pin and VSS when the converter is used.  It must be
connected to external source when the converter is not
used. 
29 VLSS P 
Ground of Analog Circuit 
This is an analog ground pin.  It should be connected to VSS
externally. 
Driver 
26 IREF I 
Current Reference for Brightness Adjustment 
This pin is segment current reference pin.  A resistor
should be connected between this pin and VSS.  Set the
current lower than 12.5μA. 
27 VCOMH O 
Voltage Output High Level for COM Signal 
This pin is the input pin for the voltage output high level
for COM signals.  A capacitor should be connected
between this pin and VSS. 
DC/DC Converter 
6 VBAT P 
Power Supply for DC/DC Converter Circuit 
This is the power supply pin for the internal buffer of the
DC/DC voltage converter.  It must be connected to
external source when the converter is used.  It should be
connected to VDD when the converter is not used. 
4 / 5 
2 / 3 
C1P / C1N 
C2P / C2N I 
Positive Terminal of the Flying Inverting Capacitor 
Negative Terminal of the Flying Boost Capacitor 
The charge-pump capacitors are required between the
terminals.  They must be floated when the converter is
not used. 
Interface 
10 
11 
12 
BS0 
BS1 
BS2 
I 
Communicating Protocol Select 
These pins are MCU interface selection input.  See the
following table: 
 BS0 BS1 BS2 
I2C 0 1 0 
3-wire SPI 1 0 0 
4-wire SPI 0 0 0 
8-bit 68XX Parallel 0 0 1 
8-bit 80XX Parallel 0 1 1  
14 RES# I 
Power Reset for Controller and Driver 
This pin is reset signal input.  When the pin is low,
initialization of the chip is executed. 
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
1.5 Pin Definition (Continued) 
Pin Number Symbol I/O Function 
Interface (Continued) 
13 CS# I 
Chip Select 
This pin is the chip select input.  The chip is enabled for
MCU communication only when CS# is pulled low. 
15 D/C# I 
Data/Command Control 
This pin is Data/Command control pin.  When the pin is
pulled high, the input at D7~D0 is treated as display data.
When the pin is pulled low, the input at D7~D0 will be
transferred to the command register.  For detail
relationship to MCU interface signals, please refer to the
Timing Characteristics Diagrams. 
When the pin is pulled high and serial interface mode is
selected, the data at SDIN is treated as data.  When it is
pulled low, the data at SDIN will be transferred to the
command register.  In I2C mode, this pin acts as SA0 for
slave address selection. 
17 E/RD# I 
Read/Write Enable or Read 
This pin is MCU interface input.  When interfacing to a
68XX-series microprocessor, this pin will be used as the
Enable (E) signal. Read/write operation is initiated when
this pin is pulled high and the CS# is pulled low. 
When connecting to an 80XX-microprocessor, this pin
receives the Read (RD#) signal.  Data read operation is
initiated when this pin is pulled low and CS# is pulled
low. 
16 R/W# I 
Read/Write Select or Write 
This pin is MCU interface input.  When interfacing to a
68XX-series microprocessor, this pin will be used as
Read/Write (R/W#) selection input.  Pull this pin to
“High” for read mode and pull it to “Low” for write
mode. 
When 80XX interface mode is selected, this pin will be
the Write (WR#) input.  Data write operation is initiated
when this pin is pulled low and the CS# is pulled low. 
18~25 D0~D7 I/O
Host Data Input/Output Bus 
These pins are 8-bit bi-directional data bus to be
connected to the microprocessor’s data bus.  When serial
mode is selected, D1 will be the serial data input SDIN
and D0 will be the serial clock input SCLK.  When I2C
mode is selected, D2 & D1 should be tired together and
serve as SDAout & SDAin in application and D0 is the
serial clock input SCL.  
Reserve 
7 N.C. - 
Reserved Pin 
The N.C. pins between function pins are reserved for
compatible and flexible design. 
1, 30 N.C. (GND) - 
Reserved Pin (Supporting Pin) 
The supporting pins can reduce the influences from
stresses on the function pins.  These pins must be
connected to external ground. 
 4
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
1.6 Block Diagram 
1.6.1 VCC Supplied Externally 
V
LS
S
C2
C5
Se
gm
en
t 1
27
Se
gm
en
t 0
C
om
m
on
 0
C
om
m
on
 3
1
~ ~ ~ ~
IR
EF
V
C
O
M
H
V
D
D
R1
R
ES
#
C3
V
SS
SSD1306
C1
V
C
C
V
B
A
T
C4
C
1P
C
1N
C
2N
C
2P
Active Area 0.96"
128 x 64 Pixels
C
om
m
on
 6
3
C
om
m
on
 3
2
~
D
0
D
7~D
/C
#
E/
R
D
#
R
/W
#
B
S1
B
S2
C
S#B
S0
 
 
MCU Interface Selection: BS0, BS1 and BS2 
Pins connected to MCU interface: CS#, RES#, D/C#, R/W#, E/RD#, and 
D0~D7 
 
C1, C3: 0.1μF 
C2: 2.2μF 
C4, C5: 4.7μF / 16V, X7R 
R1: 560kΩ, R1 = (Voltage at IREF – VSS) / IREF 
 5
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
1.6.2 VCC Generated by Internal DC/DC Circuit 
E/
R
D
#
R
/W
#
B
S1
B
S2
C
S#B
S0
V
LS
S
Se
gm
en
t 1
27
Se
gm
en
t 0
C
om
m
on
 0
C
om
m
on
 3
1
~ ~ ~ ~
IR
EF
V
C
O
M
H
V
D
D
R1
R
ES
#
C2
V
SS
SSD1306
C1
V
C
C
V
B
A
T
C4
C3C5C6
C
1P
C
1N
C
2N
C
2P
Active Area 0.96"
128 x 64 Pixels
C
om
m
on
 6
3
C
om
m
on
 3
2
~
D
0
D
7~D
/C
#
 
 
MCU Interface Selection: BS0, BS1 and BS2 
Pins connected to MCU interface: CS#, RES#, D/C#, R/W#, E/RD#, and 
D0~D7 
 
C1, C2, C5, C6: 1μF 
C3: 2.2μF 
C4: 4.7μF / 16V, X7R 
R1: 390kΩ, R1 = (Voltage at IREF – VSS) / IREF 
 6
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
2. Absolute Maximum Ratings 
Parameter Symbol Min Max Unit Notes 
Supply Voltage for Logic VDD -0.3 4 V 1, 2 
Supply Voltage for Display VCC 0 11 V 1, 2 
Supply Voltage for DC/DC VBAT -0.3 5 V 1, 2 
Operating Temperature TOP -30 70 °C - 
Storage Temperature TSTG -40 80 °C - 
Note 1: All the above voltages are on the basis of “VSS = 0V”. 
Note 2: When this module is used beyond the above absolute maximum ratings, 
permanent breakage of the module may occur. Also, for normal operations, it is 
desirable to use this module under the conditions according to Section 3. 
“Optics & Electrical Characteristics”. If this module is used beyond these 
conditions, malfunctioning of the module can occur and the reliability of the 
module may deteriorate. 
 7
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
3. Optics & Electrical Characteristics 
3.1 Optics Characteristics 
Characteristics Symbol Conditions Min Typ Max Unit
Brightness 
(VCC Supplied Externally) 
Lbr
With Polarizer 
(Note 3) 100 120 - cd/m
2
Brightness 
(VCC Generated by Internal DC/DC) 
Lbr
With Polarizer 
(Note 4) 70 90 - cd/m
2
C.I.E. (White) (x) (y) Without Polarizer
0.28
0.29
0.32 
0.33 
0.36 
0.37  
Dark Room Contrast CR  - >2000:1 -  
View Angle   >160 - - degree
* Optical measurement taken at VDD = 2.8V, VCC = 9V & 7.25V. 
Software configuration follows Section 4.4 Initialization. 
 
 
3.2 DC Characteristics 
Characteristics Symbol Conditions Min Typ Max Unit
Supply Voltage for Logic VDD - 1.65 2.8 3.3 V 
Supply Voltage for Display
(Supplied Externally) VCC Note 3 8.5 9 9.5 V 
Supply Voltage for DC/DC VBAT Internal DC/DC Enable 3.5 - 4.2 V 
Supply Voltage for Display
(Generated by Internal DC/DC) VCC Note 4 7 7.25 7.5 V 
High Level Input VIH - 0.8×VDD - VDD V 
Low Level Input VIL - 0 - 0.2×VDD V 
High Level Output VOH IOUT = 100μA, 3.3MHz 0.9×VDD - VDD V 
Low Level Output VOL IOUT = 100μA, 3.3MHz 0 - 0.1×VDD V 
Operating Current for VDD IDD - - 180 300 μA
Note 5 - 7.3 9.1 mAOperating Current for VCC
(VCC Supplied Externally) 
ICC
Note 6 - 12.3 15.4 mA
Note 7 - 17.3 21.6 mAOperating Current for VBAT
(VCC Generated by Internal DC/DC)
IBAT Note 8 - 23.1 28.9 mA
Sleep Mode Current for VDD IDD, SLEEP - - 1 5 μA 
Sleep Mode Current for VCC ICC, SLEEP - - 1 5 μA 
Note 3 & 4: Brightness (Lbr) and Supply Voltage for Display (VCC) are subject to the 
change of the panel characteristics and the customer’s request. 
Note 5: VDD = 2.8V, VCC = 9V, 50% Display Area Turn on. 
Note 6: VDD = 2.8V, VCC = 9V, 100% Display Area Turn on. 
Note 7: VDD = 2.8V, VCC = 7.25V, 50% Display Area Turn on. 
Note 8: VDD = 2.8V, VCC = 7.25V, 100% Display Area Turn on. 
 
 8
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
* Software configuration follows Section 4.4 Initialization. 
 
 
3.3 AC Characteristics 
3.3.1 68XX-Series MPU Parallel Interface Timing Characteristics: 
Symbol Description Min Max Unit
tcycle Clock Cycle Time 300 - ns 
tAS Address Setup Time 0 - ns 
tAH Address Hold Time 0 - ns 
tDSW Write Data Setup Time 40 - ns 
tDHW Write Data Hold Time 7 - ns 
tDHR Read Data Hold Time 20 - ns 
tOH Output Disable Time - 70 ns 
tACC Access Time - 140 ns 
Chip Select Low Pulse Width (Read) 120 
PWCSL
Chip Select Low Pulse width (Write) 60 
- ns 
Chip Select High Pulse Width (Read) 60 
PWCSH
Chip Select High Pulse Width (Write) 60 
- ns 
tR Rise Time - 40 ns 
tF Fall Time - 40 ns 
* (VDD - VSS = 1.65V to 3.3V, Ta = 25°C) 
 
 
 
 
 9
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
3.3.2 80XX-Series MPU Parallel Interface Timing Characteristics: 
Symbol Description Min Max Unit
tcycle Clock Cycle Time 300 - ns 
tAS Address Setup Time 10 - ns 
tAH Address Hold Time 0 - ns 
tDSW Write Data Setup Time 40 - ns 
tDHW Write Data Hold Time 7 - ns 
tDHR Read Data Hold Time 20 - ns 
tOH Output Disable Time - 70 ns 
tACC Access Time - 140 ns 
tPWLR Read Low Time 120 - ns 
tPWLW Write Low Time 60 - ns 
tPWHR Read High Time 60 - ns 
tPWHW Write High Time 60 - ns 
tCS Chip Select Setup Time 0 - ns 
tCSH Chip Select Hold Time to Read Signal 0 - ns 
tCSF Chip Select Hold Time 20 - ns 
tR Rise Time - 40 ns 
tF Fall Time - 40 ns 
* (VDD - VSS = 1.65V to 3.3V, Ta = 25°C) 
 
 
( Read Timing )  
 
( Write Timing )  
 10
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
3.3.3 Serial Interface Timing Characteristics: (4-wire SPI) 
Symbol Description Min Max Unit
tcycle Clock Cycle Time 100 - ns 
tAS Address Setup Time 15 - ns 
tAH Address Hold Time 15 - ns 
tCSS Chip Select Setup Time 20 - ns 
tCSH Chip Select Hold Time 10 - ns 
tDSW Write Data Setup Time 15 - ns 
tDHW Write Data Hold Time 15 - ns 
tCLKL Clock Low Time 20 - ns 
tCLKH Clock High Time 20 - ns 
tR Rise Time - 40 ns 
tF Fall Time - 40 ns 
* (VDD - VSS = 1.65V to 3.3V, Ta = 25°C) 
 
 
 
 
 11
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
3.3.4 Serial Interface Timing Characteristics: (3-wire SPI) 
Symbol Description Min Max Unit
tcycle Clock Cycle Time 100 - ns 
tCSS Chip Select Setup Time 20 - ns 
tCSH Chip Select Hold Time 10 - ns 
tDSW Write Data Setup Time 15 - ns 
tDHW Write Data Hold Time 15 - ns 
tCLKL Clock Low Time 20 - ns 
tCLKH Clock High Time 20 - ns 
tR Rise Time - 40 ns 
tF Fall Time - 40 ns 
* (VDD - VSS = 1.65V to 3.3V, Ta = 25°C) 
 
 
 
 
 12
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
3.3.5 I2C Interface Timing Characteristics: 
Symbol Description Min Max Unit
tcycle Clock Cycle Time 2.5 - us 
tHSTART Start Condition Hold Time 0.6 - us 
Data Hold Time (for “SDAOUT” Pin) 0 tHD
Data Hold Time (for “SDAIN” Pin) 300 
- ns 
tSD Data Setup Time 100 - ns 
tSSTART
Start Condition Setup Time 
(Only relevant for a repeated Start 
condition) 
0.6 - us 
tSSTOP Stop Condition Setup Time 0.6 - us 
tR Rise Time for Data and Clock Pin  300 ns 
tF Fall Time for Data and Clock Pin  300 ns 
tIDLE
Idle Time before a New Transmission 
can Start 1.3 - us 
* (VDD - VSS = 1.65V to 3.3V, Ta = 25°C) 
 
 
 
 
 13
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
4. Functional Specification 
4.1. Commands 
Refer to the Technical Manual for the SSD1306 
 
 
4.2 Power down and Power up Sequence 
To protect OEL panel and extend the panel life time, the driver IC power up/down 
routine should include a delay period between high voltage and low voltage power 
sources during turn on/off.  It gives the OEL panel enough time to complete the 
action of charge and discharge before/after the operation. 
 
4.2.1 Power up Sequence: 
1. Power up VDD
2. Send Display off command 
3. Initialization 
4. Clear Screen 
5. Power up VCC
6. Delay 100ms 
(When VCC is stable) 
7. Send Display on command 
 
 
 
Display on 
VDD
VDD on 
VCC on 
VSS/Ground
VCC
 
4.2.2 Power down Sequence: 
1. Send Display off command 
2. Power down VCC
3. Delay 100ms 
(When VCC is reach 0 and panel 
is completely discharges) 
4. Power down VDD
 
Dis
 
 
 
 
4.3 Reset Circuit 
When RES# input is low, the chip is initialized with the following status: 
1. Display is OFF 
2. 128×64 Display Mode 
3. Normal segment and display data column and row address mapping (SEG0 
mapped to column address 00h and COM0 mapped to row address 00h) 
4. Shift register data clear in serial interface 
5. Display start line is set at display RAM address 0 
6. Column address counter is set at 0 
7. Normal scan direction of the COM outputs 
8. Contrast control register is set at 7Fh 
9. Normal display mode (Equivalent to A4h command) 
 
VDD off 
VDD
play off 
VCC off 
VCC
VSS/Ground
 14
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
4.4 Actual Application Example 
Command usage and explanation of an actual example 
 
<Initialization>
 
* Written Value for Parameters 
(1) ? VCC Supplied Externally 
(2) ? VCC Generated by Internal DC/DC Circuit 
 
If the noise is accidentally occurred at the displaying window during the operation, 
please reset the display in order to recover the display function. 
* Set Charge Pump 
0x8D, 0x10(1) / 0x14(2)
Set Multiplex Ratio 
0xA8, 0x3F 
Set Display Offset 
0xD3, 0x00 
Set Display Start Line 
0x40 
Set Segment Re-Map 
0xA1
Set COM Output Scan Direction 
0xC8
Set COM Pins Hardware Configuration 
0xDA, 0x12
* Set Contrast Control 
0x81, 
Set Display Off 
0xAE 
Set Entire Display On/Off
0xA4 
Set Normal/Inverse Display
0xA6 
0x9F(1) / 0xCF(2)
* Set Pre-Charge Period
0xD9, 0x22(1) / 0xF1(2)
Set VCOMH Deselect Level
0xDB, 0x40
Set Display On 
0xAF 
Clear Screen 
Set Display Clock Divide Ratio/Oscillator Frequency 
0xD5, 0x80 
 15
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
5. Reliability 
5.1 Contents of Reliability Tests 
Item Conditions Criteria 
High Temperature Operation 70°C, 240 hrs 
Low Temperature Operation -30°C, 240 hrs 
High Temperature Storage 80°C, 240 hrs  
Low Temperature Storage -40°C, 240 hrs 
High Temperature/Humidity Operation 60°C, 90% RH, 120 hrs 
Thermal Shock -40°C ⇔ 85°C, 24 cycles 60 mins dwell 
The operational 
functions work. 
* The samples used for the above tests do not include polarizer. 
* No moisture condensation is observed during tests. 
 
 
5.2 Lifetime 
End of lifetime is specified as 50% of initial brightness reached. 
Parameter Min Max Unit Condition Notes
Operating Life Time 10,000 - hr 100 cd/m2, 50% Checkerboard 6 
Storage Life Time 20,000 - hr Ta = 25°C, 50% RH - 
Note 6: The average operating lifetime at room temperature is estimated by the 
accelerated operation at high temperature conditions. 
 
 
5.3 Failure Check Standard 
After the completion of the described reliability test, the samples were left at room 
temperature for 2 hrs prior to conducting the failure test at 23±5°C; 55±15% RH. 
 
 16
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6. Outgoing Quality Control Specifications 
6.1 Environment Required 
Customer’s test & measurement are required to be conducted under the following 
conditions: 
Temperature: 23 ± 5°C 
Humidity: 55 ± 15 %RH 
Fluorescent Lamp: 30W 
Distance between the Panel & Lamp: ≥ 50 cm 
Distance between the Panel & Eyes of the Inspector: ≥ 30 cm 
Finger glove (or finger cover) must be worn by the inspector. 
Inspection table or jig must be anti-electrostatic. 
 
 
6.2 Sampling Plan 
Level II, Normal Inspection, Single Sampling, MIL-STD-105E 
 
 
6.3 Criteria & Acceptable Quality Level 
Partition AQL Definition 
Major 0.65 Defects in Pattern Check (Display On) 
Minor 1.0 Defects in Cosmetic Check (Display Off) 
 
6.3.1 Cosmetic Check (Display Off) in Non-Active Area 
Check Item Classification Criteria 
Minor 
X > 6 mm  (Along with Edge) 
Y > 1 mm  (Perpendicular to edge)
 
Panel 
General Chipping 
X
Y
X 
Y
 
 17
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6.3.1 Cosmetic Check (Display Off) in Non-Active Area (Continued) 
Check Item Classification Criteria 
Panel Crack Minor 
Any crack is not allowable. 
 
Cupper Exposed 
(Even Pin or Film) Minor 
Not Allowable by Naked Eye 
Inspection 
 
Film or Trace Damage Minor 
Terminal Lead Twist Minor 
Not Allowable 
Terminal Lead Broken Minor 
Not Allowable 
Terminal Lead Prober 
Mark Acceptable
 
 18
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6.3.1 Cosmetic Check (Display Off) in Non-Active Area (Continued) 
Check Item Classification Criteria 
Minor 
NG if any bent lead cause lead 
shorting. 
 Terminal Lead Bent 
(Not Twist or Broken) 
Minor 
NG for horizontally bent lead more 
than 50% of its width. 
 
Glue or Contamination 
on Pin 
(Couldn’t Be Removed 
by Alcohol) 
Minor 
Ink Marking on Back 
Side of panel 
(Exclude on Film) 
Acceptable Ignore for Any 
 
 19
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6.3.2 Cosmetic Check (Display Off) in Active Area 
Check Item Classification Criteria 
Any Dirt & Scratch on 
Polarizer’s Protective Film Acceptable
Ignore for not Affect the 
Polarizer 
Scratches, Fiber, Line-Shape 
Defect 
(On Polarizer) 
Minor 
W ≤ 0.1 Ignore 
W > 0.1, L ≤ 2 n ≤ 1 
L > 2 n = 0 
Dirt, Black Spot, Foreign 
Material, 
(On Polarizer) 
Minor 
Φ ≤ 0.1 Ignore 
0.1 <Φ ≤ 0.25 n ≤ 1 
0.25 <Φ n = 0 
Dent, Bubbles, White spot 
(Any Transparent Spot on 
Polarizer) 
Minor 
Φ ≤ 0.5 
? Ignore if no Influence on 
Display 
0.5 < Φ n = 0 
 
Fingerprint, Flow Mark 
(On Polarizer) Minor Not Allowable 
* Protective film should not be tear off when cosmetic check. 
** Definition of W & L & Φ (Unit: mm): Φ = (a + b) / 2 
 
 
 
L 
b: Minor Axis 
W 
a: Major Axis 
 20
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
6.3.3 Pattern Check (Display On) in Active Area 
Check Item Classification Criteria 
 
No Display Major 
Flicker Major Not Allowable 
 
Missing Line Major 
Pixel Short Major 
 
Darker Pixel Major 
 
 
Wrong Display Major 
Un-uniform Major 
 
 
 21
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
7. Package Specifications
cs Tray Vacuum packing
 
Tray 420x285 T=0.8mm
16 P
EPE PROTECTTIVE
Brimary Box 4 SET
CARTON BOX
Module
EPE COVER FOAM 351x212x1,
ANTISTATIC x 1 Pcs
x s 15 pc
x 1 pcs (Empty)
Staggered Stacking
x cs 
Wra d with adhesive tape
 16 p
ppe
Exsiccator x 2 pcs
Vacuum packing bag
EPE PROTECTTIVE
Label
Primary L450mm x W296 x H110, B wave
x 4Pcs
Carton Box L464mm x W313mm x H472mm, AB wave
B 
370mm x 280mm x 20mm
Univision Technology Inc.
Part ID :
Lot ID :
Q'ty :
QC :
Label
A 
Pri   C SET 
B 
C 
(Major / Maximum)
 
 
Item Quantity 
Holding Trays (A) 15 per Primary Box 
Total Trays (B) 16 per Primary Box (Including 1 Empty Tray) 
Primary Box (C) 1~4 per Carton (4 as Major / Maximum) 
 
 22
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
8. Precautions When Using These OEL Display Modules 
8.1 Handling Precautions 
1) Since the display panel is being made of glass, do not apply mechanical 
impacts such us dropping from a high position. 
2) If the display panel is broken by some accident and the internal organic 
substance leaks out, be careful not to inhale nor lick the organic substance. 
3) If pressure is applied to the display surface or its neighborhood of the OEL 
display module, the cell structure may be damaged and be careful not to apply 
pressure to these sections. 
4) The polarizer covering the surface of the OEL display module is soft and easily 
scratched.  Please be careful when handling the OEL display module. 
5) When the surface of the polarizer of the OEL display module has soil, clean the 
surface.  It takes advantage of by using following adhesion tape. 
* Scotch Mending Tape No. 810 or an equivalent 
Never try to breathe upon the soiled surface nor wipe the surface using cloth 
containing solvent such as ethyl alcohol, since the surface of the polarizer will 
become cloudy. 
Also, pay attention that the following liquid and solvent may spoil the 
polarizer: 
* Water 
* Ketone 
* Aromatic Solvents 
6) Hold OEL display module very carefully when placing OEL display module 
into the system housing. Do not apply excessive stress or pressure to OEL 
display module.  And, do not over bend the film with electrode pattern layouts.  
These stresses will influence the display performance.  Also, secure sufficient 
rigidity for the outer cases. 
 
7) Do not apply stress to the LSI chips and the surrounding molded sections. 
8) Do not disassemble nor modify the OEL display module. 
9) Do not apply input signals while the logic power is off. 
10) Pay sufficient attention to the working environments when handing OEL 
display modules to prevent occurrence of element breakage accidents by static 
electricity. 
* Be sure to make human body grounding when handling OEL display 
modules. 
* Be sure to ground tools to use or assembly such as soldering irons. 
* To suppress generation of static electricity, avoid carrying out assembly work 
under dry environments. 
* Protective film is being applied to the surface of the display panel of the OEL 
display module.  Be careful since static electricity may be generated when 
exfoliating the protective film. 
 23
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
11) Protection film is being applied to the surface of the display panel and removes 
the protection film before assembling it.  At this time, if the OEL display 
module has been stored for a long period of time, residue adhesive material of 
the protection film may remain on the surface of the display panel after 
removed of the film.  In such case, remove the residue material by the method 
introduced in the above Section 5). 
12) If electric current is applied when the OEL display module is being dewed or 
when it is placed under high humidity environments, the electrodes may be 
corroded and be careful to avoid the above. 
 
 
8.2 Storage Precautions 
1) When storing OEL display modules, put them in static electricity preventive 
bags avoiding exposure to direct sun light nor to lights of fluorescent lamps, etc. 
and, also, avoiding high temperature and high humidity environments or low 
temperature (less than 0°C) environments.  (We recommend you to store these 
modules in the packaged state when they were shipped from Univision 
Technology Inc.) 
At that time, be careful not to let water drops adhere to the packages or bags nor 
let dewing occur with them. 
2) If electric current is applied when water drops are adhering to the surface of the 
OEL display module, when the OEL display module is being dewed or when it 
is placed under high humidity environments, the electrodes may be corroded 
and be careful about the above. 
 
 
8.3 Designing Precautions 
1) The absolute maximum ratings are the ratings which cannot be exceeded for 
OEL display module, and if these values are exceeded, panel damage may be 
happen. 
2) To prevent occurrence of malfunctioning by noise, pay attention to satisfy the 
VIL and VIH specifications and, at the same time, to make the signal line cable 
as short as possible. 
3) We recommend you to install excess current preventive unit (fuses, etc.) to the 
power circuit (VDD).  (Recommend value: 0.5A) 
4) Pay sufficient attention to avoid occurrence of mutual noise interference with 
the neighboring devices. 
5) As for EMI, take necessary measures on the equipment side basically. 
6) When fastening the OEL display module, fasten the external plastic housing 
section. 
7) If power supply to the OEL display module is forcibly shut down by such errors 
as taking out the main battery while the OEL display panel is in operation, we 
cannot guarantee the quality of this OEL display module. 
8) The electric potential to be connected to the rear face of the IC chip should be 
as follows: SSD1306 
* Connection (contact) to any other potential than the above may lead to 
rupture of the IC. 
 
 
 24
 
 
 Univision Technology Inc. Doc. No: SAS1-9046-B 
8.4 Precautions when disposing of the OEL display modules 
1) Request the qualified companies to handle industrial wastes when disposing of 
the OEL display modules.  Or, when burning them, be sure to observe the 
environmental and hygienic laws and regulations. 
 
 
8.5 Other Precautions 
1) When an OEL display module is operated for a long of time with fixed pattern 
may remain as an after image or slight contrast deviation may occur. 
Nonetheless, if the operation is interrupted and left unused for a while, normal 
state can be restored.  Also, there will be no problem in the reliability of the 
module. 
2) To protect OEL display modules from performance drops by static electricity 
rapture, etc., do not touch the following sections whenever possible while 
handling the OEL display modules. 
* Pins and electrodes 
* Pattern layouts such as the FPC 
3) With this OEL display module, the OEL driver is being exposed.  Generally 
speaking, semiconductor elements change their characteristics when light is 
radiated according to the principle of the solar battery.  Consequently, if this 
OEL driver is exposed to light, malfunctioning may occur. 
* Design the product and installation method so that the OEL driver may be 
shielded from light in actual usage. 
* Design the product and installation method so that the OEL driver may be 
shielded from light during the inspection processes. 
4) Although this OEL display module stores the operation state data by the 
commands and the indication data, when excessive external noise, etc. enters 
into the module, the internal status may be changed.  It therefore is necessary 
to take appropriate measures to suppress noise generation or to protect from 
influences of noise on the system design. 
5) We recommend you to construct its software to make periodical refreshment of 
the operation statuses (re-setting of the commands and re-transference of the 
display data) to cope with catastrophic noise. 
 
 25
 
 
