From owner-svn-src-head@FreeBSD.ORG Mon May 6 13:34:38 2013 Return-Path: Delivered-To: svn-src-head@freebsd.org Received: from mx1.freebsd.org (mx1.FreeBSD.org [8.8.178.115]) by hub.freebsd.org (Postfix) with ESMTP id 2CDBFF74; Mon, 6 May 2013 13:34:38 +0000 (UTC) (envelope-from gber@FreeBSD.org) Received: from svn.freebsd.org (svn.freebsd.org [IPv6:2001:1900:2254:2068::e6a:0]) by mx1.freebsd.org (Postfix) with ESMTP id 0E489617; Mon, 6 May 2013 13:34:38 +0000 (UTC) Received: from svn.freebsd.org ([127.0.1.70]) by svn.freebsd.org (8.14.6/8.14.6) with ESMTP id r46DYbUK004819; Mon, 6 May 2013 13:34:37 GMT (envelope-from gber@svn.freebsd.org) Received: (from gber@localhost) by svn.freebsd.org (8.14.6/8.14.5/Submit) id r46DYasu004813; Mon, 6 May 2013 13:34:36 GMT (envelope-from gber@svn.freebsd.org) Message-Id: <201305061334.r46DYasu004813@svn.freebsd.org> From: Grzegorz Bernacki Date: Mon, 6 May 2013 13:34:36 +0000 (UTC) To: src-committers@freebsd.org, svn-src-all@freebsd.org, svn-src-head@freebsd.org Subject: svn commit: r250291 - in head/sys: arm/mv boot/fdt/dts dev/cesa X-SVN-Group: head MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-BeenThere: svn-src-head@freebsd.org X-Mailman-Version: 2.1.14 Precedence: list List-Id: SVN commit messages for the src tree for head/-current List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Mon, 06 May 2013 13:34:38 -0000 Author: gber Date: Mon May 6 13:34:36 2013 New Revision: 250291 URL: http://svnweb.freebsd.org/changeset/base/250291 Log: Move initialization of CESA decoding windows from common section to driver specific files. - window initialization is done during device attach - CESA TDMA decoding windows values are set based on DTS, not copied from CPU registers - remove unnecessary virtual mapping - update dts file Obtained from: Semihalf Modified: head/sys/arm/mv/common.c head/sys/arm/mv/mv_machdep.c head/sys/arm/mv/mvwin.h head/sys/boot/fdt/dts/db78460.dts head/sys/dev/cesa/cesa.c head/sys/dev/cesa/cesa.h Modified: head/sys/arm/mv/common.c ============================================================================== --- head/sys/arm/mv/common.c Sun May 5 22:42:10 2013 (r250290) +++ head/sys/arm/mv/common.c Mon May 6 13:34:36 2013 (r250291) @@ -83,7 +83,7 @@ static int decode_win_usb_valid(void); static int decode_win_eth_valid(void); static int decode_win_pcie_valid(void); static int decode_win_sata_valid(void); -static int decode_win_cesa_valid(void); + static int decode_win_idma_valid(void); static int decode_win_xor_valid(void); @@ -93,11 +93,10 @@ static void decode_win_cpu_setup(void); static void decode_win_usb_setup(u_long); static void decode_win_eth_setup(u_long); static void decode_win_sata_setup(u_long); -static void decode_win_cesa_setup(u_long); + static void decode_win_idma_setup(u_long); static void decode_win_xor_setup(u_long); -static void decode_win_cesa_dump(u_long); static void decode_win_usb_dump(u_long); static void decode_win_eth_dump(u_long base); static void decode_win_idma_dump(u_long base); @@ -127,7 +126,6 @@ struct soc_node_spec { }; static struct soc_node_spec soc_nodes[] = { - { "mrvl,cesa", &decode_win_cesa_setup, &decode_win_cesa_dump }, { "mrvl,ge", &decode_win_eth_setup, &decode_win_eth_dump }, { "mrvl,usb-ehci", &decode_win_usb_setup, &decode_win_usb_dump }, { "mrvl,sata", &decode_win_sata_setup, NULL }, @@ -143,7 +141,6 @@ struct fdt_pm_mask_entry fdt_pm_mask_tab { "mrvl,usb-ehci", CPU_PM_CTRL_USB(0) }, { "mrvl,usb-ehci", CPU_PM_CTRL_USB(1) }, { "mrvl,usb-ehci", CPU_PM_CTRL_USB(2) }, - { "mrvl,cesa", CPU_PM_CTRL_CRYPTO }, { "mrvl,xor", CPU_PM_CTRL_XOR }, { "mrvl,sata", CPU_PM_CTRL_SATA }, @@ -529,7 +526,7 @@ soc_decode_win(void) if (!decode_win_cpu_valid() || !decode_win_usb_valid() || !decode_win_eth_valid() || !decode_win_idma_valid() || !decode_win_pcie_valid() || !decode_win_sata_valid() || - !decode_win_cesa_valid() || !decode_win_xor_valid()) + !decode_win_xor_valid()) return (EINVAL); decode_win_cpu_setup(); @@ -537,7 +534,7 @@ soc_decode_win(void) if (!decode_win_usb_valid() || !decode_win_eth_valid() || !decode_win_idma_valid() || !decode_win_pcie_valid() || !decode_win_sata_valid() || - !decode_win_cesa_valid() || !decode_win_xor_valid()) + !decode_win_xor_valid()) return (EINVAL); #endif if (MV_DUMP_WIN) @@ -570,11 +567,6 @@ WIN_REG_BASE_IDX_RD(win_usb, br, MV_WIN_ WIN_REG_BASE_IDX_WR(win_usb, cr, MV_WIN_USB_CTRL) WIN_REG_BASE_IDX_WR(win_usb, br, MV_WIN_USB_BASE) -WIN_REG_BASE_IDX_RD(win_cesa, cr, MV_WIN_CESA_CTRL) -WIN_REG_BASE_IDX_RD(win_cesa, br, MV_WIN_CESA_BASE) -WIN_REG_BASE_IDX_WR(win_cesa, cr, MV_WIN_CESA_CTRL) -WIN_REG_BASE_IDX_WR(win_cesa, br, MV_WIN_CESA_BASE) - WIN_REG_BASE_IDX_RD(win_eth, br, MV_WIN_ETH_BASE) WIN_REG_BASE_IDX_RD(win_eth, sz, MV_WIN_ETH_SIZE) WIN_REG_BASE_IDX_RD(win_eth, har, MV_WIN_ETH_REMAP) @@ -1791,98 +1783,6 @@ decode_win_xor_dump(u_long base) #endif /************************************************************************** - * CESA TDMA windows routines - **************************************************************************/ -#if defined(SOC_MV_KIRKWOOD) || defined(SOC_MV_DISCOVERY) -/* - * Dump CESA TDMA decode windows. - */ -static void -decode_win_cesa_dump(u_long base) -{ - int i; - - if (pm_is_disabled(CPU_PM_CTRL_CRYPTO)) - return; - - for (i = 0; i < MV_WIN_CESA_MAX; i++) - printf("CESA window#%d: c 0x%08x, b 0x%08x\n", i, - win_cesa_cr_read(base, i), win_cesa_br_read(base, i)); -} - - -/* - * Set CESA TDMA decode windows. - */ -static void -decode_win_cesa_setup(u_long base) -{ - uint32_t br, cr; - int i, j; - - if (pm_is_disabled(CPU_PM_CTRL_CRYPTO)) - return; - - /* Disable and clear all CESA windows */ - for (i = 0; i < MV_WIN_CESA_MAX; i++) { - win_cesa_cr_write(base, i, 0); - win_cesa_br_write(base, i, 0); - } - - /* Only access to active DRAM banks is required. */ - for (i = 0; i < MV_WIN_DDR_MAX; i++) - if (ddr_is_active(i)) { - br = ddr_base(i); - cr = (((ddr_size(i) - 1) & 0xffff0000) | - (ddr_attr(i) << 8) | (ddr_target(i) << 4) | 1); - - /* Set the first available CESA window */ - for (j = 0; j < MV_WIN_CESA_MAX; j++) { - if (win_cesa_cr_read(base, j) & 0x1) - continue; - - win_cesa_br_write(base, j, br); - win_cesa_cr_write(base, j, cr); - break; - } - } -} - -/* - * Check CESA TDMA decode windows. - */ -static int -decode_win_cesa_valid(void) -{ - - return (decode_win_can_cover_ddr(MV_WIN_CESA_MAX)); -} -#else - -/* - * Provide dummy functions to satisfy the build for SoCs not equipped with - * CESA - */ - -static int -decode_win_cesa_valid(void) -{ - - return (1); -} - -static void -decode_win_cesa_setup(u_long base) -{ -} - -static void -decode_win_cesa_dump(u_long base) -{ -} -#endif - -/************************************************************************** * SATA windows routines **************************************************************************/ static void @@ -1979,33 +1879,34 @@ static int win_cpu_from_dt(void) { pcell_t ranges[48]; - u_long sram_base, sram_size; phandle_t node; int i, entry_size, err, t, tuple_size, tuples; + u_long sram_base, sram_size; + t = 0; /* Retrieve 'ranges' property of '/localbus' node. */ if ((err = fdt_get_ranges("/localbus", ranges, sizeof(ranges), - &tuples, &tuple_size)) != 0) - return (0); - - /* - * Fill CPU decode windows table. - */ - bzero((void *)&cpu_win_tbl, sizeof(cpu_win_tbl)); + &tuples, &tuple_size)) == 0) { + /* + * Fill CPU decode windows table. + */ + bzero((void *)&cpu_win_tbl, sizeof(cpu_win_tbl)); - entry_size = tuple_size / sizeof(pcell_t); - cpu_wins_no = tuples; + entry_size = tuple_size / sizeof(pcell_t); + cpu_wins_no = tuples; - for (i = 0, t = 0; t < tuples; i += entry_size, t++) { - cpu_win_tbl[t].target = 1; - cpu_win_tbl[t].attr = fdt32_to_cpu(ranges[i + 1]); - cpu_win_tbl[t].base = fdt32_to_cpu(ranges[i + 2]); - cpu_win_tbl[t].size = fdt32_to_cpu(ranges[i + 3]); - cpu_win_tbl[t].remap = ~0; - debugf("target = 0x%0x attr = 0x%0x base = 0x%0x " - "size = 0x%0x remap = 0x%0x\n", cpu_win_tbl[t].target, - cpu_win_tbl[t].attr, cpu_win_tbl[t].base, - cpu_win_tbl[t].size, cpu_win_tbl[t].remap); + for (i = 0, t = 0; t < tuples; i += entry_size, t++) { + cpu_win_tbl[t].target = 1; + cpu_win_tbl[t].attr = fdt32_to_cpu(ranges[i + 1]); + cpu_win_tbl[t].base = fdt32_to_cpu(ranges[i + 2]); + cpu_win_tbl[t].size = fdt32_to_cpu(ranges[i + 3]); + cpu_win_tbl[t].remap = ~0; + debugf("target = 0x%0x attr = 0x%0x base = 0x%0x " + "size = 0x%0x remap = 0x%0x\n", + cpu_win_tbl[t].target, + cpu_win_tbl[t].attr, cpu_win_tbl[t].base, + cpu_win_tbl[t].size, cpu_win_tbl[t].remap); + } } /* @@ -2015,7 +1916,7 @@ win_cpu_from_dt(void) if (fdt_is_compatible(node, "mrvl,cesa-sram")) goto moveon; - if ((node = OF_finddevice("/")) == -1) + if ((node = OF_finddevice("/")) == 0) return (ENXIO); if ((node = fdt_find_compatible(node, "mrvl,cesa-sram", 0)) == 0) @@ -2026,11 +1927,12 @@ moveon: if (fdt_regsize(node, &sram_base, &sram_size) != 0) return (EINVAL); - cpu_win_tbl[++t].target = MV_WIN_CESA_TARGET; - cpu_win_tbl[t].attr = MV_WIN_CESA_ATTR; + cpu_win_tbl[t].target = MV_WIN_CESA_TARGET; + cpu_win_tbl[t].attr = MV_WIN_CESA_ATTR(1); cpu_win_tbl[t].base = sram_base; cpu_win_tbl[t].size = sram_size; cpu_win_tbl[t].remap = ~0; + cpu_wins_no++; debugf("sram: base = 0x%0lx size = 0x%0lx\n", sram_base, sram_size); return (0); Modified: head/sys/arm/mv/mv_machdep.c ============================================================================== --- head/sys/arm/mv/mv_machdep.c Sun May 5 22:42:10 2013 (r250290) +++ head/sys/arm/mv/mv_machdep.c Mon May 6 13:34:36 2013 (r250291) @@ -310,7 +310,6 @@ platform_devmap_init(void) { phandle_t root, child; pcell_t bank_count; - u_long base, size; int i, num_mapped; i = 0; @@ -381,29 +380,6 @@ platform_devmap_init(void) } } - /* - * CESA SRAM range. - */ - if ((child = OF_finddevice("sram")) != -1) - if (fdt_is_compatible(child, "mrvl,cesa-sram")) - goto moveon; - - if ((child = fdt_find_compatible(root, "mrvl,cesa-sram", 0)) == 0) - /* No CESA SRAM node. */ - return (0); -moveon: - if (i >= FDT_DEVMAP_MAX) - return (ENOMEM); - - if (fdt_regsize(child, &base, &size) != 0) - return (EINVAL); - - fdt_devmap[i].pd_va = MV_CESA_SRAM_BASE; /* XXX */ - fdt_devmap[i].pd_pa = base; - fdt_devmap[i].pd_size = size; - fdt_devmap[i].pd_prot = VM_PROT_READ | VM_PROT_WRITE; - fdt_devmap[i].pd_cache = PTE_NOCACHE; - return (0); } Modified: head/sys/arm/mv/mvwin.h ============================================================================== --- head/sys/arm/mv/mvwin.h Sun May 5 22:42:10 2013 (r250290) +++ head/sys/arm/mv/mvwin.h Mon May 6 13:34:36 2013 (r250291) @@ -208,16 +208,28 @@ #define MV_WIN_DDR_MAX 4 #endif /* SOC_MV_DOVE */ -#define MV_WIN_CESA_CTRL(n) (0x8 * (n) + 0xa04) -#define MV_WIN_CESA_BASE(n) (0x8 * (n) + 0xa00) -#define MV_WIN_CESA_MAX 4 +/* + * These values are valid only for peripherals decoding windows + * Bit in ATTR is zeroed according to CS bank number + */ +#define MV_WIN_DDR_ATTR(cs) (0x0F & ~(0x01 << (cs))) +#define MV_WIN_DDR_TARGET 0x0 #if defined(SOC_MV_DISCOVERY) #define MV_WIN_CESA_TARGET 9 -#define MV_WIN_CESA_ATTR 1 +#define MV_WIN_CESA_ATTR(eng_sel) 1 +#elif defined(SOC_MV_ARMADAXP) +#define MV_WIN_CESA_TARGET 9 +/* + * Bits [2:3] of cesa attribute select engine: + * eng_sel: + * 1: engine1 + * 2: engine0 + */ +#define MV_WIN_CESA_ATTR(eng_sel) (1 | ((eng_sel) << 2)) #else #define MV_WIN_CESA_TARGET 3 -#define MV_WIN_CESA_ATTR 0 +#define MV_WIN_CESA_ATTR(eng_sel) 0 #endif #define MV_WIN_USB_CTRL(n) (0x10 * (n) + 0x320) Modified: head/sys/boot/fdt/dts/db78460.dts ============================================================================== --- head/sys/boot/fdt/dts/db78460.dts Sun May 5 22:42:10 2013 (r250290) +++ head/sys/boot/fdt/dts/db78460.dts Mon May 6 13:34:36 2013 (r250291) @@ -303,6 +303,11 @@ >; }; + sram@ffff0000 { + compatible = "mrvl,cesa-sram"; + reg = <0xffff0000 0x00010000>; + }; + chosen { stdin = "serial0"; stdout = "serial0"; Modified: head/sys/dev/cesa/cesa.c ============================================================================== --- head/sys/dev/cesa/cesa.c Sun May 5 22:42:10 2013 (r250290) +++ head/sys/dev/cesa/cesa.c Mon May 6 13:34:36 2013 (r250291) @@ -80,6 +80,7 @@ static void cesa_intr(void *); static int cesa_newsession(device_t, u_int32_t *, struct cryptoini *); static int cesa_freesession(device_t, u_int64_t); static int cesa_process(device_t, struct cryptop *, int); +static int decode_win_cesa_setup(struct cesa_softc *sc); static struct resource_spec cesa_res_spec[] = { { SYS_RES_MEMORY, 0, RF_ACTIVE }, @@ -995,10 +996,10 @@ cesa_attach(device_t dev) sc->sc_error = 0; sc->sc_dev = dev; - error = cesa_setup_sram(sc); - if (error) { - device_printf(dev, "could not setup SRAM\n"); - return (error); + /* Check if CESA peripheral device has power turned on */ + if (soc_power_ctrl_get(CPU_PM_CTRL_CRYPTO) != CPU_PM_CTRL_CRYPTO) { + device_printf(dev, "not powered on\n"); + return (ENXIO); } soc_id(&d, &r); @@ -1038,6 +1039,20 @@ cesa_attach(device_t dev) sc->sc_bsh = rman_get_bushandle(*(sc->sc_res)); sc->sc_bst = rman_get_bustag(*(sc->sc_res)); + /* Setup CESA decoding windows */ + error = decode_win_cesa_setup(sc); + if (error) { + device_printf(dev, "could not setup decoding windows\n"); + goto err1; + } + + /* Acquire SRAM base address */ + error = cesa_setup_sram(sc); + if (error) { + device_printf(dev, "could not setup SRAM\n"); + goto err1; + } + /* Setup interrupt handler */ error = bus_setup_intr(dev, sc->sc_res[1], INTR_TYPE_NET | INTR_MPSAFE, NULL, cesa_intr, sc, &(sc->sc_icookie)); @@ -1609,3 +1624,50 @@ cesa_process(device_t dev, struct crypto return (0); } + +/* + * Set CESA TDMA decode windows. + */ +static int +decode_win_cesa_setup(struct cesa_softc *sc) +{ + struct mem_region availmem_regions[FDT_MEM_REGIONS]; + int availmem_regions_sz; + uint32_t memsize, br, cr, i; + + /* Grab physical memory regions information from DTS */ + if (fdt_get_mem_regions(availmem_regions, &availmem_regions_sz, + &memsize) != 0) + return (ENXIO); + + if (availmem_regions_sz > MV_WIN_CESA_MAX) { + device_printf(sc->sc_dev, "Too much memory regions, cannot " + " set CESA windows to cover whole DRAM \n"); + return (ENXIO); + } + + /* Disable and clear all CESA windows */ + for (i = 0; i < MV_WIN_CESA_MAX; i++) { + CESA_WRITE(sc, MV_WIN_CESA_BASE(i), 0); + CESA_WRITE(sc, MV_WIN_CESA_CTRL(i), 0); + } + + /* Fill CESA TDMA decoding windows with information acquired from DTS */ + for (i = 0; i < availmem_regions_sz; i++) { + br = availmem_regions[i].mr_start; + cr = availmem_regions[i].mr_size; + + /* Don't add entries with size lower than 64KB */ + if (cr & 0xffff0000) { + cr = (((cr - 1) & 0xffff0000) | + (MV_WIN_DDR_ATTR(i) << MV_WIN_CPU_ATTR_SHIFT) | + (MV_WIN_DDR_TARGET << MV_WIN_CPU_TARGET_SHIFT) | + MV_WIN_CPU_ENABLE_BIT); + CESA_WRITE(sc, MV_WIN_CESA_BASE(i), br); + CESA_WRITE(sc, MV_WIN_CESA_CTRL(i), cr); + } + } + + return (0); +} + Modified: head/sys/dev/cesa/cesa.h ============================================================================== --- head/sys/dev/cesa/cesa.h Sun May 5 22:42:10 2013 (r250290) +++ head/sys/dev/cesa/cesa.h Mon May 6 13:34:36 2013 (r250291) @@ -333,6 +333,11 @@ struct cesa_chain_info { #define CESA_TDMA_EMR_BOTH_HIT CESA_TDMA_ECR_BOTH_HIT #define CESA_TDMA_EMR_DATA_ERROR CESA_TDMA_ECR_DATA_ERROR +/* CESA TDMA address decoding registers */ +#define MV_WIN_CESA_CTRL(n) (0x8 * (n) + 0xA04) +#define MV_WIN_CESA_BASE(n) (0x8 * (n) + 0xA00) +#define MV_WIN_CESA_MAX 4 + /* CESA SA registers definitions */ #define CESA_SA_CMD 0xDE00 #define CESA_SA_CMD_ACTVATE (1 << 0)