mirror of
https://github.com/torvalds/linux.git
synced 2024-11-27 14:41:39 +00:00
Xtensa improvements for 4.1:
- fix locking issues in ISS network driver; - document PIC and MX interrupt distributor device tree bindings; - add CY7C67300 USB controller support to XTFPGA. -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJVK2UPAAoJEFH5zJH4P6BEtdEQAJpThJvrVr+Wn0BkgnSZoA3I jRKhIwj+3c8XXcRRY+4T/hU+9Rh7+XhKjTy+u4Rbgbm5bhmvjvbwuDRS+czsa/RC r/FE874QZD5O8KLtdqkTkyRJ4XmKDQHbDUpTuk300xQeV53fFwa6EeOclVrmZMzz yBDaFG4rmPa7/4TTvbyLwloA355pbKuhAFT2ndRFFHty4KrfE/XZcKQk25ubgTak PYgBGfUpyZ0F7WZ92L8F3WYcud0p4PlYXelQDVVa5iJDLQGkyrJAzDx8e+URVI+E ym9SWVUD33kAhXwQ2i3vm7HEDD4JZJbMZQupWKHy6aqFeaXv31tU5KDOu0V3148O 9ezrAU5Ciav9NGUDQ9318Rb3cJkYoPelHWE5QHEU60VOOt4UHw3wsBtcuCnUSODl BllotRHXYFoBsWcwOBgH1j36wsOGTKxn98wRdHvCLqD6vwneKCv8WRRNRU2N0jvB VTVL4AOPDLmoiwcqomcSXes16ZKU98fgvbSdaCqojDDtYpsj6bsrs67joPwp9+5j 3HA3+47Hn4uaoFiDbs5N/oLgv+fFUY83o6LwxtAAufF2U92KZEX99zayQ0wB54+C U1KR8lmXJcl2KjDXY6tGmfyXrBCwxFk2/WqN43yvvLSxDtDUtDJAw3SHCtQG6Hcd HZFasgLoxxphwtuAkWny =sZxq -----END PGP SIGNATURE----- Merge tag 'xtensa-for-next-20150413' of git://github.com/jcmvbkbc/linux-xtensa into for_next Xtensa improvements for 4.1: - fix locking issues in ISS network driver; - document PIC and MX interrupt distributor device tree bindings; - add CY7C67300 USB controller support to XTFPGA. Signed-off-by: Chris Zankel <chris@zankel.net>
This commit is contained in:
commit
2ba9268dd6
@ -0,0 +1,18 @@
|
||||
* Xtensa Interrupt Distributor and Programmable Interrupt Controller (MX)
|
||||
|
||||
Required properties:
|
||||
- compatible: Should be "cdns,xtensa-mx".
|
||||
|
||||
Remaining properties have exact same meaning as in Xtensa PIC
|
||||
(see cdns,xtensa-pic.txt).
|
||||
|
||||
Examples:
|
||||
pic: pic {
|
||||
compatible = "cdns,xtensa-mx";
|
||||
/* one cell: internal irq number,
|
||||
* two cells: second cell == 0: internal irq number
|
||||
* second cell == 1: external irq number
|
||||
*/
|
||||
#interrupt-cells = <2>;
|
||||
interrupt-controller;
|
||||
};
|
@ -0,0 +1,25 @@
|
||||
* Xtensa built-in Programmable Interrupt Controller (PIC)
|
||||
|
||||
Required properties:
|
||||
- compatible: Should be "cdns,xtensa-pic".
|
||||
- interrupt-controller: Identifies the node as an interrupt controller.
|
||||
- #interrupt-cells: The number of cells to define the interrupts.
|
||||
It may be either 1 or 2.
|
||||
When it's 1, the first cell is the internal IRQ number.
|
||||
When it's 2, the first cell is the IRQ number, and the second cell
|
||||
specifies whether it's internal (0) or external (1).
|
||||
Periferals are usually connected to a fixed external IRQ, but for different
|
||||
core variants it may be mapped to different internal IRQ.
|
||||
IRQ sensitivity and priority are fixed for each core variant and may not be
|
||||
changed at runtime.
|
||||
|
||||
Examples:
|
||||
pic: pic {
|
||||
compatible = "cdns,xtensa-pic";
|
||||
/* one cell: internal irq number,
|
||||
* two cells: second cell == 0: internal irq number
|
||||
* second cell == 1: external irq number
|
||||
*/
|
||||
#interrupt-cells = <2>;
|
||||
interrupt-controller;
|
||||
};
|
@ -349,8 +349,8 @@ static void iss_net_timer(unsigned long priv)
|
||||
{
|
||||
struct iss_net_private *lp = (struct iss_net_private *)priv;
|
||||
|
||||
spin_lock(&lp->lock);
|
||||
iss_net_poll();
|
||||
spin_lock(&lp->lock);
|
||||
mod_timer(&lp->timer, jiffies + lp->timer_val);
|
||||
spin_unlock(&lp->lock);
|
||||
}
|
||||
@ -361,7 +361,7 @@ static int iss_net_open(struct net_device *dev)
|
||||
struct iss_net_private *lp = netdev_priv(dev);
|
||||
int err;
|
||||
|
||||
spin_lock(&lp->lock);
|
||||
spin_lock_bh(&lp->lock);
|
||||
|
||||
err = lp->tp.open(lp);
|
||||
if (err < 0)
|
||||
@ -376,9 +376,11 @@ static int iss_net_open(struct net_device *dev)
|
||||
while ((err = iss_net_rx(dev)) > 0)
|
||||
;
|
||||
|
||||
spin_lock(&opened_lock);
|
||||
spin_unlock_bh(&lp->lock);
|
||||
spin_lock_bh(&opened_lock);
|
||||
list_add(&lp->opened_list, &opened);
|
||||
spin_unlock(&opened_lock);
|
||||
spin_unlock_bh(&opened_lock);
|
||||
spin_lock_bh(&lp->lock);
|
||||
|
||||
init_timer(&lp->timer);
|
||||
lp->timer_val = ISS_NET_TIMER_VALUE;
|
||||
@ -387,7 +389,7 @@ static int iss_net_open(struct net_device *dev)
|
||||
mod_timer(&lp->timer, jiffies + lp->timer_val);
|
||||
|
||||
out:
|
||||
spin_unlock(&lp->lock);
|
||||
spin_unlock_bh(&lp->lock);
|
||||
return err;
|
||||
}
|
||||
|
||||
@ -395,7 +397,7 @@ static int iss_net_close(struct net_device *dev)
|
||||
{
|
||||
struct iss_net_private *lp = netdev_priv(dev);
|
||||
netif_stop_queue(dev);
|
||||
spin_lock(&lp->lock);
|
||||
spin_lock_bh(&lp->lock);
|
||||
|
||||
spin_lock(&opened_lock);
|
||||
list_del(&opened);
|
||||
@ -405,18 +407,17 @@ static int iss_net_close(struct net_device *dev)
|
||||
|
||||
lp->tp.close(lp);
|
||||
|
||||
spin_unlock(&lp->lock);
|
||||
spin_unlock_bh(&lp->lock);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int iss_net_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
{
|
||||
struct iss_net_private *lp = netdev_priv(dev);
|
||||
unsigned long flags;
|
||||
int len;
|
||||
|
||||
netif_stop_queue(dev);
|
||||
spin_lock_irqsave(&lp->lock, flags);
|
||||
spin_lock_bh(&lp->lock);
|
||||
|
||||
len = lp->tp.write(lp, &skb);
|
||||
|
||||
@ -438,7 +439,7 @@ static int iss_net_start_xmit(struct sk_buff *skb, struct net_device *dev)
|
||||
pr_err("%s: %s failed(%d)\n", dev->name, __func__, len);
|
||||
}
|
||||
|
||||
spin_unlock_irqrestore(&lp->lock, flags);
|
||||
spin_unlock_bh(&lp->lock);
|
||||
|
||||
dev_kfree_skb(skb);
|
||||
return NETDEV_TX_OK;
|
||||
@ -466,9 +467,9 @@ static int iss_net_set_mac(struct net_device *dev, void *addr)
|
||||
|
||||
if (!is_valid_ether_addr(hwaddr->sa_data))
|
||||
return -EADDRNOTAVAIL;
|
||||
spin_lock(&lp->lock);
|
||||
spin_lock_bh(&lp->lock);
|
||||
memcpy(dev->dev_addr, hwaddr->sa_data, ETH_ALEN);
|
||||
spin_unlock(&lp->lock);
|
||||
spin_unlock_bh(&lp->lock);
|
||||
return 0;
|
||||
}
|
||||
|
||||
@ -520,11 +521,11 @@ static int iss_net_configure(int index, char *init)
|
||||
*lp = (struct iss_net_private) {
|
||||
.device_list = LIST_HEAD_INIT(lp->device_list),
|
||||
.opened_list = LIST_HEAD_INIT(lp->opened_list),
|
||||
.lock = __SPIN_LOCK_UNLOCKED(lp.lock),
|
||||
.dev = dev,
|
||||
.index = index,
|
||||
};
|
||||
};
|
||||
|
||||
spin_lock_init(&lp->lock);
|
||||
/*
|
||||
* If this name ends up conflicting with an existing registered
|
||||
* netdevice, that is OK, register_netdev{,ice}() will notice this
|
||||
|
@ -59,4 +59,7 @@
|
||||
/* 5*rx buffs + 5*tx buffs */
|
||||
#define OETH_SRAMBUFF_SIZE (5 * 0x600 + 5 * 0x600)
|
||||
|
||||
#define C67X00_PADDR (XCHAL_KIO_PADDR + 0x0D0D0000)
|
||||
#define C67X00_SIZE 0x10
|
||||
#define C67X00_IRQ 5
|
||||
#endif /* __XTENSA_XTAVNET_HARDWARE_H */
|
||||
|
@ -189,6 +189,7 @@ void __init platform_calibrate_ccount(void)
|
||||
#include <linux/serial_8250.h>
|
||||
#include <linux/if.h>
|
||||
#include <net/ethoc.h>
|
||||
#include <linux/usb/c67x00.h>
|
||||
|
||||
/*----------------------------------------------------------------------------
|
||||
* Ethernet -- OpenCores Ethernet MAC (ethoc driver)
|
||||
@ -232,6 +233,38 @@ static struct platform_device ethoc_device = {
|
||||
},
|
||||
};
|
||||
|
||||
/*----------------------------------------------------------------------------
|
||||
* USB Host/Device -- Cypress CY7C67300
|
||||
*/
|
||||
|
||||
static struct resource c67x00_res[] = {
|
||||
[0] = { /* register space */
|
||||
.start = C67X00_PADDR,
|
||||
.end = C67X00_PADDR + C67X00_SIZE - 1,
|
||||
.flags = IORESOURCE_MEM,
|
||||
},
|
||||
[1] = { /* IRQ number */
|
||||
.start = C67X00_IRQ,
|
||||
.end = C67X00_IRQ,
|
||||
.flags = IORESOURCE_IRQ,
|
||||
},
|
||||
};
|
||||
|
||||
static struct c67x00_platform_data c67x00_pdata = {
|
||||
.sie_config = C67X00_SIE1_HOST | C67X00_SIE2_UNUSED,
|
||||
.hpi_regstep = 4,
|
||||
};
|
||||
|
||||
static struct platform_device c67x00_device = {
|
||||
.name = "c67x00",
|
||||
.id = -1,
|
||||
.num_resources = ARRAY_SIZE(c67x00_res),
|
||||
.resource = c67x00_res,
|
||||
.dev = {
|
||||
.platform_data = &c67x00_pdata,
|
||||
},
|
||||
};
|
||||
|
||||
/*----------------------------------------------------------------------------
|
||||
* UART
|
||||
*/
|
||||
@ -268,6 +301,7 @@ static struct platform_device xtavnet_uart = {
|
||||
/* platform devices */
|
||||
static struct platform_device *platform_devices[] __initdata = {
|
||||
ðoc_device,
|
||||
&c67x00_device,
|
||||
&xtavnet_uart,
|
||||
};
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user