OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [orpsocv2/] [sw/] [drivers/] [simple-spi/] [simple-spi.c] - Diff between revs 485 and 505

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 485 Rev 505
Line 7... Line 7...
 
 
#include "board.h"
#include "board.h"
#include "simple-spi.h"
#include "simple-spi.h"
#include "cpu-utils.h"
#include "cpu-utils.h"
 
 
 
#ifdef SPI_NUM_CORES
const int spi_base_adr[1] = {
const int SPI_BASE_ADR[SPI_NUM_CORES] = {SPI_BASE_ADDRESSES_CSV};
 
#else
 
// For older builds - need to change them all over to newer format
#ifdef SPI0_BASE
#ifdef SPI0_BASE
        SPI0_BASE
const int SPI_BASE_ADR[1] = {SPI0_BASE};
#else
#else
        0
// No SPI present
 
const int SPI_BASE_ADR[1] = {-1};
#endif
#endif
};
#endif
 
 
 
 
void
void
spi_core_enable(int core)
spi_core_enable(int core)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPCR)) |= SIMPLESPI_SPCR_SPE;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR)) |= SIMPLESPI_SPCR_SPE;
}
}
 
 
void
void
spi_core_disable(int core)
spi_core_disable(int core)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPCR)) &= ~SIMPLESPI_SPCR_SPE;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR)) &= ~SIMPLESPI_SPCR_SPE;
}
}
 
 
void
void
spi_core_interrupt_enable(int core)
spi_core_interrupt_enable(int core)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPCR)) |= SIMPLESPI_SPCR_SPIE;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR)) |= SIMPLESPI_SPCR_SPIE;
}
}
 
 
void
void
spi_core_interrupt_disable(int core)
spi_core_interrupt_disable(int core)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPCR)) &= ~SIMPLESPI_SPCR_SPIE;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR)) &= ~SIMPLESPI_SPCR_SPIE;
}
}
 
 
void
void
spi_core_interrupt_flag_clear(int core)
spi_core_interrupt_flag_clear(int core)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPSR)) = SIMPLESPI_SPSR_SPIF;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPSR)) = SIMPLESPI_SPSR_SPIF;
}
}
 
 
void
void
spi_core_clock_setup(int core, char polarity, char phase, char rate,
spi_core_clock_setup(int core, char polarity, char phase, char rate,
                          char ext_rate)
                          char ext_rate)
{
{
  char spcr = REG8((spi_base_adr[core] + SIMPLESPI_SPCR));
  char spcr = REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR));
 
 
  if (polarity)
  if (polarity)
    spcr |= SIMPLESPI_SPCR_CPOL;
    spcr |= SIMPLESPI_SPCR_CPOL;
  else
  else
    spcr &= ~SIMPLESPI_SPCR_CPOL;
    spcr &= ~SIMPLESPI_SPCR_CPOL;
Line 64... Line 68...
  else
  else
    spcr &= ~SIMPLESPI_SPCR_CPHA;
    spcr &= ~SIMPLESPI_SPCR_CPHA;
 
 
  spcr = (spcr & ~SIMPLESPI_SPCR_SPR) | (rate & SIMPLESPI_SPCR_SPR);
  spcr = (spcr & ~SIMPLESPI_SPCR_SPR) | (rate & SIMPLESPI_SPCR_SPR);
 
 
  REG8((spi_base_adr[core] + SIMPLESPI_SPCR)) = spcr;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPCR)) = spcr;
 
 
  char sper = REG8((spi_base_adr[core] + SIMPLESPI_SPER));
  char sper = REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPER));
 
 
  sper = (sper & ~SIMPLESPI_SPER_ESPR) | (ext_rate & SIMPLESPI_SPER_ESPR);
  sper = (sper & ~SIMPLESPI_SPER_ESPR) | (ext_rate & SIMPLESPI_SPER_ESPR);
 
 
  REG8((spi_base_adr[core] + SIMPLESPI_SPER)) = sper;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPER)) = sper;
 
 
}
}
 
 
void
void
spi_core_set_int_count(int core, char cnt)
spi_core_set_int_count(int core, char cnt)
{
{
  char sper = REG8((spi_base_adr[core] + SIMPLESPI_SPER));
  char sper = REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPER));
 
 
  sper = (sper & ~SIMPLESPI_SPER_ICNT) | cnt;
  sper = (sper & ~SIMPLESPI_SPER_ICNT) | cnt;
 
 
  REG8((spi_base_adr[core] + SIMPLESPI_SPER)) = sper;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPER)) = sper;
 
 
}
}
// No decode on slave select lines, so assert correct bit to select slave
// No decode on slave select lines, so assert correct bit to select slave
void
void
spi_core_slave_select(int core, char slave_sel_dec)
spi_core_slave_select(int core, char slave_sel_dec)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SSPU)) = slave_sel_dec;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SSPU)) = slave_sel_dec;
}
}
 
 
int
int
spi_core_data_avail(int core)
spi_core_data_avail(int core)
{
{
  return !!!(REG8((spi_base_adr[core]+SIMPLESPI_SPSR))&SIMPLESPI_SPSR_RFEMPTY);
  return !!!(REG8((SPI_BASE_ADR[core]+SIMPLESPI_SPSR))&SIMPLESPI_SPSR_RFEMPTY);
}
}
 
 
int
int
spi_core_write_avail(int core)
spi_core_write_avail(int core)
{
{
  return !!!(REG8((spi_base_adr[core]+SIMPLESPI_SPSR))&SIMPLESPI_SPSR_WFFULL);
  return !!!(REG8((SPI_BASE_ADR[core]+SIMPLESPI_SPSR))&SIMPLESPI_SPSR_WFFULL);
}
}
 
 
// Should call spi_core_write_avail() before calling this, we don't check
// Should call spi_core_write_avail() before calling this, we don't check
void
void
spi_core_write_data(int core, char data)
spi_core_write_data(int core, char data)
{
{
  REG8((spi_base_adr[core] + SIMPLESPI_SPDR)) = data;
  REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPDR)) = data;
}
}
 
 
char
char
spi_core_read_data(int core)
spi_core_read_data(int core)
{
{
  return REG8((spi_base_adr[core] + SIMPLESPI_SPDR));
  return REG8((SPI_BASE_ADR[core] + SIMPLESPI_SPDR));
}
}
 
 
 No newline at end of file
 No newline at end of file

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.