> On Wed, Oct 12, 2016 at 04:26:20PM -0400, Joe Nosay wrote:
> > Where in the code is the problem?
> > On Tue, Oct 11, 2016 at 11:49 PM, <[hidden email]> wrote:
> 836 vd = malloc(sizeof(struct vdsk_dring), M_DEVBUF, M_NOWAIT);
> 837 if (vd == NULL)
> 838 return NULL;
> assuming this suceeds...
> 840 size = roundup(nentries * sizeof(struct vd_desc), PAGE_SIZE);
> 842 if (bus_dmamap_create(t, size, 1, size, 0,
> 843 BUS_DMA_NOWAIT | BUS_DMA_ALLOCNOW, &vd->vd_map) != 0)
> 844 return (NULL);
> but this fails.
> Now we return NULL, due to failure. but there's no reference to vd
> which will allow us to free it later.
> (I may be misunderstanding what bus_dmamap_create does, but probably not.