Forum Discussion

Altera_Forum's avatar
Altera_Forum
Icon for Honored Contributor rankHonored Contributor
16 years ago

Frame Reader Initialization

Hello,

I want to implement a Frame Reader which should read data from memory and send its AVALON Video protocol to an alpha blending mixer. My clocked video output settings for PAL are:

Image Width/Active pixels: 720

Image Height/Active lines: 576

Bits per Pixel per color planes: 8

Color plane transmission format: sequence

Interlaced Video

Pixel fifo size: 720

Fifo Level at which to start output: 719

Video in and out use the same Clock

Use control port

Sync signals: Embedded in video

Active picture line: 23

Horizontal blanking: 24

F rising edge line: 313

F falling edge line: 1

Vertical blanking rising edge line: 311

Vertical blanking: 25

I have written the value 128 to all corresponding addresses of the ram. For test purposes I am using the onchip ram for this. The RAM has two masters, the NIOS II and the frame reader. The settings of the frame reader are:

Bits per pixel per color plane: 8

Number of color planes in parallel: 1

Number of color planes in sequence: 2

Maximum Image width: 40

Maximum Image height: 40

Master port width: 64

Read master FIFO depth: 64

Read master FIFO burst target: 32

Use separate clock for the Avalon MM master interface: unchecked

(The data-width of the onchip RAM is 64.)

For initialisation of the frame reader I have written the following function which is called in once the main function of my NIOS II software:

void initFrameReader()

{

alt_printf("Initialize Frame Reader.\r\n");

// start Frame Reader

IOWR(FRAMEREADER_BASE, 0, 1);

// Frame Select

IOWR(FRAMEREADER_BASE, 3, 0);

// Frame 0 Base Address

IOWR(FRAMEREADER_BASE, 4, ONCHIP_MEM_BASE);

// Frame 0 Words

IOWR(FRAMEREADER_BASE, 5, 800); // 40*40 / ( 64/(8*4) ) = 800

// Frame 0 Single Cycle Color Patterns

IOWR(FRAMEREADER_BASE, 6, 6400); // 40*40*4 number of pixels in the frame multiplied by the number of single cycles required to represent one pixel

// Frame 0 Reserved

// IOWR(FRAMEREADER_BASE, 7, 0); // reserved for future use ?

// Frame 0 Width

IOWR(FRAMEREADER_BASE, 8, 40);

// Frame 0 Height

IOWR(FRAMEREADER_BASE, 9, 40);

// Frame 0 Interlaced

IOWR(FRAMEREADER_BASE, 10, 8); // See VIP Processing Suite - Table 4-4

}

But as soon as I Activate the Layer the Frame Reader corresponds to, I do not get a valid picture. Even if I deactivate it on runtime, it does not get a valid picture anymore. I have to reset the cpu to get the alpha blending mixer get work again (with frame reader layer deactivated).

What could be the problem? I have double-checked the BSP-Editor, none of my program memory addresses are placed on the onchip-mem. Could it be an arbitration problem? As far as I know the arbitration of the sopc-builder is round-robin and only requesting masters are included in the arbitration. But I am not writing data to the onchip memory while the frame reader is reading data from the RAM.

Could someone double-check the initialisation settings of the frame reader? Did I miss something, or did I missunderstand anything?

I would be pleased if anyone can helb me.

