User Tools

Site Tools


chumbyhackerboard:vga

Link to this comparison view

Next revision
Previous revision
chumbyhackerboard:vga [2010/09/21 04:00]
ladyada created
chumbyhackerboard:vga [2016/01/28 18:05] (current)
Line 4: Line 4:
 use 278 & 556 ohm resistors for the R2R ladder, this will give you ~0.7v signal when plugged into a 75 ohm termination such as a monitor. ​ use 278 & 556 ohm resistors for the R2R ladder, this will give you ~0.7v signal when plugged into a 75 ohm termination such as a monitor. ​
  
-====== VSync ====== 
  
-We want to get the Vsync to about 60hz 
  
-By default, the '​internal'​ LCD sync rate is 117 Hz +====== Horizontal Sync HW_LCDIF_VDCTRL2======
-<​code>​ +
-chumby-:/ # cat /​proc/​driver/​chumbyfwfb/​fb_stats +
-PXP frequency: ​         59 Hz +
-LCDIF frequency: ​       117 Hz +
-VSYNC Edge IRQs:        49077 +
-Cur Frame Done IRQs:    49224 +
-Missed PXP firings: ​    5 +
-</​code>​+
  
-This is set by the  HW_CLKCTRL_PIX register+For the LCD, this is by default = 0x45000190
  
-<​code>​ +We want...
-chumby-:/ # regutil -r HW_CLKCTRL_PIX +
-Value at 0x80040060: 0x0000001d +
-</​code>​+
  
-Lets divide the frequency by 2 which means multiplying the divider by two+  * Per horizontal line: 640 pixels 
 +  * Front porch: 16 pixels 
 +  * Sync pulse width: 96 pixels 
 +  * Back porch: 48 pixels
  
-<​code>​ +SO!
-chumby-:/ # regutil -w HW_CLKCTRL_PIX=0x38 +
-Setting 0x80040060: 0x0000000e -> 0x00000038 ok +
-</​code>​+
  
-<code> +HW_LCDIF_VDCTRL2 = (96) << 24 | (640 + 16 + 96+ 48) = 0x60000320 
-chumby-:/ # cat /​proc/​driver/​chumbyfwfb/​fb_stats + 
-PXP frequency: ​         32 Hz +====== Vsync HW_LCDIF_VDCTRL1 ====== 
-LCDIF frequency       62 Hz + 
-VSYNC Edge IRQs       69919 +For the LCD, this is by default = 0x0000011a (dec. 282) 
-Cur Frame Done IRQs   70118 + 
-Missed PXP firings    5 +We want... 
-</code>+ 
 +  * Per vertical line480 horizontal lines 
 +  * Front porch11 horizontal lines 
 +  * Sync pulse2 horizontal lines 
 +  * back porch31 horizontal lines 
 + 
 +so HW_LCDIF_VDCTRL1 = 524 (0x20C) 
 + 
 +====== HW_LCDIF_VDCTRL0 ====== 
 + 
 +<file> 
 +VSYNC_OEB = 0 (generate vsync) 
 +ENABLE_PRESENT = 0 (no enable necessary) 
 +0x0 
 + 
 +VSYNC_POL = 0 (negative sync!) 
 +HSYNC_POL = 0 (negative sync!) 
 +DOTCLK_POL = D/
 +ENABLE_POL = D/C 
 +0x0 
 + 
 +VSYNC_PERIOD_UNIT = 1 (count in lines) 
 +VSYNC_PULSE_WIDTH_UNIT = 1 (count in lines) 
 +0x3 
 + 
 +HALF_LINE = 0  
 +HALF_LINE_MODE = 1 (no half line for vga, right?) 
 +0x4 
 + 
 +VSYNC_PULSE_WIDTH = 2  
 +0x2 
 +</file> 
 + 
 +-> 0x00340002 
 + 
 +====== HW_LCDIF_VDCTRL3 ====== 
 +by default = 0x004b0027 
 + 
 +  * MUX_SYNC_SIGNALS = 0 
 +  * VSYNC_ONLY = 1 (?) 
 +  * HORIZONTAL_WAIT_CNT = 48 (h back porch) + 96 (sync pulse) = 0xDE and then  
 +  * VERTICAL_WAIT_CNT = 31 (v back porch) + 2 (sync pulse) = 0x21 
 + 
 +-> 0x00DE0021 
 + 
 +====== HW_LCDIF_TRANSFER_COUNT ====== 
 +By default, (32x0x240 LCD) =  0x00f00140 
 + 
 +For 640x480 VGA it should be = 0x01E00280 
 + 
 +====== HW_CLKCTRL_PIX ====== 
 + 
 +So the main clock is 454 right? 
 + 
 +To get a pixel clock of 25.175 MHz, 454 MHz / 18 -> DIV = 0x12 
 +CLKGATE = 0 
 +DIV = 0x12 -> CLK of 21 Mhz 
 + 
 +Hmm, guess our chip isnt running at 454? Or is it our scope? Try 0x0F for 25MHz  which matches with eveything else. Which means we're running at 375MHz? 
 + 
 +===== Results? ===== 
 +PIXCLK = 0x0F 
 + 
 +HSync = 31.3Khz (should be 31.46) 
 + 
 +Vsync = 59.75 Hz (should be 60.04) 
 + 
 +Vsync negative pulse = 63.9 uS (should be 63.57) (it is low from the negative edge of one HSync to another negative Hsync edge) 
 + 
 +Hsync negative pulse = 3.83 uS (should be 3.81) 
 + 
 +HSync Back porch = 5 uS (should be 1.9?), Hsync front porch = ~14.2uS (should be 0.9?)
/home/ladyada/public_html/wiki/data/attic/chumbyhackerboard/vga.1285041631.txt.gz · Last modified: 2016/01/28 18:05 (external edit)