source: rtems/bsps/arm/atsam/spi/sc16is752.c @ 534f9dbe

5
Last change on this file since 534f9dbe was 534f9dbe, checked in by Sebastian Huber <sebastian.huber@…>, on 08/03/20 at 07:42:25

arm/atsam: Make interrupt server configurable

The external UART over SPI device SC16IS752 uses the interrupt server
for interrupt processing. The interrupt server is also heavily used by
libbsd. The interrupt processing for the SC16IS752 is time critical and
doesn't work if network traffic is processed at the same priority.
With #4033 custom interrupt servers are available. Change
atsam_sc16is752_spi_create() to support user-defined interrupt servers.
Introduced atsam_sc16is752_spi_config to cut down the argument count of
this function.

Close #4038.

  • Property mode set to 100644
File size: 2.3 KB
Line 
1
2/*
3 * Copyright (c) 2016 embedded brains GmbH.  All rights reserved.
4 *
5 *  embedded brains GmbH
6 *  Dornierstr. 4
7 *  82178 Puchheim
8 *  Germany
9 *  <rtems@embedded-brains.de>
10 *
11 * The license and distribution terms for this file may be
12 * found in the file LICENSE in this distribution or at
13 * http://www.rtems.org/license/LICENSE.
14 */
15
16#include <bsp/sc16is752.h>
17
18#include <rtems/irq-extension.h>
19
20static void atsam_sc16i752_irqs_handler(void *arg)
21{
22  atsam_sc16is752_spi_context *ctx = arg;
23
24    sc16is752_interrupt_handler(&ctx->base.base);
25    PIO_EnableIt(&ctx->irq_pin);
26}
27
28static void atsam_sc16i752_interrupt(const Pin *pin, void *arg)
29{
30  atsam_sc16is752_spi_context *ctx = arg;
31
32  if(PIO_ItIsActive(&ctx->irq_pin)) {
33    PIO_DisableIt(&ctx->irq_pin);
34    rtems_interrupt_server_entry_submit(&ctx->irqs_entry);
35  }
36}
37
38static bool atsam_sc16is752_install_interrupt(sc16is752_context *base)
39{
40  atsam_sc16is752_spi_context *ctx = (atsam_sc16is752_spi_context *)base;
41  rtems_status_code sc;
42  uint8_t rv;
43
44  sc = rtems_interrupt_server_entry_initialize(ctx->irqs_index,
45    &ctx->irqs_entry);
46  rtems_interrupt_server_action_prepend(&ctx->irqs_entry,
47    &ctx->irqs_action, atsam_sc16i752_irqs_handler, ctx);
48
49  rv = PIO_Configure(&ctx->irq_pin, 1);
50  PIO_ConfigureIt(&ctx->irq_pin, atsam_sc16i752_interrupt, ctx);
51  PIO_EnableIt(&ctx->irq_pin);
52
53  return (sc == RTEMS_SUCCESSFUL) && (rv == 1);
54}
55
56static void atsam_sc16is752_remove_interrupt(sc16is752_context *base)
57{
58  atsam_sc16is752_spi_context *ctx = (atsam_sc16is752_spi_context *)base;
59  rtems_status_code sc;
60
61  PIO_DisableIt(&ctx->irq_pin);
62  sc = PIO_RemoveIt(&ctx->irq_pin, atsam_sc16i752_interrupt, ctx);
63  assert(sc == RTEMS_SUCCESSFUL);
64}
65
66int atsam_sc16is752_spi_create(
67  atsam_sc16is752_spi_context      *ctx,
68  const atsam_sc16is752_spi_config *config
69)
70{
71  ctx->base.base.mode = config->mode;
72  ctx->base.base.input_frequency = config->input_frequency;
73  ctx->base.base.install_irq = atsam_sc16is752_install_interrupt;
74  ctx->base.base.remove_irq = atsam_sc16is752_remove_interrupt;
75  ctx->base.spi_path = config->spi_path;
76  ctx->base.cs = config->spi_chip_select;
77  ctx->base.speed_hz = config->spi_speed_hz;
78  ctx->irq_pin = config->irq_pin;
79  ctx->irqs_index = config->server_index;
80
81  return sc16is752_spi_create(&ctx->base, config->device_path);
82}
Note: See TracBrowser for help on using the repository browser.