21 Replies

  • Altera_Forum's avatar
    Altera_Forum
    Icon for Honored Contributor rankHonored Contributor

    Hello, your post is very usful.

    I want to implement a Frame Reader which should read vide frames data from SDRAM and send its AVALON Video protocol to an Clocked video output ip to be displayed on a screen.The setting of the frame reader is :

    Bits per pixel per color plane: 8

    Number of color planes in parallel: 3

    Number of color planes in sequence: 1

    Maximum Image width: 800

    Maximum Image height: 600

    Master port width: 32

    Read master FIFO depth=Read master FIFO burst target: 64

    Use separate clock for the Avalon MM master interface: unchecked

    and read the frames from 2 memory locations.I will use the interrupt register to prevent the data lost and indicat the frame completion.

    At the begining of the siftware , i reset this register . but when reading it the interrupt register read 0 not 1.

    Is there any wrong in my software which is attached below.

    Kindly advise . Your reply will be highly appreciated.Waiting your reply ASAP

    while(1)

    {

    alt_u32 a , interrupt , Frame0_Select , Frame0_Base_Address , Frame_0_Words , Frame_0_Single_Cycle , Frame_0_Reserved , Frame_0_width , Frame_0_height , Frame_0_progressive , Frame_0_start;

    //master port width =32(R0 byte,B0 byte,G0 byte,empty byte)

    IOWR(ALT_VIP_VFR_0_BASE, 2, 2); // reset the interrupt???????

    interrupt=IORD(ALT_VIP_VFR_0_BASE, 2);// it always red 0??????

    IOWR(ALT_VIP_VFR_0_BASE, 3, 0); // Frame0 Select

    Frame0_Select=IORD(ALT_VIP_VFR_0_BASE, 3);

    IOWR(ALT_VIP_VFR_0_BASE, 4, ALTMEMDDR_BASE);

    // Frame 0 Base Address

    Frame0_Base_Address=IORD(ALT_VIP_VFR_0_BASE, 4);

    IOWR(ALT_VIP_VFR_0_BASE, 5, 480000);

    // Frame 0 Words => (640*480*3*8)/24

    Frame_0_Words=IORD(ALT_VIP_VFR_0_BASE, 5);

    printf("Frame 0 Words\n");

    IOWR(ALT_VIP_VFR_0_BASE, 6, 480000);//Frame0Single Cycle Color Patterns

    Frame_0_Single_Cycle=IORD(ALT_VIP_VFR_0_BASE, 6);

    printf("Frame 0 Single Cycle Color Patterns\n");

    IOWR(ALT_VIP_VFR_0_BASE, 7, 0); // Frame 0 Reserved Bit

    Frame_0_Reserved=IORD(ALT_VIP_VFR_0_BASE, 7);

    printf("Frame 0 Reserved Bit\n");

    IOWR(ALT_VIP_VFR_0_BASE, 8, 800);

    Frame_0_width=IORD(ALT_VIP_VFR_0_BASE, 8);

    printf("frame 0 Width\n");

    IOWR(ALT_VIP_VFR_0_BASE, 9, 600);// Frame 0 Height

    Frame_0_height=IORD(ALT_VIP_VFR_0_BASE,9);

    IOWR(ALT_VIP_VFR_0_BASE, 10, 3); // Frame 0 Interlaced => 3 = 0011

    Frame_0_progressive=IORD(ALT_VIP_VFR_0_BASE, 10);

    IOWR(ALT_VIP_VFR_0_BASE, 0, 1); //start reading

    Frame_0_start=IORD(ALT_VIP_VFR_0_BASE, 0);

    IOWR(ALT_VIP_VFR_0_BASE, 2, 2);// reset the interrupt

    a=IORD(ALT_VIP_VFR_0_BASE, 2);

    while (a&&0x02==1)

    {

    a=IORD(ALT_VIP_VFR_0_BASE, 2);

    }

    IOWR(ALT_VIP_VFR_0_BASE, 2, 2); // reset the interrupt

    IOWR(ALT_VIP_VFR_0_BASE, 3, 1);// Frame1 Select

    IOWR(ALT_VIP_VFR_0_BASE,11,ALTMEMDDR_BASE+0xE1000);//Frame address

    IOWR(ALT_VIP_VFR_0_BASE, 12, 480000);// Frame 1 Words

    IOWR(ALT_VIP_VFR_0_BASE, 13, 480000); // Frame 1Single Cycle Color

    IOWR(ALT_VIP_VFR_0_BASE, 14, 0);// Frame 1Reserved Bit

    IOWR(ALT_VIP_VFR_0_BASE, 15, 800);// Frame 1 Width

    IOWR(ALT_VIP_VFR_0_BASE, 16, 600); // Frame 1 Height

    IOWR(ALT_VIP_VFR_0_BASE, 17, 3);// Frame 1 progressive=> 3

    IOWR(ALT_VIP_VFR_0_BASE, 0, 1);//start reading

    IORD(ALT_VIP_VFR_0_BASE, 2);//read the interrupt register

    a=IORD(ALT_VIP_VFR_0_BASE, 2);

    while (a&&0x02==1)

    {

    a=IORD(ALT_VIP_VFR_0_BASE, 2);

    }

    } 

    }