blob: 254c7a35d80ea5b0b5745f68447b3a6072521fbb (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
/*
* Copyright (C) 2009
* Albin Tonnerre, Free Electrons <albin.tonnerre@free-electrons.com>
*
* SPDX-License-Identifier: GPL-2.0+
*/
#include <common.h>
#include <asm/arch/hardware.h>
#include <asm/arch/at91_spi.h>
#include <asm/arch/gpio.h>
#include <spi.h>
#define SBC_A9260_CS0_PIN AT91_PIN_PA3
#define SBC_A9260_CS1_PIN AT91_PIN_PC11
int spi_cs_is_valid(unsigned int bus, unsigned int cs)
{
return bus == 0 && (cs == 1 || cs == 0);
}
void spi_cs_activate(struct spi_slave *slave)
{
if(slave->cs == 0)
at91_set_gpio_value(SBC_A9260_CS0_PIN, 0);
else if(slave->cs == 1)
at91_set_gpio_value(SBC_A9260_CS1_PIN, 0);
}
void spi_cs_deactivate(struct spi_slave *slave)
{
if(slave->cs == 0)
at91_set_gpio_value(SBC_A9260_CS0_PIN, 1);
else if(slave->cs == 1)
at91_set_gpio_value(SBC_A9260_CS1_PIN, 1);
}
void spi_init_f(void)
{
/* everything done in board_init */
}
|