![](/media/cache/group/default_image.jpg.50x50_q85.jpg)
capstone_finish
Dependencies: BufferedSerial motor_sn7544
ov7670.h@6:fe8b32cb9357, 2019-08-13 (annotated)
- Committer:
- kangmingyo
- Date:
- Tue Aug 13 07:51:37 2019 +0000
- Revision:
- 6:fe8b32cb9357
- Parent:
- 5:53dd2abce6b3
- Child:
- 7:152fba230106
version3;
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
mio | 0:f3f80a0695ff | 1 | #include "mbed.h" |
mio | 0:f3f80a0695ff | 2 | #include "ov7670reg.h" |
mio | 0:f3f80a0695ff | 3 | |
mio | 0:f3f80a0695ff | 4 | #define OV7670_WRITE (0x42) |
mio | 0:f3f80a0695ff | 5 | #define OV7670_READ (0x43) |
mio | 0:f3f80a0695ff | 6 | #define OV7670_WRITEWAIT (20) |
mio | 0:f3f80a0695ff | 7 | #define OV7670_NOACK (0) |
mio | 0:f3f80a0695ff | 8 | #define OV7670_REGMAX (201) |
kangmingyo | 4:7b63cf3d205f | 9 | #define OV7670_I2CFREQ (40000) |
mio | 0:f3f80a0695ff | 10 | |
mio | 0:f3f80a0695ff | 11 | // |
mio | 0:f3f80a0695ff | 12 | // OV7670 + FIFO AL422B camera board test |
mio | 0:f3f80a0695ff | 13 | // |
kangmingyo | 2:e98408458d2b | 14 | class OV7670 |
mio | 0:f3f80a0695ff | 15 | { |
mio | 0:f3f80a0695ff | 16 | public: |
kangmingyo | 4:7b63cf3d205f | 17 | I2C _i2c ; |
mio | 0:f3f80a0695ff | 18 | InterruptIn vsync,href; |
mio | 0:f3f80a0695ff | 19 | DigitalOut wen ; |
mio | 0:f3f80a0695ff | 20 | PortIn data ; |
mio | 0:f3f80a0695ff | 21 | DigitalOut rrst,oe,rclk ; |
mio | 0:f3f80a0695ff | 22 | volatile int LineCounter ; |
mio | 0:f3f80a0695ff | 23 | volatile int LastLines ; |
mio | 0:f3f80a0695ff | 24 | volatile bool CaptureReq ; |
mio | 0:f3f80a0695ff | 25 | volatile bool Busy ; |
mio | 0:f3f80a0695ff | 26 | volatile bool Done ; |
mio | 0:f3f80a0695ff | 27 | |
mio | 0:f3f80a0695ff | 28 | OV7670( |
mio | 0:f3f80a0695ff | 29 | PinName sda,// Camera I2C port |
mio | 0:f3f80a0695ff | 30 | PinName scl,// Camera I2C port |
mio | 0:f3f80a0695ff | 31 | PinName vs, // VSYNC |
mio | 0:f3f80a0695ff | 32 | PinName hr, // HREF |
mio | 0:f3f80a0695ff | 33 | PinName we, // WEN |
mio | 0:f3f80a0695ff | 34 | PortName port, // 8bit bus port |
mio | 0:f3f80a0695ff | 35 | int mask, // 0b0000_0M65_4000_0321_L000_0000_0000_0000 = 0x07878000 |
mio | 0:f3f80a0695ff | 36 | PinName rt, // /RRST |
mio | 0:f3f80a0695ff | 37 | PinName o, // /OE |
kangmingyo | 2:e98408458d2b | 38 | PinName rc // RCLK |
kangmingyo | 4:7b63cf3d205f | 39 | ) : _i2c(sda,scl),vsync(vs),href(hr),wen(we),data(port,mask),rrst(rt),oe(o),rclk(rc) |
mio | 0:f3f80a0695ff | 40 | { |
kangmingyo | 4:7b63cf3d205f | 41 | _i2c.stop() ; |
kangmingyo | 4:7b63cf3d205f | 42 | _i2c.frequency(OV7670_I2CFREQ) ; |
mio | 0:f3f80a0695ff | 43 | vsync.fall(this,&OV7670::VsyncHandler) ; |
mio | 0:f3f80a0695ff | 44 | href.rise(this,&OV7670::HrefHandler) ; |
mio | 0:f3f80a0695ff | 45 | CaptureReq = false ; |
mio | 0:f3f80a0695ff | 46 | Busy = false ; |
mio | 0:f3f80a0695ff | 47 | Done = false ; |
mio | 0:f3f80a0695ff | 48 | LineCounter = 0 ; |
mio | 0:f3f80a0695ff | 49 | rrst = 1 ; |
mio | 0:f3f80a0695ff | 50 | oe = 1 ; |
mio | 0:f3f80a0695ff | 51 | rclk = 1 ; |
mio | 0:f3f80a0695ff | 52 | wen = 0 ; |
mio | 0:f3f80a0695ff | 53 | } |
mio | 0:f3f80a0695ff | 54 | |
mio | 0:f3f80a0695ff | 55 | // capture request |
mio | 0:f3f80a0695ff | 56 | void CaptureNext(void) |
mio | 0:f3f80a0695ff | 57 | { |
mio | 0:f3f80a0695ff | 58 | CaptureReq = true ; |
mio | 0:f3f80a0695ff | 59 | Busy = true ; |
mio | 0:f3f80a0695ff | 60 | } |
kangmingyo | 2:e98408458d2b | 61 | |
mio | 0:f3f80a0695ff | 62 | // capture done? (with clear) |
mio | 0:f3f80a0695ff | 63 | bool CaptureDone(void) |
mio | 0:f3f80a0695ff | 64 | { |
mio | 0:f3f80a0695ff | 65 | bool result ; |
mio | 0:f3f80a0695ff | 66 | if (Busy) { |
mio | 0:f3f80a0695ff | 67 | result = false ; |
mio | 0:f3f80a0695ff | 68 | } else { |
mio | 0:f3f80a0695ff | 69 | result = Done ; |
mio | 0:f3f80a0695ff | 70 | Done = false ; |
mio | 0:f3f80a0695ff | 71 | } |
mio | 0:f3f80a0695ff | 72 | return result ; |
mio | 0:f3f80a0695ff | 73 | } |
mio | 0:f3f80a0695ff | 74 | |
mio | 0:f3f80a0695ff | 75 | // write to camera |
mio | 0:f3f80a0695ff | 76 | void WriteReg(int addr,int data) |
mio | 0:f3f80a0695ff | 77 | { |
kangmingyo | 4:7b63cf3d205f | 78 | int status; |
kangmingyo | 4:7b63cf3d205f | 79 | char data_write[2]; |
kangmingyo | 4:7b63cf3d205f | 80 | data_write[0]= addr; |
kangmingyo | 4:7b63cf3d205f | 81 | data_write[1]= data; |
kangmingyo | 4:7b63cf3d205f | 82 | status = _i2c.write(OV7670_WRITE,data_write,2,0); |
kangmingyo | 4:7b63cf3d205f | 83 | if(status!=0){ |
kangmingyo | 4:7b63cf3d205f | 84 | // printf("I2C configuration error(adr: %x)!\r\n",addr); |
kangmingyo | 4:7b63cf3d205f | 85 | while(1){ |
kangmingyo | 4:7b63cf3d205f | 86 | } |
kangmingyo | 4:7b63cf3d205f | 87 | } |
mio | 0:f3f80a0695ff | 88 | } |
mio | 0:f3f80a0695ff | 89 | |
mio | 0:f3f80a0695ff | 90 | // read from camera |
mio | 0:f3f80a0695ff | 91 | int ReadReg(int addr) |
mio | 0:f3f80a0695ff | 92 | { |
kangmingyo | 4:7b63cf3d205f | 93 | char data_write[2]; |
kangmingyo | 4:7b63cf3d205f | 94 | char data_read[2]; |
kangmingyo | 4:7b63cf3d205f | 95 | int data; |
kangmingyo | 4:7b63cf3d205f | 96 | int status; |
kangmingyo | 4:7b63cf3d205f | 97 | |
kangmingyo | 4:7b63cf3d205f | 98 | data_write[0]=addr; |
kangmingyo | 4:7b63cf3d205f | 99 | _i2c.write(OV7670_WRITE, data_write, 1, 0); |
kangmingyo | 4:7b63cf3d205f | 100 | status =_i2c.read(OV7670_READ, data_read, 1, 0); |
kangmingyo | 4:7b63cf3d205f | 101 | data = (int)data_read[0]; |
kangmingyo | 5:53dd2abce6b3 | 102 | // printf("Data is %x\r\n",data); |
kangmingyo | 4:7b63cf3d205f | 103 | // printf("Status is %d\r\n",status); |
mio | 0:f3f80a0695ff | 104 | return data ; |
mio | 0:f3f80a0695ff | 105 | } |
mio | 0:f3f80a0695ff | 106 | |
kangmingyo | 2:e98408458d2b | 107 | void Reset(void) |
kangmingyo | 2:e98408458d2b | 108 | { |
mio | 0:f3f80a0695ff | 109 | WriteReg(0x12,0x80) ; // RESET CAMERA |
mio | 0:f3f80a0695ff | 110 | wait_ms(200) ; |
mio | 0:f3f80a0695ff | 111 | } |
kangmingyo | 2:e98408458d2b | 112 | |
kangmingyo | 2:e98408458d2b | 113 | void InitQQVGA565(bool flipv,bool fliph) |
kangmingyo | 2:e98408458d2b | 114 | { |
mio | 0:f3f80a0695ff | 115 | // QQVGA RGB565 |
mio | 0:f3f80a0695ff | 116 | WriteReg(REG_CLKRC,0x80); |
kangmingyo | 2:e98408458d2b | 117 | WriteReg(REG_COM11,0x0A) ; |
mio | 0:f3f80a0695ff | 118 | WriteReg(REG_TSLB,0x04); |
mio | 0:f3f80a0695ff | 119 | WriteReg(REG_COM7,0x04) ; |
mio | 0:f3f80a0695ff | 120 | WriteReg(REG_RGB444, 0x00); |
mio | 0:f3f80a0695ff | 121 | WriteReg(REG_COM15, 0xd0); |
mio | 0:f3f80a0695ff | 122 | WriteReg(REG_HSTART,0x16) ; |
mio | 0:f3f80a0695ff | 123 | WriteReg(REG_HSTOP,0x04) ; |
mio | 0:f3f80a0695ff | 124 | WriteReg(REG_HREF,0x24) ; |
mio | 0:f3f80a0695ff | 125 | WriteReg(REG_VSTART,0x02) ; |
mio | 0:f3f80a0695ff | 126 | WriteReg(REG_VSTOP,0x7a) ; |
mio | 0:f3f80a0695ff | 127 | WriteReg(REG_VREF,0x0a) ; |
mio | 0:f3f80a0695ff | 128 | WriteReg(REG_COM10,0x02) ; |
mio | 0:f3f80a0695ff | 129 | WriteReg(REG_COM3, 0x04); |
mio | 0:f3f80a0695ff | 130 | WriteReg(REG_COM14, 0x1a); |
mio | 1:509676f3be32 | 131 | WriteReg(REG_MVFP,0x07 | (flipv ? 0x10:0) | (fliph ? 0x20:0)) ; |
mio | 0:f3f80a0695ff | 132 | WriteReg(0x72, 0x22); |
mio | 0:f3f80a0695ff | 133 | WriteReg(0x73, 0xf2); |
mio | 0:f3f80a0695ff | 134 | |
mio | 0:f3f80a0695ff | 135 | // COLOR SETTING |
mio | 0:f3f80a0695ff | 136 | WriteReg(0x4f,0x80); |
mio | 0:f3f80a0695ff | 137 | WriteReg(0x50,0x80); |
mio | 0:f3f80a0695ff | 138 | WriteReg(0x51,0x00); |
mio | 0:f3f80a0695ff | 139 | WriteReg(0x52,0x22); |
mio | 0:f3f80a0695ff | 140 | WriteReg(0x53,0x5e); |
mio | 0:f3f80a0695ff | 141 | WriteReg(0x54,0x80); |
mio | 0:f3f80a0695ff | 142 | WriteReg(0x56,0x40); |
mio | 0:f3f80a0695ff | 143 | WriteReg(0x58,0x9e); |
mio | 0:f3f80a0695ff | 144 | WriteReg(0x59,0x88); |
mio | 0:f3f80a0695ff | 145 | WriteReg(0x5a,0x88); |
mio | 0:f3f80a0695ff | 146 | WriteReg(0x5b,0x44); |
mio | 0:f3f80a0695ff | 147 | WriteReg(0x5c,0x67); |
mio | 0:f3f80a0695ff | 148 | WriteReg(0x5d,0x49); |
mio | 0:f3f80a0695ff | 149 | WriteReg(0x5e,0x0e); |
mio | 0:f3f80a0695ff | 150 | WriteReg(0x69,0x00); |
mio | 0:f3f80a0695ff | 151 | WriteReg(0x6a,0x40); |
mio | 0:f3f80a0695ff | 152 | WriteReg(0x6b,0x0a); |
mio | 0:f3f80a0695ff | 153 | WriteReg(0x6c,0x0a); |
mio | 0:f3f80a0695ff | 154 | WriteReg(0x6d,0x55); |
mio | 0:f3f80a0695ff | 155 | WriteReg(0x6e,0x11); |
mio | 0:f3f80a0695ff | 156 | WriteReg(0x6f,0x9f); |
mio | 0:f3f80a0695ff | 157 | |
mio | 0:f3f80a0695ff | 158 | WriteReg(0xb0,0x84); |
kangmingyo | 2:e98408458d2b | 159 | } |
mio | 0:f3f80a0695ff | 160 | |
kangmingyo | 2:e98408458d2b | 161 | void InitQVGA565(bool flipv,bool fliph) |
kangmingyo | 2:e98408458d2b | 162 | { |
mio | 0:f3f80a0695ff | 163 | // QVGA RGB565 |
mio | 0:f3f80a0695ff | 164 | WriteReg(REG_CLKRC,0x80); |
mio | 0:f3f80a0695ff | 165 | WriteReg(REG_COM11,0x0A) ; |
mio | 0:f3f80a0695ff | 166 | WriteReg(REG_TSLB,0x04); |
mio | 0:f3f80a0695ff | 167 | WriteReg(REG_COM7,0x04) ; |
mio | 0:f3f80a0695ff | 168 | WriteReg(REG_RGB444, 0x00); |
mio | 0:f3f80a0695ff | 169 | WriteReg(REG_COM15, 0xd0); |
mio | 0:f3f80a0695ff | 170 | WriteReg(REG_HSTART,0x16) ; |
mio | 0:f3f80a0695ff | 171 | WriteReg(REG_HSTOP,0x04) ; |
mio | 0:f3f80a0695ff | 172 | WriteReg(REG_HREF,0x80) ; |
mio | 0:f3f80a0695ff | 173 | WriteReg(REG_VSTART,0x02) ; |
mio | 0:f3f80a0695ff | 174 | WriteReg(REG_VSTOP,0x7a) ; |
mio | 0:f3f80a0695ff | 175 | WriteReg(REG_VREF,0x0a) ; |
mio | 0:f3f80a0695ff | 176 | WriteReg(REG_COM10,0x02) ; |
mio | 0:f3f80a0695ff | 177 | WriteReg(REG_COM3, 0x04); |
mio | 0:f3f80a0695ff | 178 | WriteReg(REG_COM14, 0x19); |
mio | 1:509676f3be32 | 179 | WriteReg(REG_MVFP,0x07 | (flipv ? 0x10:0) | (fliph ? 0x20:0)) ; |
mio | 0:f3f80a0695ff | 180 | WriteReg(0x72, 0x11); |
mio | 0:f3f80a0695ff | 181 | WriteReg(0x73, 0xf1); |
mio | 0:f3f80a0695ff | 182 | |
mio | 0:f3f80a0695ff | 183 | // COLOR SETTING |
mio | 0:f3f80a0695ff | 184 | WriteReg(0x4f,0x80); |
mio | 0:f3f80a0695ff | 185 | WriteReg(0x50,0x80); |
mio | 0:f3f80a0695ff | 186 | WriteReg(0x51,0x00); |
mio | 0:f3f80a0695ff | 187 | WriteReg(0x52,0x22); |
mio | 0:f3f80a0695ff | 188 | WriteReg(0x53,0x5e); |
mio | 0:f3f80a0695ff | 189 | WriteReg(0x54,0x80); |
mio | 0:f3f80a0695ff | 190 | WriteReg(0x56,0x40); |
mio | 0:f3f80a0695ff | 191 | WriteReg(0x58,0x9e); |
mio | 0:f3f80a0695ff | 192 | WriteReg(0x59,0x88); |
mio | 0:f3f80a0695ff | 193 | WriteReg(0x5a,0x88); |
mio | 0:f3f80a0695ff | 194 | WriteReg(0x5b,0x44); |
mio | 0:f3f80a0695ff | 195 | WriteReg(0x5c,0x67); |
mio | 0:f3f80a0695ff | 196 | WriteReg(0x5d,0x49); |
mio | 0:f3f80a0695ff | 197 | WriteReg(0x5e,0x0e); |
mio | 0:f3f80a0695ff | 198 | WriteReg(0x69,0x00); |
mio | 0:f3f80a0695ff | 199 | WriteReg(0x6a,0x40); |
mio | 0:f3f80a0695ff | 200 | WriteReg(0x6b,0x0a); |
mio | 0:f3f80a0695ff | 201 | WriteReg(0x6c,0x0a); |
mio | 0:f3f80a0695ff | 202 | WriteReg(0x6d,0x55); |
mio | 0:f3f80a0695ff | 203 | WriteReg(0x6e,0x11); |
mio | 0:f3f80a0695ff | 204 | WriteReg(0x6f,0x9f); |
mio | 0:f3f80a0695ff | 205 | |
mio | 0:f3f80a0695ff | 206 | WriteReg(0xb0,0x84); |
kangmingyo | 2:e98408458d2b | 207 | } |
kangmingyo | 6:fe8b32cb9357 | 208 | void InitQQVGAYUV(bool flipv,bool fliph) |
kangmingyo | 2:e98408458d2b | 209 | { |
kangmingyo | 5:53dd2abce6b3 | 210 | WriteReg(0x11,0x01); |
kangmingyo | 2:e98408458d2b | 211 | WriteReg(REG_COM7, 0x00); // YUV |
kangmingyo | 2:e98408458d2b | 212 | WriteReg(REG_COM17, 0x00); // color bar disable |
kangmingyo | 5:53dd2abce6b3 | 213 | WriteReg(REG_COM3, 0x04); |
kangmingyo | 2:e98408458d2b | 214 | WriteReg(0x12, 0x00);//COM7 |
kangmingyo | 5:53dd2abce6b3 | 215 | |
kangmingyo | 2:e98408458d2b | 216 | WriteReg(0x14, 0x1A);//COM9 |
kangmingyo | 2:e98408458d2b | 217 | WriteReg(0x3D, 0x40);//COM13 |
kangmingyo | 2:e98408458d2b | 218 | WriteReg(REG_COM15, 0xC0); |
kangmingyo | 5:53dd2abce6b3 | 219 | WriteReg(REG_TSLB,0x0C); |
kangmingyo | 6:fe8b32cb9357 | 220 | WriteReg(REG_COM14, 0x1a); // divide by 4 |
kangmingyo | 2:e98408458d2b | 221 | WriteReg(0x72, 0x22); // downsample by 4 |
kangmingyo | 2:e98408458d2b | 222 | WriteReg(0x73, 0xf2); // divide by 4 |
kangmingyo | 6:fe8b32cb9357 | 223 | // WriteReg(REG_HREF, 0xa4); |
kangmingyo | 6:fe8b32cb9357 | 224 | // WriteReg(REG_HSTART, 0x16); |
kangmingyo | 6:fe8b32cb9357 | 225 | // WriteReg(REG_HSTOP, 0x04); |
kangmingyo | 6:fe8b32cb9357 | 226 | // WriteReg(REG_VREF, 0x0a); |
kangmingyo | 6:fe8b32cb9357 | 227 | // WriteReg(REG_VSTART, 0x02); |
kangmingyo | 6:fe8b32cb9357 | 228 | // WriteReg(REG_VSTOP, 0x7a); |
kangmingyo | 5:53dd2abce6b3 | 229 | WriteReg(0x70,0x3A); |
kangmingyo | 5:53dd2abce6b3 | 230 | WriteReg(0x71,0x35); |
kangmingyo | 6:fe8b32cb9357 | 231 | |
kangmingyo | 5:53dd2abce6b3 | 232 | WriteReg(0xA2,0x02); |
kangmingyo | 5:53dd2abce6b3 | 233 | |
kangmingyo | 5:53dd2abce6b3 | 234 | |
kangmingyo | 5:53dd2abce6b3 | 235 | |
kangmingyo | 5:53dd2abce6b3 | 236 | |
kangmingyo | 5:53dd2abce6b3 | 237 | |
kangmingyo | 5:53dd2abce6b3 | 238 | |
kangmingyo | 5:53dd2abce6b3 | 239 | /* END MARKER */ |
kangmingyo | 2:e98408458d2b | 240 | } |
mio | 0:f3f80a0695ff | 241 | |
mio | 0:f3f80a0695ff | 242 | |
mio | 0:f3f80a0695ff | 243 | // vsync handler |
mio | 0:f3f80a0695ff | 244 | void VsyncHandler(void) |
mio | 0:f3f80a0695ff | 245 | { |
mio | 0:f3f80a0695ff | 246 | // Capture Enable |
mio | 0:f3f80a0695ff | 247 | if (CaptureReq) { |
mio | 0:f3f80a0695ff | 248 | wen = 1 ; |
mio | 0:f3f80a0695ff | 249 | Done = false ; |
mio | 0:f3f80a0695ff | 250 | CaptureReq = false ; |
mio | 0:f3f80a0695ff | 251 | } else { |
mio | 0:f3f80a0695ff | 252 | wen = 0 ; |
mio | 0:f3f80a0695ff | 253 | if (Busy) { |
mio | 0:f3f80a0695ff | 254 | Busy = false ; |
mio | 0:f3f80a0695ff | 255 | Done = true ; |
mio | 0:f3f80a0695ff | 256 | } |
mio | 0:f3f80a0695ff | 257 | } |
mio | 0:f3f80a0695ff | 258 | |
mio | 0:f3f80a0695ff | 259 | // Hline Counter |
mio | 0:f3f80a0695ff | 260 | LastLines = LineCounter ; |
mio | 0:f3f80a0695ff | 261 | LineCounter = 0 ; |
mio | 0:f3f80a0695ff | 262 | } |
kangmingyo | 2:e98408458d2b | 263 | |
mio | 0:f3f80a0695ff | 264 | // href handler |
mio | 0:f3f80a0695ff | 265 | void HrefHandler(void) |
mio | 0:f3f80a0695ff | 266 | { |
mio | 0:f3f80a0695ff | 267 | LineCounter++ ; |
mio | 0:f3f80a0695ff | 268 | } |
kangmingyo | 2:e98408458d2b | 269 | |
mio | 0:f3f80a0695ff | 270 | // Data Read |
mio | 0:f3f80a0695ff | 271 | int ReadOneByte(void) |
mio | 0:f3f80a0695ff | 272 | { |
mio | 0:f3f80a0695ff | 273 | int result ; |
mio | 0:f3f80a0695ff | 274 | rclk = 1 ; |
mio | 0:f3f80a0695ff | 275 | // wait_us(1) ; |
mio | 0:f3f80a0695ff | 276 | result = data ; |
mio | 0:f3f80a0695ff | 277 | rclk = 0 ; |
mio | 0:f3f80a0695ff | 278 | return result ; |
mio | 0:f3f80a0695ff | 279 | } |
mio | 0:f3f80a0695ff | 280 | |
mio | 0:f3f80a0695ff | 281 | // Data Read (PortIn) |
kangmingyo | 4:7b63cf3d205f | 282 | int ReadOneWord(void) |
mio | 0:f3f80a0695ff | 283 | { |
kangmingyo | 2:e98408458d2b | 284 | // int r,r1,r2,r3,r4 ; |
kangmingyo | 2:e98408458d2b | 285 | // rclk = 1 ; |
kangmingyo | 2:e98408458d2b | 286 | // r = data ; |
kangmingyo | 2:e98408458d2b | 287 | // rclk = 0 ; |
kangmingyo | 2:e98408458d2b | 288 | // r1 = r & 0x07800000 ; |
kangmingyo | 2:e98408458d2b | 289 | // r1 = r1 >> (26-7-0) ; // bit26 to bit7 |
kangmingyo | 2:e98408458d2b | 290 | // r2 = r & 0x00078000 ; |
kangmingyo | 2:e98408458d2b | 291 | // r2 = r2 >> (18-3-0) ; // bit18 to bit3 |
kangmingyo | 2:e98408458d2b | 292 | // rclk = 1 ; |
kangmingyo | 2:e98408458d2b | 293 | // r = data ; |
kangmingyo | 2:e98408458d2b | 294 | // rclk = 0 ; |
kangmingyo | 2:e98408458d2b | 295 | // r3 = r & 0x07800000 ; |
kangmingyo | 2:e98408458d2b | 296 | // r3 = r3 >> (26-7-8) ; // bit26 to bit7 |
kangmingyo | 2:e98408458d2b | 297 | // r4 = r & 0x00078000 ; |
kangmingyo | 2:e98408458d2b | 298 | // r4 = r4 >> (18-3-8) ; // bit18 to bit3 |
kangmingyo | 2:e98408458d2b | 299 | |
kangmingyo | 2:e98408458d2b | 300 | int r,r1,r2; |
kangmingyo | 2:e98408458d2b | 301 | rclk=1; |
kangmingyo | 2:e98408458d2b | 302 | r = data; |
kangmingyo | 2:e98408458d2b | 303 | rclk=0; |
kangmingyo | 2:e98408458d2b | 304 | r1 = r<<8; |
kangmingyo | 2:e98408458d2b | 305 | rclk=1; |
kangmingyo | 2:e98408458d2b | 306 | r= data; |
kangmingyo | 2:e98408458d2b | 307 | rclk=0; |
kangmingyo | 2:e98408458d2b | 308 | r2 = r; |
kangmingyo | 2:e98408458d2b | 309 | |
kangmingyo | 2:e98408458d2b | 310 | |
kangmingyo | 2:e98408458d2b | 311 | return r2+r1 ; |
mio | 0:f3f80a0695ff | 312 | } |
kangmingyo | 2:e98408458d2b | 313 | |
mio | 0:f3f80a0695ff | 314 | // Data Start |
mio | 0:f3f80a0695ff | 315 | void ReadStart(void) |
kangmingyo | 2:e98408458d2b | 316 | { |
mio | 0:f3f80a0695ff | 317 | rrst = 0 ; |
mio | 0:f3f80a0695ff | 318 | oe = 0 ; |
mio | 0:f3f80a0695ff | 319 | wait_us(1) ; |
mio | 0:f3f80a0695ff | 320 | rclk = 0 ; |
mio | 0:f3f80a0695ff | 321 | wait_us(1) ; |
mio | 0:f3f80a0695ff | 322 | rclk = 1 ; |
kangmingyo | 2:e98408458d2b | 323 | wait_us(1) ; |
mio | 0:f3f80a0695ff | 324 | rrst = 1 ; |
mio | 0:f3f80a0695ff | 325 | } |
kangmingyo | 2:e98408458d2b | 326 | |
mio | 0:f3f80a0695ff | 327 | // Data Stop |
mio | 0:f3f80a0695ff | 328 | void ReadStop(void) |
mio | 0:f3f80a0695ff | 329 | { |
mio | 0:f3f80a0695ff | 330 | oe = 1 ; |
mio | 0:f3f80a0695ff | 331 | ReadOneByte() ; |
mio | 0:f3f80a0695ff | 332 | rclk = 1 ; |
mio | 0:f3f80a0695ff | 333 | } |
mio | 0:f3f80a0695ff | 334 | }; |