Writing driver, produce external clock signal?

This forum is for supported devices using an ARMv7 Texas Instruments (TI) SoC.

Writing driver, produce external clock signal?

Postby pgib8 » Mon Mar 02, 2015 11:36 pm

Hi, I'm trying to write a camera driver. I need to provide a clock to the camera and I'm not sure how to do this.
I tried something like this:
$this->bbcode_second_pass_code('', 'my_xclk = clk_get(NULL, "cam_xclk");
clk_enable(my_xclk);')
(Error checking is in the original code)

I'm missing a link between this code and an actual pin, or is the clk struct already tied to a pin?
Btw. I'm using Gumstix Overo EarthSTORM and the pin I want to use is c25 (CAM_XCLKA).

Maybe someone knows a little about this and can point me into the right direction?
pgib8
 
Posts: 2
Joined: Mon Mar 02, 2015 11:21 pm

Re: Writing driver, produce external clock signal?

Postby 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;
}
')
pgib8
 
Posts: 2
Joined: Mon Mar 02, 2015 11:21 pm


Return to Texas Instruments (TI)

Who is online

Users browsing this forum: No registered users and 5 guests