 by pgib8 » Fri Mar 06, 2015 10:16 pm
by pgib8 » Fri Mar 06, 2015 10:16 pm 
			
			So it literally took me 30 hours to get a simple clock output from the ISP.
I was originally trying to work with what Linux had to offer but it turned into a nightmare. I cut through the red tape by controlling the registers directly. This is my starting point for writing a camera driver for the OV2640, and again, this is for the Gumstix Overo EarthSTORM with AM3703 processor.
$this->bbcode_second_pass_code('', '
// Processor AM3703 (AM/DM37x Multimedia Device)
// Enable clock output for camera (XCLK) on pin C25 (cam_xclka)
static void __iomem* my_io;
int init_module(void) {
 unsigned int i;
 //Step 1: Configure pin-mux to use cam_xclka function (as opposed to gpio_96).
 my_io = ioremap(0x48002110, SZ_1);
 i = ioread32(my_io);
 i &= ~(0xffff0000); //CONTROL_PADCONF_CAM_XCLKA[15:0]
 iowrite32(i, my_io);
 //Step 2: Enable clocks and power of the ISP (Image Signal Processor).
 my_io = ioremap(0x48004F10, SZ_1);
 iowrite32(0x01, my_io); //enable L3/L4 interconnect clocks for camera interface.
 my_io = ioremap(0x48004F48, SZ_1);
 iowrite32(0x02, my_io); //wake-up transition for camera clock domain.
 my_io = ioremap(0x48306FE0, SZ_1);
 iowrite32(0x30107, my_io);  //turn on power to camera core domain
 //Step 3: Configure CAM_MCLK which comes from DPLL4 M5.
 my_io = ioremap(0x48004F40, SZ_1);
 iowrite32(0x1E, my_io); //CAM_MCLK is DPLL4 clock divided by 30
 my_io = ioremap(0x48004D00, SZ_1);
 i = ioread32(my_io);
 i &= ~(1 << 30);        //power-up DPLL4_M5_CLK
 iowrite32(i, my_io);
 my_io = ioremap(0x48004F00, SZ_1);
 iowrite32(0x01, my_io); //enable CAM_MCLK
 //Step 4: Turn on cam_xclka
 my_io = ioremap(0x480BC050, SZ_1);
 i = ioread32(my_io);
 i &= ~0x0000001F;  //clear DIVA[4:0] (xclka divisor)
 i |= 0x1E;         //set DIVA, cam_xclka = CAM_MCLK divided by 30
 iowrite32(i, my_io);
 //Note: DIVB[9:5] can be used to turn on cam_xclkb.
 //Note: On my system the clock came out at 7.2MHz
 return 0;
}
')