Перейти к содержанию

опросить магнетометр на stm32f3descovery


Рекомендуемые сообщения

Не могу опросить магнитометр по I2C. На линиях какие-то сигналы проскакивают, но никакого результата не могу достичь. Кто-то что-то знает по этому поводу? Как заставить работать его.



 

#include "stm32f30x.h"

            
int a1=0, j=0;
int main(void)
{
RCC->AHBENR|=RCC_AHBENR_GPIOBEN;// тактирование портa B включено
RCC->AHBENR|=RCC_AHBENR_GPIOEEN;//21 тактирование портa Е включено
RCC->APB1ENR|=RCC_APB1ENR_I2C1EN;// тактирование I2C1 включено


GPIOB->MODER|=0x0000A000; // альтернативная функция линий PB7,PB6
GPIOB->OTYPER|=(1<<6);  //настройка линии PB7 на выход открытый сток
GPIOB->OTYPER|=(1<<7);  //настройка линии PB6 на выход открытый сток
GPIOB->OSPEEDR=0xFFFFFFFF;
GPIOB->AFR[0] |= 0x44000000;  //настройка линий PB7,PB6 на функцию AF4


GPIOE->MODER=0x55555555; //настройка порта Е на выход

EXTI->EMR=1<<23;
EXTI->IMR=1<<23;
NVIC_EnableIRQ(I2C1_EV_IRQn);

//инициализация I2C мастер
I2C1->CR1=(0<<0); //PE=0

I2C1->TIMINGR=(0x4<<28);//PRESC[3:0]: Timing prescaler
I2C1->TIMINGR=(0x8<<20);//SCLDEL[3:0]: Data setup time
I2C1->TIMINGR=(0x8<<16);//SDADEL[3:0]: Data hold time
I2C1->TIMINGR=(0xC3<<8);//SCLH[7:0]: SCL high period (master mode)
I2C1->TIMINGR=(0xC7<<0);//SCLL[7:0]: SCL low period (master mode)

I2C1->CR1=(0<<17);//для мастера = 0 NOSTRETCH: Clock stretching disable
I2C1->CR1=(1<<6);//TCIE: Transfer Complete interrupt enable
I2C1->CR1=(1<<2);//RXIE: RX Interrupt enable(RXNE)
I2C1->CR1=(1<<1);//TXIE: TX Interrupt enable(TXIS)
I2C1->CR2=(0<<11);//ADD10=0 -7 bits
I2C1->CR2=(0<<10);//RD_WRN=0 передача
I2C1->CR2=(1<<25);//AUTOEND
I2C1->CR1|=(1<<0); //PE=1

I2C1->CR2 = 0x03<<1;//adress 
I2C1->CR2|=1<<13;//start

??????

a1=I2C1->RXDR;




    while (1){
    //    I2C1->CR2|=1<<13;//start
        if((a1&0x1)>0)    GPIOE->ODR =1<<9;
        else            GPIOE->ODR =(0<<9);

        if((a1 & 0x2)>0)    GPIOE->ODR |=1<<10;
        else            GPIOE->ODR &= ~(1<<10);

        if((a1 & 0x4)>0)    GPIOE->ODR |=1<<11;
        else            GPIOE->ODR &= ~(1<<11);

        if((a1 & 0x8)>0)    GPIOE->ODR |=1<<12;
        else            GPIOE->ODR &= ~(1<<12);

        if((a1 & 0x10)>0)    GPIOE->ODR |=1<<13;
        else            GPIOE->ODR &= ~(1<<13);

        if((a1 & 0x20)>0)    GPIOE->ODR |=1<<14;
        else            GPIOE->ODR &= ~(1<<14);

        if((a1 & 0x40)>0)    GPIOE->ODR |=1<<15;
        else            GPIOE->ODR &= ~(1<<15);

        if((a1 & 0x80)>0)    GPIOE->ODR |=1<<8;
        else            GPIOE->ODR &= ~(1<<8);


}}

void I2C1_EV_EXTI23_IRQHandler () {a1=2;}

 

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

Присоединяйтесь к обсуждению

