1ca987d46SWarner Losh /*- 2ca987d46SWarner Losh * Copyright (c) 1998 Michael Smith <msmith@freebsd.org> 3ca987d46SWarner Losh * All rights reserved. 4ca987d46SWarner Losh * 5ca987d46SWarner Losh * Redistribution and use in source and binary forms, with or without 6ca987d46SWarner Losh * modification, are permitted provided that the following conditions 7ca987d46SWarner Losh * are met: 8ca987d46SWarner Losh * 1. Redistributions of source code must retain the above copyright 9ca987d46SWarner Losh * notice, this list of conditions and the following disclaimer. 10ca987d46SWarner Losh * 2. Redistributions in binary form must reproduce the above copyright 11ca987d46SWarner Losh * notice, this list of conditions and the following disclaimer in the 12ca987d46SWarner Losh * documentation and/or other materials provided with the distribution. 13ca987d46SWarner Losh * 14ca987d46SWarner Losh * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 15ca987d46SWarner Losh * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 16ca987d46SWarner Losh * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 17ca987d46SWarner Losh * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 18ca987d46SWarner Losh * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 19ca987d46SWarner Losh * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 20ca987d46SWarner Losh * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 21ca987d46SWarner Losh * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 22ca987d46SWarner Losh * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 23ca987d46SWarner Losh * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 24ca987d46SWarner Losh * SUCH DAMAGE. 25ca987d46SWarner Losh */ 26ca987d46SWarner Losh 27ca987d46SWarner Losh #include <sys/cdefs.h> 28ca987d46SWarner Losh __FBSDID("$FreeBSD$"); 29ca987d46SWarner Losh 30ca987d46SWarner Losh #include <stand.h> 31ca987d46SWarner Losh #include <string.h> 32ca987d46SWarner Losh 33ca987d46SWarner Losh #include "bootstrap.h" 34ca987d46SWarner Losh 35c1418270SIan Lepore #ifdef LOADER_GELI_SUPPORT 36c1418270SIan Lepore #include "geliboot.h" 37c1418270SIan Lepore #endif 38c1418270SIan Lepore 39ca987d46SWarner Losh int 40ca987d46SWarner Losh devopen(struct open_file *f, const char *fname, const char **file) 41ca987d46SWarner Losh { 42ca987d46SWarner Losh struct devdesc *dev; 43ca987d46SWarner Losh int result; 44ca987d46SWarner Losh 45ca987d46SWarner Losh result = archsw.arch_getdev((void **)&dev, fname, file); 46ca987d46SWarner Losh if (result) 47ca987d46SWarner Losh return (result); 48ca987d46SWarner Losh 49ca987d46SWarner Losh /* point to device-specific data so that device open can use it */ 50c1418270SIan Lepore f->f_dev = dev->d_dev; 51ca987d46SWarner Losh f->f_devdata = dev; 52ca987d46SWarner Losh result = dev->d_dev->dv_open(f, dev); 53ca987d46SWarner Losh if (result != 0) { 54ca987d46SWarner Losh f->f_devdata = NULL; 55*0c489895SToomas Soome f->f_dev = NULL; 56ca987d46SWarner Losh free(dev); 57ca987d46SWarner Losh return (result); 58ca987d46SWarner Losh } 59ca987d46SWarner Losh 60c1418270SIan Lepore #ifdef LOADER_GELI_SUPPORT 61c1418270SIan Lepore /* 62c1418270SIan Lepore * If f->f_dev is geli-encrypted and we can decrypt it (will prompt for 63c1418270SIan Lepore * pw if needed), this will attach the geli code to the open_file by 64c1418270SIan Lepore * replacing f->f_dev and f_devdata with pointers to a geli_devdesc. 65c1418270SIan Lepore */ 66c1418270SIan Lepore if (f->f_dev->dv_type == DEVT_DISK) { 67c1418270SIan Lepore geli_probe_and_attach(f); 68c1418270SIan Lepore } 69c1418270SIan Lepore #endif 70c1418270SIan Lepore 71ca987d46SWarner Losh return (0); 72ca987d46SWarner Losh } 73ca987d46SWarner Losh 74ca987d46SWarner Losh int 75ca987d46SWarner Losh devclose(struct open_file *f) 76ca987d46SWarner Losh { 77ca987d46SWarner Losh 78ca987d46SWarner Losh free(f->f_devdata); 79ca987d46SWarner Losh return (0); 80ca987d46SWarner Losh } 81