aboutsummaryrefslogtreecommitdiff
path: root/board/calao/sbc35_a9g20/spi.c
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 */
}