Вы публикуете как гость. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
  • Сообщения

    • @korsaj Сегодня попробовал сделать как ты посоветовал. Получился следующий код. #define F_CPU 7372800UL #define BAUND 9600L #define UBRRL_value (F_CPU/(BAUND*16))-1 #include <avr/io.h> #include <util/delay.h> #include <avr/interrupt.h> #include <stdlib.h> void init_pin(void); #define C_PC0 (~PINC&(1<<PC0)) #define C_PC1 (~PINC&(1<<PC1)) #define LED_1_ON() PORTD|=(1<<PD2) #define LED_1_OFF() PORTD&=~(1<<PD2) #define LED_2_ON() PORTD|=(1<<PD3) #define LED_2_OFF() PORTD&=~(1<<PD3) #define FLAG_END_RX (1<<3) #define FLAG_ERR_RX (1<<4) #define BUF_SIZE 20 char rx_buf[BUF_SIZE]; char buf_index = 0; volatile start=1, flags; char b; ISR(USART_RXC_vect) { b=UDR; if(!(flags & FLAG_END_RX)) { rx_buf[buf_index]=UDR; if(rx_buf[buf_index] == 0x0D) { flags |= FLAG_END_RX; return; } buf_index++; if(buf_index >= BUF_SIZE) { buf_index = 0; flags |= FLAG_ERR_RX; } } } void init_UART() { UBRRL = UBRRL_value; UBRRH = UBRRL_value>>8; UCSRB|=(1<<TXEN); UCSRB|=(1<<RXEN); UCSRC|=((1<<URSEL)|(1<<UCSZ0)|(1<<UCSZ1)); UCSRB|=(1<<RXCIE); sei(); flags = 0; } void send_UART(char value) { while(!(UCSRA&(1<<UDRE))); UDR=value; } int main(void) { init_pin(); init_UART(); while(1) { if (start==1) { _delay_ms(500); send_UART('O'); send_UART('K'); send_UART('!'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); start=0; } if (b == '0') { LED_1_ON(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '1') { LED_1_OFF(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '2') { LED_1_ON(); LED_2_ON(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('2'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (b == '3') { LED_1_OFF(); LED_2_OFF(); send_UART('N'); send_UART('+'); send_UART('0'); send_UART('3'); send_UART(0x0D); send_UART(0x0A); _delay_ms(10); b=4; } if (C_PC0) { send_UART('P'); send_UART('C'); send_UART('0'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } if (C_PC1) { send_UART('P'); send_UART('C'); send_UART('1'); send_UART(0x0D); send_UART(0x0A); _delay_ms(250); } } } void init_pin(void) { DDRC = 0b00000000; PORTC = 0b11111111; DDRD |= ((1<<2)|(1<<3)); PORTD &=~ ((1<<2)|(1<<3)); } Ну как сказать всё работает, но вот меня очень интересует приём команд на саму ATMEGA16. Он так и работает только с цифрами. Более ничего корректно принять не получается даже используя таблицу ascii. А мне нужно будет принимать команды и посложней чем просто буквенно - цифровые. Потому как возвращаясь к командам самого плеера там в этих командах хранятся различные данные. Вот примерно так это всё выглядит. AT+QM \ r \ n Запрос режима работы [0: Bluetooth], [1: MP3] AT+M1 \ r \ n Номер текущего файла AT+M2 \ r \ n Общее количество звуковых файлов AT+MD \ r \ n Источник музыки USB или SD Card AT+MT \ r \ n Общее время воспроизведения текущего файла AT+MK \ r \ n Время воспроизведения текущего файла AT+MP \ r \ n Текущее состояние плеера [0]Стоп, [1]Воспроизведение, [2]Пауза К примеру при отправке команды AT+M1 \ r \ n в ответ мы получим M1 + 000002 \ r \ n при этом здесь может быть любое число в hex формате. Мне же нужно каким то образом принять эти данные и обработать их соответствующим образом. Но при этом и нужно учитывать так же что плеер может сам отправить эти данные по началу воспроизведения трека. Вот в этом сейчас и стоит основная задача. Чего я и пытаюсь получить в итоге.
    • Ну тогда дорога к сименсу в гости - они вам какой-нибудь Desigo CC или даже Siematic предложат, тыщ за 10 долларов. Ну и ещё тыщ 5 надо будет отдать за контроллеры и их конфигурирование.   А если попроще - то можно к отечественным MasterSCADA обратиться, либо к WiredBoard - у них не совсем SCADA система, но нормальные контроллеры, довольно просто настраиваются и можно графическую оболочку рисовать.
    • тогда вы имеете то, что имеете, и никак от этого не избавиться. Хоть святой водой окропите. "Или трусы или крестик" (с) Нагрузки у вас немаленькие. Вы же с нуля переделываете, снова некуда ? Понятие LowESR очень неконкретное. Сколько вешать в граммах ? пустая трата времени
    • Да все это туфта, выеденного яйца не стоит. В общем чушь собачья. На мониторе тему уже сплавили в мусорку, а здесь треп еще будет на 10 страницах. Все камеры, их у него было три, исправные. Записывают отлично. А дальше вся проблема в этом. Особо интересно - монтажник видео.
    • 1. А это как определяется?  Так пробовали на другом смотреть? 2. Так как всё-таки смотрели - напрямую с камеры или "Копирование файлов на компьютер ничего не меняет по сравнению с просмотром с камеры напрямую"?
    • Может быть повторюсь, но - самому впаивать в имеющую схему радиодетали не имею желания, хочется узнать - может есть в природе плата, которую необходимо будет просто приобрести и  расключить правильно? Я так понимаю один канал надо инвертировать, но чем. Вопрос только в этом
  • Похожий контент

×
×
  • Создать...