1 /* 2 * A system pager implementation residing in a separate task. 3 * 4 * Copyright (C) 2022, 2023 Paul Boddie <paul@boddie.org.uk> 5 * 6 * This program is free software; you can redistribute it and/or 7 * modify it under the terms of the GNU General Public License as 8 * published by the Free Software Foundation; either version 2 of 9 * the License, or (at your option) any later version. 10 * 11 * This program is distributed in the hope that it will be useful, 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 * GNU General Public License for more details. 15 * 16 * You should have received a copy of the GNU General Public License 17 * along with this program; if not, write to the Free Software 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, 19 * Boston, MA 02110-1301, USA 20 */ 21 22 #pragma once 23 24 #include <exec/pager.h> 25 #include <fsserver/notification.h> 26 #include <fsserver/resource.h> 27 28 #include "notifier_interface.h" 29 #include "parent_pager_object_interface.h" 30 31 32 33 /* A simple system pager also acting as a region mapper. */ 34 35 class ExternalPager : public ExecPager, public ParentPagerObject, 36 public NotificationSupport, public Resource 37 { 38 protected: 39 l4_cap_idx_t _task, _server, _ipc_gate; 40 41 public: 42 explicit ExternalPager(address_t start = 0, address_t end = 0); 43 44 /* Server details. */ 45 46 virtual ipc_server_default_config_type config(); 47 48 virtual void *interface() 49 { return static_cast<ParentPagerObject *>(this); } 50 51 /* Task and thread management. */ 52 53 virtual void set_task(l4_cap_idx_t cap); 54 virtual void set_server(l4_cap_idx_t cap); 55 virtual void set_gate(l4_cap_idx_t cap); 56 57 /* Resource methods. */ 58 59 virtual void close(); 60 61 /* Notification methods, implementing PagerObject. */ 62 63 virtual long exception(l4_exc_regs_t regs, 64 l4_snd_fpage_t *region); 65 66 virtual long page_fault(l4_umword_t pfa, l4_umword_t pc, 67 l4_snd_fpage_t *region); 68 69 /* Region manager/mapper methods. */ 70 71 virtual long attach(address_t *start, address_t size, map_flags_t flags, 72 l4_cap_idx_t ds, address_t offset, unsigned char align); 73 74 /* Parent methods. */ 75 76 virtual long signal(unsigned long sig, unsigned long val); 77 78 /* Notification methods. */ 79 80 virtual long subscribe(l4_cap_idx_t notifier, notify_flags_t flags); 81 82 virtual long unsubscribe(l4_cap_idx_t notifier); 83 }; 84 85 /* vim: tabstop=2 expandtab shiftwidth=2 86 */