int i;
for (i = 0; i < 10; i++) {
- ao_spi_get(0);
+ ao_spi_get(0, AO_SPI_SPEED_FAST);
stm_gpio_set(&stm_gpioc, 12, 0);
ao_spi_send(data, 4, 0);
stm_gpio_set(&stm_gpioc, 12, 1);
int i;
for (i = 0; i < 10; i++) {
- ao_spi_get(0);
+ ao_spi_get(0, AO_SPI_SPEED_FAST);
stm_gpio_set(&stm_gpioc, 12, 0);
ao_spi_recv(data, 4, 0);
stm_gpio_set(&stm_gpioc, 12, 1);
}
}
+static void
+ao_i2c_write(void) {
+ unsigned char data[] = { 0x55, 0xaa, 0xff, 0x00 };
+ int i;
+ for (i = 0; i < 10; i++) {
+ ao_i2c_get(0);
+ if (ao_i2c_start(0, 0x55))
+ ao_i2c_send(data, 4, 0, TRUE);
+ else {
+ printf ("i2c start failed\n");
+ ao_i2c_put(0);
+ break;
+ }
+ ao_i2c_put(0);
+ printf(".");
+ flush();
+ ao_delay(100);
+ }
+}
static void
ao_temp (void)
{
- struct ao_adc adc;
+ struct ao_data packet;
int temp;
- ao_adc_get(&adc);
+ ao_data_get(&packet);
/*
* r = (110 - 25) / (ts_cal_hot - ts_cal_cold)
* 25 + (110 - 25) * (temp - ts_cal_cold) / (ts_cal_hot - ts_cal_cold)
*/
- temp = 25 + (110 - 25) * (adc.temp - stm_temp_cal.ts_cal_cold) / (stm_temp_cal.ts_cal_hot - stm_temp_cal.ts_cal_cold);
+ temp = 25 + (110 - 25) * (packet.adc.temp - stm_temp_cal.ts_cal_cold) / (stm_temp_cal.ts_cal_hot - stm_temp_cal.ts_cal_cold);
printf ("temp: %d\n", temp);
}
{ ao_dma_test, "D\0DMA test" },
{ ao_spi_write, "W\0SPI write" },
{ ao_spi_read, "R\0SPI read" },
+ { ao_i2c_write, "i\0I2C write" },
{ ao_temp, "t\0Show temp" },
{ 0, NULL }
};
ao_timer_init();
ao_dma_init();
ao_cmd_init();
-// ao_lcd_stm_init();
+ ao_lcd_stm_init();
// ao_lcd_font_init();
ao_spi_init();
+ ao_i2c_init();
ao_timer_set_adc_interval(100);
ao_adc_init();
+ ao_usb_init();
ao_cmd_register(&ao_demo_cmds[0]);