]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
sim: bfin: add new CGU (clock generation) model (bf60x)
authorMike Frysinger <vapier@gentoo.org>
Wed, 18 May 2011 17:14:24 +0000 (13:14 -0400)
committerMike Frysinger <vapier@gentoo.org>
Mon, 1 Jan 2024 23:23:25 +0000 (18:23 -0500)
This models the new clock generation unit found on BF60x processors.

2012-08-28  Mike Frysinger  <vapier@gentoo.org>

* configure.ac (SIM_AC_OPTION_HARDWARE): Add bfin_cgu.
* configure: Regenerated.
* dv-bfin_cgu.c, dv-bfin_cgu.h: New device model.
* machs.h (BFIN_MMR_CGU_SIZE): Define.

sim/bfin/dv-bfin_cgu.c [new file with mode: 0644]
sim/bfin/dv-bfin_cgu.h [new file with mode: 0644]
sim/bfin/local.mk
sim/bfin/machs.h

diff --git a/sim/bfin/dv-bfin_cgu.c b/sim/bfin/dv-bfin_cgu.c
new file mode 100644 (file)
index 0000000..92f161b
--- /dev/null
@@ -0,0 +1,162 @@
+/* Blackfin Clock Generation Unit (CGU) model.
+
+   Copyright (C) 2010-2016 Free Software Foundation, Inc.
+   Contributed by Analog Devices, Inc.
+
+   This file is part of simulators.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+#include "config.h"
+
+#include "sim-main.h"
+#include "machs.h"
+#include "devices.h"
+#include "dv-bfin_cgu.h"
+
+/* The CGU is made up of sub-devices (PLL/PCU), but for simplicity,
+   we have just one device model for all the pieces.  */
+
+struct bfin_cgu
+{
+  bu32 base;
+
+  /* Order after here is important -- matches hardware MMR layout.  */
+  bu32 ctl;
+  bu32 stat;
+  bu32 div;
+  bu32 clkoutsel;
+  bu32 eng;
+};
+#define mmr_base()      offsetof(struct bfin_cgu, ctl)
+#define mmr_offset(mmr) (offsetof(struct bfin_cgu, mmr) - mmr_base())
+
+static const char * const mmr_names[] =
+{
+  "CGU_CTL", "CGU_STAT", "CGU_DIV", "CGU_CLKOUTSEL", "CGU_ENG",
+};
+#define mmr_name(off) mmr_names[(off) / 4]
+
+static unsigned
+bfin_cgu_io_write_buffer (struct hw *me, const void *source,
+                         int space, address_word addr, unsigned nr_bytes)
+{
+  struct bfin_cgu *cgu = hw_data (me);
+  bu32 mmr_off;
+  bu32 value;
+  bu32 *valuep;
+
+  value = dv_load_4 (source);
+
+  mmr_off = addr - cgu->base;
+  valuep = (void *)((unsigned long)cgu + mmr_base() + mmr_off);
+
+  HW_TRACE_WRITE ();
+
+  dv_bfin_mmr_require_32 (me, addr, nr_bytes, true);
+
+  switch (mmr_off)
+    {
+    default:
+      *valuep = value;
+      break;
+    }
+
+  return nr_bytes;
+}
+
+static unsigned
+bfin_cgu_io_read_buffer (struct hw *me, void *dest,
+                        int space, address_word addr, unsigned nr_bytes)
+{
+  struct bfin_cgu *cgu = hw_data (me);
+  bu32 mmr_off;
+  bu32 *valuep;
+
+  mmr_off = addr - cgu->base;
+  valuep = (void *)((unsigned long)cgu + mmr_base() + mmr_off);
+
+  HW_TRACE_READ ();
+
+  dv_bfin_mmr_require_32 (me, addr, nr_bytes, false);
+
+  switch (mmr_off)
+    {
+    default:
+      dv_store_4 (dest, *valuep);
+      break;
+    }
+
+  return nr_bytes;
+}
+
+static const struct hw_port_descriptor bfin_cgu_ports[] =
+{
+  { "cgu", 0, 0, output_port, },
+  { NULL, 0, 0, 0, },
+};
+
+static void
+attach_bfin_cgu_regs (struct hw *me, struct bfin_cgu *cgu)
+{
+  address_word attach_address;
+  int attach_space;
+  unsigned attach_size;
+  reg_property_spec reg;
+
+  if (hw_find_property (me, "reg") == NULL)
+    hw_abort (me, "Missing \"reg\" property");
+
+  if (!hw_find_reg_array_property (me, "reg", 0, &reg))
+    hw_abort (me, "\"reg\" property must contain three addr/size entries");
+
+  hw_unit_address_to_attach_address (hw_parent (me),
+                                    &reg.address,
+                                    &attach_space, &attach_address, me);
+  hw_unit_size_to_attach_size (hw_parent (me), &reg.size, &attach_size, me);
+
+  if (attach_size != BFIN_MMR_CGU_SIZE)
+    hw_abort (me, "\"reg\" size must be %#x", BFIN_MMR_CGU_SIZE);
+
+  hw_attach_address (hw_parent (me),
+                    0, attach_space, attach_address, attach_size, me);
+
+  cgu->base = attach_address;
+}
+
+static void
+bfin_cgu_finish (struct hw *me)
+{
+  struct bfin_cgu *cgu;
+
+  cgu = HW_ZALLOC (me, struct bfin_cgu);
+
+  set_hw_data (me, cgu);
+  set_hw_io_read_buffer (me, bfin_cgu_io_read_buffer);
+  set_hw_io_write_buffer (me, bfin_cgu_io_write_buffer);
+  set_hw_ports (me, bfin_cgu_ports);
+
+  attach_bfin_cgu_regs (me, cgu);
+
+  /* Initialize the CGU.  */
+  cgu->ctl  = 0x00001000;
+  cgu->stat = 0x000003F5;
+  cgu->div  = 0x04084844;
+}
+
+const struct hw_descriptor dv_bfin_cgu_descriptor[] =
+{
+  {"bfin_cgu", bfin_cgu_finish,},
+  {NULL, NULL},
+};
diff --git a/sim/bfin/dv-bfin_cgu.h b/sim/bfin/dv-bfin_cgu.h
new file mode 100644 (file)
index 0000000..e84fd06
--- /dev/null
@@ -0,0 +1,24 @@
+/* Blackfin Clock Generation Unit (CGU) model.
+
+   Copyright (C) 2010-2016 Free Software Foundation, Inc.
+   Contributed by Analog Devices, Inc.
+
+   This file is part of simulators.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+#ifndef DV_BFIN_CGU_H
+#define DV_BFIN_CGU_H
+
+#endif
index cce693006a892886e9f4a637674f4bc2f8087229..8c2b58aced07a1df71a84f1594c1e4543c2a7777 100644 (file)
@@ -52,6 +52,7 @@ noinst_PROGRAMS += %D%/run
 
 %C%_SIM_EXTRA_HW_DEVICES = \
        bfin_cec \
+       bfin_cgu \
        bfin_ctimer \
        bfin_dma \
        bfin_dmac \
index 3f7e67fe5bbcc60925bf3cc967c1b660dcd33539..b25051711b76863e0407a465c9281febb7acc955 100644 (file)
@@ -51,6 +51,7 @@ extern const SIM_MACH * const bfin_sim_machs[];
 #define BFIN_COREMMR_WP_BASE           0xFFE07000
 #define BFIN_COREMMR_WP_SIZE           0x204
 
+#define BFIN_MMR_CGU_SIZE              (4 * 5)
 #define BFIN_MMR_DMA_SIZE              (4 * 16)
 #define BFIN_MMR_DMAC0_BASE            0xFFC00C00
 #define BFIN_MMR_DMAC1_BASE            0xFFC01C00