bl_mcu_sdk/examples/peripherals/cam/cam_int/main.c
jzlv 356f258e83 [sync] sync from internal repo
* use nuttx libc, disable system libc
* use tlsf as default
* update lhal flash driver
* add example readme
* add flash ini for new flash tool
* add fw header for new flash tool
2023-01-17 21:04:07 +08:00

73 lines
1.9 KiB
C

#include "bflb_mtimer.h"
#include "bflb_i2c.h"
#include "bflb_cam.h"
#include "image_sensor.h"
#include "board.h"
#define CAM_FRAME_COUNT_USE 50
static struct bflb_device_s *i2c0;
static struct bflb_device_s *cam0;
static volatile uint32_t cam_int_cnt = 0, pic_size;
static uint8_t *pic;
void cam_isr(int irq, void *arg)
{
bflb_cam_int_clear(cam0, CAM_INTCLR_NORMAL);
cam_int_cnt++;
pic_size = bflb_cam_get_frame_info(cam0, &pic);
bflb_cam_pop_one_frame(cam0);
printf("CAM interrupt, pop picture %d: 0x%08x, len: %d\r\n", cam_int_cnt, (uint32_t)pic, pic_size);
}
int main(void)
{
uint32_t i;
struct bflb_cam_config_s cam_config;
struct image_sensor_config_s *sensor_config;
board_init();
board_dvp_gpio_init();
i2c0 = bflb_device_get_by_name("i2c0");
cam0 = bflb_device_get_by_name("cam0");
if (image_sensor_scan(i2c0, &sensor_config)) {
printf("\r\nSensor name: %s\r\n", sensor_config->name);
} else {
printf("\r\nError! Can't identify sensor!\r\n");
while (1) {
}
}
bflb_cam_int_mask(cam0, CAM_INTMASK_NORMAL, false);
bflb_irq_attach(cam0->irq_num, cam_isr, NULL);
bflb_irq_enable(cam0->irq_num);
memcpy(&cam_config, sensor_config, IMAGE_SENSOR_INFO_COPY_SIZE);
cam_config.with_mjpeg = false;
cam_config.input_source = CAM_INPUT_SOURCE_DVP;
cam_config.output_format = CAM_OUTPUT_FORMAT_AUTO;
cam_config.output_bufaddr = BFLB_PSRAM_BASE;
cam_config.output_bufsize = cam_config.resolution_x * cam_config.resolution_y * 12;
bflb_cam_init(cam0, &cam_config);
bflb_cam_start(cam0);
while (cam_int_cnt < CAM_FRAME_COUNT_USE) {
}
bflb_cam_stop(cam0);
//for (i = 0; i < pic_size; i++) {
// printf("%02x", pic[i]);
//}
//printf("\r\n");
printf("end\r\n");
while (1) {
bflb_mtimer_delay_ms(1000);
}
}