реклама на сайте
подробности

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> 23k256, как использовать эту ram
jcxz
сообщение Apr 15 2015, 02:23
Сообщение #16


Гуру
******

Группа: Свой
Сообщений: 5 228
Регистрация: 3-07-08
Из: Омск
Пользователь №: 38 713



Не знаю какие у вас там синяки, но я вроде ясно написал выше: повесьте хотя-бы светодиоды на все линии (CS, SCLK, MOSI, MISO) и по шагам отладьте.
Если уж и это непонятно, то и не знаю как ещё советовать.
Go to the top of the page
 
+Quote Post
jukebox
сообщение Apr 15 2015, 20:04
Сообщение #17


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 12-03-15
Пользователь №: 85 618



Цитата(jcxz @ Apr 15 2015, 02:23) *
Не знаю какие у вас там синяки, но я вроде ясно написал выше: повесьте хотя-бы светодиоды на все линии (CS, SCLK, MOSI, MISO) и по шагам отладьте.
Если уж и это непонятно, то и не знаю как ещё советовать.


Да понятно, чего тут может быть непонятного.Куплю подходящий контроллер и дожму эту озу.
Go to the top of the page
 
+Quote Post
jukebox
сообщение Jul 15 2015, 19:30
Сообщение #18


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 12-03-15
Пользователь №: 85 618



Цитата(jukebox @ Apr 15 2015, 21:04) *
Да понятно, чего тут может быть непонятного.Куплю подходящий контроллер и дожму эту озу.


Ну чтож, все оказалось просто.
Принцип следующий :
CS = 0
0х1
opcode (byte,page,sequential)
CS =1
---
CS = 0
0х2 ; запись
adr
adr
data
CS = 1
---====

CS = 0
0х3 ; чтение
adr
adr
8 impulses CLK ; на MISO появл data
CS = 1
Go to the top of the page
 
+Quote Post
ostroukhovio
сообщение Jan 19 2017, 12:52
Сообщение #19





Группа: Новичок
Сообщений: 1
Регистрация: 19-01-17
Пользователь №: 95 070



Всем привет. Тоже начал знакомство с этой микросхемой на XMega128A1. Потыкал осциллографом при попытках чтения SPI и тактируется по CLK и данные идут из MOSI но ответа от чипа нет.
Вот код для SRAM.
Код
/*Привязка к линиям микроконтроллера*/
#define SRAM_SPI SPIC //Регистр SPI
#define SRAM_PORT PORTC //PORT SPI
#define SRAM_CS_PORT PORTC //Доступ к чипу
#define SRAM_CS_PIN 3
#define SRAM_HOLD_PORT PORTC //Запрет записи
#define SRAM_HOLD_PIN 4
#define SRAM_MOSI_PORT PORTC //MOSI
#define SRAM_MOSI_PIN 5
#define SRAM_MISO_PORT PORTC //MISO
#define SRAM_MISO_PIN 6
#define SRAM_SCK_PORT PORTC //SCK
#define SRAM_SCK_PIN 7


void SRAM_Init(void){
    SRAM_SPI.DATA = 0;
    SRAM_PORT.DIR &= ~(1 << SRAM_MISO_PIN);
    SRAM_PORT.DIR |= (1 << SRAM_HOLD_PIN) | (1 << SRAM_MOSI_PIN) | (1 << SRAM_SCK_PIN) | (1 << SRAM_CS_PIN);
    SRAM_SPI.CTRL = SPI_ENABLE_bm | SPI_MASTER_bm | SPI_MODE_0_gc | SPI_PRESCALER_DIV128_gc;
    SRAM_HOLD_PORT.OUT |= (1 << SRAM_HOLD_PIN);
    SRAM_CS_PORT.OUT &= ~(1 << SRAM_CS_PIN);
    _delay_us(1);
    SRAM_SPI.DATA = 0x1;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = 0x0;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_CS_PORT.OUT |= (1 << SRAM_CS_PIN);
}
uint8_t SRAM_Write(uint16_t addr, uint8_t data){
    SRAM_CS_PORT.OUT &= ~(1 << SRAM_CS_PIN);
    _delay_us(1);
    SRAM_SPI.DATA = 0x2;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = addr >> 8;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = addr & 0xFF;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = data;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_CS_PORT.OUT |= (1 << SRAM_CS_PIN);
    return SPIC.DATA;
}
uint8_t SRAM_Read(uint16_t addr){
    SRAM_CS_PORT.OUT &= ~(1 << SRAM_CS_PIN);
    _delay_us(1);
    SRAM_SPI.DATA = 3;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = addr >> 8;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_SPI.DATA = addr & 0xFF;
    while(!(SPIC.STATUS & (1<<7)));
    SRAM_CS_PORT.OUT |= (1 << SRAM_CS_PIN);
    return SRAM_SPI.DATA;
    
}


Кто хорошо знаком с данным чипом, помогите пожалуйста.
Go to the top of the page
 
+Quote Post
k155la3
сообщение Jan 19 2017, 16:43
Сообщение #20


Профессионал
*****

Группа: Свой
Сообщений: 1 123
Регистрация: 8-03-09
Из: Днепр
Пользователь №: 45 848



Цитата(ostroukhovio @ Jan 19 2017, 15:52) *
Всем привет. Тоже начал знакомство с этой микросхемой на XMega128A1. Потыкал осциллографом при попытках чтения SPI и тактируется по CLK и данные идут из MOSI но ответа от чипа нет.
. . .
Кто хорошо знаком с данным чипом, помогите пожалуйста.

Юзал я давненько этот девайс но на на XMmega а на MSP430.
Оно как-то "завелось" сразу, даже и воспоминаний не осталось.
0. Проверьте аппаратную часть (разводка-подключение, обрывы и сопли, питание, отсутствие помех итд )
1. Проверьте что настройки SPI процессора (полярность и фаза) соотв-ют требуемым для 23k256
2. Возможно что причина - в некорректной работе приемника SPI процессора из-за настроек
или в софте драйвера, обеспечивающего работу узла SPI. Для начала отключите 23k256 от
SPI и соедините MOSI - MISO. Проверите и правильность "улета" и "прилета" по SPI.
3. Как ОНО работает - подробнейшим образом расписано выше.

ps - эти мс есть на разное питание. Проверьте соотв-ие.


Сообщение отредактировал k155la3 - Jan 19 2017, 16:45
Go to the top of the page
 
+Quote Post
jukebox
сообщение May 22 2017, 10:14
Сообщение #21


Участник
*

Группа: Участник
Сообщений: 15
Регистрация: 12-03-15
Пользователь №: 85 618



Кто хорошо знаком с данным чипом, помогите пожалуйста.
[/quote]


ostroukhovio вы ввели два байта адреса для считывания, и не продолжили вводить третий байт (пустой), во время введения которого из озу исходит байт данных.
Адрес для теста лучше писать первый байт 0, второй (младший) - какой то до 10.Так проще.

Сообщение отредактировал jukebox - May 22 2017, 10:37
Go to the top of the page
 
+Quote Post

2 страниц V  < 1 2
Reply to this topicStart new topic
2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 18th July 2025 - 20:22
Рейтинг@Mail.ru


Страница сгенерированна за 0.01396 секунд с 7
ELECTRONIX ©2004-2016