Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/mac68k/obio For wdc_obio_match(), struct wdc_regs i...



details:   https://anonhg.NetBSD.org/src/rev/5fe92316bebd
branches:  trunk
changeset: 972604:5fe92316bebd
user:      rin <rin%NetBSD.org@localhost>
date:      Sun May 31 08:59:40 2020 +0000

description:
For wdc_obio_match(), struct wdc_regs is too large for stack.
Use kmem_alloc(9) instead.

Frame size becomes:
    3088 --> 0

diffstat:

 sys/arch/mac68k/obio/wdc_obio.c |  46 ++++++++++++++++++++++------------------
 1 files changed, 25 insertions(+), 21 deletions(-)

diffs (94 lines):

diff -r e8590bbe2ce4 -r 5fe92316bebd sys/arch/mac68k/obio/wdc_obio.c
--- a/sys/arch/mac68k/obio/wdc_obio.c   Sun May 31 08:38:54 2020 +0000
+++ b/sys/arch/mac68k/obio/wdc_obio.c   Sun May 31 08:59:40 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: wdc_obio.c,v 1.29 2017/10/20 07:06:07 jdolecek Exp $ */
+/*     $NetBSD: wdc_obio.c,v 1.30 2020/05/31 08:59:40 rin Exp $ */
 
 /*
  * Copyright (c) 2002 Takeshi Shibagaki  All rights reserved.
@@ -32,14 +32,14 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: wdc_obio.c,v 1.29 2017/10/20 07:06:07 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: wdc_obio.c,v 1.30 2020/05/31 08:59:40 rin Exp $");
 
 #include <sys/types.h>
 #include <sys/param.h>
 #include <sys/systm.h>
 #include <sys/device.h>
-#include <sys/malloc.h>
 #include <sys/kernel.h>
+#include <sys/kmem.h>
 #include <sys/callout.h>
 
 #include <machine/bus.h>
@@ -87,45 +87,49 @@
 wdc_obio_match(device_t parent, cfdata_t match, void *aux)
 {
        struct obio_attach_args *oa = (struct obio_attach_args *) aux;
-       struct wdc_regs wdr;
+       struct wdc_regs *wdr;
        int i, result = 0;
 
+       wdr = kmem_alloc(sizeof(struct wdc_regs), KM_SLEEP);
+
        switch (current_mac_model->machineid) {
        case MACH_MACPB150:
        case MACH_MACPB190:
        case MACH_MACPB190CS:
        case MACH_MACP580:
        case MACH_MACQ630:
-               wdr.cmd_iot = wdr.ctl_iot = oa->oa_tag;
+               wdr->cmd_iot = wdr->ctl_iot = oa->oa_tag;
 
-               if (bus_space_map(wdr.cmd_iot, IDEBase, WDC_OBIO_REG_NPORTS,
-                               0, &wdr.cmd_baseioh))
-                       return 0;
+               if (bus_space_map(wdr->cmd_iot, IDEBase, WDC_OBIO_REG_NPORTS,
+                               0, &wdr->cmd_baseioh))
+                       goto out;
 
-               mac68k_bus_space_handle_swapped(wdr.cmd_iot, &wdr.cmd_baseioh);
+               mac68k_bus_space_handle_swapped(wdr->cmd_iot,
+                   &wdr->cmd_baseioh);
 
                for (i = 0; i < WDC_NREG; i++) {
-                       if (bus_space_subregion(wdr.cmd_iot, wdr.cmd_baseioh,
-                                           4 * i, 4, &wdr.cmd_iohs[i]) != 0) {
-                               return 0;
-                       }
+                       if (bus_space_subregion(wdr->cmd_iot, wdr->cmd_baseioh,
+                                           4 * i, 4, &wdr->cmd_iohs[i]) != 0)
+                               goto out;
                }
-               wdc_init_shadow_regs(&wdr);
+               wdc_init_shadow_regs(wdr);
 
 
-               if (bus_space_subregion(wdr.cmd_iot, wdr.cmd_baseioh,
+               if (bus_space_subregion(wdr->cmd_iot, wdr->cmd_baseioh,
                                        WDC_OBIO_AUXREG_OFFSET,
                                        WDC_OBIO_AUXREG_NPORTS,
-                                       &wdr.ctl_ioh))
-                       return 0;
+                                       &wdr->ctl_ioh))
+                       goto out;
 
-               result = wdcprobe(&wdr);
+               result = wdcprobe(wdr);
 
-               bus_space_unmap(wdr.cmd_iot, wdr.cmd_baseioh, WDC_OBIO_REG_NPORTS);
+               bus_space_unmap(wdr->cmd_iot, wdr->cmd_baseioh,
+                   WDC_OBIO_REG_NPORTS);
 
-               return (result);
+               goto out;
        }
-       return 0;
+out:   kmem_free(wdr, sizeof(struct wdc_regs));
+       return result;
 }
 
 void



Home | Main Index | Thread Index | Old Index